forked from ocaml/ocaml
-
Notifications
You must be signed in to change notification settings - Fork 0
/
lexgen.mli
60 lines (48 loc) · 2.17 KB
/
lexgen.mli
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
(**************************************************************************)
(* *)
(* OCaml *)
(* *)
(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)
(* *)
(* Copyright 1996 Institut National de Recherche en Informatique et *)
(* en Automatique. *)
(* *)
(* All rights reserved. This file is distributed under the terms of *)
(* the GNU Lesser General Public License version 2.1, with the *)
(* special exception on linking described in the file LICENSE. *)
(* *)
(**************************************************************************)
(* raised when there are too many bindings (>= 254 memory cells) *)
exception Memory_overflow
(* Representation of automata *)
type automata =
Perform of int * tag_action list
| Shift of automata_trans * (automata_move * memory_action list) array
and automata_trans =
No_remember
| Remember of int * tag_action list
and automata_move =
Backtrack
| Goto of int
and memory_action =
| Copy of int * int
| Set of int
and tag_action = SetTag of int * int | EraseTag of int
type ident = string * Syntax.location
(* Representation of entry points *)
type tag_base = Start | End | Mem of int
type tag_addr = Sum of (tag_base * int)
type ident_info =
| Ident_string of bool * tag_addr * tag_addr
| Ident_char of bool * tag_addr
type t_env = (ident * ident_info) list
type ('args,'action) automata_entry =
{ auto_name: string;
auto_args: 'args ;
auto_mem_size : int ;
auto_initial_state: int * memory_action list ;
auto_actions: (int * t_env * 'action) list }
(* The entry point *)
val make_dfa :
('args, 'action) Syntax.entry list ->
('args, 'action) automata_entry list * automata array