sbepp
Loading...
Searching...
No Matches
sbepp Namespace Reference

The main sbepp namespace. More...

Namespaces

namespace  cursor_ops
 Contains cursor wrappers which allow more precise control over its position.
 
namespace  detail
 Namespace for various implementation details. Should not be used directly.
 

Classes

struct  byte_type
 Trait to get view's byte type. More...
 
class  char_opt_t
 Built-in char optional type. More...
 
class  char_t
 Built-in char required type. More...
 
class  composite_traits
 Provides various traits/attributes of a <composite> element. More...
 
class  cursor
 Represents cursor which is used in cursor-based API. Clients should not use undocumented methods. More...
 
class  data_traits
 Provides various traits/attributes of a <data> element. More...
 
struct  default_init_t
 Tag for dynamic_array_ref::resize(). Used to skip value initialization. More...
 
class  double_opt_t
 Built-in double optional type. More...
 
class  double_t
 Built-in double required type. More...
 
class  enum_traits
 Provides various traits/attributes of an <enum> element. More...
 
class  enum_value_traits
 Provides various traits/attributes of a <validValue> element. More...
 
class  field_traits
 Provides various traits/attributes of a <field> element. More...
 
class  float_opt_t
 Built-in float optional type. More...
 
class  float_t
 Built-in float required type. More...
 
class  group_traits
 Provides various traits/attributes of a <group> element. More...
 
class  int16_opt_t
 Built-in int16 optional type. More...
 
class  int16_t
 Built-in int16 required type. More...
 
class  int32_opt_t
 Built-in int32 optional type. More...
 
class  int32_t
 Built-in int32 required type. More...
 
class  int64_opt_t
 Built-in int64 optional type. More...
 
class  int64_t
 Built-in int64 required type. More...
 
class  int8_opt_t
 Built-in int8 optional type. More...
 
class  int8_t
 Built-in int8 required type. More...
 
struct  is_enum
 Checks if T is an enumeration. More...
 
struct  is_enum< T, detail::void_t< decltype(tag_invoke(std::declval< detail::visit_tag >(), std::declval< T >(), std::declval< int & >()))> >
 
class  message_traits
 Provides various traits/attributes of a <message> element. More...
 
struct  nullopt_t
 Tag type used to initialize optional types with null value. More...
 
class  schema_traits
 Provides various traits/attributes of a <messageSchema> element. More...
 
class  set_choice_traits
 Provides various traits/attributes of a <choice> element. More...
 
class  set_traits
 Provides various traits/attributes of a <set> element. More...
 
struct  size_bytes_checked_result
 Result type of size_bytes_checked More...
 
struct  traits_tag
 Maps representation type to its tag. More...
 
struct  traits_tag< char_opt_t >
 
struct  traits_tag< char_t >
 
struct  traits_tag< detail::static_array_ref< Byte, Value, N, Tag > >
 
struct  traits_tag< double_opt_t >
 
struct  traits_tag< double_t >
 
struct  traits_tag< float_opt_t >
 
struct  traits_tag< float_t >
 
struct  traits_tag< int16_opt_t >
 
struct  traits_tag< int16_t >
 
struct  traits_tag< int32_opt_t >
 
struct  traits_tag< int32_t >
 
struct  traits_tag< int64_opt_t >
 
struct  traits_tag< int64_t >
 
struct  traits_tag< int8_opt_t >
 
struct  traits_tag< int8_t >
 
struct  traits_tag< uint16_opt_t >
 
struct  traits_tag< uint16_t >
 
struct  traits_tag< uint32_opt_t >
 
struct  traits_tag< uint32_t >
 
struct  traits_tag< uint64_opt_t >
 
struct  traits_tag< uint64_t >
 
struct  traits_tag< uint8_opt_t >
 
struct  traits_tag< uint8_t >
 
struct  type_list
 An empty structure to represent a sequence of types. More...
 
class  type_traits
 Provides various traits and attributes of a <type> element. More...
 
class  type_traits< char_opt_t >
 
class  type_traits< char_t >
 
class  type_traits< double_opt_t >
 
class  type_traits< double_t >
 
class  type_traits< float_opt_t >
 
class  type_traits< float_t >
 
class  type_traits< int16_opt_t >
 
class  type_traits< int16_t >
 
class  type_traits< int32_opt_t >
 
class  type_traits< int32_t >
 
class  type_traits< int64_opt_t >
 
class  type_traits< int64_t >
 
class  type_traits< int8_opt_t >
 
class  type_traits< int8_t >
 
class  type_traits< uint16_opt_t >
 
class  type_traits< uint16_t >
 
class  type_traits< uint32_opt_t >
 
class  type_traits< uint32_t >
 
class  type_traits< uint64_opt_t >
 
class  type_traits< uint64_t >
 
class  type_traits< uint8_opt_t >
 
class  type_traits< uint8_t >
 
class  uint16_opt_t
 Built-in uint16 optional type. More...
 
class  uint16_t
 Built-in uint16 required type. More...
 
class  uint32_opt_t
 Built-in uint32 optional type. More...
 
class  uint32_t
 Built-in uint32 required type. More...
 
class  uint64_opt_t
 Built-in uint64 optional type. More...
 
class  uint64_t
 Built-in uint64 required type. More...
 
class  uint8_opt_t
 Built-in uint8 optional type. More...
 
class  uint8_t
 Built-in uint8 required type. More...
 
