aboutsummaryrefslogtreecommitdiff
path: root/vernac/comAssumption.mli
blob: 2b794b001a5cf653b22f4b372fe7bbc6cea5b339 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
(************************************************************************)
(*         *   The Coq Proof Assistant / The Coq Development Team       *)
(*  v      *   INRIA, CNRS and contributors - Copyright 1999-2018       *)
(* <O___,, *       (see CREDITS file for the list of authors)           *)
(*   \VV/  **************************************************************)
(*    //   *    This file is distributed under the terms of the         *)
(*         *     GNU Lesser General Public License Version 2.1          *)
(*         *     (see LICENSE file for the text of the license)         *)
(************************************************************************)

open Names
open Constr
open Entries
open Vernacexpr
open Constrexpr
open Decl_kinds

(** {6 Parameters/Assumptions} *)

val do_assumptions : program_mode:bool -> locality * polymorphic * assumption_object_kind ->
  Declaremods.inline -> (ident_decl list * constr_expr) with_coercion list -> bool

(************************************************************************)
(** Internal API  *)
(************************************************************************)

(** Exported for Classes *)

(** returns [false] if the assumption is neither local to a section,
    nor in a module type and meant to be instantiated. *)
val declare_assumption : coercion_flag -> assumption_kind ->
  types in_universes_entry ->
  UnivNames.universe_binders -> Impargs.manual_implicits ->
  bool (** implicit *) -> Declaremods.inline -> variable CAst.t ->
  GlobRef.t * Univ.Instance.t * bool

val do_primitive : lident -> CPrimitives.op_or_type -> constr_expr option -> unit