# define YYERROR_VERBOSE ]b4_error_verbose[
#endif
-#ifdef YYSTYPE
-typedef YYSTYPE yystype;
-#else
+#if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED)
]m4_ifdef([b4_stype],
[b4_syncline([b4_stype_line], [b4_filename])
-typedef union b4_stype yystype;
+union YYSTYPE b4_stype;
/* Line __line__ of lalr1.cc. */
b4_syncline([@oline@], [@ofile@])],
-[typedef int yystype;])[
-# define YYSTYPE yystype
+[typedef int YYSTYPE;])[
+# define yystype YYSTYPE /* obsolescent; will be withdrawn */
+# define YYSTYPE_IS_DECLARED 1
+# define YYSTYPE_IS_TRIVIAL 1
#endif
/* Copy the second part of user declarations. */
]/* Line __line__ of lalr1.cc. */
b4_syncline([@oline@], [@ofile@])[
-/* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N]. */
+/* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N].
+ If N is 0, then set CURRENT to the empty location which ends
+ the previous symbol: RHS[0] (always defined). */
#ifndef YYLLOC_DEFAULT
-# define YYLLOC_DEFAULT(Current, Rhs, N) \
-do { \
- ((Current).begin = (Rhs)[1].begin); \
- ((Current).end = (Rhs)[N].end); \
+# define YYLLOC_DEFAULT(Current, Rhs, N) \
+do { \
+ if (N) \
+ { \
+ (Current).begin = (Rhs)[1].begin; \
+ (Current).end = (Rhs)[N].end; \
+ } \
+ else \
+ { \
+ (Current).begin = (Current).end = (Rhs)[0].end; \
+ } \
} while (0)
#endif
typedef ]b4_int_type_for([b4_translate])[ TokenNumberType;
typedef ]b4_int_type_for([b4_rhs])[ RhsNumberType;
typedef int StateType;
- typedef yystype SemanticType;
+ typedef YYSTYPE SemanticType;
typedef ]b4_location_type[ LocationType;
};
}
]b4_parser_class_name[ (bool debug][]b4_param[]b4_parse_param_decl[) :
]b4_constructor[][debug_ (debug),
- cdebug_ (std::cerr)]b4_parse_param_cons[
+ yycdebug_ (&std::cerr)]b4_parse_param_cons[
{
}
]b4_parser_class_name[ (bool debug,
LocationType][]b4_param[]b4_parse_param_decl[) :
]b4_constructor[][debug_ (debug),
- cdebug_ (std::cerr)]b4_parse_param_cons[
+ yycdebug_ (&std::cerr)]b4_parse_param_cons[
{
- cdebug_ << __FILE__ << ':' << __LINE__
- << ": this constructor is provided by backward compatibility"
- << ", but will be removed in the near future."
- << std::endl;
+ *yycdebug_ << __FILE__ << ':' << __LINE__
+ << ": this constructor is provided by backward compatibility"
+ << ", but will be removed in the near future."
+ << std::endl;
}
virtual ~]b4_parser_class_name[ ()
virtual int parse ();
+ /// Return the current debugging stream.
+ std::ostream& debug_stream () const;
+ /// Set the current debugging stream.
+ void set_debug_stream (std::ostream &);
+
private:
virtual void lex_ ();
virtual void error_ ();
- virtual void print_ ();
virtual void report_syntax_error_ ();
#if YYDEBUG
virtual void symprint_ (int yytype,
/* Debugging. */
int debug_;
- std::ostream& cdebug_;
+ std::ostream* yycdebug_;
/* Look-ahead and look-ahead in internal form. */
int looka_;
m4_if(b4_defines_flag, 0, [], [#include @output_header_name@])[
+/* A pseudo ostream that takes debug_ into account. */
+# define YYCDEBUG \
+ for (bool yydebugcond_ = debug_; yydebugcond_; yydebugcond_ = false) \
+ (*yycdebug_)
+
/* Enable debugging if requested. */
#if YYDEBUG
-# define YYCDEBUG \
- if (debug_) \
- cdebug_
-
# define YY_SYMBOL_PRINT(Title, Type, Value, Location) \
do { \
if (debug_) \
{ \
- cdebug_ << (Title) << ' '; \
+ *yycdebug_ << (Title) << ' '; \
symprint_ ((Type), (Value), (Location)); \
- cdebug_ << std::endl; \
+ *yycdebug_ << std::endl; \
} \
} while (0)
#else /* !YYDEBUG */
-# define YYCDEBUG if (0) cdebug_
# define YY_SYMBOL_PRINT(Title, Type, Value, Location)
# define YY_REDUCE_PRINT(Rule)
# define YY_STACK_PRINT()
/* Pacify ``unused variable'' warnings. */
(void) yyvaluep;
(void) yylocationp;
+ /* Backward compatibility, but should be removed eventually. */
+ std::ostream& cdebug_ = *yycdebug_;
+ (void) cdebug_;
- cdebug_ << (yytype < ntokens_ ? "token" : "nterm")
- << ' ' << name_[yytype] << " ("
- << *yylocationp << ": ";
+ *yycdebug_ << (yytype < ntokens_ ? "token" : "nterm")
+ << ' ' << name_[yytype] << " ("
+ << *yylocationp << ": ";
switch (yytype)
{
]m4_map([b4_symbol_actions], m4_defn([b4_symbol_printers]))dnl
[ default:
break;
}
- cdebug_ << ')';
+ *yycdebug_ << ')';
}
#endif /* ! YYDEBUG */
location_stack_.pop (n);
}
+std::ostream&
+yy::]b4_parser_class_name[::debug_stream () const
+{
+ return *yycdebug_;
+}
+
+void
+yy::]b4_parser_class_name[::set_debug_stream (std::ostream& o)
+{
+ yycdebug_ = &o;
+}
+
+
int
yy::]b4_parser_class_name[::parse ()
{
This behavior is undocumented and Bison
users should not rely upon it. */
if (len_)
- {
- yyval = semantic_stack_[len_ - 1];
- yyloc = location_stack_[len_ - 1];
- }
+ yyval = semantic_stack_[len_ - 1];
else
- {
- yyval = semantic_stack_[0];
- yyloc = location_stack_[0];
- }
+ yyval = semantic_stack_[0];
- if (len_)
- {
- Slice<LocationType, LocationStack> slice (location_stack_, len_);
- YYLLOC_DEFAULT (yyloc, slice, len_);
- }
+ {
+ Slice<LocationType, LocationStack> slice (location_stack_, len_);
+ YYLLOC_DEFAULT (yyloc, slice, len_);
+ }
YY_REDUCE_PRINT (n_);
switch (n_)
{
void
yy::]b4_parser_class_name[::stack_print_ ()
{
- cdebug_ << "Stack now";
+ *yycdebug_ << "Stack now";
for (StateStack::const_iterator i = state_stack_.begin ();
i != state_stack_.end (); ++i)
- cdebug_ << ' ' << *i;
- cdebug_ << std::endl;
+ *yycdebug_ << ' ' << *i;
+ *yycdebug_ << std::endl;
}
/** Report that the YYRULE is going to be reduced. */
{
unsigned int yylno = rline_[yyrule];
/* Print the symbols being reduced, and their result. */
- cdebug_ << "Reducing stack by rule " << n_ - 1
- << " (line " << yylno << "), ";
+ *yycdebug_ << "Reducing stack by rule " << n_ - 1
+ << " (line " << yylno << "), ";
for (]b4_int_type_for([b4_prhs])[ i = prhs_[n_];
0 <= rhs_[i]; ++i)
- cdebug_ << name_[rhs_[i]] << ' ';
- cdebug_ << "-> " << name_[r1_[n_]] << std::endl;
+ *yycdebug_ << name_[rhs_[i]] << ' ';
+ *yycdebug_ << "-> " << name_[r1_[n_]] << std::endl;
}
#endif // YYDEBUG