struct  unknown_enum_value_tag
 Tag for unknown enum values. More...
 

Concepts

concept  array_type
 Concept for sbepp::is_array_type<T>::value
 
concept  required_type
 Concept for sbepp::is_required_type<T>::value
 
concept  optional_type
 Concept for sbepp::is_optional_type<T>::value
 
concept  non_array_type
 Concept for sbepp::is_non_array_type<T>::value
 
concept  type
 Concept for sbepp::is_type<T>::value
 
concept  enumeration
 Concept for sbepp::is_enum<T>::value
 
concept  set
 Concept for sbepp::is_set<T>::value
 
concept  composite
 Concept for sbepp::is_composite<T>::value
 
concept  message
 Concept for sbepp::is_message<T>::value
 
concept  flat_group
 Concept for sbepp::is_flat_group<T>::value
 
concept  nested_group
 Concept for sbepp::is_nested_group<T>::value
 
concept  group
 Concept for sbepp::is_group<T>::value
 
concept  group_entry
 Concept for sbepp::is_group_entry<T>::value
 
concept  data
 Concept for sbepp::is_data<T>::value
 
concept  type_tag
 Concept for sbepp::is_type_tag<Tag>::value
 
concept  enum_tag
 Concept for sbepp::is_enum_tag<Tag>::value
 
concept  enum_value_tag
 Concept for sbepp::is_enum_value_tag<Tag>::value
 
concept  set_tag
 Concept for sbepp::is_set_tag<Tag>::value
 
concept  set_choice_tag
 Concept for sbepp::is_set_choice_tag<Tag>::value
 
concept  composite_tag
 Concept for sbepp::is_composite_tag<Tag>::value
 
concept  field_tag
 Concept for sbepp::is_field_tag<Tag>::value
 
concept  group_tag
 Concept for sbepp::is_group_tag<Tag>::value
 
concept  data_tag
 Concept for sbepp::is_data_tag<Tag>::value
 
concept  message_tag
 Concept for sbepp::is_message_tag<Tag>::value
 
concept  schema_tag
 Concept for sbepp::is_schema_tag<Tag>::value
 

Typedefs

using length_t = std::uint64_t
 Represents type_traits::length() value type.
 
using offset_t = std::uint64_t
 Represents offset trait value type, e.g. type_traits::offset()
 
using version_t = std::uint64_t
 Represents version trait value type, e.g. type_traits::since_version()
 
using schema_id_t = std::uint32_t
 Represents schema_traits::id() value type.
 
using message_id_t = std::uint32_t
 Represents message_traits::id() value type.
 
using block_length_t = std::uint64_t
 Represents block_length trait value type, e.g. message_traits::block_length()
 
using member_id_t = std::uint16_t
 Represents id trait value type, e.g. field_traits::id()
 
using choice_index_t = std::uint8_t
 Represents set_choice_traits::index() value type.
 
template<typename View>
using byte_type_t = typename byte_type<View>::type
 Shortcut for byte_type<T>::type
 
template<typename ValueType>
using traits_tag_t = typename traits_tag<ValueType>::type
 Shorthand for sbepp::traits_tag<T>::type
 
template<typename T>
using is_array_type = typename detail::is_array_type_impl<T>::type
 Checks if T is an array type.
 
template<typename T>
using is_required_type = detail::is_base_of_tmp<detail::required_base, T>
 Checks if T is a required numeric type.
 
template<typename T>
using is_optional_type = detail::is_base_of_tmp<detail::optional_base, T>
 Checks if T is an optional numeric type.
 
template<typename T>
using is_non_array_type
 Checks if T is a numeric type.
 
template<typename T>
using is_type
 Checks if T is a type of any kind.
 
template<typename T>
using is_set = detail::is_base_of_tmp<detail::bitset_base, T>
 Checks if T is a set.
 
template<typename T>
using is_composite = detail::is_base_of_tmp<detail::composite_base, T>
 Checks if T is a composite.
 
template<typename T>
using is_message = detail::is_base_of_tmp<detail::message_base, T>
 Checks if T is a message.
 
template<typename T>
using is_flat_group = detail::is_base_of_tmp<detail::flat_group_base, T>
 Checks if T is a flat group.
 
template<typename T>
using is_nested_group = detail::is_base_of_tmp<detail::nested_group_base, T>
 Checks if T is a nested group.
 
template<typename T>
using is_group
 Checks if T is a group of any kind.
 
template<typename T>
using is_group_entry = detail::is_base_of_tmp<detail::entry_base, T>
 Checks if T is a group entry.
 
template<typename T>
using is_data = typename detail::is_data_impl<T>::type
 Checks if T is a data.
 
template<typename Tag>
using is_type_tag = detail::has_traits<type_traits, Tag>
 Checks if Tag is a type tag.
 
template<typename Tag>
using is_enum_tag = detail::has_traits<enum_traits, Tag>
 Checks if Tag is an enum tag.
 
template<typename Tag>
using is_enum_value_tag = detail::has_traits<enum_value_traits, Tag>
 Checks if Tag is an enum value tag.
 
template<typename Tag>
using is_set_tag = detail::has_traits<set_traits, Tag>
 Checks if Tag is a set tag.
 
template<typename Tag>
using is_set_choice_tag = detail::has_traits<set_choice_traits, Tag>
 Checks if Tag is a set choice tag.
 
