考虑以下代码
{-# LANGUAGE ConstraintKinds #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE KindSignatures #-}
{-# LANGUAGE DataKinds #-}
module Test () where
type C x = x ~ 1
type family F x = r where
F 0 = 0
F 1 = 2
F 2 = 4
我试图说服gchi解决:kind! forall x . C x => F x
进入2
。但看起来我只能使用Type kinded stuff
=>
的权利。有没有办法解决这个问题?特别是我得到了
<interactive>:1:20: error:
• Expected a type, but ‘F x’ has kind ‘GHC.Types.Nat’
• In the type ‘forall x. C x => F x’
编辑:将其包装在代理中似乎不起作用:
:kind! (forall x . C x => Proxy (F x))
(forall x . C x => Proxy (F x)) :: *
= C x => Proxy (F x)