Module Context.Named
This module represents contexts that can capture non-anonymous variables. Individual declarations are then designated by the identifiers they bind.
module Declaration : sig ... endRepresentation of local declarations.
type ('constr, 'types) pt= ('constr, 'types) Declaration.pt listNamed-context is represented as a list of declarations. Inner-most declarations are at the beginning of the list. Outer-most declarations are at the end of the list.
val empty : ('c, 't) ptempty named-context
val add : ('c, 't) Declaration.pt -> ('c, 't) pt -> ('c, 't) ptReturn a new named-context enriched by with a given inner-most declaration.
val length : ('c, 't) pt -> intReturn the number of local declarations in a given named-context.
val lookup : Names.Id.t -> ('c, 't) pt -> ('c, 't) Declaration.ptReturn a declaration designated by an identifier of the variable bound in that declaration.
- raises Not_found
if the designated identifier is not bound in a given named-context.
val equal : ('c -> 'c -> bool) -> ('c, 'c) pt -> ('c, 'c) pt -> boolCheck whether given two named-contexts are equal.
val iter : ('c -> unit) -> ('c, 'c) pt -> unitPerform a given action on every declaration in a given named-context.
val fold_inside : ('a -> ('c, 't) Declaration.pt -> 'a) -> init:'a -> ('c, 't) pt -> 'aReduce all terms in a given named-context to a single value. Innermost declarations are processed first.
val fold_outside : (('c, 't) Declaration.pt -> 'a -> 'a) -> ('c, 't) pt -> init:'a -> 'aReduce all terms in a given named-context to a single value. Outermost declarations are processed first.
val to_vars : ('c, 't) pt -> Names.Id.Set.tReturn the set of all identifiers bound in a given named-context.
val drop_bodies : ('c, 't) pt -> ('c, 't) ptTurn all
LocalDefintoLocalAssum, leaveLocalAssumunchanged.
val to_instance : (Names.Id.t -> 'r) -> ('c, 't) pt -> 'r listto_instance Ωbuilds an instanceargssuch thatΩ ⊢ args:ΩwhereΩis a named-context and with the local definitions ofΩskipped. Example: forid1:T,id2:=c,id3:U, it givesVar id1, Var id3. Allidjare supposed distinct.