blob: c9d7cc57400ce0f456217aac9a4931c8438b6fa9 (
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
(***********************************************************************)
(* v * The Coq Proof Assistant / The Coq Development Team *)
(* <O___,, * INRIA-Rocquencourt & LRI-CNRS-Orsay *)
(* \VV/ *************************************************************)
(* // * This file is distributed under the terms of the *)
(* * GNU Lesser General Public License Version 2.1 *)
(***********************************************************************)
(*i $Id$ i*)
(*i*)
open Names
open Libnames
open Term
open Sign
open Declarations
open Entries
open Indtypes
open Safe_typing
open Library
open Nametab
(*i*)
(* This module provides the official functions to declare new variables,
parameters, constants and inductive types. Using the following functions
will add the entries in the global environment (module [Global]), will
register the declarations in the library (module [Lib]) --- so that the
reset works properly --- and will fill some global tables such as
[Nametab] and [Impargs]. *)
open Nametab
type section_variable_entry =
| SectionLocalDef of constr * types option * bool (* opacity *)
| SectionLocalAssum of types
type variable_declaration = dir_path * section_variable_entry * strength
val declare_variable : variable -> variable_declaration -> object_name
type constant_declaration = constant_entry * strength
(* [declare_constant id cd] declares a global declaration
(constant/parameter) with name [id] in the current section; it returns
the full path of the declaration *)
val declare_constant : identifier -> constant_declaration -> object_name
val redeclare_constant : identifier -> Cooking.recipe * strength -> unit
(*
val declare_parameter : identifier -> constr -> constant
*)
(* [declare_mind me] declares a block of inductive types with
their constructors in the current section; it returns the path of
the whole block *)
val declare_mind : mutual_inductive_entry -> object_name
val out_inductive : Libobject.obj -> mutual_inductive_entry
val make_strength_0 : unit -> strength
val make_strength_1 : unit -> strength
val make_strength_2 : unit -> strength
val is_less_persistent_strength : strength * strength -> bool
val strength_min : strength * strength -> strength
(*s Corresponding test and access functions. *)
val is_constant : section_path -> bool
val constant_strength : section_path -> strength
val out_variable : Libobject.obj -> identifier * variable_declaration
val get_variable : variable -> named_declaration * strength
val get_variable_with_constraints :
variable -> named_declaration * Univ.constraints * strength
val variable_strength : variable -> strength
val find_section_variable : variable -> section_path
val last_section_hyps : dir_path -> identifier list
val clear_proofs : named_context -> named_context
(*s Global references *)
val context_of_global_reference : global_reference -> section_context
(* Turn a global reference into a construction *)
val constr_of_reference : global_reference -> constr
(* Turn a construction denoting a global into a reference;
raise [Not_found] if not a global *)
val reference_of_constr : constr -> global_reference
val global_qualified_reference : qualid -> constr
val global_absolute_reference : section_path -> constr
val global_reference_in_absolute_module : dir_path -> identifier -> constr
val construct_qualified_reference : qualid -> constr
val construct_absolute_reference : section_path -> constr
(* This should eventually disappear *)
(* [construct_reference] returns the object corresponding to
the name [id] in the global environment. It looks also for variables in a
given environment instead of looking in the current global environment. *)
val global_reference : identifier -> constr
val construct_reference : Sign.named_context option -> identifier -> constr
val is_global : identifier -> bool
val strength_of_global : global_reference -> strength
val library_part : global_reference -> dir_path
|