我想知道GHCi(或其他地方)中是否存在使用任意类型表达式扩展类型同义词和族的功能。
例如,如果我有这些类型,
data A = A
data B = B
data F a = F a
data G a = G a
data H a b = H a b
type S a b = H (F a) (G b)
type T a = S (a) (H B a)
type family R a :: *
type instance R (H a b) = H b a
然后我希望能够在ghci会话中获得这种输出。
> :t undefined :: T (S B A)
undefined :: T (S B A) :: T (S B A)
> :texpand undefined :: T (S B A)
undefined :: T (S B A) :: H (F ((H (F B) (G A)))) (G (H B (H (F B) (G A))))
> :texpand undefined :: R (T (S B A))
undefined :: R (T (S B A)) :: H (G (H B (H (F B) (G A)))) (F ((H (F B) (G A))))
据我所知,GHCi实际上并没有提供类似:texpand
命令的任何内容,而且我不确定它是否仍然是该信息的最佳界面。但是,似乎可以从某种程度上从GHC中提取扩展类型,我真的希望能够以交互方式看到它们。
黑客,文档链接,关于GHCi未来增加的推测性讨论都欢迎。
答案 0 :(得分:19)
:kind!
会这样做:
λ> :kind! T (S B A)
T (S B A) :: *
= H (F (H (F B) (G A))) (G (H B (H (F B) (G A))))
λ> :kind! R (T (S B A))
R (T (S B A)) :: *
= H (G (H B (H (F B) (G A)))) (F (H (F B) (G A)))
(为方便起见,您可以在:def k! \x -> return (":kind! " ++ x)
中添加.ghci
之类的内容。)