C++ Actor Framework 1.0.0
Loading...
Searching...
No Matches
caf::config_value_reader Class Referencefinal

Extracts objects from a config_value. More...

#include <config_value_reader.hpp>

Inheritance diagram for caf::config_value_reader:
caf::deserializer

Public Types

using super = deserializer
 
using key_ptr = const std::string*
 
using value_type
 
using stack_type = std::stack<value_type, std::vector<value_type>>
 
- Public Types inherited from caf::deserializer
using super = load_inspector_base<deserializer>
 

Public Member Functions

 config_value_reader (const config_value *input)
 
 config_value_reader (const config_value *input, actor_system &sys)
 
 config_value_reader (const config_value_reader &)=delete
 
config_value_readeroperator= (const config_value_reader &)=delete
 
value_type & top ()
 
void pop ()
 
bool fetch_next_object_type (type_id_t &type) override
 Reads run-time-type information for the next object if available.
 
bool begin_object (type_id_t type, std::string_view name) override
 Begins processing of an object, may perform a type check depending on the data format.
 
bool end_object () override
 Ends processing of an object.
 
bool begin_field (std::string_view) override
 
bool begin_field (std::string_view name, bool &is_present) override
 
bool begin_field (std::string_view name, span< const type_id_t > types, size_t &index) override
 
bool begin_field (std::string_view name, bool &is_present, span< const type_id_t > types, size_t &index) override
 
bool end_field () override
 
bool begin_tuple (size_t size) override
 Begins processing of a fixed-size sequence.
 
bool end_tuple () override
 Ends processing of a sequence.
 
bool begin_key_value_pair () override
 Begins processing of a tuple with two elements, whereas the first element represents the key in an associative array.
 
bool end_key_value_pair () override
 Ends processing of a key-value pair after both values were written.
 
bool begin_sequence (size_t &size) override
 Begins processing of a sequence.
 
bool end_sequence () override
 Ends processing of a sequence.
 
bool begin_associative_array (size_t &size) override
 Begins processing of an associative array (map).
 
bool end_associative_array () override
 Ends processing of an associative array (map).
 
bool value (std::byte &x) override
 Reads x from the input.
 
bool value (bool &x) override
 Reads x from the input.
 
bool value (int8_t &x) override
 Reads x from the input.
 
bool value (uint8_t &x) override
 Reads x from the input.
 
bool value (int16_t &x) override
 Reads x from the input.
 
bool value (uint16_t &x) override
 Reads x from the input.
 
bool value (int32_t &x) override
 Reads x from the input.
 
bool value (uint32_t &x) override
 Reads x from the input.
 
bool value (int64_t &x) override
 Reads x from the input.
 
bool value (uint64_t &x) override
 Reads x from the input.
 
bool value (float &x) override
 Reads x from the input.
 
bool value (double &x) override
 Reads x from the input.
 
bool value (long double &x) override
 Reads x from the input.
 
bool value (std::string &x) override
 Reads x from the input.
 
bool value (std::u16string &x) override
 Reads x from the input.
 
bool value (std::u32string &x) override
 Reads x from the input.
 
bool value (span< std::byte > x) override
 Reads a byte sequence from the input.
 
- Public Member Functions inherited from caf::deserializer
 deserializer (actor_system &sys) noexcept
 
actor_systemcontext () const noexcept
 
bool has_human_readable_format () const noexcept
 
virtual bool fetch_next_object_name (std::string_view &type_name)
 Reads run-time-type information for the next object if available.
 
bool next_object_name_matches (std::string_view type_name)
 Convenience function for querying fetch_next_object_name comparing the result to type_name in one shot.
 
bool assert_next_object_name (std::string_view type_name)
 Like next_object_name_matches, but sets an error on the deserializer on a mismatch.
 
template<class T >
std::enable_if_t< std::is_integral_v< T >, bool > value (T &x) noexcept
 Reads x from the input.
 
virtual bool list (std::vector< bool > &xs)
 Adds each boolean in xs to the output.
 

Additional Inherited Members

- Protected Attributes inherited from caf::deserializer
actor_systemcontext_ = nullptr
 Provides access to the proxy_registry and to the actor_system.
 
bool has_human_readable_format_ = false
 Configures whether client code should assume human-readable output.
 

Detailed Description

Extracts objects from a config_value.

Member Typedef Documentation

◆ value_type

using caf::config_value_reader::value_type
Initial value:
std::variant<const settings*, const config_value*, key_ptr,
absent_field, sequence, associative_array>

Member Function Documentation

◆ begin_associative_array()

bool caf::config_value_reader::begin_associative_array ( size_t & size)
overridevirtual

Begins processing of an associative array (map).