template<typename Tag>
using is_composite_tag = detail::has_traits<composite_traits, Tag>
 Checks if Tag is a composite tag.
 
template<typename Tag>
using is_field_tag = detail::has_traits<field_traits, Tag>
 Checks if Tag is a field tag.
 
template<typename Tag>
using is_group_tag = detail::has_traits<group_traits, Tag>
 Checks if Tag is a group tag.
 
template<typename Tag>
using is_data_tag = detail::has_traits<data_traits, Tag>
 Checks if Tag is a data tag.
 
template<typename Tag>
using is_message_tag = detail::has_traits<message_traits, Tag>
 Checks if Tag is a message tag.
 
template<typename Tag>
using is_schema_tag = detail::has_traits<schema_traits, Tag>
 Checks if Tag is a schema tag.
 

Enumerations

enum class  field_presence { required , optional , constant }
 Represents presence trait value type, e.g. type_traits::presence() More...
 
enum class  endian { little , big , native }
 Represents schema_traits::byte_order() value type. When SBEPP_HAS_ENDIAN is 1, it's just an alias to std::endian. Requires SBEPP_BYTE_ORDER to be defined if endianness is not detected automatically. More...
 
enum class  eos_null { none , single , all }
 Represents number of null bytes that can be added after the end-of-string by detail::static_array_ref::assign_string() More...
 

Functions

void assertion_failed (char const *expr, char const *function, char const *file, long line)
 When SBEPP_ASSERT_HANDLER or SBEPP_ENABLE_ASSERTS_WITH_HANDLER is defined, this function is called for failed assertions. Must be defined by the client.
 
template<typename T>
constexpr std::size_t size_bytes (T v) noexcept
 Returns the size of the underlying data represented by message/group/entry/data/composite view, including headers.
 
template<typename T, typename Byte>
constexpr std::size_t size_bytes (T v, cursor< Byte > c) noexcept
 Similar to sbepp::size_bytes but has constant complexity because it expects c to be set at the end of v. Useful to read the whole message and then get its size in constant time. Not applicable to composites.
 
template<typename T>
constexpr auto get_header (T v) noexcept -> decltype(v(detail::get_header_tag{}))
 Returns the header of a message/group.
 
template<typename T>
constexpr auto addressof (T v) noexcept -> decltype(v(detail::addressof_tag{}))
 Returns pointer to the underlying data referenced by a view.
 
template<typename Enum>
constexpr std::underlying_type< Enum >::type to_underlying (Enum e) noexcept
 Converts an enumeration to its underlying type. Equivalent to C++23 std::to_underlying()
 
template<typename View>
constexpr cursor< byte_type_t< View > > init_cursor (View view) noexcept
 Initializes cursor from a message/group view with the same byte type.
 
template<typename View>
constexpr cursor< typename std::add_const< byte_type_t< View > >::type > init_const_cursor (View view) noexcept
 Initializes cursor from a message/group view with const byte type.
 
template<typename Message>
constexpr auto fill_message_header (Message m) noexcept -> decltype(m(detail::fill_message_header_tag{}))
 Fills message header.
 
template<typename Group, typename Size>
constexpr auto fill_group_header (Group g, Size num_in_group) noexcept -> decltype(g(detail::fill_group_header_tag{}, num_in_group))
 Fills group header.
 
template<template< typename > class View, typename Byte>
constexpr View< Byte > make_view (Byte *ptr, const std::size_t size) noexcept
 Constructs view from memory buffer.
 
template<template< typename > class View, typename Byte>
constexpr View< typename std::add_const< Byte >::type > make_const_view (Byte *ptr, const std::size_t size) noexcept
 Constructs read-only view from memory buffer.
 
template<typename Visitor, typename View, typename Cursor, typename = detail::enable_if_t<detail::is_cursor_visitable_view<View>::value>>
constexpr Visitor && visit (View view, Cursor &c, Visitor &&visitor={})
 Visits a view using given cursor.
 
template<typename Visitor, typename View, typename = detail::enable_if_t<detail::is_cursor_visitable_view<View>::value>>
constexpr Visitor && visit (View view, Visitor &&visitor={})
 Visits a message, group or entry view.
 
template<typename Visitor, typename Composite>
constexpr Visitor && visit (Composite view, Visitor &&visitor={})
 Visits a composite view.
 
template<typename Visitor, typename Set>
constexpr Visitor && visit (Set s, Visitor &&visitor={})
 Visits set choices.
 
template<typename Visitor, typename Enum>
constexpr Visitor && visit (Enum e, Visitor &&visitor={})
 Visits an enum value.
 
template<typename Visitor, typename View, typename Cursor>
constexpr detail::enable_if_t< is_composite< View >::value, Visitor && > visit (View view, Cursor &c, Visitor &&visitor={})
 Visits a composite view using given cursor.
 
template<typename Visitor, typename View, typename Cursor, typename = detail::enable_if_t<detail::is_cursor_visitable_view<View>::value>>
constexpr Visitor && visit_children (View view, Cursor &c, Visitor &&visitor={})
 Visits view's children using provided cursor.
 
template<typename Visitor, typename View, typename = detail::enable_if_t<detail::is_cursor_visitable_view<View>::value>>
constexpr Visitor && visit_children (View view, Visitor &&visitor={})
 Visits view's children.
 
template<typename Visitor, typename View>
constexpr detail::enable_if_t< is_composite< View >::value, Visitor && > visit_children (View view, Visitor &&visitor={})
 Visits composite children using provided cursor.
 
