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