blob: 5ff475f79b824eb925c7354275da7053a5d91b1c (
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
|
(***********************************************************************
v * The Coq Proof Assistant / The Coq Development Team
<O___,, * CNRS-Ecole Polytechnique-INRIA Futurs-Universite Paris Sud
\VV/ *************************************************************
// * This file is distributed under the terms of the
* GNU Lesser General Public License Version 2.1
***********************************************************************)
open Util
(*********************************************************************
General entry keys *)
(** This intermediate abstract representation of entries can
both be reified into mlexpr for the ML extensions and
dynamically interpreted as entries for the Coq level extensions *)
type 'a prod_entry_key =
| Alist1 of 'a prod_entry_key
| Alist1sep of 'a prod_entry_key * string
| Alist0 of 'a prod_entry_key
| Alist0sep of 'a prod_entry_key * string
| Aopt of 'a prod_entry_key
| Amodifiers of 'a prod_entry_key
| Aself
| Anext
| Atactic of int
| Agram of 'a Gramext.g_entry
| Aentry of string * string
(*********************************************************************
Entry keys for constr notations *)
type side = Left | Right
type production_position =
| BorderProd of side * Gramext.g_assoc option
| InternalProd
type production_level =
| NextLevel
| NumLevel of int
type ('lev,'pos) constr_entry_key_gen =
| ETName | ETReference | ETBigint
| ETConstr of ('lev * 'pos)
| ETPattern
| ETOther of string * string
| ETConstrList of ('lev * 'pos) * Token.pattern list
(* Entries level (left-hand-side of grammar rules) *)
type constr_entry_key =
(int,unit) constr_entry_key_gen
(* Entries used in productions (in right-hand-side of grammar rules) *)
type constr_prod_entry_key =
(production_level,production_position) constr_entry_key_gen
(* Entries used in productions, vernac side (e.g. "x bigint" or "x ident") *)
type simple_constr_prod_entry_key =
(production_level,unit) constr_entry_key_gen
|