1995-08-09 08:06:35 -07:00
|
|
|
(***********************************************************************)
|
|
|
|
(* *)
|
1996-04-30 07:53:58 -07:00
|
|
|
(* Objective Caml *)
|
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 GNU Library General Public License. *)
|
1995-08-09 08:06:35 -07:00
|
|
|
(* *)
|
|
|
|
(***********************************************************************)
|
|
|
|
|
|
|
|
(* $Id$ *)
|
|
|
|
|
1998-08-07 03:04:19 -07:00
|
|
|
(* Module [Parsing]: the run-time library for parsers generated by [ocamlyacc]*)
|
1995-05-04 03:15:53 -07:00
|
|
|
|
|
|
|
val symbol_start : unit -> int
|
|
|
|
val symbol_end : unit -> int
|
|
|
|
(* [symbol_start] and [symbol_end] are to be called in the action part
|
|
|
|
of a grammar rule only. They return the position of the string that
|
|
|
|
matches the left-hand side of the rule: [symbol_start()] returns
|
|
|
|
the position of the first character; [symbol_end()] returns the
|
|
|
|
position of the last character, plus one. The first character
|
|
|
|
in a file is at position 0. *)
|
|
|
|
val rhs_start: int -> int
|
|
|
|
val rhs_end: int -> int
|
1995-10-03 07:06:15 -07:00
|
|
|
(* Same as [symbol_start] and [symbol_end], but return the
|
1995-05-04 03:15:53 -07:00
|
|
|
position of the string matching the [n]th item on the
|
|
|
|
right-hand side of the rule, where [n] is the integer parameter
|
|
|
|
to [lhs_start] and [lhs_end]. [n] is 1 for the leftmost item. *)
|
|
|
|
val clear_parser : unit -> unit
|
|
|
|
(* Empty the parser stack. Call it just after a parsing function
|
|
|
|
has returned, to remove all pointers from the parser stack
|
|
|
|
to structures that were built by semantic actions during parsing.
|
|
|
|
This is optional, but lowers the memory requirements of the
|
|
|
|
programs. *)
|
|
|
|
|
|
|
|
exception Parse_error
|
1995-08-09 06:15:01 -07:00
|
|
|
(* Raised when a parser encounters a syntax error.
|
|
|
|
Can also be raised from the action part of a grammar rule,
|
|
|
|
to initiate error recovery. *)
|
1995-05-04 03:15:53 -07:00
|
|
|
|
|
|
|
(*--*)
|
|
|
|
|
|
|
|
(* The following definitions are used by the generated parsers only.
|
|
|
|
They are not intended to be used by user programs. *)
|
|
|
|
|
1995-07-12 07:28:51 -07:00
|
|
|
type parser_env
|
|
|
|
|
1995-05-04 03:15:53 -07:00
|
|
|
type parse_tables =
|
1995-07-12 07:28:51 -07:00
|
|
|
{ actions : (parser_env -> Obj.t) array;
|
1995-06-18 07:45:56 -07:00
|
|
|
transl_const : int array;
|
|
|
|
transl_block : int array;
|
1995-05-04 03:15:53 -07:00
|
|
|
lhs : string;
|
|
|
|
len : string;
|
|
|
|
defred : string;
|
|
|
|
dgoto : string;
|
|
|
|
sindex : string;
|
|
|
|
rindex : string;
|
|
|
|
gindex : string;
|
|
|
|
tablesize : int;
|
|
|
|
table : string;
|
1995-08-09 02:39:43 -07:00
|
|
|
check : string;
|
|
|
|
error_function : string -> unit }
|
1995-05-04 03:15:53 -07:00
|
|
|
|
|
|
|
exception YYexit of Obj.t
|
|
|
|
|
|
|
|
val yyparse :
|
|
|
|
parse_tables -> int -> (Lexing.lexbuf -> 'a) -> Lexing.lexbuf -> 'b
|
1995-07-12 07:28:51 -07:00
|
|
|
val peek_val : parser_env -> int -> 'a
|
1995-08-09 02:39:43 -07:00
|
|
|
val is_current_lookahead : 'a -> bool
|
|
|
|
val parse_error : string -> unit
|