43 lines
1.6 KiB
OCaml
43 lines
1.6 KiB
OCaml
(***********************************************************************)
|
|
(* *)
|
|
(* 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 Q Public License version 1.0. *)
|
|
(* *)
|
|
(***********************************************************************)
|
|
|
|
(* This apparently useless implementation file is in fact required
|
|
by the pa_ocamllex syntax extension *)
|
|
|
|
(* The shallow abstract syntax *)
|
|
|
|
type location =
|
|
{ start_pos: int;
|
|
end_pos: int;
|
|
start_line: int;
|
|
start_col: int }
|
|
|
|
type regular_expression =
|
|
Epsilon
|
|
| Characters of Cset.t
|
|
| Eof
|
|
| Sequence of regular_expression * regular_expression
|
|
| Alternative of regular_expression * regular_expression
|
|
| Repetition of regular_expression
|
|
| Bind of regular_expression * (string * location)
|
|
|
|
type ('arg,'action) entry =
|
|
{name:string ;
|
|
shortest : bool ;
|
|
args : 'arg ;
|
|
clauses : (regular_expression * 'action) list}
|
|
|
|
type lexer_definition =
|
|
{ header: location;
|
|
entrypoints: ((string list, location) entry) list;
|
|
trailer: location }
|