blob: 2121671a89c621e3a3f254521ffcb8266a3b54d0 (
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
|
(************************************************************************)
(* 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 *)
(************************************************************************)
(*i $Id$ i*)
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
type constr_prod_entry_key =
(production_level,production_position) constr_entry_key_gen
type constr_entry_key =
(int,unit) constr_entry_key_gen
type simple_constr_prod_entry_key =
(production_level,unit) constr_entry_key_gen
|