Genintern
type intern_variable_status = {
intern_ids : Names.Id.Set.t; |
notation_variable_status : (bool Stdlib.ref * Notation_term.subscopes option Stdlib.ref * Notation_term.notation_var_binders option Stdlib.ref * Notation_term.notation_var_internalization_type) Names.Id.Map.t; |
}
type glob_sign = {
ltacvars : Names.Id.Set.t; |
genv : Environ.env; |
extra : Store.t; |
intern_sign : intern_variable_status; |
strict_check : bool; |
}
val empty_glob_sign : strict:bool -> Environ.env -> glob_sign
type glob_constr_and_expr = Glob_term.glob_constr * Constrexpr.constr_expr option
In globalize tactics, we need to keep the initial constr_expr
to recompute in the environment by the effective calls to Intro, Inversion, etc The constr_expr
field is None
in TacDef though
type glob_constr_pattern_and_expr = Names.Id.Set.t * glob_constr_and_expr * Pattern.constr_pattern
The type of functions used for internalizing generic arguments.
val intern : ('raw, 'glb, 'top) Genarg.genarg_type -> ('raw, 'glb) intern_fun
val generic_intern : (Genarg.raw_generic_argument, Genarg.glob_generic_argument) intern_fun
type ('raw, 'glb) intern_pat_fun = ?loc:Loc.t -> ('raw, 'glb) intern_fun
val intern_pat : ('raw, 'glb, 'top) Genarg.genarg_type -> ('raw, 'glb) intern_pat_fun
val generic_intern_pat : (Genarg.raw_generic_argument, Genarg.glob_generic_argument) intern_pat_fun
type 'glb ntn_subst_fun = Names.Id.Set.t -> Glob_term.glob_constr Names.Id.Map.t -> 'glb -> 'glb
val substitute_notation : ('raw, 'glb, 'top) Genarg.genarg_type -> 'glb ntn_subst_fun
val generic_substitute_notation : Genarg.glob_generic_argument ntn_subst_fun
Registering functions
val register_intern0 : ('raw, 'glb, 'top) Genarg.genarg_type -> ('raw, 'glb) intern_fun -> unit
val register_intern_pat : ('raw, 'glb, 'top) Genarg.genarg_type -> ('raw, 'glb) intern_pat_fun -> unit
val register_ntn_subst0 : ('raw, 'glb, 'top) Genarg.genarg_type -> 'glb ntn_subst_fun -> unit