(************************************************************************) (* * The Coq Proof Assistant / The Coq Development Team *) (* v * INRIA, CNRS and contributors - Copyright 1999-2019 *) (* universe_decl_expr option -> (one_inductive_expr * decl_notation list) list -> cumulative:bool -> poly:bool -> private_ind:bool -> uniform:uniform_inductive_flag -> Declarations.recursivity_kind -> unit (** User-interface API *) (** Prepare a "match" template for a given inductive type. For each branch of the match, we list the constructor name followed by enough pattern variables. [Not_found] is raised if the given string isn't the qualid of a known inductive type. *) val make_cases : Names.inductive -> string list list (************************************************************************) (** Internal API, exported for Record *) (************************************************************************) (** Registering a mutual inductive definition together with its associated schemes *) type one_inductive_impls = Impargs.manual_implicits (* for inds *) * Impargs.manual_implicits list (* for constrs *) val declare_mutual_inductive_with_eliminations : ?primitive_expected:bool -> mutual_inductive_entry -> UnivNames.universe_binders -> one_inductive_impls list -> MutInd.t val should_auto_template : Id.t -> bool -> bool (** [should_auto_template x b] is [true] when [b] is [true] and we automatically use template polymorphism. [x] is the name of the inductive under consideration. *) val template_polymorphism_candidate : Environ.env -> Entries.universes_entry -> Constr.rel_context -> Sorts.t option -> bool (** [template_polymorphism_candidate env uctx params conclsort] is [true] iff an inductive with params [params] and conclusion [conclsort] would be definable as template polymorphic. It should have at least one universe in its monomorphic universe context that can be made parametric in its conclusion sort, if one is given. If the [Template Check] flag is false we just check that the conclusion sort is not small. *) val sign_level : Environ.env -> Evd.evar_map -> Constr.rel_declaration list -> Univ.Universe.t (** [sign_level env sigma ctx] computes the universe level of the context [ctx] as the [sup] of its individual assumptions, which should be well-typed in [env] and [sigma] *)