boost::log::sinks::event_log::basic_event_composer — An event composer.
// In header: <boost/log/sinks/event_log_backend.hpp> template<typename CharT> class basic_event_composer { public: // types typedef CharT char_type; // Character type. typedef std::basic_string< char_type > string_type; // String type to be used as a message text holder. typedef std::basic_ostream< char_type > stream_type; // Output stream type. typedef basic_attribute_values_view< char_type > values_view_type; // Attribute values view type. typedef function1< event_id_t, values_view_type const & > event_id_mapper_type; // Event identifier mapper type. typedef function3< void, stream_type &, values_view_type const &, string_type const & > formatter_type; // Type of an insertion composer (a formatter) typedef std::vector< string_type > insertion_list; // Type of the composed insertions list. // construct/copy/destruct explicit basic_event_composer(event_id_mapper_type const &); basic_event_composer(basic_event_composer const &); basic_event_composer& operator=(basic_event_composer); ~basic_event_composer(); // public member functions void swap(basic_event_composer &); event_map_reference operator[](event_id_t); event_map_reference operator[](event_id_t::integer_type); event_id_t operator()(values_view_type const &, string_type const &, insertion_list &) const; };
This class is a function object that extracts event identifier from the attribute values set and formats insertion strings for the particular event. Each insertion string is formatted with a distinct formatter, which can be created just like regular sinks formatters.
Before using, the composer must be initialized with the following information:
Event identifier extraction logic. One can use basic_direct_event_id_mapping
or basic_custom_event_id_mapping
classes in order to create such extractor and pass it to the composer constructor.
Event identifiers and insertion string formatters. The composer provides the following syntax to provide this information:
event_composer comp; comp[MY_EVENT_ID1] % formatter1 % ... % formatterN; comp[MY_EVENT_ID2] % formatter1 % ... % formatterN; ...
The event identifiers in square brackets are provided by the message compiler generated header (the actual names are specified in the .mc file). The formatters represent the insertion strings that will be used to replace placeholders in event messages, thus the number and the order of the formatters must correspond to the message definition.
basic_event_composer
public
construct/copy/destructexplicit basic_event_composer(event_id_mapper_type const & id_mapper);
Default constructor. Creates an empty map of events.
Parameters: |
|
basic_event_composer(basic_event_composer const & that);
Copy constructor. Performs a deep copy of the object.
basic_event_composer& operator=(basic_event_composer that);
Assignment. Provides strong exception guarantee.
~basic_event_composer();
Destructor
basic_event_composer
public member functionsvoid swap(basic_event_composer & that);
Swaps *this
and that
objects.
event_map_reference operator[](event_id_t id);
Initiates creation of a new event description. The result of the operator can be used to add formatters for insertion strings construction. The returned reference type is implementation detail.
Parameters: |
|
event_map_reference operator[](event_id_t::integer_type id);
Initiates creation of a new event description. The result of the operator can be used to add formatters for insertion strings construction. The returned reference type is implementation detail.
Parameters: |
|
event_id_t operator()(values_view_type const & attributes, string_type const & message, insertion_list & insertions) const;
Event composition operator. Extracts an event identifier from the attribute values by calling event ID mapper. Then runs all formatters that were registered for the event with the extracted ID. The results of formatting are returned in the insertions
parameter.
Parameters: |
|
||||||
Returns: | An event identifier that was extracted from |