template<typename Visitor, typename View, typename Cursor>
constexpr detail::enable_if_t< is_composite< View >::value, Visitor && > visit_children (View view, Cursor &c, Visitor &&visitor={})
 Visits composite children using provided cursor.
 
template<typename E, typename = detail::enable_if_t<is_enum<E>::value>>
constexpr const char * enum_to_string (const E e) noexcept
 Converts enum to string.
 
template<typename Set, typename Visitor>
constexpr auto visit_set (const Set s, Visitor &&visitor) noexcept -> decltype(s(detail::visit_set_tag{}, std::forward< Visitor >(visitor)))
 Visits set choices in order of their declaration.
 
template<typename Tag, typename ViewOrSet>
constexpr auto get_by_tag (ViewOrSet viewOrSet) noexcept -> decltype(viewOrSet(detail::access_by_tag_tag{}, Tag{}))
 Gets field or set choice value by tag.
 
template<typename Tag, typename View, typename Cursor>
constexpr auto get_by_tag (View view, Cursor &&c) noexcept -> decltype(view(detail::access_by_tag_tag{}, Tag{}, std::forward< Cursor >(c)))
 Gets field value by tag using given cursor.
 
template<typename Tag, typename ViewOrSet, typename Value>
constexpr auto set_by_tag (ViewOrSet &&viewOrSet, Value &&value) noexcept -> decltype(std::forward< ViewOrSet >(viewOrSet)(detail::access_by_tag_tag{}, Tag{}, std::forward< Value >(value)))
 Sets field or set choice value by tag.
 
template<typename Tag, typename View, typename Value, typename Cursor>
constexpr auto set_by_tag (View view, Value &&value, Cursor &&c) -> decltype(view(detail::access_by_tag_tag{}, Tag{}, std::forward< Value >(value), std::forward< Cursor >(c)))
 Sets field value by tag using given cursor.
 
template<typename View>
constexpr size_bytes_checked_result size_bytes_checked (View view, std::size_t size) noexcept
 Calculates view size with additional safety checks.
 

Variables

constexpr default_init_t default_init {}
 Helper to pass default_init_t to dynamic_array_ref::resize().
 
constexpr nullopt_t nullopt {0}
 Helper constant used to initialize optional types with null value.
 
template<typename T>
constexpr bool is_array_type_v = is_array_type<T>::value
 Shorthand for sbepp::is_array_type<T>::value
 
template<typename T>
constexpr bool is_required_type_v = is_required_type<T>::value
 Shorthand for sbepp::is_required_type<T>::value
 
template<typename T>
constexpr bool is_optional_type_v = is_optional_type<T>::value
 Shorthand for sbepp::is_optional_type<T>::value
 
template<typename T>
constexpr bool is_non_array_type_v = is_non_array_type<T>::value
 Shorthand for sbepp::is_non_array_type<T>::value
 
template<typename T>
constexpr bool is_type_v = is_type<T>::value
 Shorthand for sbepp::is_type<T>::value
 
template<typename T>
constexpr bool is_enum_v = is_enum<T>::value
 Shorthand for sbepp::is_enum<T>::value
 
template<typename T>
constexpr bool is_set_v = is_set<T>::value
 Shorthand for sbepp::is_set<T>::value
 
template<typename T>
constexpr bool is_composite_v = is_composite<T>::value
 Shorthand for sbepp::is_composite<T>::value
 
template<typename T>
constexpr bool is_message_v = is_message<T>::value
 Shorthand for sbepp::is_message<T>::value
 
template<typename T>
constexpr bool is_flat_group_v = is_flat_group<T>::value
 Shorthand for sbepp::is_flat_group<T>::value
 
template<typename T>
constexpr bool is_nested_group_v = is_nested_group<T>::value
 Shorthand for sbepp::is_nested_group<T>::value
 
template<typename T>
constexpr bool is_group_v = is_group<T>::value
 Shorthand for sbepp::is_group<T>::value
 
template<typename T>
constexpr bool is_group_entry_v = is_group_entry<T>::value
 Shorthand for sbepp::is_group_entry<T>::value
 
template<typename T>
constexpr bool is_data_v = is_data<T>::value
 Shorthand for sbepp::is_data<T>::value
 
template<typename Tag>
constexpr bool is_type_tag_v = is_type_tag<Tag>::value
 Shorthand for sbepp::is_type_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_enum_tag_v = is_enum_tag<Tag>::value
 Shorthand for sbepp::is_enum_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_enum_value_tag_v = is_enum_value_tag<Tag>::value
 Shorthand for sbepp::is_enum_value_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_set_tag_v = is_set_tag<Tag>::value
 Shorthand for sbepp::is_set_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_set_choice_tag_v = is_set_choice_tag<Tag>::value
 Shorthand for sbepp::is_set_choice_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_composite_tag_v = is_composite_tag<Tag>::value
 Shorthand for sbepp::is_composite_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_field_tag_v = is_field_tag<Tag>::value
 Shorthand for sbepp::is_field_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_group_tag_v = is_group_tag<Tag>::value
 Shorthand for sbepp::is_group_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_data_tag_v = is_data_tag<Tag>::value
 Shorthand for sbepp::is_data_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_message_tag_v = is_message_tag<Tag>::value
 Shorthand for sbepp::is_message_tag<Tag>::value
 
