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