我想知道是否有在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未来添加的推测性讨论。