Kea  1.9.9-git
isc::eval::EvalParser::semantic_type Class Reference

A buffer to store and retrieve objects. More...

#include <parser.h>

Public Types

typedef semantic_type self_type
 Type of *this. More...
 

Public Member Functions

 semantic_type () YY_NOEXCEPT
 Empty construction. More...
 
template<typename T >
 semantic_type (YY_RVREF(T) t)
 Construct and fill. More...
 
 ~semantic_type () YY_NOEXCEPT
 Destruction, allowed only if empty. More...
 
template<typename T >
T & as () YY_NOEXCEPT
 Accessor to a built T. More...
 
template<typename T >
const T & as () const YY_NOEXCEPT
 Const accessor to a built T (for printer). More...
 
template<typename T >
T & build ()
 Instantiate an empty T in here. More...
 
template<typename T >
T & build (const T &t)
 Instantiate a T in here from t. More...
 
template<typename T >
void copy (const self_type &that)
 Copy the content of that to this. More...
 
template<typename T >
void destroy ()
 Destroy the stored T. More...
 
template<typename T >
T & emplace ()
 Instantiate an empty T in here. More...
 
template<typename T >
T & emplace (const T &t)
 Instantiate a T in here from t. More...
 
template<typename T >
void move (self_type &that)
 Move the content of that to this. More...
 
template<typename T >
void swap (self_type &that) YY_NOEXCEPT
 Swap the content with that, of same type. More...
 

Detailed Description

A buffer to store and retrieve objects.

Sort of a variant, but does not keep track of the nature of the stored data, since that knowledge is available via the current parser state.

Definition at line 217 of file parser.h.

Member Typedef Documentation

Type of *this.

Definition at line 221 of file parser.h.

Constructor & Destructor Documentation

isc::eval::EvalParser::semantic_type::semantic_type ( )
inline

Empty construction.

Definition at line 224 of file parser.h.

template<typename T >
isc::eval::EvalParser::semantic_type::semantic_type ( YY_RVREF(T)  t)
inline

Construct and fill.

Definition at line 231 of file parser.h.

References EVAL_ASSERT, and YY_MOVE.

isc::eval::EvalParser::semantic_type::~semantic_type ( )
inline

Destruction, allowed only if empty.

Definition at line 246 of file parser.h.

References EVAL_ASSERT.

Member Function Documentation

template<typename T >
T& isc::eval::EvalParser::semantic_type::as ( )
inline

Accessor to a built T.

Definition at line 307 of file parser.h.

References EVAL_ASSERT.

Referenced by copy(), and move().

template<typename T >
const T& isc::eval::EvalParser::semantic_type::as ( ) const
inline

Const accessor to a built T (for printer).

Definition at line 318 of file parser.h.

References EVAL_ASSERT.

template<typename T >
T& isc::eval::EvalParser::semantic_type::build ( )
inline

Instantiate an empty T in here.

Obsolete, use emplace.

Definition at line 290 of file parser.h.

template<typename T >
T& isc::eval::EvalParser::semantic_type::build ( const T &  t)
inline

Instantiate a T in here from t.

Obsolete, use emplace.

Definition at line 299 of file parser.h.

template<typename T >
void isc::eval::EvalParser::semantic_type::copy ( const self_type that)
inline

Copy the content of that to this.

Definition at line 373 of file parser.h.

References as().

Referenced by isc::eval::EvalParser::basic_symbol< Base >::basic_symbol().

+ Here is the call graph for this function:

template<typename T >
void isc::eval::EvalParser::semantic_type::destroy ( )
inline

Destroy the stored T.

Definition at line 381 of file parser.h.

Referenced by move().

template<typename T >
T& isc::eval::EvalParser::semantic_type::emplace ( )
inline

Instantiate an empty T in here.

Definition at line 266 of file parser.h.

References EVAL_ASSERT.

template<typename T >
T& isc::eval::EvalParser::semantic_type::emplace ( const T &  t)
inline

Instantiate a T in here from t.

Definition at line 277 of file parser.h.

References EVAL_ASSERT.

template<typename T >
void isc::eval::EvalParser::semantic_type::move ( self_type that)
inline

Move the content of that to this.

Destroys that.

Definition at line 348 of file parser.h.

References as(), and destroy().

+ Here is the call graph for this function:

template<typename T >
void isc::eval::EvalParser::semantic_type::swap ( self_type that)
inline

Swap the content with that, of same type.

Both variants must be built beforehand, because swapping the actual data requires reading it (with as()), and this is not possible on unconstructed variants: it would require some dynamic testing, which should not be the variant's responsibility. Swapping between built and (possibly) non-built is done with self_type::move ().

Definition at line 336 of file parser.h.

References EVAL_ASSERT.

Member Data Documentation

long double isc::eval::EvalParser::semantic_type::yyalign_me

Strongest alignment constraints.

Definition at line 457 of file parser.h.

char isc::eval::EvalParser::semantic_type::yyraw[size]

A buffer large enough to store any of the semantic values.

Definition at line 459 of file parser.h.


The documentation for this class was generated from the following file: