Many 'inline' keywords were in the declarations. They rather belong in
definitions, so move them.
* data/c++.m4 (basic_symbol, by_type): Many inlines here.
* data/lalr1.cc (yytranslate_, yy_destroy_, by_state, yypush_, yypop_): Inline
these as well.
(move): Move the definition outside the struct, where it belongs.
typedef Base super_type;
/// Default constructor.
typedef Base super_type;
/// Default constructor.
- inline basic_symbol ();
- inline basic_symbol (const basic_symbol& other);
+ basic_symbol (const basic_symbol& other);
/// Constructor for valueless symbols.
/// Constructor for valueless symbols.
- inline basic_symbol (typename Base::value_type t]b4_locations_if([,
- const location_type& l])[);
+ basic_symbol (typename Base::value_type t]b4_locations_if([,
+ const location_type& l])[);
/// Constructor for symbols with semantic value.
/// Constructor for symbols with semantic value.
- inline basic_symbol (typename Base::value_type t,
- const semantic_type& v]b4_locations_if([,
- const location_type& l])[);
+ basic_symbol (typename Base::value_type t,
+ const semantic_type& v]b4_locations_if([,
+ const location_type& l])[);
~basic_symbol ();
/// Destructive move, \a s is emptied into this.
~basic_symbol ();
/// Destructive move, \a s is emptied into this.
- inline void move (basic_symbol& s);
+ void move (basic_symbol& s);
/// The semantic value.
semantic_type value;]b4_locations_if([
/// The semantic value.
semantic_type value;]b4_locations_if([
struct by_type
{
/// Default constructor.
struct by_type
{
/// Default constructor.
- inline by_type (const by_type& other);
+ by_type (const by_type& other);
- inline by_type (token_type t);
+ ///
+ by_type (token_type t);
/// Steal the type of \a that.
void move (by_type& that);
/// Steal the type of \a that.
void move (by_type& that);
int type;
/// The type (corresponding to \a type).
int type;
/// The type (corresponding to \a type).
/// -1 when this symbol is empty.
/// -1 when this symbol is empty.
- inline int type_get () const;
- inline token_type token () const;
+ token_type token () const;
/// The type used to store the symbol type.
typedef token_type value_type;
/// The type used to store the symbol type.
typedef token_type value_type;
// basic_symbol.
template <typename Base>
// basic_symbol.
template <typename Base>
]b4_parser_class_name[::basic_symbol<Base>::basic_symbol ()
: value ()
{}
template <typename Base>
]b4_parser_class_name[::basic_symbol<Base>::basic_symbol ()
: value ()
{}
template <typename Base>
]b4_parser_class_name[::basic_symbol<Base>::basic_symbol (const basic_symbol& other)
: Base (other)
, value ()]b4_locations_if([
]b4_parser_class_name[::basic_symbol<Base>::basic_symbol (const basic_symbol& other)
: Base (other)
, value ()]b4_locations_if([
]b4_parser_class_name[::basic_symbol<Base>::basic_symbol (]b4_join(
[typename Base::value_type t],
[const semantic_type& v],
]b4_parser_class_name[::basic_symbol<Base>::basic_symbol (]b4_join(
[typename Base::value_type t],
[const semantic_type& v],
]b4_symbol_variant([this->type_get ()], [value], [copy], [v])])[}
template <typename Base>
]b4_symbol_variant([this->type_get ()], [value], [copy], [v])])[}
template <typename Base>
]b4_parser_class_name[::basic_symbol<Base>::basic_symbol (]b4_join(
[typename Base::value_type t],
b4_locations_if([const location_type& l]))[)
]b4_parser_class_name[::basic_symbol<Base>::basic_symbol (]b4_join(
[typename Base::value_type t],
b4_locations_if([const location_type& l]))[)
}
template <typename Base>
}
template <typename Base>
void
]b4_parser_class_name[::basic_symbol<Base>::move (basic_symbol& s)
{
void
]b4_parser_class_name[::basic_symbol<Base>::move (basic_symbol& s)
{
]b4_parser_class_name[::by_type::by_type ()
: type (-1)
{}
]b4_parser_class_name[::by_type::by_type ()
: type (-1)
{}
]b4_parser_class_name[::by_type::by_type (const by_type& other)
: type (other.type)
{}
]b4_parser_class_name[::by_type::by_type (const by_type& other)
: type (other.type)
{}
]b4_parser_class_name[::by_type::by_type (token_type t)
: type (yytranslate_ (t))
{}
]b4_parser_class_name[::by_type::by_type (token_type t)
: type (yytranslate_ (t))
{}
int
]b4_parser_class_name[::by_type::type_get () const
{
return type;
}
]b4_token_ctor_if([[
int
]b4_parser_class_name[::by_type::type_get () const
{
return type;
}
]b4_token_ctor_if([[
]b4_parser_class_name[::token_type
]b4_parser_class_name[::by_type::token () const
{
]b4_parser_class_name[::token_type
]b4_parser_class_name[::by_type::token () const
{
# sometimes in the cc file.
m4_define([b4_yytranslate_define],
[[ // Symbol number corresponding to token number t.
# sometimes in the cc file.
m4_define([b4_yytranslate_define],
[[ // Symbol number corresponding to token number t.
]b4_parser_class_name[::token_number_type
]b4_parser_class_name[::yytranslate_ (]b4_token_ctor_if([token_type],
[int])[ t)
]b4_parser_class_name[::token_number_type
]b4_parser_class_name[::yytranslate_ (]b4_token_ctor_if([token_type],
[int])[ t)
static const ]b4_int_type(b4_table_ninf, b4_table_ninf)[ yytable_ninf_;
/// Convert a scanner token number \a t to a symbol number.
static const ]b4_int_type(b4_table_ninf, b4_table_ninf)[ yytable_ninf_;
/// Convert a scanner token number \a t to a symbol number.
- static inline token_number_type yytranslate_ (]b4_token_ctor_if([token_type], [int])[ t);
+ static token_number_type yytranslate_ (]b4_token_ctor_if([token_type], [int])[ t);
// Tables.
]b4_parser_tables_declare[]b4_error_verbose_if([
// Tables.
]b4_parser_tables_declare[]b4_error_verbose_if([
/// If null, print nothing.
/// \param s The symbol.
template <typename Base>
/// If null, print nothing.
/// \param s The symbol.
template <typename Base>
- inline void yy_destroy_ (const char* yymsg,
- basic_symbol<Base>& yysym) const;
+ void yy_destroy_ (const char* yymsg, basic_symbol<Base>& yysym) const;
private:
/// Type access provider for state based symbols.
struct by_state
{
/// Default constructor.
private:
/// Type access provider for state based symbols.
struct by_state
{
/// Default constructor.
- inline by_state (state_type s);
+ by_state (state_type s);
- inline by_state (const by_state& other);
+ by_state (const by_state& other);
- void move (by_state& that)
- {
- state = that.state;
- that.state = -1;
- }
+ void move (by_state& that);
/// The state.
state_type state;
/// The type (corresponding to \a state).
/// The state.
state_type state;
/// The type (corresponding to \a state).
- inline int type_get () const;
/// The type used to store the symbol type.
typedef state_type value_type;
/// The type used to store the symbol type.
typedef state_type value_type;
/// if null, no trace is output.
/// \param s the symbol
/// \warning the contents of \a s.value is stolen.
/// if null, no trace is output.
/// \param s the symbol
/// \warning the contents of \a s.value is stolen.
- inline void yypush_ (const char* m, stack_symbol_type& s);
+ void yypush_ (const char* m, stack_symbol_type& s);
/// Push a new look ahead token on the state on the stack.
/// \param m a debug message to display
/// Push a new look ahead token on the state on the stack.
/// \param m a debug message to display
/// \param s the state
/// \param sym the symbol (for its value and location).
/// \warning the contents of \a s.value is stolen.
/// \param s the state
/// \param sym the symbol (for its value and location).
/// \warning the contents of \a s.value is stolen.
- inline void yypush_ (const char* m, state_type s, symbol_type& sym);
+ void yypush_ (const char* m, state_type s, symbol_type& sym);
/// Pop \a n symbols the three stacks.
/// Pop \a n symbols the three stacks.
- inline void yypop_ (unsigned int n = 1);
+ void yypop_ (unsigned int n = 1);
]b4_token_ctor_if([], [b4_public_types_define])[
// by_state.
]b4_token_ctor_if([], [b4_public_types_define])[
// by_state.
]b4_parser_class_name[::by_state::by_state ()
: state (-1)
{}
]b4_parser_class_name[::by_state::by_state ()
: state (-1)
{}
]b4_parser_class_name[::by_state::by_state (const by_state& other)
: state (other.state)
{}
]b4_parser_class_name[::by_state::by_state (const by_state& other)
: state (other.state)
{}
+ inline
+ void
+ ]b4_parser_class_name[::by_state::move (by_state& that)
+ {
+ state = that.state;
+ that.state = -1;
+ }
+
+ inline
]b4_parser_class_name[::by_state::by_state (state_type s)
: state (s)
{}
]b4_parser_class_name[::by_state::by_state (state_type s)
: state (s)
{}
int
]b4_parser_class_name[::by_state::type_get () const
{
int
]b4_parser_class_name[::by_state::type_get () const
{
void
]b4_parser_class_name[::yy_destroy_ (const char* yymsg, basic_symbol<Base>& yysym) const
{
void
]b4_parser_class_name[::yy_destroy_ (const char* yymsg, basic_symbol<Base>& yysym) const
{
void
]b4_parser_class_name[::yypush_ (const char* m, state_type s, symbol_type& sym)
{
void
]b4_parser_class_name[::yypush_ (const char* m, state_type s, symbol_type& sym)
{
void
]b4_parser_class_name[::yypush_ (const char* m, stack_symbol_type& s)
{
void
]b4_parser_class_name[::yypush_ (const char* m, stack_symbol_type& s)
{
void
]b4_parser_class_name[::yypop_ (unsigned int n)
{
void
]b4_parser_class_name[::yypop_ (unsigned int n)
{