Provides seqan3::type_list and metaprogramming utilities for working on type lists and type packs. More...
Collaboration diagram for Type List:Typedefs | |
| template<typename ... types> | |
| using | seqan3::type_list = meta::list< types... > |
| Type that contains multiple types, an alias for meta::list. | |
Type pack traits (return a single type) | |
| template<ptrdiff_t idx, typename ... pack_t> | |
| using | seqan3::pack_traits::at = typename decltype(detail::at< idx, pack_t... >())::type |
| Return the type at given index from the type pack. More... | |
| template<typename ... pack_t> | |
| using | seqan3::pack_traits::front = typename decltype(detail::front< pack_t... >())::type |
| Return the first type from the type pack. More... | |
| template<typename ... pack_t> | |
| using | seqan3::pack_traits::back = typename decltype((std::type_identity< pack_t >{},...))::type |
| Return the last type from the type pack. More... | |
Type pack traits (return a type list) | |
| template<typename ... pack_t> | |
| using | seqan3::pack_traits::drop_front = typename decltype(detail::drop_front< pack_t... >())::type |
| Return a seqan3::type_list of all the types in the type pack, except the first. More... | |
| template<template< typename > typename trait_t, typename ... pack_t> | |
| using | seqan3::pack_traits::transform = seqan3::type_list< trait_t< pack_t >... > |
| Apply a transformation trait to every type in the pack and return a seqan3::type_list of the results. More... | |
| template<ptrdiff_t i, typename ... pack_t> | |
| using | seqan3::pack_traits::take = seqan3::list_traits::take< i, type_list< pack_t... > > |
Return a seqan3::type_list of the first n types in the type pack. More... | |
| template<ptrdiff_t i, typename ... pack_t> | |
| using | seqan3::pack_traits::drop = seqan3::list_traits::drop< i, type_list< pack_t... > > |
Return a seqan3::type_list of the types in the type pack, except the first n. More... | |
| template<ptrdiff_t i, typename ... pack_t> | |
| using | seqan3::pack_traits::take_last = seqan3::list_traits::take_last< i, type_list< pack_t... > > |
Return a seqan3::type_list of the last n types in the type pack. More... | |
| template<ptrdiff_t i, typename ... pack_t> | |
| using | seqan3::pack_traits::drop_last = seqan3::list_traits::drop_last< i, type_list< pack_t... > > |
Return a seqan3::type_list of the types the type pack, except the last n. More... | |
| template<ptrdiff_t i, typename ... pack_t> | |
| using | seqan3::pack_traits::split_after = seqan3::list_traits::split_after< i, type_list< pack_t... > > |
| Split a type pack into two parts returned as a pair of seqan3::type_list. More... | |
| template<typename replace_t , std::ptrdiff_t i, typename ... pack_t> | |
| using | seqan3::pack_traits::replace_at = decltype(seqan3::list_traits::replace_at< replace_t, i, type_list< pack_t... > >()) |
| Replace the type at the given index with the given type. More... | |
Type list traits (return a single type) | |
| template<ptrdiff_t idx, seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::at = typename decltype(detail::at< idx >(list_t{}))::type |
| Return the type at given index from the type list. More... | |
| template<seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::front = typename decltype(detail::front(list_t{}))::type |
| Return the first type from the type list. More... | |
| template<seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::back = typename decltype(detail::back(list_t{}))::type |
| Return the last type from the type list. More... | |
Type list traits (return a type list) | |
| template<typename ... lists_t> | |
| using | seqan3::list_traits::concat = decltype(detail::concat(lists_t{}...)) |
| Join two seqan3::type_list s into one. More... | |
| template<seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::drop_front = decltype(detail::drop_front(list_t{})) |
| Return a seqan3::type_list of all the types in the type list, except the first. More... | |
| template<ptrdiff_t i, seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::take = typename decltype(detail::split_after< i >(type_list<>{}, list_t{}))::first_type |
Return a seqan3::type_list of the first n types in the input type list. More... | |
| template<ptrdiff_t i, seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::drop = typename decltype(detail::split_after< i >(type_list<>{}, list_t{}))::second_type |
Return a seqan3::type_list of the types in the input type list, except the first n. More... | |
| template<ptrdiff_t i, seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::take_last = drop< size< list_t > - i, list_t > |
Return a seqan3::type_list of the last n types in the input type list. More... | |
| template<ptrdiff_t i, seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::drop_last = take< size< list_t > - i, list_t > |
Return a seqan3::type_list of the types the input type list, except the last n. More... | |
| template<ptrdiff_t i, seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::split_after = decltype(detail::split_after< i >(type_list<>{}, list_t{})) |
| Split a seqan3::type_list into two parts returned as a pair of seqan3::type_list. More... | |
| template<template< typename > typename trait_t, seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::transform = decltype(detail::transform< trait_t >(list_t{})) |
| Apply a transformation trait to every type in the list and return a seqan3::type_list of the results. More... | |
| template<typename replace_t , std::ptrdiff_t i, seqan3::detail::type_list_specialisation list_t> | |
| using | seqan3::list_traits::replace_at = decltype(detail::replace_at< replace_t >(detail::split_after< i >(type_list<>{}, list_t{}))) |
| Replace the type at the given index with the given type. More... | |
Type pack traits (return a value) | |
| template<typename ... pack_t> | |
| constexpr size_t | seqan3::pack_traits::size = sizeof...(pack_t) |
| The size of a type pack. More... | |
| template<typename query_t , typename ... pack_t> | |
| constexpr ptrdiff_t | seqan3::pack_traits::count = (SEQAN3_IS_SAME(query_t, pack_t) + ... + 0) |
| Count the occurrences of a type in a pack. More... | |
| template<typename query_t , typename ... pack_t> | |
| constexpr ptrdiff_t | seqan3::pack_traits::find = seqan3::pack_traits::detail::find<query_t, pack_t...>() |
| Get the index of the first occurrence of a type in a pack. More... | |
| template<template< typename > typename pred_t, typename ... pack_t> | |
| constexpr ptrdiff_t | seqan3::pack_traits::find_if = seqan3::pack_traits::detail::find_if<pred_t, pack_t...>() |
| Get the index of the first type in a pack that satisfies the given predicate. More... | |
| template<typename query_t , typename ... pack_t> | |
| constexpr bool | seqan3::pack_traits::contains = (find<query_t, pack_t...> != -1) |
| Whether a type occurs in a pack or not. More... | |
Type list traits (return a value) | |
| template<typename ... pack_t> | |
| constexpr size_t | seqan3::list_traits::size< type_list< pack_t... > > = sizeof...(pack_t) |
| The size of a type list. More... | |
| template<typename query_t , typename ... pack_t> | |
| constexpr ptrdiff_t | seqan3::list_traits::count< query_t, type_list< pack_t... > > |
| Count the occurrences of a type in a type list. More... | |
| template<typename query_t , typename ... pack_t> | |
| constexpr ptrdiff_t | seqan3::list_traits::find< query_t, type_list< pack_t... > > |
| Get the index of the first occurrence of a type in a type list. More... | |
| template<template< typename > typename pred_t, typename ... pack_t> | |
| constexpr ptrdiff_t | seqan3::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. More... | |
| template<typename query_t , seqan3::detail::type_list_specialisation list_t> | |
| constexpr bool | seqan3::list_traits::contains = (find<query_t, list_t> != -1) |
| Whether a type occurs in a type list or not. More... | |
Provides seqan3::type_list and metaprogramming utilities for working on type lists and type packs.
All traits are defined in the header <seqan3/core/type_list/traits.hpp>.
| using seqan3::pack_traits::at = typedef typename decltype(detail::at<idx, pack_t...>())::type |
Return the type at given index from the type pack.
| idx | The index; must be smaller than the size of the pack. |
| pack_t | The type pack. |
Negative indexes are supported (e.g. at<-1, int, double, bool &> is bool &).
| using seqan3::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 seqan3::pack_traits::back = typedef typename decltype((std::type_identity<pack_t>{}, ...))::type |
Return the last type from the type pack.
| pack_t | The type pack. |
Notably faster than seqan3::pack_traits::at<size<pack...> - 1, pack...> (no recursive template instantiations).
| using seqan3::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 seqan3::pack_traits::at<size<pack...> - 1, pack...> (no recursive template instantiations).
| using seqan3::list_traits::concat = typedef decltype(detail::concat(lists_t{}...)) |
Join two seqan3::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 seqan3::list_traits::drop = typedef typename decltype(detail::split_after<i>(type_list<>{}, list_t{}))::second_type |
Return a seqan3::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 seqan3::pack_traits::drop = typedef seqan3::list_traits::drop<i, type_list<pack_t...> > |
Return a seqan3::type_list of the types in the type pack, except the first n.
| i | The amount to drop; must be >= 0 and <= the size of the type pack. |
| pack_t | The type pack. |
| using seqan3::pack_traits::drop_front = typedef typename decltype(detail::drop_front<pack_t...>())::type |
Return a seqan3::type_list of all the types in the type pack, except the first.
| pack_t | The type pack. |
| using seqan3::list_traits::drop_front = typedef decltype(detail::drop_front(list_t{})) |
Return a seqan3::type_list of all the types in the type list, except the first.
| list_t | The (input) type list. |
| using seqan3::list_traits::drop_last = typedef take<size<list_t> - i, list_t> |
Return a seqan3::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 seqan3::pack_traits::drop_last = typedef seqan3::list_traits::drop_last<i, type_list<pack_t...> > |
Return a seqan3::type_list of the types the type pack, except the last n.
| i | The amount to drop; must be >= 0 and <= the size of the type pack. |
| pack_t | The type pack. |
| using seqan3::pack_traits::front = typedef typename decltype(detail::front<pack_t...>())::type |
Return the first type from the type pack.
| pack_t | The type pack. |
| using seqan3::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 seqan3::list_traits::replace_at = typedef decltype(detail::replace_at<replace_t>(detail::split_after<i>(type_list<>{}, 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 seqan3::pack_traits::replace_at = typedef decltype(seqan3::list_traits::replace_at<replace_t, i, type_list<pack_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. |
| pack_t | The (input) type pack. |
| using seqan3::list_traits::split_after = typedef decltype(detail::split_after<i>(type_list<>{}, list_t{})) |
Split a seqan3::type_list into two parts returned as a pair of seqan3::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 seqan3::pack_traits::split_after = typedef seqan3::list_traits::split_after<i, type_list<pack_t...> > |
Split a type pack into two parts returned as a pair of seqan3::type_list.
| i | The number of elements after which to split; must be >= 0 and <= the size of the type pack. |
| pack_t | The type pack. |
| using seqan3::list_traits::take = typedef typename decltype(detail::split_after<i>(type_list<>{}, list_t{}))::first_type |
Return a seqan3::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 seqan3::pack_traits::take = typedef seqan3::list_traits::take<i, type_list<pack_t...> > |
Return a seqan3::type_list of the first n types in the type pack.
| i | The target size; must be >= 0 and <= the size of the type pack. |
| pack_t | The type pack. |
| using seqan3::list_traits::take_last = typedef drop<size<list_t> - i, list_t> |
Return a seqan3::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 seqan3::pack_traits::take_last = typedef seqan3::list_traits::take_last<i, type_list<pack_t...> > |
Return a seqan3::type_list of the last n types in the type pack.
| i | The target size; must be >= 0 and <= the size of the type pack. |
| pack_t | The type pack. |
| using seqan3::pack_traits::transform = typedef seqan3::type_list<trait_t<pack_t>...> |
Apply a transformation trait to every type in the pack and return a seqan3::type_list of the results.
| trait_t | The transformation trait, can be an alias template, e.g. a transformation trait shortcut. |
| pack_t | The type pack. |
The transformation trait given as first argument can 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 pack.
| using seqan3::list_traits::transform = typedef decltype(detail::transform<trait_t>(list_t{})) |
Apply a transformation trait to every type in the list and return a seqan3::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 pack or not.
| query_t | The type you are searching for. |
| pack_t | The type pack. |
true or false.i, where i is the index of the first occurrence
|
inlineconstexpr |
Whether a type occurs in a type list or not.
| query_t | The type you are searching for. |
| pack_t | The type pack. |
true or false.i, where i is the index of the first occurrence
|
inlineconstexpr |
Count the occurrences of a type in a pack.
| query_t | The type you are searching for. |
| pack_t | The type pack. |
query_t in pack_t.
|
inlineconstexpr |
Count the occurrences of a type in a type list.
| query_t | The type you are searching for. |
| pack_t | The type pack. |
query_t in pack_t.
|
inlineconstexpr |
Get the index of the first occurrence of a type in a pack.
| query_t | The type you are searching for. |
| pack_t | The type pack. |
query_t in pack_t or -1 if it is not contained.i, where i is the return value
|
inlineconstexpr |
Get the index of the first occurrence of a type in a type list.
| query_t | The type you are searching for. |
| pack_t | The type pack. |
query_t in pack_t or -1 if it is not contained.i, where i is the return value
|
inlineconstexpr |
Get the index of the first type in a pack that satisfies the given predicate.
| pred_t | The predicate that is being evaluated (a class template). |
| pack_t | The type pack. |
-1 if no types match.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 |
Get the index of the first type in a type list that satisfies the given predicate.
| pred_t | The predicate that is being evaluated (a class template). |
| pack_t | The type pack. |
-1 if no types match.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 pack.
| pack_t | The type pack. |
sizeof...(pack_t)
|
inlineconstexpr |
The size of a type list.
| pack_t | The type pack. |
sizeof...(pack_t)