...one of the most highly
regarded and expertly designed C++ library projects in the
world.
— Herb Sutter and Andrei
Alexandrescu, C++
Coding Standards
boost::log::attributes::mutable_constant — A class of an attribute that holds a single constant value with ability to change it.
// In header: <boost/log/attributes/mutable_constant.hpp> template<typename T, typename MutexT = void, typename ScopedWriteLockT = auto, typename ScopedReadLockT = auto> class mutable_constant : public attribute { public: // types typedef T value_type; // The attribute value type. // member classes/structs/unions // Factory implementation. class impl : public attribute::impl { public: // construct/copy/destruct explicit impl(value_type const &); explicit impl(value_type &&); // private member functions BOOST_STATIC_ASSERT_MSG(!, "Boost.Log: Mutex and both lock types either must not be void or must all be void"); // public member functions virtual attribute_value get_value(); void set(value_type const &); void set(value_type &&); value_type get() const; }; // construct/copy/destruct explicit mutable_constant(value_type const &); explicit mutable_constant(value_type &&); explicit mutable_constant(cast_source const &); // public member functions void set(value_type const &); void set(value_type &&); value_type get() const; // protected member functions impl * get_impl() const; };
The mutable_constant attribute stores a single value of type, specified as the first template argument. This value is returned on each attribute value acquisition.
The attribute also allows to modify the stored value, even if the attribute is registered in an attribute set. In order to ensure thread safety of such modifications the mutable_constant
class is also parametrized with three additional template arguments: mutex type, scoped write and scoped read lock types. If not specified, the lock types are automatically deduced based on the mutex type.
The implementation may avoid using these types to actually create and use the mutex, if a more efficient synchronization method is available (such as atomic operations on the value type). By default no synchronization is done.
mutable_constant
public
construct/copy/destructexplicit mutable_constant(value_type const & value);
Constructor with the stored value initialization
explicit mutable_constant(value_type && value);
Constructor with the stored value initialization
explicit mutable_constant(cast_source const & source);
Constructor for casting support
mutable_constant
public member functionsvoid set(value_type const & value);
The method sets a new attribute value. The implementation exclusively locks the mutex in order to protect the value assignment.
void set(value_type && value);
The method sets a new attribute value.
value_type get() const;
The method acquires the current attribute value. The implementation non-exclusively locks the mutex in order to protect the value acquisition.
mutable_constant
protected member functionsimpl * get_impl() const;
Returns: |
Pointer to the factory implementation |