template<typename Tag>
constexpr bool is_schema_tag_v = is_schema_tag<Tag>::value
 Shorthand for sbepp::is_schema_tag<Tag>::value
 

Detailed Description

The main sbepp namespace.

Typedef Documentation

◆ is_array_type

template<typename T>
using sbepp::is_array_type = typename detail::is_array_type_impl<T>::type

Checks if T is an array type.

Equivalent to std::true_type if T is an array type, std::false_type otherwise.

◆ is_composite

template<typename T>
using sbepp::is_composite = detail::is_base_of_tmp<detail::composite_base, T>

Checks if T is a composite.

Equivalent to std::true_type if T is a composite, std::false_type otherwise.

◆ is_composite_tag

template<typename Tag>
using sbepp::is_composite_tag = detail::has_traits<composite_traits, Tag>

Checks if Tag is a composite tag.

Equivalent to std::true_type if Tag is a composite tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_data

template<typename T>
using sbepp::is_data = typename detail::is_data_impl<T>::type

Checks if T is a data.

Equivalent to std::true_type if T is a data, std::false_type otherwise.

◆ is_data_tag

template<typename Tag>
using sbepp::is_data_tag = detail::has_traits<data_traits, Tag>

Checks if Tag is a data tag.

Equivalent to std::true_type if Tag is a data tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_enum_tag

template<typename Tag>
using sbepp::is_enum_tag = detail::has_traits<enum_traits, Tag>

Checks if Tag is an enum tag.

Equivalent to std::true_type if Tag is an enum tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_enum_value_tag

template<typename Tag>
using sbepp::is_enum_value_tag = detail::has_traits<enum_value_traits, Tag>

Checks if Tag is an enum value tag.

Equivalent to std::true_type if Tag is an enum value tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_field_tag

template<typename Tag>
using sbepp::is_field_tag = detail::has_traits<field_traits, Tag>

Checks if Tag is a field tag.

Equivalent to std::true_type if Tag is a field tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_flat_group

template<typename T>
using sbepp::is_flat_group = detail::is_base_of_tmp<detail::flat_group_base, T>

Checks if T is a flat group.

Equivalent to std::true_type if T is a flat group, std::false_type otherwise.

◆ is_group

template<typename T>
using sbepp::is_group
Initial value:
std::integral_constant<
bool,
detail::is_base_of_tmp< detail::flat_group_base, T > is_flat_group
Checks if T is a flat group.
Definition sbepp.hpp:5124
detail::is_base_of_tmp< detail::nested_group_base, T > is_nested_group
Checks if T is a nested group.
Definition sbepp.hpp:5133

Checks if T is a group of any kind.

Equivalent to std::true_type if T is a group of any kind, std::false_type otherwise.

◆ is_group_entry

template<typename T>
using sbepp::is_group_entry = detail::is_base_of_tmp<detail::entry_base, T>

Checks if T is a group entry.

Equivalent to std::true_type if T is a group entry, std::false_type otherwise.

◆ is_group_tag

template<typename Tag>
using sbepp::is_group_tag = detail::has_traits<group_traits, Tag>

Checks if Tag is a group tag.

Equivalent to std::true_type if Tag is a group tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_message

template<typename T>
using sbepp::is_message = detail::is_base_of_tmp<detail::message_base, T>

Checks if T is a message.

Equivalent to std::true_type if T is a message, std::false_type otherwise.

◆ is_message_tag

template<typename Tag>
using sbepp::is_message_tag = detail::has_traits<message_traits, Tag>

Checks if Tag is a message tag.

Equivalent to std::true_type if Tag is a message tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_nested_group

template<typename T>
using sbepp::is_nested_group = detail::is_base_of_tmp<detail::nested_group_base, T>

Checks if T is a nested group.

Equivalent to std::true_type if T is a nested group, std::false_type otherwise.

◆ is_non_array_type

template<typename T>
using sbepp::is_non_array_type
Initial value:
std::integral_constant<
bool,
detail::is_base_of_tmp< detail::optional_base, T > is_optional_type
Checks if T is an optional numeric type.
Definition sbepp.hpp:5045
detail::is_base_of_tmp< detail::required_base, T > is_required_type
Checks if T is a required numeric type.
Definition sbepp.hpp:5036

Checks if T is a numeric type.

Equivalent to std::true_type if T is a numeric type, std::false_type otherwise.

◆ is_optional_type

template<typename T>
using sbepp::is_optional_type = detail::is_base_of_tmp<detail::optional_base, T>

Checks if T is an optional numeric type.

Equivalent to std::true_type if T is an optional numeric type, std::false_type otherwise.

◆ is_required_type

template<typename T>
using sbepp::is_required_type = detail::is_base_of_tmp<detail::required_base, T>

Checks if T is a required numeric type.

Equivalent to std::true_type if T is a required numeric type, std::false_type otherwise.

◆ is_schema_tag

template<typename Tag>
using sbepp::is_schema_tag = detail::has_traits<schema_traits, Tag>

Checks if Tag is a schema tag.

Equivalent to std::true_type if Tag is a schema tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_set

template<typename T>
using sbepp::is_set = detail::is_base_of_tmp<detail::bitset_base, T>

Checks if T is a set.

Equivalent to std::true_type if T is a set, std::false_type otherwise.

◆ is_set_choice_tag

template<typename Tag>
using sbepp::is_set_choice_tag = detail::has_traits<set_choice_traits, Tag>

Checks if Tag is a set choice tag.

Equivalent to std::true_type if Tag is a set choice tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_set_tag

template<typename Tag>
using sbepp::is_set_tag = detail::has_traits<set_traits, Tag>

Checks if Tag is a set tag.

Equivalent to std::true_type if Tag is a set tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

◆ is_type

template<typename T>
using sbepp::is_type
Initial value:
std::integral_constant<
bool,
typename detail::is_array_type_impl< T >::type is_array_type
Checks if T is an array type.
Definition sbepp.hpp:5027

Checks if T is a type of any kind.

Equivalent to std::true_type if T is a type of any kind, std::false_type otherwise.

◆ is_type_tag

template<typename Tag>
using sbepp::is_type_tag = detail::has_traits<type_traits, Tag>

Checks if Tag is a type tag.

Equivalent to std::true_type if Tag is a type tag, std::false_type otherwise. Requires Tag traits to be available for correct behavior.

Enumeration Type Documentation

◆ endian

enum class sbepp::endian
strong

Represents schema_traits::byte_order() value type. When SBEPP_HAS_ENDIAN is 1, it's just an alias to std::endian. Requires SBEPP_BYTE_ORDER to be defined if endianness is not detected automatically.

Enumerator
little 

little-endian

big 

big-endian

native 

current platform endianness

◆ eos_null

enum class sbepp::eos_null
strong

Represents number of null bytes that can be added after the end-of-string by detail::static_array_ref::assign_string()

Enumerator
none 

Bytes after the last string character will not be touched. Useful when underlying buffer is zero-filled.

single 

Single byte after the last string character will be set to null. Useful when decoder will look for the first null byte to calculate string length.

all 

All bytes after the last string character will be set to null.

◆ field_presence

enum class sbepp::field_presence
strong

Represents presence trait value type, e.g. type_traits::presence()

Enumerator
required 

field is required

optional 

field is optional

constant 

field is constant

Function Documentation

◆ addressof()

template<typename T>
auto sbepp::addressof ( T v) -> decltype(v(detail::addressof_tag{}))
constexprnoexcept

Returns pointer to the underlying data referenced by a view.

Parameters
vview
Returns
pointer to the underlying data

◆ assertion_failed()

void sbepp::assertion_failed ( char const * expr,
char const * function,
char const * file,
long line )

When SBEPP_ASSERT_HANDLER or SBEPP_ENABLE_ASSERTS_WITH_HANDLER is defined, this function is called for failed assertions. Must be defined by the client.

Parameters
exprexpression that failed
functionenclosing function name
filefile name
lineline number

◆ enum_to_string()

template<typename E, typename = detail::enable_if_t<is_enum<E>::value>>
const char * sbepp::enum_to_string ( const E e)
constexprnoexcept

Converts enum to string.

Parameters
eenum to convert
Returns
pointer to a null-terminated string representing an enumerator's name or nullptr if e holds unknown value
Deprecated
Deprecated in favor of sbepp::visit, will be removed in the next major update.

◆ fill_group_header()

template<typename Group, typename Size>
auto sbepp::fill_group_header ( Group g,
Size num_in_group ) -> decltype(g(detail::fill_group_header_tag{}, num_in_group))
constexprnoexcept

Fills group header.

Automatically fills these fields in group header:

  • blockLength
  • numInGroup
  • numGroups (if exists in header)
  • numVarDataFields (if exists in header)
Parameters
ggroup
num_in_groupnumber if entries in group
Returns
group header

◆ fill_message_header()

template<typename Message>
auto sbepp::fill_message_header ( Message m) -> decltype(m(detail::fill_message_header_tag{}))
constexprnoexcept

Fills message header.

Automatically fills these fields in message header:

  • schemaId
  • templateId
  • version
  • blockLength
  • numGroups (if exists in header)
  • numVarDataFields (if exists in header)
Parameters
mmessage
Returns
message header

◆ get_by_tag() [1/2]

template<typename Tag, typename View, typename Cursor>
auto sbepp::get_by_tag ( View view,
Cursor && c ) -> decltype(view( detail::access_by_tag_tag{}, Tag{}, std::forward<Cursor>(c)))
constexprnoexcept

Gets field value by tag using given cursor.

Template Parameters
Tagfield tag
Parameters
viewmessage or entry view
ccursor
Returns
the result of the corresponding getter, e.g. view.fieldName(c)

◆ get_by_tag() [2/2]

template<typename Tag, typename ViewOrSet>
auto sbepp::get_by_tag ( ViewOrSet viewOrSet) -> decltype(viewOrSet(detail::access_by_tag_tag{}, Tag{}))
constexprnoexcept

Gets field or set choice value by tag.

Template Parameters
Tagfield or set choice tag
Parameters
viewOrSetmessage, entry, composite view or set
Returns
the result of the corresponding getter, e.g. viewOrSet.fieldOrChoiceName()

◆ get_header()

template<typename T>
auto sbepp::get_header ( T v) -> decltype(v(detail::get_header_tag{}))
constexprnoexcept

Returns the header of a message/group.

Parameters
vmessage/group view
Returns
header composite view

◆ init_const_cursor()

template<typename View>
cursor< typename std::add_const< byte_type_t< View > >::type > sbepp::init_const_cursor ( View view)
constexprnoexcept

Initializes cursor from a message/group view with const byte type.

Example:

