summaryrefslogtreecommitdiff
path: root/parsing/extend.ml
blob: 92ca4dd1572e06e0d6dc0c2c5c475e10d84fc2a9 (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
(************************************************************************)
(*  v      *   The Coq Proof Assistant  /  The Coq Development Team     *)
(* <O___,, *   INRIA - CNRS - LIX - LRI - PPS - Copyright 1999-2010     *)
(*   \VV/  **************************************************************)
(*    //   *      This file is distributed under the terms of the       *)
(*         *       GNU Lesser General Public License Version 2.1        *)
(************************************************************************)

(*i $Id: extend.ml 13329 2010-07-26 11:05:39Z herbelin $ 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
  | ETBinder of bool
  | ETConstr of ('lev * 'pos)
  | ETPattern
  | ETOther of string * string
  | ETConstrList of ('lev * 'pos) * Token.pattern list
  | ETBinderList of bool * 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