]> git.saurik.com Git - bison.git/blame - data/lalr1.java
doc: prefer the ".gv" extension to ".dot"
[bison.git] / data / lalr1.java
CommitLineData
8405b70c
PB
1# Java skeleton for Bison -*- autoconf -*-
2
7d6bad19 3# Copyright (C) 2007-2013 Free Software Foundation, Inc.
8405b70c 4
f16b0819 5# This program is free software: you can redistribute it and/or modify
8405b70c 6# it under the terms of the GNU General Public License as published by
f16b0819 7# the Free Software Foundation, either version 3 of the License, or
8405b70c 8# (at your option) any later version.
f16b0819 9#
8405b70c
PB
10# This program is distributed in the hope that it will be useful,
11# but WITHOUT ANY WARRANTY; without even the implied warranty of
12# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13# GNU General Public License for more details.
f16b0819 14#
8405b70c 15# You should have received a copy of the GNU General Public License
f16b0819 16# along with this program. If not, see <http://www.gnu.org/licenses/>.
8405b70c
PB
17
18m4_include(b4_pkgdatadir/[java.m4])
19
3bb21113
AD
20b4_defines_if([b4_fatal([%s: %%defines does not make sense in Java],
21 [b4_skeleton])])
22
aa94def1
DH
23# We do not depend on %debug in Java, but pacify warnings about
24# non-used flags.
fa819509 25b4_parse_trace_if([0], [0])
0ce61575 26
3bb21113
AD
27m4_define([b4_symbol_no_destructor_assert],
28[b4_symbol_if([$1], [has_destructor],
29 [b4_fatal([%s: %s: %%destructor does not make sense in Java],
30 [b4_skeleton],
31 [b4_symbol_action_location([$1], [destructor])])])])
32b4_symbol_foreach([b4_symbol_no_destructor_assert])
8405b70c 33
aa94def1
DH
34# Setup some macros for api.push-pull.
35b4_percent_define_default([[api.push-pull]], [[pull]])
36b4_percent_define_check_values([[[[api.push-pull]],
37 [[pull]], [[push]], [[both]]]])
38
39# Define m4 conditional macros that encode the value
40# of the api.push-pull flag.
41b4_define_flag_if([pull]) m4_define([b4_pull_flag], [[1]])
42b4_define_flag_if([push]) m4_define([b4_push_flag], [[1]])
43m4_case(b4_percent_define_get([[api.push-pull]]),
44 [pull], [m4_define([b4_push_flag], [[0]])],
45 [push], [m4_define([b4_pull_flag], [[0]])])
46
47# Define a macro to be true when api.push-pull has the value "both".
48m4_define([b4_both_if],[b4_push_if([b4_pull_if([$1],[$2])],[$2])])
49
50# Handle BISON_USE_PUSH_FOR_PULL for the test suite. So that push parsing
51# tests function as written, do not let BISON_USE_PUSH_FOR_PULL modify the
52# behavior of Bison at all when push parsing is already requested.
53b4_define_flag_if([use_push_for_pull])
54b4_use_push_for_pull_if([
55 b4_push_if([m4_define([b4_use_push_for_pull_flag], [[0]])],
56 [m4_define([b4_push_flag], [[1]])])])
57
58# Define a macro to encapsulate the parse state variables.
59# This allows them to be defined either in parse() when doing
60# pull parsing, or as class instance variable when doing push parsing.
61m4_define([b4_define_state],[[
62 /* Lookahead and lookahead in internal form. */
63 int yychar = yyempty_;
64 int yytoken = 0;
65
66 /* State. */
67 int yyn = 0;
68 int yylen = 0;
69 int yystate = 0;
70 YYStack yystack = new YYStack ();
71 int label = YYNEWSTATE;
72
73 /* Error handling. */
74 int yynerrs_ = 0;
75 ]b4_locations_if([/* The location where the error started. */
76 b4_location_type yyerrloc = null;
77
78 /* Location. */
79 b4_location_type yylloc = new b4_location_type (null, null);])[
80
81 /* Semantic value of the lookahead. */
82 ]b4_yystype[ yylval = null;
83]])
84
1c7ec959 85b4_output_begin([b4_parser_file_name])
8405b70c 86b4_copyright([Skeleton implementation for Bison LALR(1) parsers in Java],
7d6bad19 87 [2007-2013])
8405b70c
PB
88
89b4_percent_define_ifdef([package], [package b4_percent_define_get([package]);
90])[/* First part of user declarations. */
1979121c
DJ
91]b4_user_pre_prologue
92b4_user_post_prologue
8405b70c
PB
93b4_percent_code_get([[imports]])
94[/**
74d6c0fe 95 * A Bison parser, automatically generated from <tt>]m4_bpatsubst(b4_file_name, [^"\(.*\)"$], [\1])[</tt>.
8405b70c
PB
96 *
97 * @@author LALR (1) parser skeleton written by Paolo Bonzini.
98 */
1979121c
DJ
99]b4_percent_define_get3([annotations], [], [ ])dnl
100b4_public_if([public ])dnl
e254a580
DJ
101b4_abstract_if([abstract ])dnl
102b4_final_if([final ])dnl
103b4_strictfp_if([strictfp ])dnl
104[class ]b4_parser_class_name[]dnl
105b4_percent_define_get3([extends], [ extends ])dnl
106b4_percent_define_get3([implements], [ implements ])[
8405b70c
PB
107{
108 ]b4_identification[
1979121c 109]b4_error_verbose_if([[
94a62255
DH
110 /**
111 * True if verbose error messages are enabled.
112 */
1979121c
DJ
113 private boolean yyErrorVerbose = true;
114
115 /**
116 * Return whether verbose error messages are enabled.
117 */
118 public final boolean getErrorVerbose() { return yyErrorVerbose; }
119
120 /**
121 * Set the verbosity of error messages.
122 * @@param verbose True to request verbose error messages.
123 */
124 public final void setErrorVerbose(boolean verbose)
125 { yyErrorVerbose = verbose; }
126]])
8405b70c
PB
127
128b4_locations_if([[
129 /**
130 * A class defining a pair of positions. Positions, defined by the
131 * <code>]b4_position_type[</code> class, denote a point in the input.
132 * Locations represent a part of the input through the beginning
94a62255
DH
133 * and ending positions.
134 */
8405b70c 135 public class ]b4_location_type[ {
94a62255
DH
136 /**
137 * The first, inclusive, position in the range.
138 */
8405b70c
PB
139 public ]b4_position_type[ begin;
140
94a62255
DH
141 /**
142 * The first position beyond the range.
143 */
8405b70c
PB
144 public ]b4_position_type[ end;
145
146 /**
e254a580 147 * Create a <code>]b4_location_type[</code> denoting an empty range located at
8405b70c 148 * a given point.
94a62255
DH
149 * @@param loc The position at which the range is anchored.
150 */
8405b70c
PB
151 public ]b4_location_type[ (]b4_position_type[ loc) {
152 this.begin = this.end = loc;
153 }
154
155 /**
156 * Create a <code>]b4_location_type[</code> from the endpoints of the range.
157 * @@param begin The first position included in the range.
94a62255
DH
158 * @@param end The first position beyond the range.
159 */
8405b70c
PB
160 public ]b4_location_type[ (]b4_position_type[ begin, ]b4_position_type[ end) {
161 this.begin = begin;
162 this.end = end;
163 }
164
165 /**
166 * Print a representation of the location. For this to be correct,
167 * <code>]b4_position_type[</code> should override the <code>equals</code>
94a62255
DH
168 * method.
169 */
8405b70c
PB
170 public String toString () {
171 if (begin.equals (end))
172 return begin.toString ();
173 else
174 return begin.toString () + "-" + end.toString ();
175 }
176 }
177
178]])
179
8405b70c 180 b4_locations_if([[
d3b12988 181 private ]b4_location_type[ yylloc (YYStack rhs, int n)
8405b70c
PB
182 {
183 if (n > 0)
aa3bcdf3 184 return new ]b4_location_type[ (rhs.locationAt (n-1).begin, rhs.locationAt (0).end);
8405b70c
PB
185 else
186 return new ]b4_location_type[ (rhs.locationAt (0).end);
74d6c0fe 187 }]])[
8405b70c 188
01b477c6 189 /**
8405b70c
PB
190 * Communication interface between the scanner and the Bison-generated
191 * parser <tt>]b4_parser_class_name[</tt>.
192 */
193 public interface Lexer {
1979121c
DJ
194 /** Token returned by the scanner to signal the end of its input. */
195 public static final int EOF = 0;
196
6687da34 197]b4_token_enums[
1979121c 198
8405b70c
PB
199 ]b4_locations_if([[/**
200 * Method to retrieve the beginning position of the last scanned token.
94a62255
DH
201 * @@return the position at which the last scanned token starts.
202 */
8405b70c
PB
203 ]b4_position_type[ getStartPos ();
204
205 /**
206 * Method to retrieve the ending position of the last scanned token.
94a62255
DH
207 * @@return the first position beyond the last scanned token.
208 */
8405b70c
PB
209 ]b4_position_type[ getEndPos ();]])[
210
211 /**
212 * Method to retrieve the semantic value of the last scanned token.
94a62255
DH
213 * @@return the semantic value of the last scanned token.
214 */
d0ee4105 215 ]b4_yystype[ getLVal ();
8405b70c
PB
216
217 /**
8405b70c 218 * Entry point for the scanner. Returns the token identifier corresponding
d0ee4105 219 * to the next token and prepares to return the semantic value
a0d4650a 220 * ]b4_locations_if([and beginning/ending positions ])[of the token.
94a62255
DH
221 * @@return the token identifier corresponding to the next token.
222 */
01b477c6 223 int yylex () ]b4_maybe_throws([b4_lex_throws])[;
8405b70c
PB
224
225 /**
226 * Entry point for error reporting. Emits an error
e254a580 227 * ]b4_locations_if([referring to the given location ])[in a user-defined way.
8405b70c 228 *
74d6c0fe 229 * ]b4_locations_if([[@@param loc The location of the element to which the
8405b70c 230 * error message is related]])[
94a62255
DH
231 * @@param msg The string for the error message.
232 */
1979121c 233 void yyerror (]b4_locations_if([b4_location_type[ loc, ]])[String msg);]
01b477c6
PB
234 }
235
236 b4_lexer_if([[private class YYLexer implements Lexer {
237]b4_percent_code_get([[lexer]])[
238 }
8405b70c 239
94a62255
DH
240 ]])[/**
241 * The object doing lexical analysis for us.
242 */
01b477c6
PB
243 private Lexer yylexer;
244 ]
245 b4_parse_param_vars
8405b70c 246
01b477c6 247b4_lexer_if([[
8405b70c 248 /**
01b477c6 249 * Instantiates the Bison-generated parser.
8405b70c 250 */
1979121c
DJ
251 public ]b4_parser_class_name (b4_parse_param_decl([b4_lex_param_decl])[) ]b4_maybe_throws([b4_init_throws])[
252 {
253 ]b4_percent_code_get([[init]])[
01b477c6
PB
254 this.yylexer = new YYLexer(]b4_lex_param_call[);
255 ]b4_parse_param_cons[
256 }
257]])
258
259 /**
260 * Instantiates the Bison-generated parser.
74d6c0fe 261 * @@param yylexer The scanner that will supply tokens to the parser.
01b477c6 262 */
1979121c
DJ
263 b4_lexer_if([[protected]], [[public]]) b4_parser_class_name[ (]b4_parse_param_decl([[Lexer yylexer]])[) ]b4_maybe_throws([b4_init_throws])[
264 {
265 ]b4_percent_code_get([[init]])[
01b477c6
PB
266 this.yylexer = yylexer;
267 ]b4_parse_param_cons[
8405b70c
PB
268 }
269
d3b12988 270 private java.io.PrintStream yyDebugStream = System.err;
8405b70c
PB
271
272 /**
273 * Return the <tt>PrintStream</tt> on which the debugging output is
274 * printed.
275 */
d3b12988 276 public final java.io.PrintStream getDebugStream () { return yyDebugStream; }
8405b70c
PB
277
278 /**
279 * Set the <tt>PrintStream</tt> on which the debug output is printed.
280 * @@param s The stream that is used for debugging output.
281 */
d3b12988 282 public final void setDebugStream(java.io.PrintStream s) { yyDebugStream = s; }
8405b70c
PB
283
284 private int yydebug = 0;
285
286 /**
287 * Answer the verbosity of the debugging output; 0 means that all kinds of
288 * output from the parser are suppressed.
289 */
290 public final int getDebugLevel() { return yydebug; }
291
292 /**
293 * Set the verbosity of the debugging output; 0 means that all kinds of
294 * output from the parser are suppressed.
295 * @@param level The verbosity level for debugging output.
296 */
297 public final void setDebugLevel(int level) { yydebug = level; }
298
1979121c
DJ
299 /**
300 * Print an error message via the lexer.
301 *]b4_locations_if([[ Use a <code>null</code> location.]])[
302 * @@param msg The error message.
303 */
304 public final void yyerror (String msg)
305 {
306 yylexer.yyerror (]b4_locations_if([[(]b4_location_type[)null, ]])[msg);
8405b70c 307 }
1979121c
DJ
308]b4_locations_if([[
309 /**
310 * Print an error message via the lexer.
311 * @@param loc The location associated with the message.
312 * @@param msg The error message.
313 */
314 public final void yyerror (]b4_location_type[ loc, String msg)
315 {
316 yylexer.yyerror (loc, msg);
01b477c6
PB
317 }
318
1979121c
DJ
319 /**
320 * Print an error message via the lexer.
321 * @@param pos The position associated with the message.
322 * @@param msg The error message.
323 */
324 public final void yyerror (]b4_position_type[ pos, String msg)
325 {
326 yylexer.yyerror (new ]b4_location_type[ (pos), msg);
327 }]])
8405b70c
PB
328
329 [protected final void yycdebug (String s) {
330 if (yydebug > 0)
d3b12988 331 yyDebugStream.println (s);
8405b70c
PB
332 }
333
d3b12988 334 private final class YYStack {
8405b70c
PB
335 private int[] stateStack = new int[16];
336 ]b4_locations_if([[private ]b4_location_type[[] locStack = new ]b4_location_type[[16];]])[
01b477c6 337 private ]b4_yystype[[] valueStack = new ]b4_yystype[[16];
8405b70c 338
8a93f8e6
PB
339 public int size = 16;
340 public int height = -1;
a0d4650a 341
01b477c6 342 public final void push (int state, ]b4_yystype[ value]dnl
11707b2b 343 b4_locations_if([, ]b4_location_type[ loc])[) {
8405b70c 344 height++;
a0d4650a 345 if (size == height)
8405b70c 346 {
11707b2b
AD
347 int[] newStateStack = new int[size * 2];
348 System.arraycopy (stateStack, 0, newStateStack, 0, height);
349 stateStack = newStateStack;
350 ]b4_locations_if([[
351 ]b4_location_type[[] newLocStack = new ]b4_location_type[[size * 2];
352 System.arraycopy (locStack, 0, newLocStack, 0, height);
353 locStack = newLocStack;]])
354
355 b4_yystype[[] newValueStack = new ]b4_yystype[[size * 2];
356 System.arraycopy (valueStack, 0, newValueStack, 0, height);
357 valueStack = newValueStack;
358
359 size *= 2;
360 }
8405b70c
PB
361
362 stateStack[height] = state;
363 ]b4_locations_if([[locStack[height] = loc;]])[
364 valueStack[height] = value;
365 }
366
367 public final void pop () {
1a33f4f6 368 pop (1);
8405b70c
PB
369 }
370
371 public final void pop (int num) {
372 // Avoid memory leaks... garbage collection is a white lie!
373 if (num > 0) {
3f8ffd15 374 java.util.Arrays.fill (valueStack, height - num + 1, height + 1, null);
1a33f4f6 375 ]b4_locations_if([[java.util.Arrays.fill (locStack, height - num + 1, height + 1, null);]])[
8405b70c
PB
376 }
377 height -= num;
378 }
379
380 public final int stateAt (int i) {
381 return stateStack[height - i];
382 }
383
384 ]b4_locations_if([[public final ]b4_location_type[ locationAt (int i) {
385 return locStack[height - i];
386 }
387
01b477c6 388 ]])[public final ]b4_yystype[ valueAt (int i) {
8405b70c
PB
389 return valueStack[height - i];
390 }
391
392 // Print the state stack on the debug stream.
8a93f8e6 393 public void print (java.io.PrintStream out)
8405b70c
PB
394 {
395 out.print ("Stack now");
a0d4650a 396
02803d55 397 for (int i = 0; i <= height; i++)
8405b70c 398 {
11707b2b
AD
399 out.print (' ');
400 out.print (stateStack[i]);
8405b70c
PB
401 }
402 out.println ();
403 }
404 }
405
406 /**
407 * Returned by a Bison action in order to stop the parsing process and
94a62255
DH
408 * return success (<tt>true</tt>).
409 */
8405b70c
PB
410 public static final int YYACCEPT = 0;
411
412 /**
413 * Returned by a Bison action in order to stop the parsing process and
94a62255
DH
414 * return failure (<tt>false</tt>).
415 */
8405b70c
PB
416 public static final int YYABORT = 1;
417
aa94def1
DH
418]b4_push_if([
419 /**
420 * Returned by a Bison action in order to request a new token.
421 */
45c64fa6 422 public static final int YYPUSH_MORE = 4;])[
aa94def1 423
8405b70c
PB
424 /**
425 * Returned by a Bison action in order to start error recovery without
94a62255
DH
426 * printing an error message.
427 */
8405b70c
PB
428 public static final int YYERROR = 2;
429
94a62255
DH
430 /**
431 * Internal return codes that are not supported for user semantic
432 * actions.
433 */
4395a9ff 434 private static final int YYERRLAB = 3;
8405b70c
PB
435 private static final int YYNEWSTATE = 4;
436 private static final int YYDEFAULT = 5;
437 private static final int YYREDUCE = 6;
438 private static final int YYERRLAB1 = 7;
439 private static final int YYRETURN = 8;
aa94def1 440]b4_push_if([[ private static final int YYGETTOKEN = 9; /* Signify that a new token is expected when doing push-parsing. */]])[
8405b70c
PB
441
442 private int yyerrstatus_ = 0;
443
aa94def1
DH
444]b4_push_if([dnl
445b4_define_state])[
8405b70c
PB
446 /**
447 * Return whether error recovery is being done. In this state, the parser
448 * reads token until it reaches a known state, and then restarts normal
94a62255
DH
449 * operation.
450 */
d3b12988 451 public final boolean recovering ()
8405b70c
PB
452 {
453 return yyerrstatus_ == 0;
454 }
455
e254a580 456 private int yyaction (int yyn, YYStack yystack, int yylen) ]b4_maybe_throws([b4_throws])[
8405b70c 457 {
01b477c6 458 ]b4_yystype[ yyval;
8405b70c
PB
459 ]b4_locations_if([b4_location_type[ yyloc = yylloc (yystack, yylen);]])[
460
461 /* If YYLEN is nonzero, implement the default value of the action:
45eebca4 462 '$$ = $1'. Otherwise, use the top of the stack.
a0d4650a 463
8405b70c
PB
464 Otherwise, the following line sets YYVAL to garbage.
465 This behavior is undocumented and Bison
466 users should not rely upon it. */
467 if (yylen > 0)
468 yyval = yystack.valueAt (yylen - 1);
469 else
470 yyval = yystack.valueAt (0);
a0d4650a 471
8405b70c
PB
472 yy_reduce_print (yyn, yystack);
473
474 switch (yyn)
475 {
11707b2b
AD
476 ]b4_user_actions[
477 default: break;
8405b70c
PB
478 }
479
480 yy_symbol_print ("-> $$ =", yyr1_[yyn], yyval]b4_locations_if([, yyloc])[);
481
482 yystack.pop (yylen);
483 yylen = 0;
484
485 /* Shift the result of the reduction. */
486 yyn = yyr1_[yyn];
487 int yystate = yypgoto_[yyn - yyntokens_] + yystack.stateAt (0);
488 if (0 <= yystate && yystate <= yylast_
11707b2b 489 && yycheck_[yystate] == yystack.stateAt (0))
8405b70c
PB
490 yystate = yytable_[yystate];
491 else
492 yystate = yydefgoto_[yyn - yyntokens_];
493
494 yystack.push (yystate, yyval]b4_locations_if([, yyloc])[);
495 return YYNEWSTATE;
496 }
497
1979121c 498]b4_error_verbose_if([[
8405b70c
PB
499 /* Return YYSTR after stripping away unnecessary quotes and
500 backslashes, so that it's suitable for yyerror. The heuristic is
501 that double-quoting is unnecessary unless the string contains an
502 apostrophe, a comma, or backslash (other than backslash-backslash).
503 YYSTR is taken from yytname. */
504 private final String yytnamerr_ (String yystr)
505 {
506 if (yystr.charAt (0) == '"')
507 {
508 StringBuffer yyr = new StringBuffer ();
509 strip_quotes: for (int i = 1; i < yystr.length (); i++)
510 switch (yystr.charAt (i))
511 {
512 case '\'':
513 case ',':
514 break strip_quotes;
515
516 case '\\':
11707b2b 517 if (yystr.charAt(++i) != '\\')
8405b70c
PB
518 break strip_quotes;
519 /* Fall through. */
520 default:
521 yyr.append (yystr.charAt (i));
522 break;
523
524 case '"':
525 return yyr.toString ();
526 }
527 }
528 else if (yystr.equals ("$end"))
529 return "end of input";
530
531 return yystr;
532 }
1979121c 533]])[
8405b70c
PB
534
535 /*--------------------------------.
536 | Print this symbol on YYOUTPUT. |
537 `--------------------------------*/
538
539 private void yy_symbol_print (String s, int yytype,
11707b2b
AD
540 ]b4_yystype[ yyvaluep]dnl
541 b4_locations_if([, Object yylocationp])[)
8405b70c
PB
542 {
543 if (yydebug > 0)
544 yycdebug (s + (yytype < yyntokens_ ? " token " : " nterm ")
11707b2b
AD
545 + yytname_[yytype] + " ("]b4_locations_if([
546 + yylocationp + ": "])[
547 + (yyvaluep == null ? "(null)" : yyvaluep.toString ()) + ")");
8405b70c
PB
548 }
549
aa94def1 550]b4_push_if([],[[
8405b70c
PB
551 /**
552 * Parse input from the scanner that was specified at object construction
553 * time. Return whether the end of the input was reached successfully.
554 *
555 * @@return <tt>true</tt> if the parsing succeeds. Note that this does not
556 * imply that there were no syntax errors.
557 */
aa94def1
DH
558 public boolean parse () ]b4_maybe_throws([b4_list2([b4_lex_throws], [b4_throws])])[]])[
559]b4_push_if([
560 /**
561 * Push Parse input from external lexer
562 *
563 * @@param yylextoken current token
564 * @@param yylexval current lval
565]b4_locations_if([ * @@param yylexloc current position])[
566 *
45c64fa6 567 * @@return <tt>YYACCEPT, YYABORT, YYPUSH_MORE</tt>
aa94def1
DH
568 */
569 public int push_parse (int yylextoken, b4_yystype yylexval[]b4_locations_if([, b4_location_type yylexloc]))
570 b4_maybe_throws([b4_list2([b4_lex_throws], [b4_throws])])])[
8405b70c 571 {
aa94def1
DH
572 ]b4_locations_if([/* @@$. */
573 b4_location_type yyloc;])[
574]b4_push_if([],[[
575]b4_define_state[
8405b70c
PB
576 yycdebug ("Starting parse\n");
577 yyerrstatus_ = 0;
578
aa94def1
DH
579 /* Initialize the stack. */
580 yystack.push (yystate, yylval ]b4_locations_if([, yylloc])[);
8405b70c 581]m4_ifdef([b4_initial_action], [
cd735a8c 582b4_dollar_pushdef([yylval], [], [yylloc])dnl
8405b70c
PB
583 /* User initialization code. */
584 b4_user_initial_action
aa94def1
DH
585b4_dollar_popdef[]dnl
586])[
587]])[
588]b4_push_if([[
589 if (!this.push_parse_initialized)
590 {
591 push_parse_initialize ();
592]m4_ifdef([b4_initial_action], [
593b4_dollar_pushdef([yylval], [], [yylloc])dnl
594 /* User initialization code. */
595 b4_user_initial_action
596b4_dollar_popdef[]dnl
597])[
598 yycdebug ("Starting parse\n");
599 yyerrstatus_ = 0;
600 } else
601 label = YYGETTOKEN;
602
603 boolean push_token_consumed = true;
604]])[
8405b70c
PB
605 for (;;)
606 switch (label)
607 {
608 /* New state. Unlike in the C/C++ skeletons, the state is already
11707b2b 609 pushed when we come here. */
8405b70c
PB
610 case YYNEWSTATE:
611 yycdebug ("Entering state " + yystate + "\n");
612 if (yydebug > 0)
d3b12988 613 yystack.print (yyDebugStream);
a0d4650a 614
8405b70c
PB
615 /* Accept? */
616 if (yystate == yyfinal_)
aa94def1
DH
617 ]b4_push_if([{label = YYACCEPT; break;}],
618 [return true;])[
a0d4650a 619
8405b70c
PB
620 /* Take a decision. First try without lookahead. */
621 yyn = yypact_[yystate];
f2b30bdf 622 if (yy_pact_value_is_default_ (yyn))
8405b70c
PB
623 {
624 label = YYDEFAULT;
11707b2b 625 break;
8405b70c 626 }
aa94def1 627]b4_push_if([ /* Fall Through */
a0d4650a 628
aa94def1 629 case YYGETTOKEN:])[
8405b70c
PB
630 /* Read a lookahead token. */
631 if (yychar == yyempty_)
632 {
aa94def1
DH
633]b4_push_if([[
634 if (!push_token_consumed)
45c64fa6 635 return YYPUSH_MORE;
aa94def1
DH
636 yycdebug ("Reading a token: ");
637 yychar = yylextoken;
638 yylval = yylexval;]b4_locations_if([
639 yylloc = yylexloc;])[
640 push_token_consumed = false;]])[
641]b4_push_if([],[[
c4ddc0fb 642 yycdebug ("Reading a token: ");
aa94def1
DH
643 yychar = yylexer.yylex ();
644 yylval = yylexer.getLVal ();]b4_locations_if([
645 yylloc = new b4_location_type (yylexer.getStartPos (),
646 yylexer.getEndPos ());])[
647]])[
8405b70c 648 }
a0d4650a 649
8405b70c 650 /* Convert token to internal form. */
1979121c 651 if (yychar <= Lexer.EOF)
8405b70c 652 {
c4ddc0fb
AD
653 yychar = yytoken = Lexer.EOF;
654 yycdebug ("Now at end of input.\n");
8405b70c
PB
655 }
656 else
657 {
11707b2b
AD
658 yytoken = yytranslate_ (yychar);
659 yy_symbol_print ("Next token is", yytoken,
660 yylval]b4_locations_if([, yylloc])[);
8405b70c 661 }
a0d4650a 662
8405b70c
PB
663 /* If the proper action on seeing token YYTOKEN is to reduce or to
664 detect an error, take that action. */
665 yyn += yytoken;
666 if (yyn < 0 || yylast_ < yyn || yycheck_[yyn] != yytoken)
667 label = YYDEFAULT;
a0d4650a 668
8405b70c
PB
669 /* <= 0 means reduce or error. */
670 else if ((yyn = yytable_[yyn]) <= 0)
671 {
f2b30bdf 672 if (yy_table_value_is_error_ (yyn))
4395a9ff 673 label = YYERRLAB;
11707b2b
AD
674 else
675 {
676 yyn = -yyn;
677 label = YYREDUCE;
678 }
8405b70c 679 }
a0d4650a 680
8405b70c
PB
681 else
682 {
683 /* Shift the lookahead token. */
11707b2b
AD
684 yy_symbol_print ("Shifting", yytoken,
685 yylval]b4_locations_if([, yylloc])[);
a0d4650a 686
8405b70c
PB
687 /* Discard the token being shifted. */
688 yychar = yyempty_;
a0d4650a 689
8405b70c
PB
690 /* Count tokens shifted since error; after three, turn off error
691 status. */
692 if (yyerrstatus_ > 0)
693 --yyerrstatus_;
a0d4650a 694
8405b70c
PB
695 yystate = yyn;
696 yystack.push (yystate, yylval]b4_locations_if([, yylloc])[);
697 label = YYNEWSTATE;
698 }
699 break;
a0d4650a 700
8405b70c
PB
701 /*-----------------------------------------------------------.
702 | yydefault -- do the default action for the current state. |
703 `-----------------------------------------------------------*/
704 case YYDEFAULT:
705 yyn = yydefact_[yystate];
706 if (yyn == 0)
4395a9ff 707 label = YYERRLAB;
8405b70c
PB
708 else
709 label = YYREDUCE;
710 break;
a0d4650a 711
8405b70c
PB
712 /*-----------------------------.
713 | yyreduce -- Do a reduction. |
714 `-----------------------------*/
715 case YYREDUCE:
716 yylen = yyr2_[yyn];
717 label = yyaction (yyn, yystack, yylen);
11707b2b 718 yystate = yystack.stateAt (0);
8405b70c 719 break;
a0d4650a 720
8405b70c
PB
721 /*------------------------------------.
722 | yyerrlab -- here on detecting error |
723 `------------------------------------*/
4395a9ff 724 case YYERRLAB:
8405b70c
PB
725 /* If not already recovering from an error, report this error. */
726 if (yyerrstatus_ == 0)
727 {
11707b2b 728 ++yynerrs_;
d2060f06
JD
729 if (yychar == yyempty_)
730 yytoken = yyempty_;
11707b2b 731 yyerror (]b4_locations_if([yylloc, ])[yysyntax_error (yystate, yytoken));
8405b70c 732 }
a0d4650a 733
8405b70c
PB
734 ]b4_locations_if([yyerrloc = yylloc;])[
735 if (yyerrstatus_ == 3)
736 {
1979121c
DJ
737 /* If just tried and failed to reuse lookahead token after an
738 error, discard it. */
a0d4650a 739
1979121c
DJ
740 if (yychar <= Lexer.EOF)
741 {
742 /* Return failure if at end of input. */
743 if (yychar == Lexer.EOF)
aa94def1 744 ]b4_push_if([{label = YYABORT; break;}],[return false;])[
1979121c
DJ
745 }
746 else
aa94def1 747 yychar = yyempty_;
8405b70c 748 }
a0d4650a 749
8405b70c
PB
750 /* Else will try to reuse lookahead token after shifting the error
751 token. */
752 label = YYERRLAB1;
753 break;
a0d4650a 754
aa94def1 755 /*-------------------------------------------------.
8405b70c 756 | errorlab -- error raised explicitly by YYERROR. |
aa94def1 757 `-------------------------------------------------*/
8405b70c 758 case YYERROR:
a0d4650a 759
8405b70c
PB
760 ]b4_locations_if([yyerrloc = yystack.locationAt (yylen - 1);])[
761 /* Do not reclaim the symbols of the rule which action triggered
762 this YYERROR. */
763 yystack.pop (yylen);
764 yylen = 0;
765 yystate = yystack.stateAt (0);
766 label = YYERRLAB1;
767 break;
a0d4650a 768
8405b70c
PB
769 /*-------------------------------------------------------------.
770 | yyerrlab1 -- common code for both syntax error and YYERROR. |
771 `-------------------------------------------------------------*/
772 case YYERRLAB1:
11707b2b 773 yyerrstatus_ = 3; /* Each real token shifted decrements this. */
a0d4650a 774
8405b70c
PB
775 for (;;)
776 {
11707b2b 777 yyn = yypact_[yystate];
f2b30bdf 778 if (!yy_pact_value_is_default_ (yyn))
11707b2b
AD
779 {
780 yyn += yyterror_;
781 if (0 <= yyn && yyn <= yylast_ && yycheck_[yyn] == yyterror_)
782 {
783 yyn = yytable_[yyn];
784 if (0 < yyn)
785 break;
786 }
787 }
788
aa94def1
DH
789 /* Pop the current state because it cannot handle the
790 * error token. */
3e75a2c9 791 if (yystack.height == 0)
aa94def1 792 ]b4_push_if([{label = YYABORT; break;}],[return false;])[
11707b2b
AD
793
794 ]b4_locations_if([yyerrloc = yystack.locationAt (0);])[
795 yystack.pop ();
796 yystate = yystack.stateAt (0);
797 if (yydebug > 0)
798 yystack.print (yyDebugStream);
8405b70c 799 }
a0d4650a 800
aa94def1
DH
801 if (label == YYABORT)
802 /* Leave the switch. */
803 break;
804
805]b4_locations_if([
11707b2b
AD
806 /* Muck with the stack to setup for yylloc. */
807 yystack.push (0, null, yylloc);
808 yystack.push (0, null, yyerrloc);
8405b70c 809 yyloc = yylloc (yystack, 2);
11707b2b 810 yystack.pop (2);])[
8405b70c
PB
811
812 /* Shift the error token. */
813 yy_symbol_print ("Shifting", yystos_[yyn],
11707b2b 814 yylval]b4_locations_if([, yyloc])[);
a0d4650a 815
8405b70c 816 yystate = yyn;
11707b2b 817 yystack.push (yyn, yylval]b4_locations_if([, yyloc])[);
8405b70c
PB
818 label = YYNEWSTATE;
819 break;
a0d4650a 820
8405b70c
PB
821 /* Accept. */
822 case YYACCEPT:
aa94def1
DH
823 ]b4_push_if([this.push_parse_initialized = false; return YYACCEPT;],
824 [return true;])[
a0d4650a 825
8405b70c
PB
826 /* Abort. */
827 case YYABORT:
aa94def1
DH
828 ]b4_push_if([this.push_parse_initialized = false; return YYABORT;],
829 [return false;])[
8405b70c 830 }
aa94def1
DH
831}
832]b4_push_if([[
833 boolean push_parse_initialized = false;
834
835 /**
836 * (Re-)Initialize the state of the push parser.
837 */
838 public void push_parse_initialize()
839 {
840 /* Lookahead and lookahead in internal form. */
841 this.yychar = yyempty_;
842 this.yytoken = 0;
843
844 /* State. */
845 this.yyn = 0;
846 this.yylen = 0;
847 this.yystate = 0;
848 this.yystack = new YYStack ();
849 this.label = YYNEWSTATE;
850
851 /* Error handling. */
852 this.yynerrs_ = 0;
853 ]b4_locations_if([/* The location where the error started. */
854 this.yyerrloc = null;
855 this.yylloc = new b4_location_type (null, null);])[
856
857 /* Semantic value of the lookahead. */
858 this.yylval = null;
859
860 yystack.push (this.yystate, this.yylval]b4_locations_if([, this.yylloc])[);
861
862 this.push_parse_initialized = true;
863
864 }
865]b4_locations_if([
866 /**
867 * Push parse given input from an external lexer.
868 *
869 * @@param yylextoken current token
870 * @@param yylexval current lval
871 * @@param yyylexpos current position
872 *
45c64fa6 873 * @@return <tt>YYACCEPT, YYABORT, YYPUSH_MORE</tt>
aa94def1
DH
874 */
875 public int push_parse (int yylextoken, b4_yystype yylexval, b4_position_type yylexpos)
876 b4_maybe_throws([b4_list2([b4_lex_throws], [b4_throws])])
877 {
878 return push_parse (yylextoken, yylexval, new b4_location_type (yylexpos));
879 }
880])[]])
881
882b4_both_if([[
883 /**
884 * Parse input from the scanner that was specified at object construction
885 * time. Return whether the end of the input was reached successfully.
886 * This version of parse () is defined only when api.push-push=both.
887 *
888 * @@return <tt>true</tt> if the parsing succeeds. Note that this does not
889 * imply that there were no syntax errors.
890 */
891 public boolean parse () ]b4_maybe_throws([b4_list2([b4_lex_throws], [b4_throws])])[
892 {
893 if (yylexer == null)
894 throw new NullPointerException("Null Lexer");
895 int status;
896 do {
897 int token = yylexer.yylex();
898 ]b4_yystype[ lval = yylexer.getLVal();
899]b4_locations_if([dnl
900 b4_location_type yyloc = new b4_location_type (yylexer.getStartPos (),
901 yylexer.getEndPos ());])[
aa94def1
DH
902 ]b4_locations_if([status = push_parse(token,lval,yyloc);],[
903 status = push_parse(token,lval);])[
45c64fa6 904 } while (status == YYPUSH_MORE);
aa94def1 905 return (status == YYACCEPT);
8405b70c 906 }
aa94def1 907]])[
8405b70c
PB
908
909 // Generate an error message.
910 private String yysyntax_error (int yystate, int tok)
1979121c
DJ
911 {]b4_error_verbose_if([[
912 if (yyErrorVerbose)
8405b70c 913 {
d2060f06 914 /* There are many possibilities here to consider:
d2060f06
JD
915 - If this state is a consistent state with a default action,
916 then the only way this function was invoked is if the
917 default action is an error action. In that case, don't
918 check for expected tokens because there are none.
919 - The only way there can be no lookahead present (in tok) is
920 if this state is a consistent state with a default action.
921 Thus, detecting the absence of a lookahead is sufficient to
922 determine that there is no unexpected or expected token to
923 report. In that case, just report a simple "syntax error".
924 - Don't assume there isn't a lookahead just because this
925 state is a consistent state with a default action. There
926 might have been a previous inconsistent state, consistent
927 state with a non-default action, or user semantic action
928 that manipulated yychar. (However, yychar is currently out
929 of scope during semantic actions.)
930 - Of course, the expected token list depends on states to
931 have correct lookahead information, and it depends on the
932 parser not to perform extra reductions after fetching a
933 lookahead from the scanner and before detecting a syntax
934 error. Thus, state merging (from LALR or IELR) and default
935 reductions corrupt the expected token list. However, the
936 list is correct for canonical LR with one exception: it
937 will still contain any token that will not be accepted due
938 to an error action in a later state.
939 */
940 if (tok != yyempty_)
8405b70c 941 {
94a62255
DH
942 /* FIXME: This method of building the message is not compatible
943 with internationalization. */
d2060f06
JD
944 StringBuffer res =
945 new StringBuffer ("syntax error, unexpected ");
946 res.append (yytnamerr_ (yytname_[tok]));
947 int yyn = yypact_[yystate];
948 if (!yy_pact_value_is_default_ (yyn))
949 {
b4bbc4a0
JD
950 /* Start YYX at -YYN if negative to avoid negative
951 indexes in YYCHECK. In other words, skip the first
952 -YYN actions for this state because they are default
953 actions. */
954 int yyxbegin = yyn < 0 ? -yyn : 0;
b4bbc4a0
JD
955 /* Stay within bounds of both yycheck and yytname. */
956 int yychecklim = yylast_ - yyn + 1;
957 int yyxend = yychecklim < yyntokens_ ? yychecklim : yyntokens_;
958 int count = 0;
959 for (int x = yyxbegin; x < yyxend; ++x)
960 if (yycheck_[x + yyn] == x && x != yyterror_
961 && !yy_table_value_is_error_ (yytable_[x + yyn]))
962 ++count;
b4bbc4a0
JD
963 if (count < 5)
964 {
965 count = 0;
966 for (int x = yyxbegin; x < yyxend; ++x)
967 if (yycheck_[x + yyn] == x && x != yyterror_
968 && !yy_table_value_is_error_ (yytable_[x + yyn]))
969 {
970 res.append (count++ == 0 ? ", expecting " : " or ");
971 res.append (yytnamerr_ (yytname_[x]));
972 }
973 }
d2060f06 974 }
2b008529 975 return res.toString ();
8405b70c
PB
976 }
977 }
1979121c 978]])[
8405b70c
PB
979 return "syntax error";
980 }
981
f2b30bdf
JD
982 /**
983 * Whether the given <code>yypact_</code> value indicates a defaulted state.
984 * @@param yyvalue the value to check
985 */
986 private static boolean yy_pact_value_is_default_ (int yyvalue)
987 {
988 return yyvalue == yypact_ninf_;
989 }
990
991 /**
94a62255
DH
992 * Whether the given <code>yytable_</code>
993 * value indicates a syntax error.
994 * @@param yyvalue the value to check
f2b30bdf
JD
995 */
996 private static boolean yy_table_value_is_error_ (int yyvalue)
997 {
aa0cb40d 998 return yyvalue == yytable_ninf_;
f2b30bdf
JD
999 }
1000
8405b70c 1001 private static final ]b4_int_type_for([b4_pact])[ yypact_ninf_ = ]b4_pact_ninf[;
8405b70c 1002 private static final ]b4_int_type_for([b4_table])[ yytable_ninf_ = ]b4_table_ninf[;
8405b70c 1003
2c1bf9bd
AD
1004 ]b4_parser_tables_define[
1005 ]b4_integral_parser_table_define([token_number], [b4_toknum],
6f0a6f27
AD
1006 [[YYTOKEN_NUMBER[YYLEX-NUM] -- Internal symbol number corresponding
1007 to YYLEX-NUM.]])[
8405b70c
PB
1008
1009 /* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
1010 First, the terminals, then, starting at \a yyntokens_, nonterminals. */
2c1bf9bd 1011 ]b4_typed_parser_table_define([String], [tname], [b4_tname])[
8405b70c 1012
2c1bf9bd 1013 ]b4_integral_parser_table_define([rline], [b4_rline],
6f0a6f27 1014 [[YYRLINE[YYN] -- Source line where rule number YYN was defined.]])[
8405b70c 1015
aa94def1 1016
8405b70c 1017 // Report on the debug stream that the rule yyrule is going to be reduced.
d3b12988 1018 private void yy_reduce_print (int yyrule, YYStack yystack)
8405b70c
PB
1019 {
1020 if (yydebug == 0)
1021 return;
1022
1023 int yylno = yyrline_[yyrule];
1024 int yynrhs = yyr2_[yyrule];
1025 /* Print the symbols being reduced, and their result. */
1026 yycdebug ("Reducing stack by rule " + (yyrule - 1)
11707b2b 1027 + " (line " + yylno + "), ");
8405b70c
PB
1028
1029 /* The symbols being reduced. */
1030 for (int yyi = 0; yyi < yynrhs; yyi++)
1031 yy_symbol_print (" $" + (yyi + 1) + " =",
2d404819 1032 yystos_[yystack.stateAt(yynrhs - (yyi + 1))],
11707b2b
AD
1033 ]b4_rhs_value(yynrhs, yyi + 1)b4_locations_if([,
1034 b4_rhs_location(yynrhs, yyi + 1)])[);
8405b70c
PB
1035 }
1036
1037 /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
2c1bf9bd 1038 ]b4_integral_parser_table_define([translate_table], [b4_translate])[
8405b70c
PB
1039
1040 private static final ]b4_int_type_for([b4_translate])[ yytranslate_ (int t)
1041 {
1042 if (t >= 0 && t <= yyuser_token_number_max_)
1043 return yytranslate_table_[t];
1044 else
1045 return yyundef_token_;
1046 }
1047
1048 private static final int yylast_ = ]b4_last[;
1049 private static final int yynnts_ = ]b4_nterms_number[;
1050 private static final int yyempty_ = -2;
1051 private static final int yyfinal_ = ]b4_final_state_number[;
1052 private static final int yyterror_ = 1;
1053 private static final int yyerrcode_ = 256;
1054 private static final int yyntokens_ = ]b4_tokens_number[;
1055
1056 private static final int yyuser_token_number_max_ = ]b4_user_token_number_max[;
1057 private static final int yyundef_token_ = ]b4_undef_token_number[;
1058
1059]/* User implementation code. */
1060b4_percent_code_get[]dnl
1061
1062}
1063
4524c55b 1064b4_epilogue[]dnl
1c7ec959 1065b4_output_end()