![]() |
Home | Libraries | People | FAQ | More |
boost::recursive_wrapper — Solves circular dependencies, enabling recursive types.
// In header: <boost/variant/recursive_wrapper.hpp> template<typename T> class recursive_wrapper { public: // types typedef ; // construct/copy/destruct (); (); (); ~(); // modifiers (); (); (); // queries (); () ; (); () ; };
The recursive_wrapper class template has an
interface similar to a simple value container, but its content is
allocated dynamically. This allows recursive_wrapper to
hold types T whose member data leads to a circular
dependency (e.g., a data member of T has a data member
of type T).
The application of recursive_wrapper is easiest
understood in context. See
the section called “Recursive types with recursive_wrapper” for a
demonstration of a common use of the class template.
Notes:
recursive_wrapper must be capable of construction via
operator new. Thus, for instance, references are not
supported.recursive_wrapper
public
construct/copy/destruct();Default constructor.
Initializes *this by default construction of
T.
Requires: |
T must fulfill the requirements of the
DefaultConstructible [20.1.4]
concept. |
Throws: |
May fail with any exceptions arising from the default
constructor of T or, in the event of
insufficient memory, with std::bad_alloc. |
( other);Copy constructor.
Copies the content of other into
*this.
Throws: |
May fail with any exceptions arising from the
copy constructor of T or, in the event of
insufficient memory, with std::bad_alloc. |
( operand);Value constructor.
Copies operand into
*this.
Throws: |
May fail with any exceptions arising from the
copy constructor of T or, in the event of
insufficient memory, with std::bad_alloc. |
~();Destructor.
Deletes the content of *this.
Throws: |
Will not throw. |
recursive_wrapper modifiers( other);
Exchanges contents of *this and
other.
Throws: |
Will not throw. |
( rhs);Copy assignment operator.
Assigns the content of rhs to the content of
*this.
Requires: |
T must fulfill the requirements of
the Assignable
concept. |
Throws: |
May fail with any exceptions arising from the assignment
operator of T. |
( rhs);Value assignment operator.
Assigns rhs into the content of
*this.
Requires: |
T must fulfill the requirements of the
Assignable
concept. |
Throws: |
May fail with any exceptions arising from the assignment
operator of T. |