schema::messages::msg1<char> {ptr, size};
auto value = m.field(c);
m.field(1, c); // error: cursor has const-qualified byte type
constexpr cursor< typename std::add_const< byte_type_t< View > >::type > init_const_cursor(View view) noexcept
Initializes cursor from a message/group view with const byte type.
Definition sbepp.hpp:2881
Parameters
viewmessage or group view
Returns
initialized cursor

◆ init_cursor()

template<typename View>
cursor< byte_type_t< View > > sbepp::init_cursor ( View view)
constexprnoexcept

Initializes cursor from a message/group view with the same byte type.

Example:

schema::messages::msg1<char> {ptr, size};
auto c = sbepp::init_cursor(m);
auto value = m.field(c);
constexpr cursor< byte_type_t< View > > init_cursor(View view) noexcept
Initializes cursor from a message/group view with the same byte type.
Definition sbepp.hpp:2858
Parameters
viewmessage or group view
Returns
initialized cursor

◆ make_const_view()

template<template< typename > class View, typename Byte>
View< typename std::add_const< Byte >::type > sbepp::make_const_view ( Byte * ptr,
const std::size_t size )
constexprnoexcept

Constructs read-only view from memory buffer.

View's byte type will be a const-qualified buffer byte type. Example:

std::array<char, N> buf;
// creates some_schema::messages::msg1<const char>
buf.data(), buf.size());
constexpr View< Byte > make_view(Byte *ptr, const std::size_t size) noexcept
Constructs view from memory buffer.
Definition sbepp.hpp:4942
Template Parameters
Viewview template
Bytebyte type
Parameters
ptrbuffer start
sizebuffer size
Returns
constructed view

◆ make_view()

template<template< typename > class View, typename Byte>
View< Byte > sbepp::make_view ( Byte * ptr,
const std::size_t size )
constexprnoexcept

Constructs view from memory buffer.

View will have the same byte type as provided buffer. Example:

std::array<char, N> buf;
buf.data(), buf.size()); // creates some_schema::messages::msg1<char>
Template Parameters
Viewview template
Bytebyte type
Parameters
ptrbuffer start
sizebuffer size
Returns
constructed view

◆ set_by_tag() [1/2]

template<typename Tag, typename View, typename Value, typename Cursor>
auto sbepp::set_by_tag ( View view,
Value && value,
Cursor && c ) -> decltype(view( detail::access_by_tag_tag{}, Tag{}, std::forward<Value>(value), std::forward<Cursor>(c)))
constexpr

Sets field value by tag using given cursor.

Template Parameters
Tagfield tag
Parameters
viewmessage or entry view
valuevalue to set
ccursor
Returns
the result of the corresponding setter, e.g. view.fieldName(value, c)

◆ set_by_tag() [2/2]

template<typename Tag, typename ViewOrSet, typename Value>
auto sbepp::set_by_tag ( ViewOrSet && viewOrSet,
Value && value ) -> decltype(std::forward<ViewOrSet>(viewOrSet)( detail::access_by_tag_tag{}, Tag{}, std::forward<Value>(value)))
constexprnoexcept

Sets field or set choice value by tag.

Template Parameters
Tagfield or set choice tag
Parameters
viewOrSetmessage, entry, composite view or set
valuevalue to set
Returns
the result of the corresponding setter, e.g. viewOrSet.fieldOrChoiceName(value)

◆ size_bytes() [1/2]

template<typename T>
std::size_t sbepp::size_bytes ( T v)
constexprnoexcept

Returns the size of the underlying data represented by message/group/entry/data/composite view, including headers.

In general case, for message/group/entry, the complexity is O(a^n) where n is the depth of the level. For composites and data it's O(1).

Parameters
vview object
Returns
size in bytes

◆ size_bytes() [2/2]

template<typename T, typename Byte>
std::size_t sbepp::size_bytes ( T v,
cursor< Byte > c )
constexprnoexcept

Similar to sbepp::size_bytes but has constant complexity because it expects c to be set at the end of v. Useful to read the whole message and then get its size in constant time. Not applicable to composites.

Parameters
vview object
ccursor
Returns
size in bytes

◆ size_bytes_checked()

template<typename View>
size_bytes_checked_result sbepp::size_bytes_checked ( View view,
std::size_t size )
constexprnoexcept

Calculates view size with additional safety checks.

Similar to size_bytes() but stops if view doesn't fit into the given size. Useful to check that incoming message is fully contained within given buffer.

Parameters
viewmessage or group view
sizebuffer size

◆ to_underlying()

template<typename Enum>
std::underlying_type< Enum >::type sbepp::to_underlying ( Enum e)
constexprnoexcept

Converts an enumeration to its underlying type. Equivalent to C++23 std::to_underlying()

Parameters
eenumerator
Returns
enumerator's underlying value

◆ visit() [1/6]

template<typename Visitor, typename Composite>
Visitor && sbepp::visit ( Composite view,
Visitor && visitor = {} )
constexpr

Visits a composite view.

Template Parameters
Visitorvisitor type
Parameters
viewcomposite view
visitorvisitor
Returns
forwarded reference to visitor
See also
Visit API

◆ visit() [2/6]

template<typename Visitor, typename Enum>
Visitor && sbepp::visit ( Enum e,
Visitor && visitor = {} )
constexpr

Visits an enum value.

