Provides bio::meta::type_list and metaprogramming utilities for working on type lists. More...
Classes | |
struct | bio::meta::type_list< types > |
Type that contains multiple types. More... | |
Type list traits (return a single type) | |
template<ptrdiff_t idx, typename list_t > | |
using | bio::meta::list_traits::at = typename decltype(detail::at< idx >(list_t{}))::type |
Return the type at given index from the type list. | |
template<typename list_t > | |
using | bio::meta::list_traits::front = typename decltype(detail::front(list_t{}))::type |
Return the first type from the type list. | |
template<typename list_t > | |
using | bio::meta::list_traits::back = typename decltype(detail::back(list_t{}))::type |
Return the last type from the type list. | |
Type list traits (return a type list) | |
template<typename... lists_t> | |
using | bio::meta::list_traits::concat = decltype(detail::concat(lists_t{}...)) |
Join two meta::type_list s into one. | |
template<typename list_t > | |
using | bio::meta::list_traits::drop_front = decltype(detail::drop_front(list_t{})) |
Return a meta::type_list of all the types in the type list, except the first. | |
template<ptrdiff_t i, typename list_t > | |
using | bio::meta::list_traits::take = typename decltype(detail::split_after< i >(list_t{}))::first_type |
Return a meta::type_list of the first n types in the input type list. | |
template<ptrdiff_t i, typename list_t > | |
using | bio::meta::list_traits::drop = typename decltype(detail::split_after< i >(list_t{}))::second_type |
Return a meta::type_list of the types in the input type list, except the first n . | |
template<ptrdiff_t i, typename list_t > | |
using | bio::meta::list_traits::take_last = drop< size< list_t > - i, list_t > |
Return a meta::type_list of the last n types in the input type list. | |
template<ptrdiff_t i, typename list_t > | |
using | bio::meta::list_traits::drop_last = take< size< list_t > - i, list_t > |
Return a meta::type_list of the types the input type list, except the last n . | |
template<ptrdiff_t i, typename list_t > | |
using | bio::meta::list_traits::split_after = decltype(detail::split_after< i >(list_t{})) |
Split a meta::type_list into two parts returned as a pair of meta::type_list. | |
template<template< typename > typename trait_t, typename list_t > | |
using | bio::meta::list_traits::transform = decltype(detail::transform< trait_t >(list_t{})) |
Apply a transformation trait to every type in the list and return a meta::type_list of the results. | |
template<typename replace_t , std::ptrdiff_t i, typename list_t > | |
using | bio::meta::list_traits::replace_at = decltype(detail::replace_at< replace_t, i >(list_t{})) |
Replace the type at the given index with the given type. | |
template<size_t count, typename t > | |
using | bio::meta::list_traits::repeat = decltype(detail::repeat< count, t >()) |
Create a type list with the given type repeated count times.. | |
Type list traits (return a value) | |
template<typename... pack_t> | |
constexpr size_t | bio::meta::list_traits::size< type_list< pack_t... > > = sizeof...(pack_t) |
The size of a type list. | |
template<typename query_t , typename... pack_t> | |
constexpr ptrdiff_t | bio::meta::list_traits::count< query_t, type_list< pack_t... > > = meta::detail::pack_traits::count<query_t, pack_t...> |
Count the occurrences of a type in a type list. | |
template<typename query_t , typename... pack_t> | |
constexpr ptrdiff_t | bio::meta::list_traits::find< query_t, type_list< pack_t... > > |
Get the index of the first occurrence of a type in a type list. | |
template<template< typename > typename pred_t, typename... pack_t> | |
constexpr ptrdiff_t | bio::meta::list_traits::find_if< pred_t, type_list< pack_t... > > |
Get the index of the first type in a type list that satisfies the given predicate. | |
template<typename query_t , typename list_t > | |
constexpr bool | bio::meta::list_traits::contains = (find<query_t, list_t> != -1) |
Whether a type occurs in a type list or not. | |
Provides bio::meta::type_list and metaprogramming utilities for working on type lists.
All traits on type lists are defined in the header <bio/meta/type_list/traits.hpp>
.
using bio::meta::list_traits::at = typedef typename decltype(detail::at<idx>(list_t{}))::type |
Return the type at given index from the type list.
idx | The index; must be smaller than the size of the type list. |
list_t | The type_list. |
Negative indexes are supported (e.g. at<-1, type_list<int, double, bool &>>
is bool &
).
using bio::meta::list_traits::back = typedef typename decltype(detail::back(list_t{}))::type |
Return the last type from the type list.
list_t | The type list. |
Notably faster than meta::detail::pack_traits::at<size<pack...> - 1, pack...>
(no recursive template instantiations).
using bio::meta::list_traits::concat = typedef decltype(detail::concat(lists_t{}...)) |
Join two meta::type_list s into one.
list1_t | The first (input) type list. |
list2_t | The second (input) type list. |
Complexity is independent of the number of types in each list.
using bio::meta::list_traits::drop = typedef typename decltype(detail::split_after<i>(list_t{}))::second_type |
Return a meta::type_list of the types in the input type list, except the first n
.
i | The amount to drop; must be >= 0 and <= the size of the input type list. |
list_t | The (input) type list. |
using bio::meta::list_traits::drop_front = typedef decltype(detail::drop_front(list_t{})) |
Return a meta::type_list of all the types in the type list, except the first.
list_t | The (input) type list. |
using bio::meta::list_traits::drop_last = typedef take<size<list_t> - i, list_t> |
Return a meta::type_list of the types the input type list, except the last n
.
i | The amount to drop; must be >= 0 and <= the size of the input type list. |
list_t | The (input) type list. |
using bio::meta::list_traits::front = typedef typename decltype(detail::front(list_t{}))::type |
Return the first type from the type list.
list_t | The type list. |
using bio::meta::list_traits::repeat = typedef decltype(detail::repeat<count, t>()) |
Create a type list with the given type repeated count
times..
count | The number of repititions. |
t | The type to repeat |
However, with a constant of 0.2, e.g. repeat<10,int> results in 2-3 instantiations.
using bio::meta::list_traits::replace_at = typedef decltype(detail::replace_at<replace_t, i>(list_t{})) |
Replace the type at the given index with the given type.
replace_t | The type to replace the old type with. |
i | The index of the type to be replaced. |
list_t | The (input) type list. |
using bio::meta::list_traits::split_after = typedef decltype(detail::split_after<i>(list_t{})) |
Split a meta::type_list into two parts returned as a pair of meta::type_list.
i | The number of elements after which to split; must be >= 0 and <= the size of the input type list. |
list_t | The (input) type list. |
using bio::meta::list_traits::take = typedef typename decltype(detail::split_after<i>(list_t{}))::first_type |
Return a meta::type_list of the first n
types in the input type list.
i | The target size; must be >= 0 and <= the size of the input type list. |
list_t | The (input) type list. |
using bio::meta::list_traits::take_last = typedef drop<size<list_t> - i, list_t> |
Return a meta::type_list of the last n
types in the input type list.
i | The target size; must be >= 0 and <= the size of the input type list. |
list_t | The (input) type list. |
using bio::meta::list_traits::transform = typedef decltype(detail::transform<trait_t>(list_t{})) |
Apply a transformation trait to every type in the list and return a meta::type_list of the results.
trait_t | The trait to transform, must be an alias template, e.g. a transformation trait shortcut. |
list_t | The (input) type list. |
The transformation trait given as first argument must be an alias template, e.g. std::type_identity_t, not std::type_identity. The alias must take exactly one argument and be defined for all types in the input list.
|
inlineconstexpr |
Whether a type occurs in a type list or not.
i
, where i
is the index of the first occurrence
|
inlineconstexpr |
Count the occurrences of a type in a type list.
|
inlineconstexpr |
Get the index of the first occurrence of a type in a type list.
i
, where i
is the return value
|
inlineconstexpr |
Get the index of the first type in a type list that satisfies the given predicate.
Note that the predicate must be given as a type template (variable templates cannot be passed as template arguments unfortunately). This means e.g. find_if<std::is_integral, float, double, int, float>
(not std::is_integral_v
!).
i
, where i
is the return valueOther operations: O(n), possibly == i
, where i
is the return value
Only the predicate is instantiated.
|
inlineconstexpr |
The size of a type list.