Safe Haskell | None |
---|---|
Language | Haskell98 |
- modifyContextEntry :: (Dom (Name, Type) -> Dom (Name, Type)) -> ContextEntry -> ContextEntry
- modifyContextEntries :: (Dom (Name, Type) -> Dom (Name, Type)) -> Context -> Context
- modifyContext :: MonadTCM tcm => (Context -> Context) -> tcm a -> tcm a
- mkContextEntry :: MonadTCM tcm => Dom (Name, Type) -> tcm ContextEntry
- inContext :: MonadTCM tcm => [Dom (Name, Type)] -> tcm a -> tcm a
- inTopContext :: MonadTCM tcm => tcm a -> tcm a
- escapeContext :: MonadTCM tcm => Int -> tcm a -> tcm a
- addCtx :: MonadTCM tcm => Name -> Dom Type -> tcm a -> tcm a
- class AddContext b where
- addContext :: MonadTCM tcm => b -> tcm a -> tcm a
- addCtxs :: MonadTCM tcm => [Name] -> Dom Type -> tcm a -> tcm a
- addCtxString :: MonadTCM tcm => String -> Dom Type -> tcm a -> tcm a
- addCtxString_ :: MonadTCM tcm => String -> tcm a -> tcm a
- addCtxStrings_ :: MonadTCM tcm => [String] -> tcm a -> tcm a
- dummyDom :: Dom Type
- underAbstraction :: (Subst t a, MonadTCM tcm) => Dom Type -> Abs a -> (a -> tcm b) -> tcm b
- underAbstraction_ :: (Subst t a, MonadTCM tcm) => Abs a -> (a -> tcm b) -> tcm b
- addCtxTel :: MonadTCM tcm => Telescope -> tcm a -> tcm a
- addLetBinding :: MonadTCM tcm => ArgInfo -> Name -> Term -> Type -> tcm a -> tcm a
- getContext :: MonadReader TCEnv m => m [Dom (Name, Type)]
- getContextSize :: (Applicative m, MonadReader TCEnv m) => m Nat
- getContextArgs :: (Applicative m, MonadReader TCEnv m) => m Args
- getContextTerms :: (Applicative m, MonadReader TCEnv m) => m [Term]
- getContextTelescope :: (Applicative m, MonadReader TCEnv m) => m Telescope
- getContextId :: MonadReader TCEnv m => m [CtxId]
- getContextNames :: (Applicative m, MonadReader TCEnv m) => m [Name]
- lookupBV :: MonadReader TCEnv m => Nat -> m (Dom (Name, Type))
- typeOfBV' :: (Applicative m, MonadReader TCEnv m) => Nat -> m (Dom Type)
- typeOfBV :: (Applicative m, MonadReader TCEnv m) => Nat -> m Type
- nameOfBV :: (Applicative m, MonadReader TCEnv m) => Nat -> m Name
- getVarInfo :: MonadReader TCEnv m => Name -> m (Term, Dom Type)
Modifying the context
modifyContextEntry :: (Dom (Name, Type) -> Dom (Name, Type)) -> ContextEntry -> ContextEntry Source
Modify the ctxEntry
field of a ContextEntry
.
modifyContextEntries :: (Dom (Name, Type) -> Dom (Name, Type)) -> Context -> Context Source
Modify all ContextEntry
s.
modifyContext :: MonadTCM tcm => (Context -> Context) -> tcm a -> tcm a Source
Modify a Context
in a computation.
mkContextEntry :: MonadTCM tcm => Dom (Name, Type) -> tcm ContextEntry Source
inTopContext :: MonadTCM tcm => tcm a -> tcm a Source
Change to top (=empty) context.
escapeContext :: MonadTCM tcm => Int -> tcm a -> tcm a Source
Delete the last n
bindings from the context.
Adding to the context
addCtx :: MonadTCM tcm => Name -> Dom Type -> tcm a -> tcm a Source
addCtx x arg cont
add a variable to the context.
Chooses an unused Name
.
class AddContext b where Source
Various specializations of addCtx
.
addContext :: MonadTCM tcm => b -> tcm a -> tcm a Source
AddContext String Source | |
AddContext Name Source | |
AddContext Telescope Source | |
AddContext a => AddContext [a] Source | |
AddContext (Dom (String, Type)) Source | |
AddContext (Dom (Name, Type)) Source | |
AddContext (Dom Type) Source | |
AddContext ([WithHiding Name], Dom Type) Source | |
AddContext ([Name], Dom Type) Source | |
AddContext (String, Dom Type) Source | |
AddContext (Name, Dom Type) Source |
addCtxs :: MonadTCM tcm => [Name] -> Dom Type -> tcm a -> tcm a Source
add a bunch of variables with the same type to the context
addCtxString :: MonadTCM tcm => String -> Dom Type -> tcm a -> tcm a Source
Turns the string into a name and adds it to the context.
addCtxString_ :: MonadTCM tcm => String -> tcm a -> tcm a Source
Turns the string into a name and adds it to the context, with dummy type.
addCtxStrings_ :: MonadTCM tcm => [String] -> tcm a -> tcm a Source
underAbstraction :: (Subst t a, MonadTCM tcm) => Dom Type -> Abs a -> (a -> tcm b) -> tcm b Source
Go under an abstraction.
underAbstraction_ :: (Subst t a, MonadTCM tcm) => Abs a -> (a -> tcm b) -> tcm b Source
Go under an abstract without worrying about the type to add to the context.
addLetBinding :: MonadTCM tcm => ArgInfo -> Name -> Term -> Type -> tcm a -> tcm a Source
Add a let bound variable
Querying the context
getContextSize :: (Applicative m, MonadReader TCEnv m) => m Nat Source
Get the size of the current context.
getContextArgs :: (Applicative m, MonadReader TCEnv m) => m Args Source
Generate [var (n - 1), ..., var 0]
for all declarations in the context.
getContextTerms :: (Applicative m, MonadReader TCEnv m) => m [Term] Source
Generate [var (n - 1), ..., var 0]
for all declarations in the context.
getContextTelescope :: (Applicative m, MonadReader TCEnv m) => m Telescope Source
Get the current context as a Telescope
.
getContextId :: MonadReader TCEnv m => m [CtxId] Source
Check if we are in a compatible context, i.e. an extension of the given context.
getContextNames :: (Applicative m, MonadReader TCEnv m) => m [Name] Source
Get the names of all declarations in the context.