2 # C++ skeleton for Bison
3 # Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc.
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 2 of the License, or
8 # (at your option) any later version.
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.
15 # You should have received a copy of the GNU General Public License
16 # along with this program; if not, write to the Free Software
17 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
20 ## ---------------- ##
22 ## ---------------- ##
24 # Default Parser class name.
25 m4_define_default([b4_parser_class_name
], [Parser
])
29 ## ----------------- ##
30 ## Semantic Values. ##
31 ## ----------------- ##
34 # b4_lhs_value([TYPE])
35 # --------------------
36 # Expansion of $<TYPE>$.
37 m4_define([b4_lhs_value
],
38 [yyval
[]m4_ifval([$
1], [.$
1])])
41 # b4_rhs_value(RULE-LENGTH, NUM, [TYPE])
42 # --------------------------------------
43 # Expansion of $<TYPE>NUM, where the current rule has RULE-LENGTH
45 m4_define([b4_rhs_value
],
46 [semantic_stack_@
{m4_eval([$
1 - $
2])@
}m4_ifval([$
3], [.$
3])])
48 m4_define_default([b4_location_type
], [Location
])
53 m4_define([b4_lhs_location
],
57 # b4_rhs_location(RULE-LENGTH, NUM)
58 # ---------------------------------
59 # Expansion of @NUM, where the current rule has RULE-LENGTH symbols
61 m4_define([b4_rhs_location
],
62 [location_stack_@
{m4_eval([$
1 - $
2])@
}])
67 # Extra formal arguments of the constructor.
68 # Change the parameter names from "foo" into "foo_yyarg", so that
69 # there is no collision bw the user chosen attribute name, and the
70 # argument name in the constructor.
71 m4_define([b4_parse_param_decl
],
72 [m4_ifset([b4_parse_param
],
73 [m4_map_sep([b4_parse_param_decl_1
], [, ], [b4_parse_param
])])])
75 m4_define([b4_parse_param_decl_1
],
82 # Extra initialisations of the constructor.
83 m4_define([b4_parse_param_cons
],
84 [m4_ifset([b4_parse_param
],
86 b4_cc_constructor_calls(b4_parse_param
)])])
87 m4_define([b4_cc_constructor_calls
],
88 [m4_map_sep([b4_cc_constructor_call
], [,
90 m4_define([b4_cc_constructor_call
],
95 # Extra instance variables.
96 m4_define([b4_parse_param_vars
],
97 [m4_ifset([b4_parse_param
],
100 b4_cc_var_decls(b4_parse_param
)])])
101 m4_define([b4_cc_var_decls
],
102 [m4_map_sep([b4_cc_var_decl
], [
104 m4_define([b4_cc_var_decl
],
109 # We do want M4 expansion after # for CPP macros.
112 m4_if(b4_defines_flag
, 0, [],
113 [@output @output_header_name@
114 b4_copyright([C
++ Skeleton parser
for LALR(1) parsing with Bison
],
116 /* FIXME: This is wrong, we want computed header guards.
117 I don't know why the macros are missing now. :( */
118 #ifndef PARSER_HEADER_H
119 # define PARSER_HEADER_H
122 #include "location.hh"
127 /* Using locations. */
128 #define YYLSP_NEEDED ]b4_locations_flag[
130 ]b4_token_defines(b4_tokens
)[
132 /* Copy the first part of user declarations. */
135 ]/* Line __line__ of lalr1.cc. */
136 b4_syncline([@oline@
], [@ofile@
])[
138 /* Enabling traces. */
140 # define YYDEBUG ]b4_debug[
143 /* Enabling verbose error message. */
144 #ifndef YYERROR_VERBOSE
145 # define YYERROR_VERBOSE ]b4_error_verbose[
148 #if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
149 ]m4_ifdef([b4_stype
],
150 [b4_syncline([b4_stype_line
], [b4_filename
])
151 union YYSTYPE b4_stype
;
152 /* Line __line__ of lalr1.cc. */
153 b4_syncline([@oline@
], [@ofile@
])],
154 [typedef int YYSTYPE
;])[
155 # define yystype YYSTYPE /* obsolescent; will be withdrawn */
156 # define YYSTYPE_IS_DECLARED 1
157 # define YYSTYPE_IS_TRIVIAL 1
160 /* Copy the second part of user declarations. */
163 ]/* Line __line__ of lalr1.cc. */
164 b4_syncline([@oline@
], [@ofile@
])[
165 /* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N].
166 If N is 0, then set CURRENT to the empty location which ends
167 the previous symbol: RHS[0] (always defined). */
169 #ifndef YYLLOC_DEFAULT
170 # define YYLLOC_DEFAULT(Current, Rhs, N) \
174 (Current).begin = (Rhs)[1].begin; \
175 (Current).end = (Rhs)[N].end; \
179 (Current).begin = (Current).end = (Rhs)[0].end; \
186 class ]b4_parser_class_name
[;
188 template <typename P
>
194 struct Traits
<]b4_parser_class_name
[>
196 typedef ]b4_int_type_for([b4_translate
])[ TokenNumberType
;
197 typedef ]b4_int_type_for([b4_rhs
])[ RhsNumberType
;
198 typedef int StateType
;
199 typedef YYSTYPE SemanticType
;
200 typedef ]b4_location_type
[ LocationType
;
206 class ]b4_parser_class_name
[
210 typedef Traits
<]b4_parser_class_name
[>::TokenNumberType TokenNumberType
;
211 typedef Traits
<]b4_parser_class_name
[>::RhsNumberType RhsNumberType
;
212 typedef Traits
<]b4_parser_class_name
[>::StateType StateType
;
213 typedef Traits
<]b4_parser_class_name
[>::SemanticType SemanticType
;
214 typedef Traits
<]b4_parser_class_name
[>::LocationType LocationType
;
216 typedef Stack
<StateType
> StateStack
;
217 typedef Stack
<SemanticType
> SemanticStack
;
218 typedef Stack
<LocationType
> LocationStack
;
220 ]b4_parser_class_name
[ (]b4_parse_param_decl
[) :
222 yycdebug_ (&std::cerr
)]b4_parse_param_cons
[
226 virtual ~]b4_parser_class_name
[ ()
230 virtual int parse ();
232 /// Return the current debugging stream.
233 std::ostream
& debug_stream () const;
234 /// Set the current debugging stream.
235 void set_debug_stream (std::ostream
&);
237 /// Type for debugging levels.
238 typedef int debug_level_type
;
239 /// The current debugging level.
240 debug_level_type
debug_level () const;
241 /// Set the current debugging level.
242 void set_debug_level (debug_level_type l
);
246 virtual void yylex_ ();
247 virtual void error_ ();
248 virtual void report_syntax_error_ ();
250 virtual void symprint_ (int yytype
,
251 const SemanticType
* yyvaluep
,
252 const LocationType
* yylocationp
);
253 #endif /* ! YYDEBUG */
257 StateStack state_stack_
;
258 SemanticStack semantic_stack_
;
259 LocationStack location_stack_
;
262 static const ]b4_int_type_for([b4_pact
])[ pact_
[];
263 static const ]b4_int_type(b4_pact_ninf
, b4_pact_ninf
)[ pact_ninf_
;
264 static const ]b4_int_type_for([b4_defact
])[ defact_
[];
265 static const ]b4_int_type_for([b4_pgoto
])[ pgoto_
[];
266 static const ]b4_int_type_for([b4_defgoto
])[ defgoto_
[];
267 static const ]b4_int_type_for([b4_table
])[ table_
[];
268 static const ]b4_int_type(b4_table_ninf
, b4_table_ninf
)[ table_ninf_
;
269 static const ]b4_int_type_for([b4_check
])[ check_
[];
270 static const ]b4_int_type_for([b4_stos
])[ stos_
[];
271 static const ]b4_int_type_for([b4_r1
])[ r1_
[];
272 static const ]b4_int_type_for([b4_r2
])[ r2_
[];
274 #if YYDEBUG || YYERROR_VERBOSE
275 static const char* const name_
[];
278 /* More tables, for debugging. */
280 static const RhsNumberType rhs_
[];
281 static const ]b4_int_type_for([b4_prhs
])[ prhs_
[];
282 static const ]b4_int_type_for([b4_rline
])[ rline_
[];
283 static const ]b4_int_type_for([b4_toknum
])[ token_number_
[];
284 virtual void reduce_print_ (int yyrule
);
285 virtual void stack_print_ ();
288 /* Even more tables. */
289 inline TokenNumberType
translate_ (int token
);
290 inline void destruct_ (const char* yymsg
,
292 SemanticType
* yyvaluep
, LocationType
* yylocationp
);
294 /// Pop \a n symbols the three stacks.
295 inline void pop (unsigned int n
= 1);
298 static const int eof_
;
299 /* LAST_ -- Last index in TABLE_. */
300 static const int last_
;
301 static const int nnts_
;
302 static const int empty_
;
303 static const int final_
;
304 static const int terror_
;
305 static const int errcode_
;
306 static const int ntokens_
;
307 static const unsigned int user_token_number_max_
;
308 static const TokenNumberType undef_token_
;
315 /* Error handling. */
321 std::ostream
* yycdebug_
;
323 /* Look-ahead and look-ahead in internal form. */
330 /// Semantic value of the look-ahead.
332 /// Location of the look-ahead.
333 LocationType location
;
334 /// The locations where the error started and ended.
335 Location error_range_
[2];
341 ]b4_parse_param_vars
[
345 #endif /* ! defined PARSER_HEADER_H */]
347 @output @output_parser_name@
348 b4_copyright([C
++ Skeleton parser
for LALR(1) parsing with Bison
],
351 m4_if(b4_defines_flag
, 0, [], [#include @output_header_name@])[
353 /* A pseudo ostream that takes yydebug_ into account. */
355 for (bool yydebugcond_ = yydebug_; yydebugcond_; yydebugcond_ = false) \
358 /* Enable debugging if requested. */
361 # define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
365 *yycdebug_ << (Title) << ' '; \
366 symprint_ ((Type), (Value), (Location)); \
367 *yycdebug_ << std::endl; \
371 # define YY_REDUCE_PRINT(Rule) \
374 reduce_print_ (Rule); \
377 # define YY_STACK_PRINT() \
385 # define YY_SYMBOL_PRINT(Title, Type, Value, Location)
386 # define YY_REDUCE_PRINT(Rule)
387 # define YY_STACK_PRINT()
389 #endif /* !YYDEBUG */
391 #define YYACCEPT goto yyacceptlab
392 #define YYABORT goto yyabortlab
393 #define YYERROR goto yyerrorlab
396 /*--------------------------------.
397 | Print this symbol on YYOUTPUT. |
398 `--------------------------------*/
401 yy::]b4_parser_class_name
[::symprint_ (int yytype
,
402 const SemanticType
* yyvaluep
, const LocationType
* yylocationp
)
404 /* Pacify ``unused variable'' warnings. */
407 /* Backward compatibility, but should be removed eventually. */
408 std::ostream
& cdebug_
= *yycdebug_
;
411 *yycdebug_
<< (yytype
< ntokens_
? "token" : "nterm")
412 << ' ' << name_
[yytype
] << " ("
413 << *yylocationp
<< ": ";
416 ]m4_map([b4_symbol_actions
], m4_defn([b4_symbol_printers
]))dnl
422 #endif /* ! YYDEBUG */
425 yy::]b4_parser_class_name
[::destruct_ (const char* yymsg
,
426 int yytype
, SemanticType
* yyvaluep
, LocationType
* yylocationp
)
428 /* Pacify ``unused variable'' warnings. */
432 YY_SYMBOL_PRINT (yymsg
, yytype
, yyvaluep
, yylocationp
);
436 ]m4_map([b4_symbol_actions
], m4_defn([b4_symbol_destructors
]))[
443 yy::]b4_parser_class_name
[::pop (unsigned int n
)
445 state_stack_
.pop (n
);
446 semantic_stack_
.pop (n
);
447 location_stack_
.pop (n
);
451 yy::]b4_parser_class_name
[::debug_stream () const
457 yy::]b4_parser_class_name
[::set_debug_stream (std::ostream
& o
)
463 yy::]b4_parser_class_name
[::debug_level_type
464 yy::]b4_parser_class_name
[::debug_level () const
470 yy::]b4_parser_class_name
[::set_debug_level (debug_level_type l
)
477 yy::]b4_parser_class_name
[::parse ()
479 YYCDEBUG
<< "Starting parse" << std::endl
;
488 ]m4_ifdef([b4_initial_action
], [
489 m4_pushdef([b4_at_dollar
], [location
])dnl
490 m4_pushdef([b4_dollar_dollar
], [value
])dnl
491 /* User initialization code. */
493 m4_popdef([b4_dollar_dollar
])dnl
494 m4_popdef([b4_at_dollar
])dnl
495 /* Line __line__ of yacc.c. */
496 b4_syncline([@oline@
], [@ofile@
])])dnl
498 [ /* Initialize the stacks. The initial state will be pushed in
499 yynewstate, since the latter expects the semantical and the
500 location values to have been already stored, initialize these
501 stacks with a primary value. */
502 state_stack_
= StateStack (0);
503 semantic_stack_
= SemanticStack (0);
504 location_stack_
= LocationStack (0);
505 semantic_stack_
.push (value
);
506 location_stack_
.push (location
);
510 state_stack_
.push (state_
);
511 YYCDEBUG
<< "Entering state " << state_
<< std::endl
;
517 /* Try to take a decision without look-ahead. */
519 if (n_
== pact_ninf_
)
522 /* Read a look-ahead token. */
523 if (looka_
== empty_
)
526 /* Convert token to internal form. */
529 looka_
= ilooka_
= eof_
;
530 YYCDEBUG
<< "Now at end of input." << std::endl
;
534 ilooka_
= translate_ (looka_
);
535 YY_SYMBOL_PRINT ("Next token is", ilooka_
, &value
, &location
);
538 /* If the proper action on seeing token ILOOKA_ is to reduce or to
539 detect an error, take that action. */
541 if (n_
< 0 || last_
< n_
|| check_
[n_
] != ilooka_
)
544 /* Reduce or error. */
548 if (n_
== table_ninf_
)
563 /* Shift the look-ahead token. */
564 YY_SYMBOL_PRINT ("Shifting", ilooka_
, &value
, &location
);
566 /* Discard the token being shifted unless it is eof. */
570 semantic_stack_
.push (value
);
571 location_stack_
.push (location
);
573 /* Count tokens shifted since error; after three, turn off error
581 /*-----------------------------------------------------------.
582 | yydefault -- do the default action for the current state. |
583 `-----------------------------------------------------------*/
585 n_
= defact_
[state_
];
590 /*-----------------------------.
591 | yyreduce -- Do a reduction. |
592 `-----------------------------*/
595 /* If LEN_ is nonzero, implement the default value of the action:
596 `$$ = $1'. Otherwise, use the top of the stack.
598 Otherwise, the following line sets YYVAL to garbage.
599 This behavior is undocumented and Bison
600 users should not rely upon it. */
602 yyval
= semantic_stack_
[len_
- 1];
604 yyval
= semantic_stack_
[0];
607 Slice
<LocationType
, LocationStack
> slice (location_stack_
, len_
);
608 YYLLOC_DEFAULT (yyloc
, slice
, len_
);
610 YY_REDUCE_PRINT (n_
);
616 ]/* Line __line__ of lalr1.cc. */
617 b4_syncline([@oline@
], [@ofile@
])[
623 semantic_stack_
.push (yyval
);
624 location_stack_
.push (yyloc
);
626 /* Shift the result of the reduction. */
628 state_
= pgoto_
[n_
- ntokens_
] + state_stack_
[0];
629 if (0 <= state_
&& state_
<= last_
&& check_
[state_
] == state_stack_
[0])
630 state_
= table_
[state_
];
632 state_
= defgoto_
[n_
- ntokens_
];
635 /*------------------------------------.
636 | yyerrlab -- here on detecting error |
637 `------------------------------------*/
639 /* If not already recovering from an error, report this error. */
640 report_syntax_error_ ();
642 error_range_
[0] = location
;
645 /* If just tried and failed to reuse look-ahead token after an
646 error, discard it. */
648 /* Return failure if at end of input. */
651 /* If at end of input, pop the error token,
652 then the rest of the stack, then return failure. */
656 error_range_
[0] = location_stack_
[0];
658 if (state_stack_
.height () == 1)
660 destruct_ ("Error: popping",
661 stos_
[state_stack_
[0]],
663 &location_stack_
[0]);
668 destruct_ ("Error: discarding", ilooka_
, &value
, &location
);
673 /* Else will try to reuse look-ahead token after shifting the error
678 /*---------------------------------------------------.
679 | yyerrorlab -- error raised explicitly by YYERROR. |
680 `---------------------------------------------------*/
684 /* Pacify GCC when the user code never invokes YYERROR and the label
685 yyerrorlab therefore never appears in user code. */
690 error_range_
[0] = location_stack_
[len_
- 1];
692 state_
= state_stack_
[0];
695 /*-------------------------------------------------------------.
696 | yyerrlab1 -- common code for both syntax error and YYERROR. |
697 `-------------------------------------------------------------*/
699 errstatus_
= 3; /* Each real token shifted decrements this. */
704 if (n_
!= pact_ninf_
)
707 if (0 <= n_
&& n_
<= last_
&& check_
[n_
] == terror_
)
715 /* Pop the current state because it cannot handle the error token. */
716 if (state_stack_
.height () == 1)
719 error_range_
[0] = location_stack_
[0];
720 destruct_ ("Error: popping",
721 stos_
[state_
], &semantic_stack_
[0], &location_stack_
[0]);
723 state_
= state_stack_
[0];
730 error_range_
[1] = location
;
731 // Using LOCATION is tempting, but would change the location of
732 // the look-ahead. YYLOC is available though.
733 YYLLOC_DEFAULT (yyloc
, error_range_
- 1, 2);
734 semantic_stack_
.push (value
);
735 location_stack_
.push (yyloc
);
737 /* Shift the error token. */
738 YY_SYMBOL_PRINT ("Shifting", stos_
[n_
],
739 &semantic_stack_
[0], &location_stack_
[0]);
750 /* Free the lookahead. */
751 destruct_ ("Error: discarding lookahead", ilooka_
, &value
, &location
);
757 yy::]b4_parser_class_name
[::yylex_ ()
759 YYCDEBUG
<< "Reading a token: ";
761 looka_
= ]m4_default(b4_prefix
, [yy
])[lex (&value
, &location
);
763 looka_
= ]m4_default(b4_prefix
, [yy
])[lex (&value
);
767 /** Generate an error message, and invoke yyerror. */
769 yy::]b4_parser_class_name
[::report_syntax_error_ ()
771 /* If not already recovering from an error, report this error. */
778 if (pact_ninf_
< n_
&& n_
< last_
)
780 message
= "syntax error, unexpected ";
781 message
+= name_
[ilooka_
];
784 for (int x
= (n_
< 0 ? -n_
: 0); x
< ntokens_
+ nnts_
; ++x
)
785 if (check_
[x
+ n_
] == x
&& x
!= terror_
)
790 for (int x
= (n_
< 0 ? -n_
: 0); x
< ntokens_
+ nnts_
; ++x
)
791 if (check_
[x
+ n_
] == x
&& x
!= terror_
)
793 message
+= (!count
++) ? ", expecting " : " or ";
801 message
= "syntax error";
807 /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing
809 const ]b4_int_type(b4_pact_ninf
, b4_pact_ninf
) yy::b4_parser_class_name::pact_ninf_
= b4_pact_ninf
[;
810 const ]b4_int_type_for([b4_pact
])[
811 yy::]b4_parser_class_name
[::pact_
[] =
816 /* YYDEFACT[S] -- default rule to reduce with in state S when YYTABLE
817 doesn't specify something else to do. Zero means the default is an
819 const ]b4_int_type_for([b4_defact
])[
820 yy::]b4_parser_class_name
[::defact_
[] =
825 /* YYPGOTO[NTERM-NUM]. */
826 const ]b4_int_type_for([b4_pgoto
])[
827 yy::]b4_parser_class_name
[::pgoto_
[] =
832 /* YYDEFGOTO[NTERM-NUM]. */
833 const ]b4_int_type_for([b4_defgoto
])[
834 yy::]b4_parser_class_name
[::defgoto_
[] =
839 /* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If
840 positive, shift that token. If negative, reduce the rule which
841 number is the opposite. If zero, do what YYDEFACT says. */
842 const ]b4_int_type(b4_table_ninf
, b4_table_ninf
) yy::b4_parser_class_name::table_ninf_
= b4_table_ninf
[;
843 const ]b4_int_type_for([b4_table
])[
844 yy::]b4_parser_class_name
[::table_
[] =
850 const ]b4_int_type_for([b4_check
])[
851 yy::]b4_parser_class_name
[::check_
[] =
856 /* STOS_[STATE-NUM] -- The (internal number of the) accessing
857 symbol of state STATE-NUM. */
858 const ]b4_int_type_for([b4_stos
])[
859 yy::]b4_parser_class_name
[::stos_
[] =
865 /* TOKEN_NUMBER_[YYLEX-NUM] -- Internal token number corresponding
867 const ]b4_int_type_for([b4_toknum
])[
868 yy::]b4_parser_class_name
[::token_number_
[] =
874 /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
875 const ]b4_int_type_for([b4_r1
])[
876 yy::]b4_parser_class_name
[::r1_
[] =
881 /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */
882 const ]b4_int_type_for([b4_r2
])[
883 yy::]b4_parser_class_name
[::r2_
[] =
888 #if YYDEBUG || YYERROR_VERBOSE
889 /* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM.
890 First, the terminals, then, starting at NTOKENS_, nonterminals. */
892 const yy::]b4_parser_class_name
[::name_
[] =
899 /* YYRHS -- A `-1'-separated list of the rules' RHS. */
900 const yy::]b4_parser_class_name
[::RhsNumberType
901 yy::]b4_parser_class_name
[::rhs_
[] =
906 /* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in
908 const ]b4_int_type_for([b4_prhs
])[
909 yy::]b4_parser_class_name
[::prhs_
[] =
914 /* YYRLINE[YYN] -- source line where rule number YYN was defined. */
915 const ]b4_int_type_for([b4_rline
])[
916 yy::]b4_parser_class_name
[::rline_
[] =
921 /** Print the state stack from its BOTTOM up to its TOP (included). */
924 yy::]b4_parser_class_name
[::stack_print_ ()
926 *yycdebug_
<< "Stack now";
927 for (StateStack::const_iterator i
= state_stack_
.begin ();
928 i
!= state_stack_
.end (); ++i
)
929 *yycdebug_
<< ' ' << *i
;
930 *yycdebug_
<< std::endl
;
933 /** Report that the YYRULE is going to be reduced. */
936 yy::]b4_parser_class_name
[::reduce_print_ (int yyrule
)
938 unsigned int yylno
= rline_
[yyrule
];
939 /* Print the symbols being reduced, and their result. */
940 *yycdebug_
<< "Reducing stack by rule " << n_
- 1
941 << " (line " << yylno
<< "), ";
942 for (]b4_int_type_for([b4_prhs
])[ i
= prhs_
[n_
];
944 *yycdebug_
<< name_
[rhs_
[i
]] << ' ';
945 *yycdebug_
<< "-> " << name_
[r1_
[n_
]] << std::endl
;
949 /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */
950 yy::]b4_parser_class_name
[::TokenNumberType
951 yy::]b4_parser_class_name
[::translate_ (int token
)
954 const TokenNumberType
959 if ((unsigned int) token
<= user_token_number_max_
)
960 return translate_table
[token
];
965 const int yy::]b4_parser_class_name
[::eof_
= 0;
966 const int yy::]b4_parser_class_name
[::last_
= ]b4_last
[;
967 const int yy::]b4_parser_class_name
[::nnts_
= ]b4_nterms_number
[;
968 const int yy::]b4_parser_class_name
[::empty_
= -2;
969 const int yy::]b4_parser_class_name
[::final_
= ]b4_final_state_number
[;
970 const int yy::]b4_parser_class_name
[::terror_
= 1;
971 const int yy::]b4_parser_class_name
[::errcode_
= 256;
972 const int yy::]b4_parser_class_name
[::ntokens_
= ]b4_tokens_number
[;
974 const unsigned int yy::]b4_parser_class_name
[::user_token_number_max_
= ]b4_user_token_number_max
[;
975 const yy::]b4_parser_class_name
[::TokenNumberType
yy::]b4_parser_class_name
[::undef_token_
= ]b4_undef_token_number
[;
980 b4_copyright([Stack handling
for Bison C
++ parsers
], [2002, 2003, 2004])[
982 #ifndef BISON_STACK_HH
983 # define BISON_STACK_HH
989 template <class T
, class S
= std::deque
<T
> >
994 // Hide our reversed order.
995 typedef typename
S::reverse_iterator iterator
;
996 typedef typename
S::const_reverse_iterator const_iterator
;
1002 Stack (unsigned int n
) : seq_ (n
)
1008 operator [] (unsigned int i
)
1015 operator [] (unsigned int i
) const
1024 seq_
.push_front (t
);
1029 pop (unsigned int n
= 1)
1039 return seq_
.size ();
1042 inline const_iterator
begin () const { return seq_
.rbegin (); }
1043 inline const_iterator
end () const { return seq_
.rend (); }
1050 template <class T
, class S
= Stack
<T
> >
1055 Slice (const S
& stack
,
1056 unsigned int range
) : stack_ (stack
),
1063 operator [] (unsigned int i
) const
1065 return stack_
[range_
- i
];
1071 unsigned int range_
;
1075 #endif // not BISON_STACK_HH]
1078 b4_copyright([Position
class for Bison C
++ parsers
], [2002, 2003, 2004])[
1081 ** \file position.hh
1082 ** Define the Location class.
1085 #ifndef BISON_POSITION_HH
1086 # define BISON_POSITION_HH
1088 # include <iostream>
1093 /** \brief Abstract a Position. */
1097 /** \brief Initial column number. */
1098 static const unsigned int initial_column
= 0;
1099 /** \brief Initial line number. */
1100 static const unsigned int initial_line
= 1;
1102 /** \name Ctor & dtor.
1105 /** \brief Construct a Position. */
1108 line (initial_line
),
1109 column (initial_column
)
1115 /** \name Line and Column related manipulators
1118 /** \brief (line related) Advance to the COUNT next lines. */
1119 inline void lines (int count
= 1)
1121 column
= initial_column
;
1125 /** \brief (column related) Advance to the COUNT next columns. */
1126 inline void columns (int count
= 1)
1128 int leftmost
= initial_column
;
1129 int current
= column
;
1130 if (leftmost
<= current
+ count
)
1133 column
= initial_column
;
1138 /** \brief File name to which this position refers. */
1139 std::string filename
;
1140 /** \brief Current line number. */
1142 /** \brief Current column number. */
1143 unsigned int column
;
1146 /** \brief Add and assign a Position. */
1147 inline const Position
&
1148 operator+= (Position
& res
, const int width
)
1150 res
.columns (width
);
1154 /** \brief Add two Position objects. */
1155 inline const Position
1156 operator+ (const Position
& begin
, const int width
)
1158 Position res
= begin
;
1159 return res
+= width
;
1162 /** \brief Add and assign a Position. */
1163 inline const Position
&
1164 operator-= (Position
& res
, const int width
)
1166 return res
+= -width
;
1169 /** \brief Add two Position objects. */
1170 inline const Position
1171 operator- (const Position
& begin
, const int width
)
1173 return begin
+ -width
;
1176 /** \brief Intercept output stream redirection.
1177 ** \param ostr the destination output stream
1178 ** \param pos a reference to the Position to redirect
1180 inline std::ostream
&
1181 operator<< (std::ostream
& ostr
, const Position
& pos
)
1183 if (!pos
.filename
.empty ())
1184 ostr
<< pos
.filename
<< ':';
1185 return ostr
<< pos
.line
<< '.' << pos
.column
;
1189 #endif // not BISON_POSITION_HH]
1191 b4_copyright([Location
class for Bison C
++ parsers
], [2002, 2003, 2004])[
1194 ** \file location.hh
1195 ** Define the Location class.
1198 #ifndef BISON_LOCATION_HH
1199 # define BISON_LOCATION_HH
1201 # include <iostream>
1203 # include "position.hh"
1208 /** \brief Abstract a Location. */
1211 /** \name Ctor & dtor.
1214 /** \brief Construct a Location. */
1223 /** \name Line and Column related manipulators
1226 /** \brief Reset initial location to final location. */
1227 inline void step (void)
1232 /** \brief Extend the current location to the COUNT next columns. */
1233 inline void columns (unsigned int count
= 1)
1238 /** \brief Extend the current location to the COUNT next lines. */
1239 inline void lines (unsigned int count
= 1)
1247 /** \brief Beginning of the located region. */
1249 /** \brief End of the located region. */
1253 /** \brief Join two Location objects to create a Location. */
1254 inline const Location
operator+ (const Location
& begin
, const Location
& end
)
1256 Location res
= begin
;
1261 /** \brief Add two Location objects */
1262 inline const Location
operator+ (const Location
& begin
, unsigned int width
)
1264 Location res
= begin
;
1265 res
.columns (width
);
1269 /** \brief Add and assign a Location */
1270 inline Location
& operator+= (Location
& res
, unsigned int width
)
1272 res
.columns (width
);
1276 /** \brief Intercept output stream redirection.
1277 ** \param ostr the destination output stream
1278 ** \param loc a reference to the Location to redirect
1280 ** Avoid duplicate information.
1282 inline std::ostream
& operator<< (std::ostream
& ostr
, const Location
& loc
)
1284 Position last
= loc
.end
- 1;
1286 if (loc
.begin
.filename
!= last
.filename
)
1287 ostr
<< '-' << last
;
1288 else if (loc
.begin
.line
!= last
.line
)
1289 ostr
<< '-' << last
.line
<< '.' << last
.column
;
1290 else if (loc
.begin
.column
!= last
.column
)
1291 ostr
<< '-' << last
.column
;
1297 #endif // not BISON_LOCATION_HH]