| Safe Haskell | None | 
|---|---|
| Language | Haskell2010 | 
Agda.Syntax.Internal
Synopsis
- class TermSize a where
- data Suggestion = forall a.Suggest a => Suggestion a
- class Suggest a where- suggestName :: a -> Maybe String
 
- class SgTel a where
- class TelToArgs a where
- type ListTel = ListTel' ArgName
- type ListTel' a = [Dom (a, Type)]
- type DummyTermKind = String
- data IntervalView
- data PathView
- data EqualityView
- type PatternSubstitution = Substitution' DeBruijnPattern
- type Substitution = Substitution' Term
- data Substitution' a- = IdS
- | EmptyS Impossible
- | a :# (Substitution' a)
- | Strengthen Impossible (Substitution' a)
- | Wk !Int (Substitution' a)
- | Lift !Int (Substitution' a)
 
- class PatternVars a where- type PatternVarOut a
- patternVars :: a -> [Arg (Either (PatternVarOut a) Term)]
 
- data ConPatternInfo = ConPatternInfo {- conPInfo :: PatternInfo
- conPRecord :: Bool
- conPFallThrough :: Bool
- conPType :: Maybe (Arg Type)
- conPLazy :: Bool
 
- type DeBruijnPattern = Pattern' DBPatVar
- data DBPatVar = DBPatVar {}
- type Pattern = Pattern' PatVarName
- data Pattern' x- = VarP PatternInfo x
- | DotP PatternInfo Term
- | ConP ConHead ConPatternInfo [NamedArg (Pattern' x)]
- | LitP PatternInfo Literal
- | ProjP ProjOrigin QName
- | IApplyP PatternInfo Term Term x
- | DefP PatternInfo QName [NamedArg (Pattern' x)]
 
- data PatOrigin- = PatOSystem
- | PatOSplit
- | PatOVar Name
- | PatODot
- | PatOWild
- | PatOCon
- | PatORec
- | PatOLit
- | PatOAbsurd
 
- data PatternInfo = PatternInfo {- patOrigin :: PatOrigin
- patAsNames :: [Name]
 
- type PatVarName = ArgName
- data Clause = Clause {}
- type NAPs = [NamedArg DeBruijnPattern]
- type Blocked_ = Blocked ()
- type NotBlocked = NotBlocked' Term
- type Blocked = Blocked' Term
- newtype BraveTerm = BraveTerm {}
- type LevelAtom = Term
- type PlusLevel = PlusLevel' Term
- data PlusLevel' t = Plus Integer t
- type Level = Level' Term
- data Level' t = Max Integer [PlusLevel' t]
- type Sort = Sort' Term
- data Sort' t
- data IsFibrant
- type Telescope = Tele (Dom Type)
- data Tele a
- class LensSort a where
- type Type = Type' Term
- type Type' a = Type'' Term a
- data Type'' t a = El {}
- data Abs a
- type Elims = [Elim]
- type Elim = Elim' Term
- type ConInfo = ConOrigin
- data Term
- class LensConName a where- getConName :: a -> QName
- setConName :: QName -> a -> a
- mapConName :: (QName -> QName) -> a -> a
 
- data ConHead = ConHead {- conName :: QName
- conDataRecord :: DataOrRecord
- conInductive :: Induction
- conFields :: [Arg QName]
 
- data DataOrRecord
- type NamedArgs = [NamedArg Term]
- type Args = [Arg Term]
- type Dom = Dom' Term
- data Dom' t e = Dom {}
- pattern ClosedLevel :: Integer -> Level
- argFromDom :: Dom' t a -> Arg a
- namedArgFromDom :: Dom' t a -> NamedArg a
- domFromArg :: Arg a -> Dom a
- domFromNamedArg :: NamedArg a -> Dom a
- defaultDom :: a -> Dom a
- defaultArgDom :: ArgInfo -> a -> Dom a
- defaultNamedArgDom :: ArgInfo -> String -> a -> Dom a
- clausePats :: Clause -> [Arg DeBruijnPattern]
- patVarNameToString :: PatVarName -> String
- nameToPatVarName :: Name -> PatVarName
- defaultPatternInfo :: PatternInfo
- varP :: a -> Pattern' a
- dotP :: Term -> Pattern' a
- litP :: Literal -> Pattern' a
- namedVarP :: PatVarName -> Named_ Pattern
- namedDBVarP :: Int -> PatVarName -> Named_ DeBruijnPattern
- absurdP :: Int -> DeBruijnPattern
- noConPatternInfo :: ConPatternInfo
- toConPatternInfo :: ConInfo -> ConPatternInfo
- fromConPatternInfo :: ConPatternInfo -> ConInfo
- patternInfo :: Pattern' x -> Maybe PatternInfo
- patternOrigin :: Pattern' x -> Maybe PatOrigin
- properlyMatching :: Pattern' a -> Bool
- properlyMatching' :: Bool -> Bool -> Pattern' a -> Bool
- isEqualityType :: EqualityView -> Bool
- isPathType :: PathView -> Bool
- isIOne :: IntervalView -> Bool
- absurdBody :: Abs Term
- isAbsurdBody :: Abs Term -> Bool
- absurdPatternName :: PatVarName
- isAbsurdPatternName :: PatVarName -> Bool
- var :: Nat -> Term
- dontCare :: Term -> Term
- dummyLocName :: CallStack -> String
- dummyTermWith :: DummyTermKind -> CallStack -> Term
- dummyLevel :: CallStack -> Level
- dummyTerm :: CallStack -> Term
- __DUMMY_TERM__ :: HasCallStack => Term
- __DUMMY_LEVEL__ :: HasCallStack => Level
- dummySort :: CallStack -> Sort
- __DUMMY_SORT__ :: HasCallStack => Sort
- dummyType :: CallStack -> Type
- __DUMMY_TYPE__ :: HasCallStack => Type
- dummyDom :: CallStack -> Dom Type
- __DUMMY_DOM__ :: HasCallStack => Dom Type
- atomicLevel :: t -> Level' t
- varSort :: Int -> Sort
- tmSort :: Term -> Sort
- tmSSort :: Term -> Sort
- levelPlus :: Integer -> Level -> Level
- levelSuc :: Level -> Level
- mkType :: Integer -> Sort
- mkProp :: Integer -> Sort
- mkSSet :: Integer -> Sort
- isSort :: Term -> Maybe Sort
- impossibleTerm :: CallStack -> Term
- mapAbsNamesM :: Applicative m => (ArgName -> m ArgName) -> Tele a -> m (Tele a)
- mapAbsNames :: (ArgName -> ArgName) -> Tele a -> Tele a
- replaceEmptyName :: ArgName -> Tele a -> Tele a
- telFromList' :: (a -> ArgName) -> ListTel' a -> Telescope
- telFromList :: ListTel -> Telescope
- telToList :: Tele (Dom t) -> [Dom (ArgName, t)]
- listTel :: Lens' ListTel Telescope
- stripDontCare :: Term -> Term
- arity :: Type -> Nat
- suggests :: [Suggestion] -> String
- unSpine :: Term -> Term
- unSpine' :: (ProjOrigin -> Bool) -> Term -> Term
- hasElims :: Term -> Maybe (Elims -> Term, Elims)
- pDom :: LensHiding a => a -> Doc -> Doc
- prettyPrecLevelSucs :: Int -> Integer -> (Int -> Doc) -> Doc
- module Agda.Syntax.Internal.Blockers
- module Agda.Syntax.Internal.Elim
- module Agda.Syntax.Abstract.Name
- newtype MetaId = MetaId {}
- newtype ProblemId = ProblemId Nat
Documentation
class TermSize a where Source #
The size of a term is roughly the number of nodes in its syntax tree. This number need not be precise for logical correctness of Agda, it is only used for reporting (and maybe decisions regarding performance).
Not counting towards the term size are:
- sort and color annotations,
- projections.
Minimal complete definition
data Suggestion Source #
Constructors
| forall a.Suggest a => Suggestion a | 
class Suggest a where Source #
Suggest a name if available (i.e. name is not "_")
Methods
suggestName :: a -> Maybe String Source #
Instances
| Suggest String Source # | |
| Defined in Agda.Syntax.Internal | |
| Suggest Name Source # | |
| Defined in Agda.Syntax.Internal | |
| Suggest Term Source # | |
| Defined in Agda.Syntax.Internal | |
| Suggest (Abs b) Source # | |
| Defined in Agda.Syntax.Internal | |
Constructing a singleton telescope.
type DummyTermKind = String Source #
data IntervalView Source #
Constructors
| IZero | |
| IOne | |
| IMin (Arg Term) (Arg Term) | |
| IMax (Arg Term) (Arg Term) | |
| INeg (Arg Term) | |
| OTerm Term | 
Instances
| Show IntervalView Source # | |
| Defined in Agda.Syntax.Internal Methods showsPrec :: Int -> IntervalView -> ShowS # show :: IntervalView -> String # showList :: [IntervalView] -> ShowS # | |
View type as path type.
data EqualityView Source #
View type as equality type.
Constructors
| EqualityType | |
| OtherType Type | reduced | 
| IdiomType Type | reduced | 
Instances
type Substitution = Substitution' Term Source #
data Substitution' a Source #
Substitutions.
Constructors
| IdS | Identity substitution.
    | 
| EmptyS Impossible | Empty substitution, lifts from the empty context. First argument is  | 
| a :# (Substitution' a) infixr 4 | Substitution extension, ` | 
| Strengthen Impossible (Substitution' a) | Strengthening substitution.  First argument is  | 
| Wk !Int (Substitution' a) | Weakening substitution, lifts to an extended context.
    | 
| Lift !Int (Substitution' a) | Lifting substitution.  Use this to go under a binder.
    | 
Instances
class PatternVars a where Source #
Extract pattern variables in left-to-right order.
   A DotP is also treated as variable (see docu for Clause).
Associated Types
type PatternVarOut a Source #
Methods
patternVars :: a -> [Arg (Either (PatternVarOut a) Term)] Source #
Instances
| PatternVars a => PatternVars [a] Source # | |
| Defined in Agda.Syntax.Internal Associated Types type PatternVarOut [a] Source # Methods patternVars :: [a] -> [Arg (Either (PatternVarOut [a]) Term)] Source # | |
| PatternVars (NamedArg (Pattern' a)) Source # | |
| Defined in Agda.Syntax.Internal Associated Types type PatternVarOut (NamedArg (Pattern' a)) Source # | |
| PatternVars (Arg (Pattern' a)) Source # | |
| Defined in Agda.Syntax.Internal Associated Types type PatternVarOut (Arg (Pattern' a)) Source # | |
data ConPatternInfo Source #
The ConPatternInfo states whether the constructor belongs to
   a record type (True) or data type (False).
   In the former case, the PatOrigin of the conPInfo says
   whether the record pattern orginates from the expansion of an
   implicit pattern.
   The Type is the type of the whole record pattern.
   The scope used for the type is given by any outer scope
   plus the clause's telescope (clauseTel).
Constructors
| ConPatternInfo | |
| Fields 
 | |
Instances
type DeBruijnPattern = Pattern' DBPatVar Source #
Type used when numbering pattern variables.
Constructors
| DBPatVar | |
| Fields | |
Instances
Arguments
| = Pattern' PatVarName | The  | 
Patterns are variables, constructors, or wildcards.
   QName is used in ConP rather than Name since
     a constructor might come from a particular namespace.
     This also meshes well with the fact that values (i.e.
     the arguments we are matching with) use QName.
Constructors
| VarP PatternInfo x | x | 
| DotP PatternInfo Term | .t | 
| ConP ConHead ConPatternInfo [NamedArg (Pattern' x)] | 
 | 
| LitP PatternInfo Literal | E.g.  | 
| ProjP ProjOrigin QName | Projection copattern. Can only appear by itself. | 
| IApplyP PatternInfo Term Term x | Path elimination pattern, like  | 
| DefP PatternInfo QName [NamedArg (Pattern' x)] | Used for HITs, the QName should be the one from primHComp. | 
Instances
Origin of the pattern: what did the user write in this position?
Constructors
| PatOSystem | Pattern inserted by the system | 
| PatOSplit | Pattern generated by case split | 
| PatOVar Name | User wrote a variable pattern | 
| PatODot | User wrote a dot pattern | 
| PatOWild | User wrote a wildcard pattern | 
| PatOCon | User wrote a constructor pattern | 
| PatORec | User wrote a record pattern | 
| PatOLit | User wrote a literal pattern | 
| PatOAbsurd | User wrote an absurd pattern | 
Instances
| Eq PatOrigin Source # | |
| Data PatOrigin Source # | |
| Defined in Agda.Syntax.Internal Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> PatOrigin -> c PatOrigin # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c PatOrigin # toConstr :: PatOrigin -> Constr # dataTypeOf :: PatOrigin -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c PatOrigin) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c PatOrigin) # gmapT :: (forall b. Data b => b -> b) -> PatOrigin -> PatOrigin # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> PatOrigin -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> PatOrigin -> r # gmapQ :: (forall d. Data d => d -> u) -> PatOrigin -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> PatOrigin -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> PatOrigin -> m PatOrigin # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> PatOrigin -> m PatOrigin # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> PatOrigin -> m PatOrigin # | |
| Show PatOrigin Source # | |
| Generic PatOrigin Source # | |
| NFData PatOrigin Source # | |
| Defined in Agda.Syntax.Internal | |
| KillRange PatOrigin Source # | |
| Defined in Agda.Syntax.Internal Methods | |
| EmbPrj PatOrigin Source # | |
| type Rep PatOrigin Source # | |
| Defined in Agda.Syntax.Internal type Rep PatOrigin = D1 ('MetaData "PatOrigin" "Agda.Syntax.Internal" "Agda-2.6.2-I0Qlyix7vKjGEzjSnBhBdj" 'False) (((C1 ('MetaCons "PatOSystem" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons "PatOSplit" 'PrefixI 'False) (U1 :: Type -> Type)) :+: (C1 ('MetaCons "PatOVar" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 Name)) :+: C1 ('MetaCons "PatODot" 'PrefixI 'False) (U1 :: Type -> Type))) :+: ((C1 ('MetaCons "PatOWild" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons "PatOCon" 'PrefixI 'False) (U1 :: Type -> Type)) :+: (C1 ('MetaCons "PatORec" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "PatOLit" 'PrefixI 'False) (U1 :: Type -> Type) :+: C1 ('MetaCons "PatOAbsurd" 'PrefixI 'False) (U1 :: Type -> Type))))) | |
data PatternInfo Source #
Constructors
| PatternInfo | |
| Fields 
 | |
Instances
| Eq PatternInfo Source # | |
| Defined in Agda.Syntax.Internal | |
| Data PatternInfo Source # | |
| Defined in Agda.Syntax.Internal Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> PatternInfo -> c PatternInfo # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c PatternInfo # toConstr :: PatternInfo -> Constr # dataTypeOf :: PatternInfo -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c PatternInfo) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c PatternInfo) # gmapT :: (forall b. Data b => b -> b) -> PatternInfo -> PatternInfo # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> PatternInfo -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> PatternInfo -> r # gmapQ :: (forall d. Data d => d -> u) -> PatternInfo -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> PatternInfo -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> PatternInfo -> m PatternInfo # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> PatternInfo -> m PatternInfo # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> PatternInfo -> m PatternInfo # | |
| Show PatternInfo Source # | |
| Defined in Agda.Syntax.Internal Methods showsPrec :: Int -> PatternInfo -> ShowS # show :: PatternInfo -> String # showList :: [PatternInfo] -> ShowS # | |
| Generic PatternInfo Source # | |
| Defined in Agda.Syntax.Internal Associated Types type Rep PatternInfo :: Type -> Type # | |
| NFData PatternInfo Source # | |
| Defined in Agda.Syntax.Internal Methods rnf :: PatternInfo -> () # | |
| KillRange PatternInfo Source # | |
| Defined in Agda.Syntax.Internal Methods | |
| EmbPrj PatternInfo Source # | |
| type Rep PatternInfo Source # | |
| Defined in Agda.Syntax.Internal type Rep PatternInfo = D1 ('MetaData "PatternInfo" "Agda.Syntax.Internal" "Agda-2.6.2-I0Qlyix7vKjGEzjSnBhBdj" 'False) (C1 ('MetaCons "PatternInfo" 'PrefixI 'True) (S1 ('MetaSel ('Just "patOrigin") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 PatOrigin) :*: S1 ('MetaSel ('Just "patAsNames") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Name]))) | |
type PatVarName = ArgName Source #
Pattern variables.
A clause is a list of patterns and the clause body.
The telescope contains the types of the pattern variables and the de Bruijn indices say how to get from the order the variables occur in the patterns to the order they occur in the telescope. The body binds the variables in the order they appear in the telescope.
clauseTel ~ permute clausePerm (patternVars namedClausePats)
Terms in dot patterns are valid in the clause telescope.
For the purpose of the permutation and the body dot patterns count as variables. TODO: Change this!
Constructors
| Clause | |
| Fields 
 | |
Instances
type NAPs = [NamedArg DeBruijnPattern] Source #
Named pattern arguments.
type NotBlocked = NotBlocked' Term Source #
Newtypes for terms that produce a dummy, rather than crash, when applied to incompatible eliminations.
Instances
| Data BraveTerm Source # | |
| Defined in Agda.Syntax.Internal Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> BraveTerm -> c BraveTerm # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c BraveTerm # toConstr :: BraveTerm -> Constr # dataTypeOf :: BraveTerm -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c BraveTerm) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c BraveTerm) # gmapT :: (forall b. Data b => b -> b) -> BraveTerm -> BraveTerm # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> BraveTerm -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> BraveTerm -> r # gmapQ :: (forall d. Data d => d -> u) -> BraveTerm -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> BraveTerm -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> BraveTerm -> m BraveTerm # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> BraveTerm -> m BraveTerm # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> BraveTerm -> m BraveTerm # | |
| Show BraveTerm Source # | |
| DeBruijn BraveTerm Source # | |
| Defined in Agda.TypeChecking.Substitute | |
| Subst BraveTerm Source # | |
| Defined in Agda.TypeChecking.Substitute Methods applySubst :: Substitution' (SubstArg BraveTerm) -> BraveTerm -> BraveTerm Source # | |
| Apply BraveTerm Source # | |
| type SubstArg BraveTerm Source # | |
| Defined in Agda.TypeChecking.Substitute | |
type PlusLevel = PlusLevel' Term Source #
data PlusLevel' t Source #
Instances
A level is a maximum expression of a closed level and 0..n
   PlusLevel expressions each of which is an atom plus a number.
Constructors
| Max Integer [PlusLevel' t] | 
Instances
Sorts.
Constructors
| Type (Level' t) | 
 | 
| Prop (Level' t) | 
 | 
| Inf IsFibrant Integer | 
 | 
| SSet (Level' t) | 
 | 
| SizeUniv | 
 | 
| LockUniv | 
 | 
| PiSort (Dom' t t) (Sort' t) (Abs (Sort' t)) | Sort of the pi type. | 
| FunSort (Sort' t) (Sort' t) | Sort of a (non-dependent) function type. | 
| UnivSort (Sort' t) | Sort of another sort. | 
| MetaS !MetaId [Elim' t] | |
| DefS QName [Elim' t] | A postulated sort. | 
| DummyS String | A (part of a) term or type which is only used for internal purposes.
   Replaces the abuse of  | 
Instances
Instances
| Eq IsFibrant Source # | |
| Data IsFibrant Source # | |
| Defined in Agda.Syntax.Internal Methods gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> IsFibrant -> c IsFibrant # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c IsFibrant # toConstr :: IsFibrant -> Constr # dataTypeOf :: IsFibrant -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c IsFibrant) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c IsFibrant) # gmapT :: (forall b. Data b => b -> b) -> IsFibrant -> IsFibrant # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> IsFibrant -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> IsFibrant -> r # gmapQ :: (forall d. Data d => d -> u) -> IsFibrant -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> IsFibrant -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> IsFibrant -> m IsFibrant # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> IsFibrant -> m IsFibrant # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> IsFibrant -> m IsFibrant # | |
| Ord IsFibrant Source # | |
| Show IsFibrant Source # | |
| Generic IsFibrant Source # | |
| NFData IsFibrant Source # | |
| Defined in Agda.Syntax.Internal | |
| EmbPrj IsFibrant Source # | |
| type Rep IsFibrant Source # | |
Sequence of types. An argument of the first type is bound in later types and so on.
Instances
class LensSort a where Source #
Minimal complete definition
Types are terms with a sort annotation.
Instances
Binder.
Abs: The bound variable might appear in the body.
   NoAbs is pseudo-binder, it does not introduce a fresh variable,
      similar to the const of Haskell.
Constructors
| Abs | The body has (at least) one free variable.
   Danger:  | 
| NoAbs | |
Instances
Raw values.
Def is used for both defined and undefined constants.
   Assume there is a type declaration and a definition for
     every constant, even if the definition is an empty
     list of clauses.
Constructors
| Var !Int Elims | 
 | 
| Lam ArgInfo (Abs Term) | Terms are beta normal. Relevance is ignored | 
| Lit Literal | |
| Def QName Elims | 
 | 
| Con ConHead ConInfo Elims | 
 | 
| Pi (Dom Type) (Abs Type) | dependent or non-dependent function space | 
| Sort Sort | |
| Level Level | |
| MetaV !MetaId Elims | |
| DontCare Term | Irrelevant stuff in relevant position, but created
   in an irrelevant context.  Basically, an internal
   version of the irrelevance axiom  | 
| Dummy String Elims | A (part of a) term or type which is only used for internal purposes.
   Replaces the  | 
Instances
class LensConName a where Source #
Minimal complete definition
Methods
getConName :: a -> QName Source #
setConName :: QName -> a -> a Source #
mapConName :: (QName -> QName) -> a -> a Source #
Instances
| LensConName ConHead Source # | |
| Defined in Agda.Syntax.Internal | |
Store the names of the record fields in the constructor. This allows reduction of projection redexes outside of TCM. For instance, during substitution and application.
Constructors
| ConHead | |
| Fields 
 | |
Instances
data DataOrRecord Source #
Constructors
| IsData | |
| IsRecord PatternOrCopattern | 
Instances
Similar to Arg, but we need to distinguish
   an irrelevance annotation in a function domain
   (the domain itself is not irrelevant!)
   from an irrelevant argument.
Dom is used in Pi of internal syntax, in Context and Telescope.
   Arg is used for actual arguments (Var, Con, Def etc.)
   and in Abstract syntax and other situations.
- cubical
- When domFinite = Truefor the domain of aPitype, the elements should be compared by tabulating the domain type. Only supported in case the domain type is primIsOne, to obtain the correct equality for partial elements.
Constructors
| Dom | |
Instances
pattern ClosedLevel :: Integer -> Level Source #
Constant level n
argFromDom :: Dom' t a -> Arg a Source #
namedArgFromDom :: Dom' t a -> NamedArg a Source #
domFromArg :: Arg a -> Dom a Source #
domFromNamedArg :: NamedArg a -> Dom a Source #
defaultDom :: a -> Dom a Source #
defaultArgDom :: ArgInfo -> a -> Dom a Source #
clausePats :: Clause -> [Arg DeBruijnPattern] Source #
nameToPatVarName :: Name -> PatVarName Source #
namedDBVarP :: Int -> PatVarName -> Named_ DeBruijnPattern Source #
absurdP :: Int -> DeBruijnPattern Source #
Make an absurd pattern with the given de Bruijn index.
toConPatternInfo :: ConInfo -> ConPatternInfo Source #
Build partial ConPatternInfo from ConInfo
fromConPatternInfo :: ConPatternInfo -> ConInfo Source #
Build ConInfo from ConPatternInfo.
patternInfo :: Pattern' x -> Maybe PatternInfo Source #
Retrieve the PatternInfo from a pattern
properlyMatching :: Pattern' a -> Bool Source #
Does the pattern perform a match that could fail?
isEqualityType :: EqualityView -> Bool Source #
isPathType :: PathView -> Bool Source #
isIOne :: IntervalView -> Bool Source #
absurdBody :: Abs Term Source #
Absurd lambdas are internally represented as identity with variable name "()".
isAbsurdPatternName :: PatVarName -> Bool Source #
dummyLocName :: CallStack -> String Source #
Construct a string representing the call-site that created the dummy thing.
dummyTermWith :: DummyTermKind -> CallStack -> Term Source #
Aux: A dummy term to constitute a dummy termlevelsort/type.
dummyLevel :: CallStack -> Level Source #
A dummy level to constitute a level/sort created at location. Note: use macro DUMMY_LEVEL !
dummyTerm :: CallStack -> Term Source #
A dummy term created at location. Note: use macro DUMMY_TERM !
__DUMMY_TERM__ :: HasCallStack => Term Source #
__DUMMY_LEVEL__ :: HasCallStack => Level Source #
dummySort :: CallStack -> Sort Source #
A dummy sort created at location. Note: use macro DUMMY_SORT !
__DUMMY_SORT__ :: HasCallStack => Sort Source #
dummyType :: CallStack -> Type Source #
A dummy type created at location. Note: use macro DUMMY_TYPE !
__DUMMY_TYPE__ :: HasCallStack => Type Source #
dummyDom :: CallStack -> Dom Type Source #
Context entries without a type have this dummy type. Note: use macro DUMMY_DOM !
__DUMMY_DOM__ :: HasCallStack => Dom Type Source #
atomicLevel :: t -> Level' t Source #
impossibleTerm :: CallStack -> Term Source #
mapAbsNamesM :: Applicative m => (ArgName -> m ArgName) -> Tele a -> m (Tele a) Source #
A traversal for the names in a telescope.
telFromList :: ListTel -> Telescope Source #
Convert a list telescope to a telescope.
suggests :: [Suggestion] -> String Source #
unSpine' :: (ProjOrigin -> Bool) -> Term -> Term Source #
Convert Proj projection eliminations
   according to their ProjOrigin into
   Def projection applications.
hasElims :: Term -> Maybe (Elims -> Term, Elims) Source #
A view distinguishing the neutrals Var, Def, and MetaV which
   can be projected.
module Agda.Syntax.Internal.Elim
module Agda.Syntax.Abstract.Name
A meta variable identifier is just a natural number.
Instances
A "problem" consists of a set of constraints and the same constraint can be part of multiple problems.