1995-08-09 08:06:35 -07:00
|
|
|
(***********************************************************************)
|
|
|
|
(* *)
|
2011-07-27 07:17:02 -07:00
|
|
|
(* OCaml *)
|
1995-08-09 08:06:35 -07:00
|
|
|
(* *)
|
|
|
|
(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)
|
|
|
|
(* *)
|
1996-04-30 07:53:58 -07:00
|
|
|
(* Copyright 1996 Institut National de Recherche en Informatique et *)
|
1999-11-17 10:59:06 -08:00
|
|
|
(* en Automatique. All rights reserved. This file is distributed *)
|
|
|
|
(* under the terms of the Q Public License version 1.0. *)
|
1995-08-09 08:06:35 -07:00
|
|
|
(* *)
|
|
|
|
(***********************************************************************)
|
|
|
|
|
1996-02-25 06:45:47 -08:00
|
|
|
(* Compaction of an automata *)
|
|
|
|
type lex_tables =
|
|
|
|
{ tbl_base: int array; (* Perform / Shift *)
|
|
|
|
tbl_backtrk: int array; (* No_remember / Remember *)
|
|
|
|
tbl_default: int array; (* Default transition *)
|
|
|
|
tbl_trans: int array; (* Transitions (compacted) *)
|
2002-10-28 08:46:50 -08:00
|
|
|
tbl_check: int array; (* Check (compacted) *)
|
|
|
|
(* code addresses are managed in a similar fashion as transitions *)
|
|
|
|
tbl_base_code : int array; (* code ptr / base for Shift *)
|
|
|
|
tbl_backtrk_code : int array; (* nothing / code when Remember *)
|
|
|
|
(* moves to execute before transitions (compacted) *)
|
|
|
|
tbl_default_code : int array;
|
2010-01-22 04:48:24 -08:00
|
|
|
tbl_trans_code : int array;
|
2002-10-28 08:46:50 -08:00
|
|
|
tbl_check_code : int array;
|
|
|
|
(* byte code itself *)
|
|
|
|
tbl_code: int array;}
|
|
|
|
|
1995-05-04 03:15:53 -07:00
|
|
|
|
1996-02-25 06:45:47 -08:00
|
|
|
val compact_tables: Lexgen.automata array -> lex_tables
|