package rocq-runtime
Install
dune-project
Dependency
Authors
Maintainers
Sources
md5=8d522602d23e7a665631826dab9aa92b
sha512=f4f76a6a178e421c99ee7a331a2fd97a06e9c5d0168d7e60c44e3820d8e1a124370ea104ad90c7f87a9a1e9d87b2d0d7d2d387c998feeaed4a75ed04e176a4be
doc/rocq-runtime.interp/Constrexpr_ops/index.html
Module Constrexpr_opsSource
Constrexpr_ops: utilities on constr_expr
Equalities on constr_expr related types
val relevance_info_expr_eq :
Constrexpr.relevance_info_expr ->
Constrexpr.relevance_info_expr ->
boolEquality on explicitation.
val constr_expr_eq_gen :
(Constrexpr.constr_expr -> Constrexpr.constr_expr -> bool) ->
Constrexpr.constr_expr ->
Constrexpr.constr_expr ->
boolEquality on constr_expr. This is a syntactical one, which is oblivious to some parsing details, including locations.
Equality on local_binder_expr. Same properties as constr_expr_eq.
Equality on binder_kind
Retrieving locations
Constructors
Term constructors
Basic form of the corresponding constructors
val mkCastC :
(Constrexpr.constr_expr * Constr.cast_kind option * Constrexpr.constr_expr) ->
Constrexpr.constr_exprval mkLambdaC :
(Names.lname list
* Constrexpr.binder_kind
* Constrexpr.constr_expr
* Constrexpr.constr_expr) ->
Constrexpr.constr_exprval mkLetInC :
(Names.lname
* Constrexpr.constr_expr
* Constrexpr.constr_expr option
* Constrexpr.constr_expr) ->
Constrexpr.constr_exprval mkProdC :
(Names.lname list
* Constrexpr.binder_kind
* Constrexpr.constr_expr
* Constrexpr.constr_expr) ->
Constrexpr.constr_exprBasic form of application, collapsing nested applications
Optimized constructors: does not add a constructor for an empty binder list
val mkLambdaCN :
?loc:Loc.t ->
Constrexpr.local_binder_expr list ->
Constrexpr.constr_expr ->
Constrexpr.constr_exprval mkProdCN :
?loc:Loc.t ->
Constrexpr.local_binder_expr list ->
Constrexpr.constr_expr ->
Constrexpr.constr_exprAliases for the corresponding constructors; generally mkLambdaCN and mkProdCN should be preferred
val mkCLambdaN :
?loc:Loc.t ->
Constrexpr.local_binder_expr list ->
Constrexpr.constr_expr ->
Constrexpr.constr_exprval mkCProdN :
?loc:Loc.t ->
Constrexpr.local_binder_expr list ->
Constrexpr.constr_expr ->
Constrexpr.constr_exprPattern constructors
val mkCPatOr :
?loc:Loc.t ->
Constrexpr.cases_pattern_expr list ->
Constrexpr.cases_pattern_exprInterpretation of a list of patterns as a disjunctive pattern (optimized)
val mkAppPattern :
?loc:Loc.t ->
Constrexpr.cases_pattern_expr ->
Constrexpr.cases_pattern_expr list ->
Constrexpr.cases_pattern_exprApply a list of pattern arguments to a pattern
Destructors
FIXME: nothing to do here
Destruct terms of the form CRef (Ident _).
Destruct terms of the form CRef (Ident _) or CHole _.
Binder manipulation
Retrieve a list of binding names from a list of binders.
Same as names_of_local_binder_exprs, but does not take the let bindings into account.
Folds and maps
val fold_constr_expr_with_binders :
(Names.Id.t -> 'a -> 'a) ->
('a -> 'b -> Constrexpr.constr_expr -> 'b) ->
'a ->
'b ->
Constrexpr.constr_expr ->
'bUsed in typeclasses
Used in correctness and interface; absence of var capture not guaranteed in pattern-matching clauses and in binders of the form x,y:T(x)
val map_constr_expr_with_binders :
(Names.Id.t -> 'a -> 'a) ->
('a -> Constrexpr.constr_expr -> Constrexpr.constr_expr) ->
'a ->
Constrexpr.constr_expr ->
Constrexpr.constr_exprMiscellaneous
val replace_vars_constr_expr :
Names.Id.t Names.Id.Map.t ->
Constrexpr.constr_expr ->
Constrexpr.constr_exprReturn all (non-qualified) names treating binders as names
val ntn_loc :
?loc:Loc.t ->
Constrexpr.constr_notation_substitution ->
Constrexpr.notation ->
(int * int) listval patntn_loc :
?loc:Loc.t ->
Constrexpr.cases_pattern_notation_substitution ->
Constrexpr.notation ->
(int * int) list