我想在我的代码中为一些本地函数添加类型签名。但是,它们的类型涉及匿名的、存在绑定的类型变量。由于它们是匿名的,我不知道如何编写类型签名。我怎样才能引用这样的类型变量?
在下面的示例中,go
has type [b] -> Int -> Int
,其中b
是由模式 match 绑定的类型T (x_shared:xs) g
。我可以为它写什么类型的签名?
data T = forall a. T [a] (a -> a -> Int)
f :: T -> Int
f (T (x_shared:xs) g) = go xs 0
where
-- go :: what type?
go (x:xs) n = go xs $! n + g x_shared x
go [] n = n