Template Parameters
Visitorvisitor type
Parameters
eenum value to visit
visitorvisitor instance, must have on_enum_value member function with the signature equivalent to void on_enum_value(Enum, EnumValueTag)
Returns
forwarded reference to visitor

If e is one of validValue-s from schema, calls visitor.on_enum_value(e, EnumValueTag{}) where EnumValueTag is a matched value's tag that can be passed to enum_value_traits. Otherwise, calls visitor.on_enum_value(e, sbepp::unknown_enum_value_tag{}).

See also
Visit API

◆ visit() [3/6]

template<typename Visitor, typename Set>
Visitor && sbepp::visit ( Set s,
Visitor && visitor = {} )
constexpr

Visits set choices.

Template Parameters
Visitorvisitor type
Parameters
sset to visit
visitorvisitor instance, must have on_set_choice member function with the signature equivalent to void on_set_choice(bool, ChoiceTag).
Returns
forwarded reference to visitor

Visits set choices in order of their schema declaration. For each choice calls visitor.on_set_choice(choice_value, ChoiceTag{}), where choice_value is the bool value of a choice and ChoiceTag is its tag that can be passed to set_choice_traits.

See also
Visit API

◆ visit() [4/6]

template<typename Visitor, typename View, typename Cursor, typename = detail::enable_if_t<detail::is_cursor_visitable_view<View>::value>>
Visitor && sbepp::visit ( View view,
Cursor & c,
Visitor && visitor = {} )
constexpr

Visits a view using given cursor.

Template Parameters
Visitorvisitor type
Parameters
viewmessage, group or entry view
ccursor, passed as is to visitor
visitorvisitor
Returns
forwarded reference to visitor
See also
Visit API

◆ visit() [5/6]

template<typename Visitor, typename View, typename Cursor>
detail::enable_if_t< is_composite< View >::value, Visitor && > sbepp::visit ( View view,
Cursor & c,
Visitor && visitor = {} )
constexpr

Visits a composite view using given cursor.

Template Parameters
Visitorvisitor type
Parameters
viewcomposite view
ccursor, ignored
visitorvisitor
Returns
forwarded reference to visitor
Deprecated
Use non-cursor version instead. Will be removed in the next major update.
See also
Visit API

◆ visit() [6/6]

template<typename Visitor, typename View, typename = detail::enable_if_t<detail::is_cursor_visitable_view<View>::value>>
Visitor && sbepp::visit ( View view,
Visitor && visitor = {} )
constexpr

Visits a message, group or entry view.

Template Parameters
Visitorvisitor type
Parameters
viewmessage, group or entry view
visitorvisitor
Returns
forwarded reference to visitor
See also
Visit API

◆ visit_children() [1/4]

template<typename Visitor, typename View, typename Cursor, typename = detail::enable_if_t<detail::is_cursor_visitable_view<View>::value>>
Visitor && sbepp::visit_children ( View view,
Cursor & c,
Visitor && visitor = {} )
constexpr

Visits view's children using provided cursor.

Template Parameters
Visitorvisitor type
Parameters
viewmessage, group or entry view
ccursor, must point to the first view's child
visitorvisitor
Returns
forwarded reference to visitor
See also
Visit API

◆ visit_children() [2/4]

template<typename Visitor, typename View, typename Cursor>
detail::enable_if_t< is_composite< View >::value, Visitor && > sbepp::visit_children ( View view,
Cursor & c,
Visitor && visitor = {} )
constexpr

Visits composite children using provided cursor.

Template Parameters
Visitorvisitor type
Parameters
viewcomposite view
ccursor, ignored
visitorvisitor
Returns
forwarded reference to visitor
Deprecated
Use non-cursor version instead. Will be removed in the next major update.
See also
Visit API

◆ visit_children() [3/4]

template<typename Visitor, typename View, typename = detail::enable_if_t<detail::is_cursor_visitable_view<View>::value>>
Visitor && sbepp::visit_children ( View view,
Visitor && visitor = {} )
constexpr

Visits view's children.

Template Parameters
Visitorvisitor type
Parameters
viewmessage, group or entry view
visitorvisitor
Returns
forwarded reference to visitor
See also
Visit API

◆ visit_children() [4/4]

template<typename Visitor, typename View>
detail::enable_if_t< is_composite< View >::value, Visitor && > sbepp::visit_children ( View view,
Visitor && visitor = {} )
constexpr

Visits composite children using provided cursor.

Template Parameters
Visitorvisitor type
Parameters
viewcomposite view
visitorvisitor
Returns
forwarded reference to visitor
See also
Visit API

◆ visit_set()

template<typename Set, typename Visitor>
auto sbepp::visit_set ( const Set s,
Visitor && visitor ) -> decltype(s(detail::visit_set_tag{}, std::forward<Visitor>(visitor)))
constexprnoexcept

Visits set choices in order of their declaration.

Parameters
sset to visit
visitorvisitor. Must have signature void (bool choice_value, const char* choice_name)
Returns
forwarded reference to visitor
Deprecated
Deprecated in favor of sbepp::visit, will be removed in the next major update.

Variable Documentation

◆ default_init

default_init_t sbepp::default_init {}
inlineconstexpr

Helper to pass default_init_t to dynamic_array_ref::resize().

Example: ref.resize(n, sbepp::default_init);.

◆ nullopt

nullopt_t sbepp::nullopt {0}
inlineconstexpr

Helper constant used to initialize optional types with null value.

Example: msg.optionalField(sbepp::nullopt);