]> git.saurik.com Git - bison.git/blob - data/lalr1.cc
2ec1d0d702f6277d8885809279472c520bd037f5
[bison.git] / data / lalr1.cc
1 # C++ skeleton for Bison
2
3 # Copyright (C) 2002-2012 Free Software Foundation, Inc.
4
5 # This program is free software: you can redistribute it and/or modify
6 # it under the terms of the GNU General Public License as published by
7 # the Free Software Foundation, either version 3 of the License, or
8 # (at your option) any later version.
9 #
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.
14 #
15 # You should have received a copy of the GNU General Public License
16 # along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18 m4_include(b4_pkgdatadir/[c++.m4])
19
20 m4_define([b4_parser_class_name],
21 [b4_percent_define_get([[parser_class_name]])])
22
23 # The header is mandatory.
24 b4_defines_if([],
25 [b4_fatal([b4_skeleton[: using %%defines is mandatory]])])
26
27 b4_percent_define_ifdef([[location_type]], [],
28 [# Backward compatibility.
29 m4_define([b4_location_constructors])
30 m4_include(b4_pkgdatadir/[location.cc])])
31 m4_include(b4_pkgdatadir/[stack.hh])
32
33 # We do want M4 expansion after # for CPP macros.
34 m4_changecom()
35 m4_divert_push(0)dnl
36 b4_defines_if(
37 [@output(b4_spec_defines_file@)@
38 b4_copyright([Skeleton interface for Bison LALR(1) parsers in C++],
39 [2002-2012])
40 [
41 /**
42 ** \file ]b4_spec_defines_file[
43 ** Define the ]b4_namespace_ref[::parser class.
44 */
45
46 /* C++ LALR(1) parser skeleton written by Akim Demaille. */
47
48 ]b4_cpp_guard_open([b4_spec_defines_file])[
49
50 ]b4_percent_code_get([[requires]])[
51
52 #include <string>
53 #include <iostream>
54 #include "stack.hh"
55 ]b4_percent_define_ifdef([[location_type]], [],
56 [[#include "location.hh"]])[
57
58 ]b4_YYDEBUG_define[
59
60 ]b4_namespace_open[
61
62 /// A Bison parser.
63 class ]b4_parser_class_name[
64 {
65 public:
66 /// Symbol semantic values.
67 #ifndef ]b4_api_PREFIX[STYPE
68 ]m4_ifdef([b4_stype],
69 [ union semantic_type
70 {
71 b4_user_stype
72 };],
73 [m4_if(b4_tag_seen_flag, 0,
74 [[ typedef int semantic_type;]],
75 [[ typedef ]b4_api_PREFIX[STYPE semantic_type;]])])[
76 #else
77 typedef ]b4_api_PREFIX[STYPE semantic_type;
78 #endif
79 /// Symbol locations.
80 typedef ]b4_percent_define_get([[location_type]],
81 [[location]])[ location_type;
82 /// Tokens.
83 struct token
84 {
85 ]b4_token_enums(b4_tokens)[
86 };
87 /// Token type.
88 typedef token::yytokentype token_type;
89
90 /// Build a parser object.
91 ]b4_parser_class_name[ (]b4_parse_param_decl[);
92 virtual ~]b4_parser_class_name[ ();
93
94 /// Parse.
95 /// \returns 0 iff parsing succeeded.
96 virtual int parse ();
97
98 #if ]b4_api_PREFIX[DEBUG
99 /// The current debugging stream.
100 std::ostream& debug_stream () const;
101 /// Set the current debugging stream.
102 void set_debug_stream (std::ostream &);
103
104 /// Type for debugging levels.
105 typedef int debug_level_type;
106 /// The current debugging level.
107 debug_level_type debug_level () const;
108 /// Set the current debugging level.
109 void set_debug_level (debug_level_type l);
110 #endif
111
112 private:
113 /// Report a syntax error.
114 /// \param loc where the syntax error is found.
115 /// \param msg a description of the syntax error.
116 virtual void error (const location_type& loc, const std::string& msg);
117
118 /// Generate an error message.
119 /// \param state the state where the error occurred.
120 /// \param tok the lookahead token.
121 virtual std::string yysyntax_error_ (int yystate, int tok);
122
123 #if ]b4_api_PREFIX[DEBUG
124 /// \brief Report a symbol value on the debug stream.
125 /// \param yytype The token type.
126 /// \param yyvaluep Its semantic value.
127 /// \param yylocationp Its location.
128 virtual void yy_symbol_value_print_ (int yytype,
129 const semantic_type* yyvaluep,
130 const location_type* yylocationp);
131 /// \brief Report a symbol on the debug stream.
132 /// \param yytype The token type.
133 /// \param yyvaluep Its semantic value.
134 /// \param yylocationp Its location.
135 virtual void yy_symbol_print_ (int yytype,
136 const semantic_type* yyvaluep,
137 const location_type* yylocationp);
138 #endif
139
140
141 /// State numbers.
142 typedef int state_type;
143 /// State stack type.
144 typedef stack<state_type> state_stack_type;
145 /// Semantic value stack type.
146 typedef stack<semantic_type> semantic_stack_type;
147 /// location stack type.
148 typedef stack<location_type> location_stack_type;
149
150 /// The state stack.
151 state_stack_type yystate_stack_;
152 /// The semantic value stack.
153 semantic_stack_type yysemantic_stack_;
154 /// The location stack.
155 location_stack_type yylocation_stack_;
156
157 /// Whether the given \c yypact_ value indicates a defaulted state.
158 /// \param yyvalue the value to check
159 static bool yy_pact_value_is_default_ (int yyvalue);
160
161 /// Whether the given \c yytable_ value indicates a syntax error.
162 /// \param yyvalue the value to check
163 static bool yy_table_value_is_error_ (int yyvalue);
164
165 /// Internal symbol numbers.
166 typedef ]b4_int_type_for([b4_translate])[ token_number_type;
167 /* Tables. */
168 /// For a state, the index in \a yytable_ of its portion.
169 static const ]b4_int_type_for([b4_pact])[ yypact_[];
170 static const ]b4_int_type(b4_pact_ninf, b4_pact_ninf)[ yypact_ninf_;
171
172 /// For a state, default reduction number.
173 /// Unless\a yytable_ specifies something else to do.
174 /// Zero means the default is an error.
175 static const ]b4_int_type_for([b4_defact])[ yydefact_[];
176
177 static const ]b4_int_type_for([b4_pgoto])[ yypgoto_[];
178 static const ]b4_int_type_for([b4_defgoto])[ yydefgoto_[];
179
180 /// What to do in a state.
181 /// \a yytable_[yypact_[s]]: what to do in state \a s.
182 /// - if positive, shift that token.
183 /// - if negative, reduce the rule which number is the opposite.
184 /// - if zero, do what YYDEFACT says.
185 static const ]b4_int_type_for([b4_table])[ yytable_[];
186 static const ]b4_int_type(b4_table_ninf, b4_table_ninf)[ yytable_ninf_;
187
188 static const ]b4_int_type_for([b4_check])[ yycheck_[];
189
190 /// For a state, its accessing symbol.
191 static const ]b4_int_type_for([b4_stos])[ yystos_[];
192
193 /// For a rule, its LHS.
194 static const ]b4_int_type_for([b4_r1])[ yyr1_[];
195 /// For a rule, its RHS length.
196 static const ]b4_int_type_for([b4_r2])[ yyr2_[]; ]b4_error_verbose_if([
197
198 /// Convert the symbol name \a n to a form suitable for a diagnostic.
199 static std::string yytnamerr_ (const char *n);])[
200
201 ]b4_token_table_if([], [[#if ]b4_api_PREFIX[DEBUG]])[
202 /// For a symbol, its name in clear.
203 static const char* const yytname_[];
204 ]b4_token_table_if([[#if ]b4_api_PREFIX[DEBUG]])[
205 /// A type to store symbol numbers and -1.
206 typedef ]b4_int_type_for([b4_rhs])[ rhs_number_type;
207 /// A `-1'-separated list of the rules' RHS.
208 static const rhs_number_type yyrhs_[];
209 /// For each rule, the index of the first RHS symbol in \a yyrhs_.
210 static const ]b4_int_type_for([b4_prhs])[ yyprhs_[];
211 /// For each rule, its source line number.
212 static const ]b4_int_type_for([b4_rline])[ yyrline_[];
213 /// For each scanner token number, its symbol number.
214 static const ]b4_int_type_for([b4_toknum])[ yytoken_number_[];
215 /// Report on the debug stream that the rule \a r is going to be reduced.
216 virtual void yy_reduce_print_ (int r);
217 /// Print the state stack on the debug stream.
218 virtual void yystack_print_ ();
219
220 /* Debugging. */
221 int yydebug_;
222 std::ostream* yycdebug_;
223 #endif
224
225 /// Convert a scanner token number \a t to a symbol number.
226 token_number_type yytranslate_ (int t);
227
228 /// \brief Reclaim the memory associated to a symbol.
229 /// \param yymsg Why this token is reclaimed.
230 /// \param yytype The symbol type.
231 /// \param yyvaluep Its semantic value.
232 /// \param yylocationp Its location.
233 inline void yydestruct_ (const char* yymsg,
234 int yytype,
235 semantic_type* yyvaluep,
236 location_type* yylocationp);
237
238 /// Pop \a n symbols the three stacks.
239 inline void yypop_ (unsigned int n = 1);
240
241 /* Constants. */
242 static const int yyeof_;
243 /* LAST_ -- Last index in TABLE_. */
244 static const int yylast_;
245 static const int yynnts_;
246 static const int yyempty_;
247 static const int yyfinal_;
248 static const int yyterror_;
249 static const int yyerrcode_;
250 static const int yyntokens_;
251 static const unsigned int yyuser_token_number_max_;
252 static const token_number_type yyundef_token_;
253 ]b4_parse_param_vars[
254 };
255 ]b4_namespace_close[
256
257 ]b4_percent_define_flag_if([[global_tokens_and_yystype]],
258 [b4_token_defines(b4_tokens)
259
260 #ifndef ]b4_api_PREFIX[STYPE
261 /* Redirection for backward compatibility. */
262 # define ]b4_api_PREFIX[STYPE b4_namespace_ref::b4_parser_class_name::semantic_type
263 #endif
264 ])[
265 ]b4_percent_code_get([[provides]])[
266 ]b4_cpp_guard_close([b4_spec_defines_file])
267 ])dnl
268 @output(b4_parser_file_name@)@
269 b4_copyright([Skeleton implementation for Bison LALR(1) parsers in C++],
270 [2002-2012])
271 b4_percent_code_get([[top]])[]dnl
272 m4_if(b4_prefix, [yy], [],
273 [
274 // Take the name prefix into account.
275 #define yylex b4_prefix[]lex])[
276
277 /* First part of user declarations. */
278 ]b4_user_pre_prologue[
279
280 ]b4_defines_if([[
281 #include "@basename(]b4_spec_defines_file[@)"]])[
282
283 /* User implementation prologue. */
284 ]b4_user_post_prologue[
285 ]b4_percent_code_get[
286
287 ]b4_null_define[
288
289 #ifndef YY_
290 # if defined YYENABLE_NLS && YYENABLE_NLS
291 # if ENABLE_NLS
292 # include <libintl.h> /* FIXME: INFRINGES ON USER NAME SPACE */
293 # define YY_(msgid) dgettext ("bison-runtime", msgid)
294 # endif
295 # endif
296 # ifndef YY_
297 # define YY_(msgid) msgid
298 # endif
299 #endif
300
301 #define YYRHSLOC(Rhs, K) ((Rhs)[K])
302 ]b4_yylloc_default_define[
303
304 /* Suppress unused-variable warnings by "using" E. */
305 #define YYUSE(e) ((void) (e))
306
307 /* Enable debugging if requested. */
308 #if ]b4_api_PREFIX[DEBUG
309
310 /* A pseudo ostream that takes yydebug_ into account. */
311 # define YYCDEBUG if (yydebug_) (*yycdebug_)
312
313 # define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
314 do { \
315 if (yydebug_) \
316 { \
317 *yycdebug_ << Title << ' '; \
318 yy_symbol_print_ ((Type), (Value), (Location)); \
319 *yycdebug_ << std::endl; \
320 } \
321 } while (false)
322
323 # define YY_REDUCE_PRINT(Rule) \
324 do { \
325 if (yydebug_) \
326 yy_reduce_print_ (Rule); \
327 } while (false)
328
329 # define YY_STACK_PRINT() \
330 do { \
331 if (yydebug_) \
332 yystack_print_ (); \
333 } while (false)
334
335 #else /* !]b4_api_PREFIX[DEBUG */
336
337 # define YYCDEBUG if (false) std::cerr
338 # define YY_SYMBOL_PRINT(Title, Type, Value, Location) YYUSE(Type)
339 # define YY_REDUCE_PRINT(Rule) static_cast<void>(0)
340 # define YY_STACK_PRINT() static_cast<void>(0)
341
342 #endif /* !]b4_api_PREFIX[DEBUG */
343
344 #define yyerrok (yyerrstatus_ = 0)
345 #define yyclearin (yychar = yyempty_)
346
347 #define YYACCEPT goto yyacceptlab
348 #define YYABORT goto yyabortlab
349 #define YYERROR goto yyerrorlab
350 #define YYRECOVERING() (!!yyerrstatus_)
351
352 ]b4_namespace_open[]b4_error_verbose_if([[
353
354 /* Return YYSTR after stripping away unnecessary quotes and
355 backslashes, so that it's suitable for yyerror. The heuristic is
356 that double-quoting is unnecessary unless the string contains an
357 apostrophe, a comma, or backslash (other than backslash-backslash).
358 YYSTR is taken from yytname. */
359 std::string
360 ]b4_parser_class_name[::yytnamerr_ (const char *yystr)
361 {
362 if (*yystr == '"')
363 {
364 std::string yyr = "";
365 char const *yyp = yystr;
366
367 for (;;)
368 switch (*++yyp)
369 {
370 case '\'':
371 case ',':
372 goto do_not_strip_quotes;
373
374 case '\\':
375 if (*++yyp != '\\')
376 goto do_not_strip_quotes;
377 /* Fall through. */
378 default:
379 yyr += *yyp;
380 break;
381
382 case '"':
383 return yyr;
384 }
385 do_not_strip_quotes: ;
386 }
387
388 return yystr;
389 }
390 ]])[
391
392 /// Build a parser object.
393 ]b4_parser_class_name::b4_parser_class_name[ (]b4_parse_param_decl[)]m4_ifset([b4_parse_param], [
394 :])[
395 #if ]b4_api_PREFIX[DEBUG
396 ]m4_ifset([b4_parse_param], [ ], [ :])[yydebug_ (false),
397 yycdebug_ (&std::cerr)]m4_ifset([b4_parse_param], [,])[
398 #endif]b4_parse_param_cons[
399 {
400 }
401
402 ]b4_parser_class_name::~b4_parser_class_name[ ()
403 {
404 }
405
406 #if ]b4_api_PREFIX[DEBUG
407 /*--------------------------------.
408 | Print this symbol on YYOUTPUT. |
409 `--------------------------------*/
410
411 inline void
412 ]b4_parser_class_name[::yy_symbol_value_print_ (int yytype,
413 const semantic_type* yyvaluep, const location_type* yylocationp)
414 {
415 YYUSE (yylocationp);
416 YYUSE (yyvaluep);
417 std::ostream& yyo = debug_stream ();
418 std::ostream& yyoutput = yyo;
419 YYUSE (yyoutput);
420 switch (yytype)
421 {
422 ]m4_map([b4_symbol_actions], m4_defn([b4_symbol_printers]))dnl
423 [ default:
424 break;
425 }
426 }
427
428
429 void
430 ]b4_parser_class_name[::yy_symbol_print_ (int yytype,
431 const semantic_type* yyvaluep, const location_type* yylocationp)
432 {
433 *yycdebug_ << (yytype < yyntokens_ ? "token" : "nterm")
434 << ' ' << yytname_[yytype] << " ("
435 << *yylocationp << ": ";
436 yy_symbol_value_print_ (yytype, yyvaluep, yylocationp);
437 *yycdebug_ << ')';
438 }
439 #endif
440
441 void
442 ]b4_parser_class_name[::yydestruct_ (const char* yymsg,
443 int yytype, semantic_type* yyvaluep, location_type* yylocationp)
444 {
445 YYUSE (yylocationp);
446 YYUSE (yymsg);
447 YYUSE (yyvaluep);
448
449 YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp);
450
451 switch (yytype)
452 {
453 ]m4_map([b4_symbol_actions], m4_defn([b4_symbol_destructors]))[
454 default:
455 break;
456 }
457 }
458
459 void
460 ]b4_parser_class_name[::yypop_ (unsigned int n)
461 {
462 yystate_stack_.pop (n);
463 yysemantic_stack_.pop (n);
464 yylocation_stack_.pop (n);
465 }
466
467 #if ]b4_api_PREFIX[DEBUG
468 std::ostream&
469 ]b4_parser_class_name[::debug_stream () const
470 {
471 return *yycdebug_;
472 }
473
474 void
475 ]b4_parser_class_name[::set_debug_stream (std::ostream& o)
476 {
477 yycdebug_ = &o;
478 }
479
480
481 ]b4_parser_class_name[::debug_level_type
482 ]b4_parser_class_name[::debug_level () const
483 {
484 return yydebug_;
485 }
486
487 void
488 ]b4_parser_class_name[::set_debug_level (debug_level_type l)
489 {
490 yydebug_ = l;
491 }
492 #endif
493
494 inline bool
495 ]b4_parser_class_name[::yy_pact_value_is_default_ (int yyvalue)
496 {
497 return yyvalue == yypact_ninf_;
498 }
499
500 inline bool
501 ]b4_parser_class_name[::yy_table_value_is_error_ (int yyvalue)
502 {
503 return yyvalue == yytable_ninf_;
504 }
505
506 int
507 ]b4_parser_class_name[::parse ()
508 {
509 /// Lookahead and lookahead in internal form.
510 int yychar = yyempty_;
511 int yytoken = 0;
512
513 /* State. */
514 int yyn;
515 int yylen = 0;
516 int yystate = 0;
517
518 /* Error handling. */
519 int yynerrs_ = 0;
520 int yyerrstatus_ = 0;
521
522 /// Semantic value of the lookahead.
523 semantic_type yylval;
524 /// Location of the lookahead.
525 location_type yylloc;
526 /// The locations where the error started and ended.
527 location_type yyerror_range[3];
528
529 /// $$.
530 semantic_type yyval;
531 /// @@$.
532 location_type yyloc;
533
534 int yyresult;
535
536 // FIXME: This shoud be completely indented. It is not yet to
537 // avoid gratuitous conflicts when merging into the master branch.
538 try
539 {
540 YYCDEBUG << "Starting parse" << std::endl;
541
542 ]m4_ifdef([b4_initial_action], [
543 b4_dollar_pushdef([yylval], [], [yylloc])dnl
544 /* User initialization code. */
545 b4_user_initial_action
546 b4_dollar_popdef])[]dnl
547
548 [ /* Initialize the stacks. The initial state will be pushed in
549 yynewstate, since the latter expects the semantical and the
550 location values to have been already stored, initialize these
551 stacks with a primary value. */
552 yystate_stack_ = state_stack_type (0);
553 yysemantic_stack_ = semantic_stack_type (0);
554 yylocation_stack_ = location_stack_type (0);
555 yysemantic_stack_.push (yylval);
556 yylocation_stack_.push (yylloc);
557
558 /* New state. */
559 yynewstate:
560 yystate_stack_.push (yystate);
561 YYCDEBUG << "Entering state " << yystate << std::endl;
562
563 /* Accept? */
564 if (yystate == yyfinal_)
565 goto yyacceptlab;
566
567 goto yybackup;
568
569 /* Backup. */
570 yybackup:
571
572 /* Try to take a decision without lookahead. */
573 yyn = yypact_[yystate];
574 if (yy_pact_value_is_default_ (yyn))
575 goto yydefault;
576
577 /* Read a lookahead token. */
578 if (yychar == yyempty_)
579 {
580 YYCDEBUG << "Reading a token: ";
581 yychar = ]b4_c_function_call([yylex], [int],
582 [b4_api_PREFIX[STYPE*], [&yylval]][]dnl
583 b4_locations_if([, [[location*], [&yylloc]]])dnl
584 m4_ifdef([b4_lex_param], [, ]b4_lex_param))[;
585 }
586
587 /* Convert token to internal form. */
588 if (yychar <= yyeof_)
589 {
590 yychar = yytoken = yyeof_;
591 YYCDEBUG << "Now at end of input." << std::endl;
592 }
593 else
594 {
595 yytoken = yytranslate_ (yychar);
596 YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc);
597 }
598
599 /* If the proper action on seeing token YYTOKEN is to reduce or to
600 detect an error, take that action. */
601 yyn += yytoken;
602 if (yyn < 0 || yylast_ < yyn || yycheck_[yyn] != yytoken)
603 goto yydefault;
604
605 /* Reduce or error. */
606 yyn = yytable_[yyn];
607 if (yyn <= 0)
608 {
609 if (yy_table_value_is_error_ (yyn))
610 goto yyerrlab;
611 yyn = -yyn;
612 goto yyreduce;
613 }
614
615 /* Shift the lookahead token. */
616 YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc);
617
618 /* Discard the token being shifted. */
619 yychar = yyempty_;
620
621 yysemantic_stack_.push (yylval);
622 yylocation_stack_.push (yylloc);
623
624 /* Count tokens shifted since error; after three, turn off error
625 status. */
626 if (yyerrstatus_)
627 --yyerrstatus_;
628
629 yystate = yyn;
630 goto yynewstate;
631
632 /*-----------------------------------------------------------.
633 | yydefault -- do the default action for the current state. |
634 `-----------------------------------------------------------*/
635 yydefault:
636 yyn = yydefact_[yystate];
637 if (yyn == 0)
638 goto yyerrlab;
639 goto yyreduce;
640
641 /*-----------------------------.
642 | yyreduce -- Do a reduction. |
643 `-----------------------------*/
644 yyreduce:
645 yylen = yyr2_[yyn];
646 /* If YYLEN is nonzero, implement the default value of the action:
647 `$$ = $1'. Otherwise, use the top of the stack.
648
649 Otherwise, the following line sets YYVAL to garbage.
650 This behavior is undocumented and Bison
651 users should not rely upon it. */
652 if (yylen)
653 yyval = yysemantic_stack_[yylen - 1];
654 else
655 yyval = yysemantic_stack_[0];
656
657 // Compute the default @@$.
658 {
659 slice<location_type, location_stack_type> slice (yylocation_stack_, yylen);
660 YYLLOC_DEFAULT (yyloc, slice, yylen);
661 }
662
663 // Perform the reduction.
664 YY_REDUCE_PRINT (yyn);
665 switch (yyn)
666 {
667 ]b4_user_actions[
668 default:
669 break;
670 }
671
672 /* User semantic actions sometimes alter yychar, and that requires
673 that yytoken be updated with the new translation. We take the
674 approach of translating immediately before every use of yytoken.
675 One alternative is translating here after every semantic action,
676 but that translation would be missed if the semantic action
677 invokes YYABORT, YYACCEPT, or YYERROR immediately after altering
678 yychar. In the case of YYABORT or YYACCEPT, an incorrect
679 destructor might then be invoked immediately. In the case of
680 YYERROR, subsequent parser actions might lead to an incorrect
681 destructor call or verbose syntax error message before the
682 lookahead is translated. */
683 YY_SYMBOL_PRINT ("-> $$ =", yyr1_[yyn], &yyval, &yyloc);
684
685 yypop_ (yylen);
686 yylen = 0;
687 YY_STACK_PRINT ();
688
689 yysemantic_stack_.push (yyval);
690 yylocation_stack_.push (yyloc);
691
692 /* Shift the result of the reduction. */
693 yyn = yyr1_[yyn];
694 yystate = yypgoto_[yyn - yyntokens_] + yystate_stack_[0];
695 if (0 <= yystate && yystate <= yylast_
696 && yycheck_[yystate] == yystate_stack_[0])
697 yystate = yytable_[yystate];
698 else
699 yystate = yydefgoto_[yyn - yyntokens_];
700 goto yynewstate;
701
702 /*------------------------------------.
703 | yyerrlab -- here on detecting error |
704 `------------------------------------*/
705 yyerrlab:
706 /* Make sure we have latest lookahead translation. See comments at
707 user semantic actions for why this is necessary. */
708 yytoken = yytranslate_ (yychar);
709
710 /* If not already recovering from an error, report this error. */
711 if (!yyerrstatus_)
712 {
713 ++yynerrs_;
714 if (yychar == yyempty_)
715 yytoken = yyempty_;
716 error (yylloc, yysyntax_error_ (yystate, yytoken));
717 }
718
719 yyerror_range[1] = yylloc;
720 if (yyerrstatus_ == 3)
721 {
722 /* If just tried and failed to reuse lookahead token after an
723 error, discard it. */
724 if (yychar <= yyeof_)
725 {
726 /* Return failure if at end of input. */
727 if (yychar == yyeof_)
728 YYABORT;
729 }
730 else
731 {
732 yydestruct_ ("Error: discarding", yytoken, &yylval, &yylloc);
733 yychar = yyempty_;
734 }
735 }
736
737 /* Else will try to reuse lookahead token after shifting the error
738 token. */
739 goto yyerrlab1;
740
741
742 /*---------------------------------------------------.
743 | yyerrorlab -- error raised explicitly by YYERROR. |
744 `---------------------------------------------------*/
745 yyerrorlab:
746
747 /* Pacify compilers like GCC when the user code never invokes
748 YYERROR and the label yyerrorlab therefore never appears in user
749 code. */
750 if (false)
751 goto yyerrorlab;
752
753 yyerror_range[1] = yylocation_stack_[yylen - 1];
754 /* Do not reclaim the symbols of the rule which action triggered
755 this YYERROR. */
756 yypop_ (yylen);
757 yylen = 0;
758 yystate = yystate_stack_[0];
759 goto yyerrlab1;
760
761 /*-------------------------------------------------------------.
762 | yyerrlab1 -- common code for both syntax error and YYERROR. |
763 `-------------------------------------------------------------*/
764 yyerrlab1:
765 yyerrstatus_ = 3; /* Each real token shifted decrements this. */
766
767 for (;;)
768 {
769 yyn = yypact_[yystate];
770 if (!yy_pact_value_is_default_ (yyn))
771 {
772 yyn += yyterror_;
773 if (0 <= yyn && yyn <= yylast_ && yycheck_[yyn] == yyterror_)
774 {
775 yyn = yytable_[yyn];
776 if (0 < yyn)
777 break;
778 }
779 }
780
781 /* Pop the current state because it cannot handle the error token. */
782 if (yystate_stack_.height () == 1)
783 YYABORT;
784
785 yyerror_range[1] = yylocation_stack_[0];
786 yydestruct_ ("Error: popping",
787 yystos_[yystate],
788 &yysemantic_stack_[0], &yylocation_stack_[0]);
789 yypop_ ();
790 yystate = yystate_stack_[0];
791 YY_STACK_PRINT ();
792 }
793
794 yyerror_range[2] = yylloc;
795 // Using YYLLOC is tempting, but would change the location of
796 // the lookahead. YYLOC is available though.
797 YYLLOC_DEFAULT (yyloc, yyerror_range, 2);
798 yysemantic_stack_.push (yylval);
799 yylocation_stack_.push (yyloc);
800
801 /* Shift the error token. */
802 YY_SYMBOL_PRINT ("Shifting", yystos_[yyn],
803 &yysemantic_stack_[0], &yylocation_stack_[0]);
804
805 yystate = yyn;
806 goto yynewstate;
807
808 /* Accept. */
809 yyacceptlab:
810 yyresult = 0;
811 goto yyreturn;
812
813 /* Abort. */
814 yyabortlab:
815 yyresult = 1;
816 goto yyreturn;
817
818 yyreturn:
819 if (yychar != yyempty_)
820 {
821 /* Make sure we have latest lookahead translation. See comments
822 at user semantic actions for why this is necessary. */
823 yytoken = yytranslate_ (yychar);
824 yydestruct_ ("Cleanup: discarding lookahead", yytoken, &yylval,
825 &yylloc);
826 }
827
828 /* Do not reclaim the symbols of the rule which action triggered
829 this YYABORT or YYACCEPT. */
830 yypop_ (yylen);
831 while (1 < yystate_stack_.height ())
832 {
833 yydestruct_ ("Cleanup: popping",
834 yystos_[yystate_stack_[0]],
835 &yysemantic_stack_[0],
836 &yylocation_stack_[0]);
837 yypop_ ();
838 }
839
840 return yyresult;
841 }
842 catch (...)
843 {
844 YYCDEBUG << "Exception caught" << std::endl;
845 if (yychar != yyempty_)
846 {
847 /* Make sure we have latest lookahead translation. See
848 comments at user semantic actions for why this is
849 necessary. */
850 yytoken = yytranslate_ (yychar);
851 yydestruct_ ("Cleanup: discarding lookahead", yytoken, &yylval,
852 &yylloc);
853 }
854
855 while (1 < yystate_stack_.height ())
856 {
857 yydestruct_ ("Cleanup: popping",
858 yystos_[yystate_stack_[0]],
859 &yysemantic_stack_[0],
860 &yylocation_stack_[0]);
861 yypop_ ();
862 }
863 throw;
864 }
865 }
866
867 // Generate an error message.
868 std::string
869 ]b4_parser_class_name[::yysyntax_error_ (]dnl
870 b4_error_verbose_if([int yystate, int yytoken],
871 [int, int])[)
872 {]b4_error_verbose_if([[
873 std::string yyres;
874 // Number of reported tokens (one for the "unexpected", one per
875 // "expected").
876 size_t yycount = 0;
877 // Its maximum.
878 enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 };
879 // Arguments of yyformat.
880 char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM];
881
882 /* There are many possibilities here to consider:
883 - If this state is a consistent state with a default action, then
884 the only way this function was invoked is if the default action
885 is an error action. In that case, don't check for expected
886 tokens because there are none.
887 - The only way there can be no lookahead present (in yytoken) is
888 if this state is a consistent state with a default action.
889 Thus, detecting the absence of a lookahead is sufficient to
890 determine that there is no unexpected or expected token to
891 report. In that case, just report a simple "syntax error".
892 - Don't assume there isn't a lookahead just because this state is
893 a consistent state with a default action. There might have
894 been a previous inconsistent state, consistent state with a
895 non-default action, or user semantic action that manipulated
896 yychar.
897 - Of course, the expected token list depends on states to have
898 correct lookahead information, and it depends on the parser not
899 to perform extra reductions after fetching a lookahead from the
900 scanner and before detecting a syntax error. Thus, state
901 merging (from LALR or IELR) and default reductions corrupt the
902 expected token list. However, the list is correct for
903 canonical LR with one exception: it will still contain any
904 token that will not be accepted due to an error action in a
905 later state.
906 */
907 if (yytoken != yyempty_)
908 {
909 yyarg[yycount++] = yytname_[yytoken];
910 int yyn = yypact_[yystate];
911 if (!yy_pact_value_is_default_ (yyn))
912 {
913 /* Start YYX at -YYN if negative to avoid negative indexes in
914 YYCHECK. In other words, skip the first -YYN actions for
915 this state because they are default actions. */
916 int yyxbegin = yyn < 0 ? -yyn : 0;
917 /* Stay within bounds of both yycheck and yytname. */
918 int yychecklim = yylast_ - yyn + 1;
919 int yyxend = yychecklim < yyntokens_ ? yychecklim : yyntokens_;
920 for (int yyx = yyxbegin; yyx < yyxend; ++yyx)
921 if (yycheck_[yyx + yyn] == yyx && yyx != yyterror_
922 && !yy_table_value_is_error_ (yytable_[yyx + yyn]))
923 {
924 if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM)
925 {
926 yycount = 1;
927 break;
928 }
929 else
930 yyarg[yycount++] = yytname_[yyx];
931 }
932 }
933 }
934
935 char const* yyformat = YY_NULL;
936 switch (yycount)
937 {
938 #define YYCASE_(N, S) \
939 case N: \
940 yyformat = S; \
941 break
942 YYCASE_(0, YY_("syntax error"));
943 YYCASE_(1, YY_("syntax error, unexpected %s"));
944 YYCASE_(2, YY_("syntax error, unexpected %s, expecting %s"));
945 YYCASE_(3, YY_("syntax error, unexpected %s, expecting %s or %s"));
946 YYCASE_(4, YY_("syntax error, unexpected %s, expecting %s or %s or %s"));
947 YYCASE_(5, YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s"));
948 #undef YYCASE_
949 }
950
951 // Argument number.
952 size_t yyi = 0;
953 for (char const* yyp = yyformat; *yyp; ++yyp)
954 if (yyp[0] == '%' && yyp[1] == 's' && yyi < yycount)
955 {
956 yyres += yytnamerr_ (yyarg[yyi++]);
957 ++yyp;
958 }
959 else
960 yyres += *yyp;
961 return yyres;]], [[
962 return YY_("syntax error");]])[
963 }
964
965
966 /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
967 STATE-NUM. */
968 const ]b4_int_type(b4_pact_ninf, b4_pact_ninf) b4_parser_class_name::yypact_ninf_ = b4_pact_ninf[;
969 const ]b4_int_type_for([b4_pact])[
970 ]b4_parser_class_name[::yypact_[] =
971 {
972 ]b4_pact[
973 };
974
975 /* YYDEFACT[S] -- default reduction number in state S. Performed when
976 YYTABLE doesn't specify something else to do. Zero means the
977 default is an error. */
978 const ]b4_int_type_for([b4_defact])[
979 ]b4_parser_class_name[::yydefact_[] =
980 {
981 ]b4_defact[
982 };
983
984 /* YYPGOTO[NTERM-NUM]. */
985 const ]b4_int_type_for([b4_pgoto])[
986 ]b4_parser_class_name[::yypgoto_[] =
987 {
988 ]b4_pgoto[
989 };
990
991 /* YYDEFGOTO[NTERM-NUM]. */
992 const ]b4_int_type_for([b4_defgoto])[
993 ]b4_parser_class_name[::yydefgoto_[] =
994 {
995 ]b4_defgoto[
996 };
997
998 /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
999 positive, shift that token. If negative, reduce the rule which
1000 number is the opposite. If YYTABLE_NINF_, syntax error. */
1001 const ]b4_int_type(b4_table_ninf, b4_table_ninf) b4_parser_class_name::yytable_ninf_ = b4_table_ninf[;
1002 const ]b4_int_type_for([b4_table])[
1003 ]b4_parser_class_name[::yytable_[] =
1004 {
1005 ]b4_table[
1006 };
1007
1008 /* YYCHECK. */
1009 const ]b4_int_type_for([b4_check])[
1010 ]b4_parser_class_name[::yycheck_[] =
1011 {
1012 ]b4_check[
1013 };
1014
1015 /* STOS_[STATE-NUM] -- The (internal number of the) accessing
1016 symbol of state STATE-NUM. */
1017 const ]b4_int_type_for([b4_stos])[
1018 ]b4_parser_class_name[::yystos_[] =
1019 {
1020 ]b4_stos[
1021 };
1022
1023 #if ]b4_api_PREFIX[DEBUG
1024 /* TOKEN_NUMBER_[YYLEX-NUM] -- Internal symbol number corresponding
1025 to YYLEX-NUM. */
1026 const ]b4_int_type_for([b4_toknum])[
1027 ]b4_parser_class_name[::yytoken_number_[] =
1028 {
1029 ]b4_toknum[
1030 };
1031 #endif
1032
1033 /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
1034 const ]b4_int_type_for([b4_r1])[
1035 ]b4_parser_class_name[::yyr1_[] =
1036 {
1037 ]b4_r1[
1038 };
1039
1040 /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
1041 const ]b4_int_type_for([b4_r2])[
1042 ]b4_parser_class_name[::yyr2_[] =
1043 {
1044 ]b4_r2[
1045 };
1046
1047 ]b4_token_table_if([], [[#if ]b4_api_PREFIX[DEBUG]])[
1048 /* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
1049 First, the terminals, then, starting at \a yyntokens_, nonterminals. */
1050 const char*
1051 const ]b4_parser_class_name[::yytname_[] =
1052 {
1053 ]b4_tname[
1054 };
1055
1056 ]b4_token_table_if([[#if ]b4_api_PREFIX[DEBUG]])[
1057 /* YYRHS -- A `-1'-separated list of the rules' RHS. */
1058 const ]b4_parser_class_name[::rhs_number_type
1059 ]b4_parser_class_name[::yyrhs_[] =
1060 {
1061 ]b4_rhs[
1062 };
1063
1064 /* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
1065 YYRHS. */
1066 const ]b4_int_type_for([b4_prhs])[
1067 ]b4_parser_class_name[::yyprhs_[] =
1068 {
1069 ]b4_prhs[
1070 };
1071
1072 /* YYRLINE[YYN] -- Source line where rule number YYN was defined. */
1073 const ]b4_int_type_for([b4_rline])[
1074 ]b4_parser_class_name[::yyrline_[] =
1075 {
1076 ]b4_rline[
1077 };
1078
1079 // Print the state stack on the debug stream.
1080 void
1081 ]b4_parser_class_name[::yystack_print_ ()
1082 {
1083 *yycdebug_ << "Stack now";
1084 for (state_stack_type::const_iterator i = yystate_stack_.begin ();
1085 i != yystate_stack_.end (); ++i)
1086 *yycdebug_ << ' ' << *i;
1087 *yycdebug_ << std::endl;
1088 }
1089
1090 // Report on the debug stream that the rule \a yyrule is going to be reduced.
1091 void
1092 ]b4_parser_class_name[::yy_reduce_print_ (int yyrule)
1093 {
1094 unsigned int yylno = yyrline_[yyrule];
1095 int yynrhs = yyr2_[yyrule];
1096 /* Print the symbols being reduced, and their result. */
1097 *yycdebug_ << "Reducing stack by rule " << yyrule - 1
1098 << " (line " << yylno << "):" << std::endl;
1099 /* The symbols being reduced. */
1100 for (int yyi = 0; yyi < yynrhs; yyi++)
1101 YY_SYMBOL_PRINT (" $" << yyi + 1 << " =",
1102 yyrhs_[yyprhs_[yyrule] + yyi],
1103 &]b4_rhs_value(yynrhs, yyi + 1)[,
1104 &]b4_rhs_location(yynrhs, yyi + 1)[);
1105 }
1106 #endif // ]b4_api_PREFIX[DEBUG
1107
1108 /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
1109 ]b4_parser_class_name[::token_number_type
1110 ]b4_parser_class_name[::yytranslate_ (int t)
1111 {
1112 static
1113 const token_number_type
1114 translate_table[] =
1115 {
1116 ]b4_translate[
1117 };
1118 if ((unsigned int) t <= yyuser_token_number_max_)
1119 return translate_table[t];
1120 else
1121 return yyundef_token_;
1122 }
1123
1124 const int ]b4_parser_class_name[::yyeof_ = 0;
1125 const int ]b4_parser_class_name[::yylast_ = ]b4_last[;
1126 const int ]b4_parser_class_name[::yynnts_ = ]b4_nterms_number[;
1127 const int ]b4_parser_class_name[::yyempty_ = -2;
1128 const int ]b4_parser_class_name[::yyfinal_ = ]b4_final_state_number[;
1129 const int ]b4_parser_class_name[::yyterror_ = 1;
1130 const int ]b4_parser_class_name[::yyerrcode_ = 256;
1131 const int ]b4_parser_class_name[::yyntokens_ = ]b4_tokens_number[;
1132
1133 const unsigned int ]b4_parser_class_name[::yyuser_token_number_max_ = ]b4_user_token_number_max[;
1134 const ]b4_parser_class_name[::token_number_type ]b4_parser_class_name[::yyundef_token_ = ]b4_undef_token_number[;
1135
1136 ]b4_namespace_close[
1137 ]b4_epilogue[]dnl
1138 m4_divert_pop(0)