|  | 
boost::log::value_ref — Reference wrapper for a stored attribute value.
// In header: <boost/log/utility/value_ref_fwd.hpp> template<typename T, typename TagT> class value_ref : public type { public: // public member functions value_ref() = default; template<typename U> explicit value_ref(U const &) noexcept; explicit operator bool() const noexcept; bool operator!() const noexcept; bool empty() const noexcept; void swap(value_ref &) noexcept; };
The value_ref class template provides access to the stored attribute value. It is not a traditional reference wrapper since it may be empty (i.e. refer to no value at all) and it can also refer to values of different types. Therefore its interface and behavior combines features of Boost.Ref, Boost.Optional and Boost.Variant, depending on the use case.
The template parameter T can be a single type or an MPL sequence of possible types being referred. The reference wrapper will act as either an optional reference or an optional variant of references to the specified types. In any case, the referred values will not be modifiable (i.e. value_ref always models a const reference).
Template parameter TagT is optional. It can be used for customizing the operations on this reference wrapper, such as putting the referred value to log. 
value_ref public member functionsvalue_ref() = default;
Default constructor. Creates a reference wrapper that does not refer to a value.
template<typename U> explicit value_ref(U const & val) noexcept;
Initializing constructor. Creates a reference wrapper that refers to the specified value.
explicit operator bool() const noexcept;
The operator verifies if the wrapper refers to a value.
bool operator!() const noexcept;
The operator verifies if the wrapper does not refer to a value.
bool empty() const noexcept;
| Returns: | 
 | 
void swap(value_ref & that) noexcept;
Swaps two reference wrappers