blob: b54189ba6433294ebea0c432e5b3c3ab9ef5556d (
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
|
(***********************************************************************)
(* 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*)
open Names
open Term
open Declarations
open Environ
open Univ
(*s Cooking the constants. *)
type 'a modification =
| NOT_OCCUR
| DO_ABSTRACT of 'a * constr array
| DO_REPLACE of constant_body
type work_list =
(constant * constant modification) list
* (inductive * inductive modification) list
* (constructor * constructor modification) list
type recipe = {
d_from : constant_body;
d_abstract : identifier list;
d_modlist : work_list }
val cook_constant :
env -> recipe -> constr_substituted option * constr * constraints * bool
(*s Utility functions used in module [Discharge]. *)
val expmod_constr : work_list -> constr -> constr
val expmod_type : work_list -> types -> types
|