Note
the default implementation calls begin_sequence(size).

Reimplemented from caf::deserializer.

◆ begin_field() [1/4]

bool caf::config_value_reader::begin_field ( std::string_view name,
bool & is_present )
overridevirtual

Implements caf::deserializer.

◆ begin_field() [2/4]

bool caf::config_value_reader::begin_field ( std::string_view name,
bool & is_present,
span< const type_id_t > types,
size_t & index )
overridevirtual

Implements caf::deserializer.

◆ begin_field() [3/4]

bool caf::config_value_reader::begin_field ( std::string_view name,
span< const type_id_t > types,
size_t & index )
overridevirtual

Implements caf::deserializer.

◆ begin_field() [4/4]

bool caf::config_value_reader::begin_field ( std::string_view name)
overridevirtual

Implements caf::deserializer.

◆ begin_key_value_pair()

bool caf::config_value_reader::begin_key_value_pair ( )
overridevirtual

Begins processing of a tuple with two elements, whereas the first element represents the key in an associative array.

Note
the default implementation calls begin_tuple(2).

Reimplemented from caf::deserializer.

◆ begin_object()

bool caf::config_value_reader::begin_object ( type_id_t type,
std::string_view pretty_class_name )
overridevirtual

Begins processing of an object, may perform a type check depending on the data format.

Parameters
type16-bit ID for known types, invalid_type_id otherwise.
pretty_class_nameEither the output of type_name_or_anonymous or the optionally defined pretty name.

Implements caf::deserializer.

◆ begin_sequence()

bool caf::config_value_reader::begin_sequence ( size_t & size)
overridevirtual

Begins processing of a sequence.

Implements caf::deserializer.

◆ begin_tuple()

bool caf::config_value_reader::begin_tuple ( size_t size)
overridevirtual

Begins processing of a fixed-size sequence.

Implements caf::deserializer.

◆ end_associative_array()

bool caf::config_value_reader::end_associative_array ( )
overridevirtual

Ends processing of an associative array (map).

Note
the default implementation calls end_sequence().

Reimplemented from caf::deserializer.

◆ end_field()

bool caf::config_value_reader::end_field ( )
overridevirtual

Implements caf::deserializer.

◆ end_key_value_pair()

bool caf::config_value_reader::end_key_value_pair ( )
overridevirtual

Ends processing of a key-value pair after both values were written.

Note
the default implementation calls end_tuple().

Reimplemented from caf::deserializer.

◆ end_object()

bool caf::config_value_reader::end_object ( )
overridevirtual

Ends processing of an object.

Implements caf::deserializer.

◆ end_sequence()

bool caf::config_value_reader::end_sequence ( )
overridevirtual

Ends processing of a sequence.

Implements caf::deserializer.

◆ end_tuple()

bool caf::config_value_reader::end_tuple ( )
overridevirtual

Ends processing of a sequence.

Implements caf::deserializer.

◆ fetch_next_object_type()

bool caf::config_value_reader::fetch_next_object_type ( type_id_t & type)
overridevirtual

Reads run-time-type information for the next object if available.

Implements caf::deserializer.

◆ value() [1/17]

bool caf::config_value_reader::value ( bool & x)
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [2/17]

bool caf::config_value_reader::value ( double & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [3/17]

bool caf::config_value_reader::value ( float & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [4/17]

bool caf::config_value_reader::value ( int16_t & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [5/17]

bool caf::config_value_reader::value ( int32_t & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [6/17]

bool caf::config_value_reader::value ( int64_t & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [7/17]

bool caf::config_value_reader::value ( int8_t & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [8/17]

bool caf::config_value_reader::value ( long double & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [9/17]

bool caf::config_value_reader::value ( span< std::byte > x)
overridevirtual

Reads a byte sequence from the input.

Parameters
xThe byte sequence.
Returns
A non-zero error code on failure, sec::success otherwise.

Implements caf::deserializer.

◆ value() [10/17]

bool caf::config_value_reader::value ( std::byte & x)
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [11/17]

bool caf::config_value_reader::value ( std::string & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [12/17]

bool caf::config_value_reader::value ( std::u16string & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [13/17]

bool caf::config_value_reader::value ( std::u32string & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [14/17]

bool caf::config_value_reader::value ( uint16_t & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [15/17]

bool caf::config_value_reader::value ( uint32_t & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [16/17]

bool caf::config_value_reader::value ( uint64_t & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.

◆ value() [17/17]

bool caf::config_value_reader::value ( uint8_t & )
overridevirtual

Reads x from the input.

Parameters
xA reference to a builtin type.
Returns
true on success, false otherwise.

Implements caf::deserializer.


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