package rocq-runtime
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
sha256=b236dc44f92e1eeca6877c7ee188a90c2303497fe7beb99df711ed5a7ce0d824
    
    
  doc/rocq-runtime.pretyping/Glob_term/index.html
Module Glob_term
Untyped intermediate terms
glob_constr comes after constr_expr and before constr.
Resolution of names, insertion of implicit arguments placeholder, and notations are done, but coercions, inference of implicit arguments and pattern-matching compilation are not.
type existential_name = Names.Id.tSorts
type glob_sort_name = - | GSProp(*- representation of *)- SPropliteral
- | GProp(*- representation of *)- Proplevel
- | GSet(*- representation of *)- Setlevel
- | GUniv of Univ.Level.t
- | GLocalUniv of Names.lident(*- Locally bound universes (may also be nonstrict declaration) *)
- | GRawUniv of Univ.Level.t(*- Hack for funind, DO NOT USE - Note that producing the similar Constrexpr.CRawType for printing is OK, just don't try to reinterp it. *)
type 'a glob_sort_gen = - | UAnonymous of {- rigid : UState.rigid;
 - }(*- not rigid = unifiable by minimization *)
- | UNamed of 'a
type glob_level = glob_sort_name glob_sort_genlevels, occurring in universe instances
type glob_instance = glob_quality list * glob_level listtype glob_sort = glob_qvar option * (glob_sort_name * int) list glob_sort_gensort expressions
type glob_constraint = glob_sort_name * Univ.constraint_type * glob_sort_nametype 'a cases_pattern_r = - | PatVar of Names.Name.t
- | PatCstr of Names.constructor * 'a cases_pattern_g list * Names.Name.t(*
 *)- PatCstr(p,C,l,x)= "|'C' 'l' as 'x'"
The kind of patterns that occurs in "match ... with ... end"
locs here refers to the ident's location, not whole pat
and 'a cases_pattern_g = ('a cases_pattern_r, 'a) DAst.ttype cases_pattern = [ `any ] cases_pattern_gtype relevance_info = glob_relevance optiontype glob_evar_kind = Evar_kinds.glob_evar_kind = - | GImplicitArg of Names.GlobRef.t * int * Names.Id.t * bool(*- Force inference *)
- | GBinderType of Names.Name.t
- | GNamedHole of bool * Names.Id.t
- | GQuestionMark of Evar_kinds.question_mark
- | GCasesType
- | GInternalHole
- | GImpossibleCase
type 'a glob_constr_r = - | GRef of Names.GlobRef.t * glob_instance option(*- An identifier that represents a reference to an object defined either in the (global) environment or in the (local) context. *)
- | GVar of Names.Id.t(*- An identifier that cannot be regarded as "GRef". Bound variables are typically represented this way. *)
- | GEvar of existential_name CAst.t * (Names.lident * 'a glob_constr_g) list
- | GPatVar of Evar_kinds.matching_var_kind(*- Used for patterns only *)
- | GApp of 'a glob_constr_g * 'a glob_constr_g list
- | GLambda of Names.Name.t * relevance_info * binding_kind * 'a glob_constr_g * 'a glob_constr_g
- | GProd of Names.Name.t * relevance_info * binding_kind * 'a glob_constr_g * 'a glob_constr_g
- | GLetIn of Names.Name.t * relevance_info * 'a glob_constr_g * 'a glob_constr_g option * 'a glob_constr_g
- | GCases of Constr.case_style * 'a glob_constr_g option * 'a tomatch_tuples_g * 'a cases_clauses_g(*
 *)- GCases(style,r,tur,cc)= "match 'tur' return 'r' with 'cc'" (in- MatchStyle)
- | GLetTuple of Names.Name.t list * Names.Name.t * 'a glob_constr_g option * 'a glob_constr_g * 'a glob_constr_g
- | GIf of 'a glob_constr_g * Names.Name.t * 'a glob_constr_g option * 'a glob_constr_g * 'a glob_constr_g
- | GRec of glob_fix_kind * Names.Id.t array * 'a glob_decl_g list array * 'a glob_constr_g array * 'a glob_constr_g array
- | GSort of glob_sort
- | GHole of glob_evar_kind
- | GGenarg of Genarg.glob_generic_argument
- | GCast of 'a glob_constr_g * Constr.cast_kind option * 'a glob_constr_g
- | GProj of Names.Constant.t * glob_instance option * 'a glob_constr_g list * 'a glob_constr_g
- | GInt of Uint63.t
- | GFloat of Float64.t
- | GString of Pstring.t
- | GArray of glob_instance option * 'a glob_constr_g array * 'a glob_constr_g * 'a glob_constr_g
Representation of an internalized (or in other words globalized) term.
and 'a glob_constr_g = ('a glob_constr_r, 'a) DAst.tand 'a glob_decl_g =
  Names.Name.t
  * relevance_info
  * binding_kind
  * 'a glob_constr_g option
  * 'a glob_constr_gand 'a predicate_pattern_g =
  Names.Name.t * (Names.inductive * Names.Name.t list) CAst.t option(na,id) = "as 'na' in 'id'" where if id is Some(l,I,k,args).
and 'a tomatch_tuple_g = 'a glob_constr_g * 'a predicate_pattern_gand 'a tomatch_tuples_g = 'a tomatch_tuple_g listand 'a cases_clause_g =
  (Names.Id.t list * 'a cases_pattern_g list * 'a glob_constr_g) CAst.t(il,cl,t) = "|'cl' => 't'". Precondition: the free variables of t are members of il.
and 'a cases_clauses_g = 'a cases_clause_g listtype glob_constr = [ `any ] glob_constr_gtype tomatch_tuple = [ `any ] tomatch_tuple_gtype tomatch_tuples = [ `any ] tomatch_tuples_gtype cases_clause = [ `any ] cases_clause_gtype cases_clauses = [ `any ] cases_clauses_gtype glob_decl = [ `any ] glob_decl_gtype predicate_pattern = [ `any ] predicate_pattern_gtype 'a disjunctive_cases_clause_g =
  (Names.Id.t list * 'a cases_pattern_g list list * 'a glob_constr_g) CAst.ttype 'a disjunctive_cases_clauses_g = 'a disjunctive_cases_clause_g listtype 'a cases_pattern_disjunction_g = 'a cases_pattern_g listtype disjunctive_cases_clause = [ `any ] disjunctive_cases_clause_gtype disjunctive_cases_clauses = [ `any ] disjunctive_cases_clauses_gtype cases_pattern_disjunction = [ `any ] cases_pattern_disjunction_gtype 'a extended_glob_local_binder_r = - | GLocalAssum of Names.Name.t * relevance_info * binding_kind * 'a glob_constr_g
- | GLocalDef of Names.Name.t * relevance_info * 'a glob_constr_g * 'a glob_constr_g option
- | GLocalPattern of 'a cases_pattern_disjunction_g * Names.Id.t list * Names.Id.t * binding_kind * 'a glob_constr_g
and 'a extended_glob_local_binder_g =
  ('a extended_glob_local_binder_r, 'a) DAst.ttype extended_glob_local_binder = [ `any ] extended_glob_local_binder_g