Ltac_plugin.Tacexprtype ltac_constant = Names.KerName.ttype ('c, 'd, 'id) inversion_strength = | NonDepInversion of Inv.inversion_kind * 'id list * 'd Tactypes.or_and_intro_pattern_expr CAst.t Locus.or_var option |
| DepInversion of Inv.inversion_kind * 'c option * 'd Tactypes.or_and_intro_pattern_expr CAst.t Locus.or_var option |
| InversionUsing of 'c * 'id list |
type ('dconstr, 'id) induction_clause = 'dconstr Tactypes.with_bindings Tactics.destruction_arg * (Namegen.intro_pattern_naming_expr CAst.t option * 'dconstr Tactypes.or_and_intro_pattern_expr CAst.t Locus.or_var option) * 'id Locus.clause_expr optiontype ('constr, 'dconstr, 'id) induction_clause_list = ('dconstr, 'id) induction_clause list * 'constr Tactypes.with_bindings optiontype 'a with_bindings_arg = clear_flag * 'a Tactypes.with_bindingstype 'a match_context_hyps = | Hyp of Names.lname * 'a match_pattern |
| Def of Names.lname * 'a match_pattern * 'a match_pattern |
type ml_tactic_name = {}Extension indentifiers for the TACTIC EXTEND mechanism.
type open_constr_expr = unit * Constrexpr.constr_exprComposite types
type open_glob_constr = unit * Genintern.glob_constr_and_exprtype intro_pattern = Tactypes.delayed_open_constr Tactypes.intro_pattern_expr CAst.ttype intro_patterns = Tactypes.delayed_open_constr Tactypes.intro_pattern_expr CAst.t listtype or_and_intro_pattern = Tactypes.delayed_open_constr Tactypes.or_and_intro_pattern_expr CAst.ttype intro_pattern_naming = Namegen.intro_pattern_naming_expr CAst.tGeneric expressions for atomic tactics
type 'a gen_atomic_tactic_expr = | TacIntroPattern of evars_flag * 'dtrm Tactypes.intro_pattern_expr CAst.t list |
| TacApply of advanced_flag * evars_flag * 'trm with_bindings_arg list * ('nam * 'dtrm Tactypes.intro_pattern_expr CAst.t option) list |
| TacElim of evars_flag * 'trm with_bindings_arg * 'trm Tactypes.with_bindings option |
| TacCase of evars_flag * 'trm with_bindings_arg |
| TacMutualFix of Names.Id.t * int * (Names.Id.t * int * 'trm) list |
| TacMutualCofix of Names.Id.t * (Names.Id.t * 'trm) list |
| TacAssert of evars_flag * bool * 'tacexpr option option * 'dtrm Tactypes.intro_pattern_expr CAst.t option * 'trm |
| TacGeneralize of (('occvar Locus.occurrences_gen * 'trm) * Names.Name.t) list |
| TacLetTac of evars_flag * Names.Name.t * 'trm * 'nam Locus.clause_expr * letin_flag * Namegen.intro_pattern_naming_expr CAst.t option |
| TacInductionDestruct of rec_flag * evars_flag * ('trm, 'dtrm, 'nam) induction_clause_list |
| TacReduce of ('trm, 'cst, 'rpat, 'occvar) Genredexpr.red_expr_gen * 'nam Locus.clause_expr |
| TacChange of check_flag * 'rpat option * 'dtrm * 'nam Locus.clause_expr |
| TacRewrite of evars_flag * (bool * Equality.multi * 'dtrm with_bindings_arg) list * 'nam Locus.clause_expr * 'tacexpr option |
| TacInversion of ('trm, 'dtrm, 'nam) inversion_strength * Tactypes.quantified_hypothesis |
constraint 'a = < term : 'trm; dterm : 'dtrm; pattern : 'pat; red_pattern : 'rpat; constant : 'cst; reference : 'ref; name : 'nam; occvar : 'occvar; tacexpr : 'tacexpr; level : 'lev; >Possible arguments of a tactic definition
type 'a gen_tactic_arg = | TacGeneric of string option * 'lev Genarg.generic_argument |
| ConstrMayEval of ('trm, 'cst, 'rpat, 'occvar) Genredexpr.may_eval |
| Reference of 'ref |
| TacCall of ('ref * 'a gen_tactic_arg list) CAst.t |
| TacFreshId of string Locus.or_var list |
| Tacexp of 'tacexpr |
| TacPretype of 'trm |
| TacNumgoals |
constraint 'a = < term : 'trm; dterm : 'dtrm; pattern : 'pat; red_pattern : 'rpat; constant : 'cst; reference : 'ref; name : 'nam; occvar : 'occvar; tacexpr : 'tacexpr; level : 'lev; >Generic ltac expressions. 't : terms, 'p : patterns, 'c : constants, 'i : inductive, 'r : ltac refs, 'n : idents, 'l : levels
and 'a gen_tactic_expr_r = constraint 'a = < term : 't; dterm : 'dtrm; pattern : 'p; red_pattern : 'rp; constant : 'c; reference : 'r; name : 'n; occvar : 'occvar; tacexpr : 'tacexpr; level : 'l; >and 'a gen_tactic_expr = 'a gen_tactic_expr_r CAst.t constraint 'a = < term : 't; dterm : 'dtrm; pattern : 'p; red_pattern : 'rp; constant : 'c; reference : 'r; name : 'n; occvar : 'occvar; tacexpr : 'tacexpr; level : 'l; >and 'a gen_tactic_fun_ast = Names.Name.t list * 'a gen_tactic_expr constraint 'a = < term : 't; dterm : 'dtrm; pattern : 'p; red_pattern : 'rp; constant : 'c; reference : 'r; name : 'n; occvar : 'occvar; tacexpr : 'te; level : 'l; >Globalized tactics
type g_trm = Genintern.glob_constr_and_exprtype g_pat = Genintern.glob_constr_pattern_and_exprtype g_cst = Evaluable.t Genredexpr.and_short_name Locus.or_vartype g_ref = ltac_constant Loc.located Locus.or_vartype g_nam = Names.lidenttype g_occvar = int Locus.or_vartype g_dispatch = < term : g_trm; dterm : g_trm; pattern : g_pat; red_pattern : g_trm; constant : g_cst; reference : g_ref; name : g_nam; occvar : g_occvar; tacexpr : glob_tactic_expr; level : Genarg.glevel; >and glob_tactic_expr = g_dispatch gen_tactic_exprtype glob_atomic_tactic_expr = g_dispatch gen_atomic_tactic_exprtype glob_tactic_arg = g_dispatch gen_tactic_argRaw tactics
type r_ref = Libnames.qualidtype r_nam = Names.lidenttype r_lev = Genarg.rleveltype r_occvar = int Locus.or_vartype r_dispatch = < term : Genredexpr.r_trm; dterm : Genredexpr.r_trm; pattern : Genredexpr.r_pat; red_pattern : Genredexpr.r_pat; constant : Genredexpr.r_cst; reference : r_ref; name : r_nam; occvar : r_occvar; tacexpr : raw_tactic_expr; level : Genarg.rlevel; >and raw_tactic_expr = r_dispatch gen_tactic_exprtype raw_atomic_tactic_expr = r_dispatch gen_atomic_tactic_exprtype raw_tactic_arg = r_dispatch gen_tactic_argInterpreted tactics
type t_trm = EConstr.constrtype t_pat = Pattern.constr_patterntype t_cst = Evaluable.ttype t_ref = ltac_constant Loc.locatedtype t_nam = Names.Id.ttype atomic_tactic_expr = t_dispatch gen_atomic_tactic_exprMisc
type raw_strategy = (Constrexpr.constr_expr, Genredexpr.raw_red_expr, Names.lident) Rewrite.strategy_asttype glob_strategy = (Genintern.glob_constr_and_expr, Genredexpr.glob_red_expr, Names.Id.t) Rewrite.strategy_astTraces
type ltac_call_kind = | LtacMLCall of glob_tactic_expr |
| LtacNotationCall of Names.KerName.t |
| LtacNameCall of ltac_constant |
| LtacAtomCall of glob_atomic_tactic_expr |
| LtacVarCall of Names.KerName.t option * Names.Id.t * glob_tactic_expr |
| LtacConstrInterp of Environ.env * Evd.evar_map * Glob_term.glob_constr * Ltac_pretype.ltac_var_map |
type ltac_stack = ltac_call_kind Loc.located listtype ltac_trace = ltac_stack * Geninterp.Val.t Names.Id.Map.t listtype tacdef_body = | TacticDefinition of Names.lident * raw_tactic_expr |
| TacticRedefinition of Libnames.qualid * raw_tactic_expr |