variant
variant.hSimilar to:
std::variantFor C++11 and above.
template <typename... TTypes>
class variantA variadic class that can contain one a several specified types in a type safe manner.
C++11 and C++14 support up to 32 types for visitor callback callbacks.
C++17 and above supports any number of visitor callback types.
Accepts functors, etl::overload and etl::visitor types as visitor callbacks.
Accepts etl::visit since 20.28.0.
Error exception types
class variant_exceptionDescription
The base for all variant exceptions.
Derived from etl::exception.
class variant_incorrect_type_exceptionDescription
The error types emitted when a non-supported type is requested from the variant.
Construction
ETL_CONSTEXPR14 variant()Description
Default constructor.
template <typename T>
ETL_CONSTEXPR14 variant(T&& value)Description
Constructor from a value.
template <typename T, typename... TArgs>
ETL_CONSTEXPR14 explicit variant(etl::in_place_type_t<T>, TArgs&&... args)Description
Construct T from arguments.
template <size_t Index, typename... TArgs>
ETL_CONSTEXPR14 explicit variant(etl::in_place_index_t<Index>, TArgs&&... args)Description
Construct from Index using args.
template <typename T, typename U, typename... TArgs>
ETL_CONSTEXPR14 explicit variant(etl::in_place_type_t<T>,
std::initializer_list<U> init,
TArgs&&... args)Description
Construct from type, initializer_list and arguments.
template <size_t Index, typename U, typename... TArgs>
ETL_CONSTEXPR14 explicit variant(etl::in_place_index_t<Index>,
std::initializer_list<U> init,
TArgs&&... args)Description
Construct from Index, initializer_list and arguments.
ETL_CONSTEXPR14 variant(const variant& other)Description
Copy constructor.
ETL_CONSTEXPR14 variant(variant&& other)Description
Move constructor.
Operations
template <typename T, typename... TArgs>
T& emplace(TArgs&&... args)Description
Set to type T using the construction parameters args.
template <typename T>
variant& operator =(T&& value)Description
variant& operator =(const variant& other)Description
Copies other to the current variant.
variant& operator =(variant&& other)Description
Moves other to the current variant.
constexpr bool valueless_by_exception() const noexceptDescription
Returns true if the type id is etl::variant_npos.
constexpr size_t index() const noexceptDescription
Returns the index of the type contained in the variant.
Returns etl::variant_npos if the variant does not hold a valid type.
void swap(variant& rhs) noexceptDescription
Swaps rhs with the current variant.
Access
Non-member functions
get
template <size_t Index, typename... TTypes>
ETL_CONSTEXPR14 etl::variant_alternative_t<Index, etl::variant<TTypes...>>&
get(etl::variant<TTypes...>& v)Description
Get the value based on Index.
If Index matches the current index of the variant, returns a reference to the stored value, otherwise, asserts etl::variant_incorrect_type_exception.
Parameters
A reference to a variant.
template <size_t Index, typename... TTypes>
ETL_CONSTEXPR14 etl::variant_alternative_t<Index, etl::variant<TTypes...>>&&
get(etl::variant<TTypes...>&& v)Description
Get the value based on Index.
If Index matches the current index of the variant, returns a reference to the stored value, otherwise, asserts etl::variant_incorrect_type_exception.
Parameters
An rvalue reference to a variant.
template <size_t Index, typename... TTypes>
ETL_CONSTEXPR14 const etl::variant_alternative_t<Index, const etl::variant<TTypes...>>&
get(const etl::variant<TTypes...>& v)Description
Get the value based on Index.
If Index matches the current index of the variant, returns a reference to the stored value, otherwise, asserts etl::variant_incorrect_type_exception.
Parameters
A const reference to a variant.
template <size_t Index, typename... TTypes>
ETL_CONSTEXPR14 const etl::variant_alternative_t<Index, const etl::variant<TTypes...>>&&
get(const etl::variant<TTypes...>&& v)Description
Get the value based on Index.
If Index matches the current index of the variant, returns a reference to the stored value, otherwise, asserts etl::variant_incorrect_type_exception.
Parameters
A const rvalue reference to a variant.
template <typename T, typename... TTypes>
ETL_CONSTEXPR14 T& get(etl::variant<TTypes...>& v)Description
Get the value based on T.
If T matches the current type stored in the variant, returns a reference to the stored value, otherwise, asserts etl::variant_incorrect_type_exception.
Parameters
A reference to a variant.
template <typename T, typename... TTypes>
ETL_CONSTEXPR14 T&& get(etl::variant<TTypes...>&& v)Description
Get the value based on T.
If T matches the current type stored in the variant, returns a reference to the stored value, otherwise, asserts etl::variant_incorrect_type_exception.
Parameters
An rvalue reference to a variant.
template <typename T, typename... TTypes>
ETL_CONSTEXPR14 const T& get(const etl::variant<TTypes...>& v)Description
Get the value based on T.
If T matches the current type stored in the variant, returns a reference to the stored value, otherwise, asserts etl::variant_incorrect_type_exception.
Parameters
A const reference to a variant.
template <typename T, typename... TTypes>
ETL_CONSTEXPR14 const T&& get(const etl::variant<TTypes...>&& v)Description
Get the value based on T.
If T matches the current type stored in the variant, returns a reference to the stored value, otherwise, asserts etl::variant_incorrect_type_exception.
Parameters
A const rvalue reference to a variant.
get_if
template <size_t Index, typename... TTypes>
ETL_CONSTEXPR14 etl::add_pointer_t<etl::variant_alternative_t<Index, etl::variant<TTypes...>>>
get_if(etl::variant<TTypes...>* pv) noexceptDescription
Get the value based on Index.
If Index matches the current index of the variant, returns a pointer to the stored value, otherwise returns nullptr.
Parameters
A pointer to a variant.
template <size_t Index, typename... TTypes>
ETL_CONSTEXPR14 etl::add_pointer_t<const etl::variant_alternative_t<Index, etl::variant<TTypes...>>>
get_if(const etl::variant<TTypes...>* pv) noexceptDescription
Get the value based on Index.
If Index matches the current index of the variant, returns a const pointer to the stored value, otherwise returns nullptr.
Parameters
A const pointer to a variant.
template <typename T, typename... TTypes>
ETL_CONSTEXPR14 etl::add_pointer_t<T> get_if(etl::variant<TTypes...>* pv) noexceptDescription
Get the value based on T.
If T matches the current type stored in the variant, returns a pointer to the stored value, otherwise return nullptr.
Parameters
An pointer to a variant.
template <typename T, typename... TTypes>
ETL_CONSTEXPR14 etl::add_pointer_t<const T> get_if(const etl::variant<TTypes...>* pv) noexceptDescription
Get the value based on T.
If T matches the current type stored in the variant, returns a const pointer to the stored value, otherwise return nullptr.
Parameters
An const pointer to a variant.
Other
struct monostateDescription
A default constructible type.
For use as the first state to turn a non-default constructible variant into a default constructible variant.
template <typename... TTypes>
void swap(etl::variant<TTypes...>& lhs, etl::variant<TTypes...>& rhs)Description
Swaps lhs and rhs.
template <typename... TTypes>
struct variant_size<etl::variant<TTypes...>>Description
The member constant value contains the number of types.
For C++17 and above.
template <typename... TTypes>
inline constexpr size_t variant_size_v = variant_size<TTypes...>::value;Description
Has the value equal to the number of types.
Tests
Non-member functions
template <typename T, typename... TTypes>
ETL_CONSTEXPR14 bool holds_alternative(const etl::variant<TTypes...>& v) noexceptDescription
Checks if the variant v holds the alternative T.
template <size_t Index, typename... TTypes>
ETL_CONSTEXPR14 bool holds_alternative(const etl::variant<TTypes...>& v) noexceptDescription
Checks if the variant v holds the alternative Index.
template <typename... TTypes>
ETL_CONSTEXPR14 bool holds_alternative(size_t index, const etl::variant<TTypes...>& v) noexceptDescription
Checks if the variant v holds the alternative index.
Visitation
For etl::visitor
For C++11 and C++14 the maximum number of visitor types is 32. Code size may be minimised if one of the following macros are defined.
ETL_VARIANT_CPP11_MAX_8_TYPES
ETL_VARIANT_CPP11_MAX_16_TYPES
ETL_VARIANT_CPP11_MAX_24_TYPESDescription
C++17 and above support any number of visitor callback types.
etl::variant provides member functions that support two methods of visitation.
void accept_visitor(etl::visitor<TTypes...>& v)Description
Accepts an etl::visitor derived type.
Deprecated from 20.36.0
void accept_visitor(etl::visitor<TTypes...>& v) constDescription
Accepts an etl::visitor derived type.
Deprecated
Since: 20.36.0
void accept(etl::visitor<TTypes...>& v)Description
Accepts an etl::visitor derived type.
Since: 20.36.0
void accept(etl::visitor<TTypes...>& v) constDescription
Accepts an etl::visitor derived type.
Since: 20.36.0
See visitor
template <typename TVisitor>
void accept_functor(TVisitor& v)Description
Accepts a functor that overrides operator() for each type.
Deprecated since 20.36.0
template <typename TVisitor>
void accept_functor(TVisitor& v) constDescription
Accepts a functor that overrides operator() for each type.
Deprecated since 20.36.0
template <typename TVisitor>
void accept(TVisitor& v)Description
Accepts a functor that overrides operator() for each type.
Since: 20.36.0
template <typename TVisitor>
void accept(TVisitor& v) constDescription
Accepts a functor that overrides operator() for each type.
Since: 20.36.0
See overload
Visitation
For STL style etl::visit.
Since: 20.28.0
The ETL implements an STL style visit function.