RedexprInterpretation layer of redexprs such as hnf, cbv, etc.
type red_expr = (EConstr.constr, Tacred.evaluable_global_reference, Pattern.constr_pattern) Genredexpr.red_expr_genval out_with_occurrences : 'a Locus.with_occurrences -> Locus.occurrences * 'aval eval_red_expr : Environ.env -> red_expr -> red_expr_valval reduction_of_red_expr_val : ?occs:(Locus.occurrences_expr * int) -> red_expr_val -> Reductionops.e_reduction_function * Constr.cast_kindval reduction_of_red_expr : Environ.env -> red_expr -> Reductionops.e_reduction_function * Constr.cast_kindComposition of reduction_of_red_expr_val with eval_red_expr
true if we should use the vm to verify the reduction
val declare_reduction : string -> Reductionops.reduction_function -> unitAdding a custom reduction (function to be use at the ML level) NB: the effect is permanent.
val declare_red_expr : bool -> string -> red_expr -> unitAdding a custom reduction (function to be called a vernac command). The boolean flag is the locality.
Opaque and Transparent commands.
val set_strategy : bool -> (Conv_oracle.level * Tacred.evaluable_global_reference list) list -> unitSets the expansion strategy of a constant. When the boolean is true, the effect is non-synchronous (i.e. it does not survive section and module closure).
val cbv_vm : Reductionops.reduction_functioncall by value normalisation function using the virtual machine