{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE ViewPatterns #-}
module Swarm.Language.Kindcheck (
KindError (..),
processPolytype,
processType,
) where
import Control.Algebra (Has)
import Control.Effect.Reader (Reader, ask)
import Control.Effect.Throw (Throw, throwError)
import Control.Monad.Extra (unlessM)
import Data.Fix (Fix (..))
import Prettyprinter (hsep, nest, pretty, vsep, (<+>))
import Swarm.Language.Types
import Swarm.Pretty (PrettyPrec (..), ppr)
import Swarm.Util (number)
import Swarm.Util.Effect (withThrow)
processPolytype :: (Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) => Polytype -> m TydefInfo
processPolytype :: forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Polytype -> m TydefInfo
processPolytype pty :: Polytype
pty@(Polytype -> ([Var], Type)
forall t. Poly 'Quantified t -> ([Var], t)
unPoly -> ([Var]
xs, Type
_)) = do
Polytype
pty' <- (Type -> m Type) -> Polytype -> m Polytype
forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
forall (f :: * -> *) a b.
Applicative f =>
(a -> f b) -> Poly 'Quantified a -> f (Poly 'Quantified b)
traverse Type -> m Type
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Type -> m Type
processType Polytype
pty
TydefInfo -> m TydefInfo
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (TydefInfo -> m TydefInfo) -> TydefInfo -> m TydefInfo
forall a b. (a -> b) -> a -> b
$ Polytype -> Arity -> TydefInfo
TydefInfo Polytype
pty' (Int -> Arity
Arity (Int -> Arity) -> Int -> Arity
forall a b. (a -> b) -> a -> b
$ [Var] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [Var]
xs)
processType :: (Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) => Type -> m Type
processType :: forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Type -> m Type
processType Type
ty = do
Type
ty' <- Type -> m Type
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (Reader TDCtx) sig m =>
Type -> m Type
resolveTydefs Type
ty
Type -> m ()
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Type -> m ()
checkKind Type
ty'
Type -> m Type
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Type
ty'
resolveTydefs :: Has (Reader TDCtx) sig m => Type -> m Type
resolveTydefs :: forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (Reader TDCtx) sig m =>
Type -> m Type
resolveTydefs (Fix TypeF Type
tyF) =
TypeF Type -> Type
forall (f :: * -> *). f (Fix f) -> Fix f
Fix (TypeF Type -> Type) -> m (TypeF Type) -> m Type
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> case TypeF Type
tyF of
TyConF TyCon
tc [Type]
tys -> do
TyCon
tc' <- case TyCon
tc of
TCUser TDVar
u -> TDVar -> TyCon
TCUser (TDVar -> TyCon) -> m TDVar -> m TyCon
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TDVar -> m TDVar
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (Reader TDCtx) sig m =>
TDVar -> m TDVar
resolveUserTy TDVar
u
TyCon
_ -> TyCon -> m TyCon
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure TyCon
tc
TyCon -> [Type] -> TypeF Type
forall t. TyCon -> [t] -> TypeF t
TyConF TyCon
tc' ([Type] -> TypeF Type) -> m [Type] -> m (TypeF Type)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (Type -> m Type) -> [Type] -> m [Type]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
forall (m :: * -> *) a b. Monad m => (a -> m b) -> [a] -> m [b]
mapM Type -> m Type
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (Reader TDCtx) sig m =>
Type -> m Type
resolveTydefs [Type]
tys
TyRcdF Map Var Type
m -> Map Var Type -> TypeF Type
forall t. Map Var t -> TypeF t
TyRcdF (Map Var Type -> TypeF Type) -> m (Map Var Type) -> m (TypeF Type)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (Type -> m Type) -> Map Var Type -> m (Map Var Type)
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
forall (m :: * -> *) a b.
Monad m =>
(a -> m b) -> Map Var a -> m (Map Var b)
mapM Type -> m Type
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (Reader TDCtx) sig m =>
Type -> m Type
resolveTydefs Map Var Type
m
TyRecF Var
x Type
t -> Var -> Type -> TypeF Type
forall t. Var -> t -> TypeF t
TyRecF Var
x (Type -> TypeF Type) -> m Type -> m (TypeF Type)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Type -> m Type
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (Reader TDCtx) sig m =>
Type -> m Type
resolveTydefs Type
t
TyVarF {} -> TypeF Type -> m (TypeF Type)
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure TypeF Type
tyF
TyRecVarF {} -> TypeF Type -> m (TypeF Type)
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure TypeF Type
tyF
data KindError
=
ArityMismatch TyCon Int [Type]
|
UndefinedTyCon TyCon Type
|
TrivialRecTy Var Type
|
VacuousRecTy Var Type
deriving (KindError -> KindError -> Bool
(KindError -> KindError -> Bool)
-> (KindError -> KindError -> Bool) -> Eq KindError
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: KindError -> KindError -> Bool
== :: KindError -> KindError -> Bool
$c/= :: KindError -> KindError -> Bool
/= :: KindError -> KindError -> Bool
Eq, Int -> KindError -> ShowS
[KindError] -> ShowS
KindError -> String
(Int -> KindError -> ShowS)
-> (KindError -> String)
-> ([KindError] -> ShowS)
-> Show KindError
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> KindError -> ShowS
showsPrec :: Int -> KindError -> ShowS
$cshow :: KindError -> String
show :: KindError -> String
$cshowList :: [KindError] -> ShowS
showList :: [KindError] -> ShowS
Show)
instance PrettyPrec KindError where
prettyPrec :: forall ann. Int -> KindError -> Doc ann
prettyPrec Int
_ = \case
ArityMismatch TyCon
c Int
a [Type]
tys ->
Int -> Doc ann -> Doc ann
forall ann. Int -> Doc ann -> Doc ann
nest Int
2 (Doc ann -> Doc ann)
-> ([Doc ann] -> Doc ann) -> [Doc ann] -> Doc ann
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [Doc ann] -> Doc ann
forall ann. [Doc ann] -> Doc ann
vsep ([Doc ann] -> Doc ann) -> [Doc ann] -> Doc ann
forall a b. (a -> b) -> a -> b
$
[ Doc ann
"Kind error:"
, [Doc ann] -> Doc ann
forall ann. [Doc ann] -> Doc ann
hsep
[ TyCon -> Doc ann
forall a ann. PrettyPrec a => a -> Doc ann
ppr TyCon
c
, Doc ann
"requires"
, Int -> Doc ann
forall ann. Int -> Doc ann
forall a ann. Pretty a => a -> Doc ann
pretty Int
a
, Doc ann
"type"
, Var -> Doc ann
forall ann. Var -> Doc ann
forall a ann. Pretty a => a -> Doc ann
pretty (Int -> Var -> Var
number Int
a Var
"argument" Var -> Var -> Var
forall a. Semigroup a => a -> a -> a
<> Var
",")
, Doc ann
"but was given"
, Int -> Doc ann
forall ann. Int -> Doc ann
forall a ann. Pretty a => a -> Doc ann
pretty ([Type] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [Type]
tys)
]
]
[Doc ann] -> [Doc ann] -> [Doc ann]
forall a. [a] -> [a] -> [a]
++ [Doc ann
"in the type:" Doc ann -> Doc ann -> Doc ann
forall ann. Doc ann -> Doc ann -> Doc ann
<+> Type -> Doc ann
forall a ann. PrettyPrec a => a -> Doc ann
ppr (TyCon -> [Type] -> Type
TyConApp TyCon
c [Type]
tys) | Bool -> Bool
not ([Type] -> Bool
forall a. [a] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [Type]
tys)]
UndefinedTyCon TyCon
tc Type
_ty -> Doc ann
"Undefined type" Doc ann -> Doc ann -> Doc ann
forall ann. Doc ann -> Doc ann -> Doc ann
<+> TyCon -> Doc ann
forall a ann. PrettyPrec a => a -> Doc ann
ppr TyCon
tc
TrivialRecTy Var
x Type
ty ->
Int -> Doc ann -> Doc ann
forall ann. Int -> Doc ann -> Doc ann
nest Int
2 (Doc ann -> Doc ann)
-> ([Doc ann] -> Doc ann) -> [Doc ann] -> Doc ann
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [Doc ann] -> Doc ann
forall ann. [Doc ann] -> Doc ann
vsep ([Doc ann] -> Doc ann) -> [Doc ann] -> Doc ann
forall a b. (a -> b) -> a -> b
$
[ Doc ann
"Encountered trivial recursive type" Doc ann -> Doc ann -> Doc ann
forall ann. Doc ann -> Doc ann -> Doc ann
<+> Type -> Doc ann
forall a ann. PrettyPrec a => a -> Doc ann
ppr (Var -> Type -> Type
TyRec Var
x Type
ty)
, Doc ann
"Did you forget to use" Doc ann -> Doc ann -> Doc ann
forall ann. Doc ann -> Doc ann -> Doc ann
<+> Var -> Doc ann
forall a ann. PrettyPrec a => a -> Doc ann
ppr Var
x Doc ann -> Doc ann -> Doc ann
forall ann. Doc ann -> Doc ann -> Doc ann
<+> Doc ann
"in the body of the type?"
]
VacuousRecTy Var
x Type
ty ->
Int -> Doc ann -> Doc ann
forall ann. Int -> Doc ann -> Doc ann
nest Int
2 (Doc ann -> Doc ann)
-> ([Doc ann] -> Doc ann) -> [Doc ann] -> Doc ann
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [Doc ann] -> Doc ann
forall ann. [Doc ann] -> Doc ann
vsep ([Doc ann] -> Doc ann) -> [Doc ann] -> Doc ann
forall a b. (a -> b) -> a -> b
$
[ Doc ann
"Encountered vacuous recursive type" Doc ann -> Doc ann -> Doc ann
forall ann. Doc ann -> Doc ann -> Doc ann
<+> Type -> Doc ann
forall a ann. PrettyPrec a => a -> Doc ann
ppr (Var -> Type -> Type
TyRec Var
x Type
ty)
, Doc ann
"Recursive types must be productive, i.e. must not expand to themselves."
]
checkKind :: (Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) => Type -> m ()
checkKind :: forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Type -> m ()
checkKind ty :: Type
ty@(Fix TypeF Type
tyF) = case TypeF Type
tyF of
TyConF TyCon
c [Type]
tys -> do
TDCtx
tdCtx <- m TDCtx
forall r (sig :: (* -> *) -> * -> *) (m :: * -> *).
Has (Reader r) sig m =>
m r
ask
case Arity -> Int
getArity (Arity -> Int) -> Maybe Arity -> Maybe Int
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TDCtx -> TyCon -> Maybe Arity
tcArity TDCtx
tdCtx TyCon
c of
Maybe Int
Nothing -> KindError -> m ()
forall e (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (Throw e) sig m =>
e -> m a
throwError (KindError -> m ()) -> KindError -> m ()
forall a b. (a -> b) -> a -> b
$ TyCon -> Type -> KindError
UndefinedTyCon TyCon
c Type
ty
Just Int
a -> case Int -> Int -> Ordering
forall a. Ord a => a -> a -> Ordering
compare ([Type] -> Int
forall a. [a] -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length [Type]
tys) Int
a of
Ordering
EQ -> (Type -> m ()) -> [Type] -> m ()
forall (t :: * -> *) (m :: * -> *) a b.
(Foldable t, Monad m) =>
(a -> m b) -> t a -> m ()
mapM_ Type -> m ()
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Type -> m ()
checkKind [Type]
tys
Ordering
_ -> KindError -> m ()
forall e (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (Throw e) sig m =>
e -> m a
throwError (KindError -> m ()) -> KindError -> m ()
forall a b. (a -> b) -> a -> b
$ TyCon -> Int -> [Type] -> KindError
ArityMismatch TyCon
c Int
a [Type]
tys
TyVarF Var
_ Var
_ -> () -> m ()
forall a. a -> m a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
TyRcdF Map Var Type
m -> (Type -> m ()) -> Map Var Type -> m ()
forall (t :: * -> *) (m :: * -> *) a b.
(Foldable t, Monad m) =>
(a -> m b) -> t a -> m ()
mapM_ Type -> m ()
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Type -> m ()
checkKind Map Var Type
m
TyRecF Var
x Type
t -> do
Type -> m ()
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Type -> m ()
checkKind (TypeF Type -> Type -> Nat -> Type
forall t. SubstRec t => TypeF t -> t -> Nat -> t
substRec (Var -> Var -> TypeF Type
forall t. Var -> Var -> TypeF t
TyVarF Var
x Var
x) Type
t Nat
NZ)
Var -> Type -> m ()
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Var -> Type -> m ()
checkRecTy Var
x Type
t
TyRecVarF Nat
_ -> () -> m ()
forall a. a -> m a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
checkRecTy :: (Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) => Var -> Type -> m ()
checkRecTy :: forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Var -> Type -> m ()
checkRecTy Var
x Type
ty = do
m Bool -> m () -> m ()
forall (m :: * -> *). Monad m => m Bool -> m () -> m ()
unlessM (Nat -> Type -> m Bool
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
containsVar Nat
NZ Type
ty) (m () -> m ()) -> m () -> m ()
forall a b. (a -> b) -> a -> b
$ KindError -> m ()
forall e (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (Throw e) sig m =>
e -> m a
throwError (Var -> Type -> KindError
TrivialRecTy Var
x Type
ty)
m Bool -> m () -> m ()
forall (m :: * -> *). Monad m => m Bool -> m () -> m ()
unlessM (Nat -> Type -> m Bool
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
nonVacuous Nat
NZ Type
ty) (m () -> m ()) -> m () -> m ()
forall a b. (a -> b) -> a -> b
$ KindError -> m ()
forall e (sig :: (* -> *) -> * -> *) (m :: * -> *) a.
Has (Throw e) sig m =>
e -> m a
throwError (Var -> Type -> KindError
VacuousRecTy Var
x Type
ty)
containsVar ::
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat ->
Type ->
m Bool
containsVar :: forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
containsVar Nat
i ty :: Type
ty@(Fix TypeF Type
tyF) = case TypeF Type
tyF of
TyRecVarF Nat
j -> Bool -> m Bool
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Nat
i Nat -> Nat -> Bool
forall a. Eq a => a -> a -> Bool
== Nat
j)
TyVarF {} -> Bool -> m Bool
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Bool
False
TyConF (TCUser TDVar
u) [Type]
tys -> do
Type
ty' <-
(ExpandTydefErr -> KindError)
-> ThrowC ExpandTydefErr m Type -> m Type
forall e2 (sig :: (* -> *) -> * -> *) (m :: * -> *) e1 a.
Has (Throw e2) sig m =>
(e1 -> e2) -> ThrowC e1 m a -> m a
withThrow
(\(UnexpandedUserType TDVar
_) -> TyCon -> Type -> KindError
UndefinedTyCon (TDVar -> TyCon
TCUser TDVar
u) Type
ty)
(TDVar -> [Type] -> ThrowC ExpandTydefErr m Type
forall (sig :: (* -> *) -> * -> *) (m :: * -> *) t.
(Has (Reader TDCtx) sig m, Has (Throw ExpandTydefErr) sig m,
Typical t) =>
TDVar -> [t] -> m t
expandTydef TDVar
u [Type]
tys)
Nat -> Type -> m Bool
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
containsVar Nat
i Type
ty'
TyConF TyCon
_ [Type]
tys -> [Bool] -> Bool
forall (t :: * -> *). Foldable t => t Bool -> Bool
or ([Bool] -> Bool) -> m [Bool] -> m Bool
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (Type -> m Bool) -> [Type] -> m [Bool]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
forall (m :: * -> *) a b. Monad m => (a -> m b) -> [a] -> m [b]
mapM (Nat -> Type -> m Bool
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
containsVar Nat
i) [Type]
tys
TyRcdF Map Var Type
m -> Map Var Bool -> Bool
forall (t :: * -> *). Foldable t => t Bool -> Bool
or (Map Var Bool -> Bool) -> m (Map Var Bool) -> m Bool
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (Type -> m Bool) -> Map Var Type -> m (Map Var Bool)
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
(a -> m b) -> t a -> m (t b)
forall (m :: * -> *) a b.
Monad m =>
(a -> m b) -> Map Var a -> m (Map Var b)
mapM (Nat -> Type -> m Bool
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
containsVar Nat
i) Map Var Type
m
TyRecF Var
_ Type
ty' -> Nat -> Type -> m Bool
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
containsVar (Nat -> Nat
NS Nat
i) Type
ty'
nonVacuous ::
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat ->
Type ->
m Bool
nonVacuous :: forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
nonVacuous Nat
i ty :: Type
ty@(Fix TypeF Type
tyF) = case TypeF Type
tyF of
TyRecVarF Nat
j -> Bool -> m Bool
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Nat
i Nat -> Nat -> Bool
forall a. Eq a => a -> a -> Bool
/= Nat
j)
TyConF (TCUser TDVar
u) [Type]
tys -> do
Type
ty' <-
(ExpandTydefErr -> KindError)
-> ThrowC ExpandTydefErr m Type -> m Type
forall e2 (sig :: (* -> *) -> * -> *) (m :: * -> *) e1 a.
Has (Throw e2) sig m =>
(e1 -> e2) -> ThrowC e1 m a -> m a
withThrow
(\(UnexpandedUserType TDVar
_) -> TyCon -> Type -> KindError
UndefinedTyCon (TDVar -> TyCon
TCUser TDVar
u) Type
ty)
(TDVar -> [Type] -> ThrowC ExpandTydefErr m Type
forall (sig :: (* -> *) -> * -> *) (m :: * -> *) t.
(Has (Reader TDCtx) sig m, Has (Throw ExpandTydefErr) sig m,
Typical t) =>
TDVar -> [t] -> m t
expandTydef TDVar
u [Type]
tys)
Nat -> Type -> m Bool
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
nonVacuous Nat
i Type
ty'
TyRecF Var
_ Type
ty' -> Nat -> Type -> m Bool
forall (sig :: (* -> *) -> * -> *) (m :: * -> *).
(Has (Reader TDCtx) sig m, Has (Throw KindError) sig m) =>
Nat -> Type -> m Bool
nonVacuous (Nat -> Nat
NS Nat
i) Type
ty'
TyConF {} -> Bool -> m Bool
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Bool
True
TyRcdF {} -> Bool -> m Bool
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Bool
True
TyVarF {} -> Bool -> m Bool
forall a. a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Bool
True