SeqAn3  3.0.3
The Modern C++ library for sequence analysis.
traits.hpp
Go to the documentation of this file.
1 // -----------------------------------------------------------------------------------------------------
2 // Copyright (c) 2006-2020, Knut Reinert & Freie Universität Berlin
3 // Copyright (c) 2016-2020, Knut Reinert & MPI für molekulare Genetik
4 // This file may be used, modified and/or redistributed under the terms of the 3-clause BSD-License
5 // shipped with this file and also available at: https://github.com/seqan/seqan3/blob/master/LICENSE.md
6 // -----------------------------------------------------------------------------------------------------
7 
13 #pragma once
14 
15 #include <seqan3/std/type_traits>
16 
19 
20 // ----------------------------------------------------------------------------
21 // seqan3::list_traits::detail
22 // ----------------------------------------------------------------------------
23 
24 namespace seqan3::list_traits::detail
25 {
26 
32 template <ptrdiff_t idx, typename ...pack_t>
33 std::type_identity<seqan3::pack_traits::at<idx, pack_t...>> at(type_list<pack_t...>);
34 
39 template <typename ...pack_t>
40 std::type_identity<seqan3::pack_traits::front<pack_t...>> front(type_list<pack_t...>);
41 
46 template <typename ...pack_t>
47 std::type_identity<seqan3::pack_traits::back<pack_t...>> back(type_list<pack_t...>);
48 
54 template <typename ...pack1_t,
55  typename ...pack2_t>
56 type_list<pack1_t..., pack2_t...> concat(type_list<pack1_t...>, type_list<pack2_t...>);
57 
64 template <typename ...pack1_t,
65  typename ...pack2_t,
66  typename ...more_lists_t>
67 auto concat(type_list<pack1_t...>, type_list<pack2_t...>, more_lists_t ...)
68 {
69  return concat(type_list<pack1_t..., pack2_t...>{}, more_lists_t{}...);
70 }
71 
76 template <typename ...pack_t>
77 pack_traits::drop_front<pack_t...> drop_front(type_list<pack_t...>);
78 
84 template <template <typename> typename trait_t, typename ...pack_t>
85 pack_traits::transform<trait_t, pack_t...> transform(type_list<pack_t...>);
86 
92 template <ptrdiff_t idx,
93  typename ...pack1_t>
94 pack_traits::split_after<idx, pack1_t...> split_after(type_list<pack1_t...>);
95 
102 template <typename replace_t,
103  ptrdiff_t idx,
104  typename ...pack_t>
105 pack_traits::replace_at<replace_t, idx, pack_t...> replace_at(type_list<pack_t...>);
106 
107 } // namespace seqan3::list_traits::detail
108 
109 // ----------------------------------------------------------------------------
110 // seqan3::list_traits
111 // ----------------------------------------------------------------------------
112 
114 namespace seqan3::list_traits
115 {
116 
122 template <typename list_t>
123  requires seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>
124 inline constexpr size_t size = 0;
126 
133 template <typename ...pack_t>
134 inline constexpr size_t size<type_list<pack_t...>> = sizeof...(pack_t);
135 
137 template <typename query_t, typename list_t>
138  requires seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>
139 inline constexpr ptrdiff_t count = -1;
141 
148 template <typename query_t, typename ...pack_t>
149 inline constexpr ptrdiff_t count<query_t, type_list<pack_t...>> =
150  seqan3::pack_traits::count<query_t, pack_t...>;
151 
153 template <typename query_t, typename list_t>
154  requires seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>
155 inline constexpr ptrdiff_t find = -1;
157 
164 template <typename query_t, typename ...pack_t>
165 inline constexpr ptrdiff_t find<query_t, type_list<pack_t...>> =
166  seqan3::pack_traits::detail::find<query_t, pack_t...>();
167 
169 template <template <typename> typename pred_t, typename list_t>
170  requires seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>
171 inline constexpr ptrdiff_t find_if = -1;
173 
180 template <template <typename> typename pred_t, typename ...pack_t>
181 inline constexpr ptrdiff_t find_if<pred_t, type_list<pack_t...>> =
182  seqan3::pack_traits::detail::find_if<pred_t, pack_t...>();
183 
190 template <typename query_t, typename list_t>
192  requires seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>
194 inline constexpr bool contains = (find<query_t, list_t> != -1);
195 
197 
218 template <ptrdiff_t idx, typename list_t>
220  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) &&
221  ((idx >= 0 && idx < size<list_t>) || (-idx <= size<list_t>))
223 using at = typename decltype(detail::at<idx>(list_t{}))::type;
224 
238 template <typename list_t>
240  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) && (size<list_t> > 0)
242 using front = typename decltype(detail::front(list_t{}))::type;
243 
260 template <typename list_t>
262  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) && (size<list_t> > 0)
264 using back = typename decltype(detail::back(list_t{}))::type;
265 
267 
288 template <typename ...lists_t>
290  requires (seqan3::detail::template_specialisation_of<lists_t, seqan3::type_list> && ...)
292 using concat = decltype(detail::concat(lists_t{}...));
293 
307 template <typename list_t>
309  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) && (size<list_t> > 0)
311 using drop_front = decltype(detail::drop_front(list_t{}));
312 
327 template <ptrdiff_t i, typename list_t>
329  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) && (i >= 0 && i <= size<list_t>)
331 using take = typename decltype(detail::split_after<i>(list_t{}))::first_type;
332 
347 template <ptrdiff_t i, typename list_t>
349  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) && (i >= 0 && i <= size<list_t>)
351 using drop = typename decltype(detail::split_after<i>(list_t{}))::second_type;
352 
367 template <ptrdiff_t i, typename list_t>
369  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) && (i >= 0 && i <= size<list_t>)
371 using take_last = drop<size<list_t> - i, list_t>;
372 
387 template <ptrdiff_t i, typename list_t>
389  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) && (i >= 0 && i <= size<list_t>)
391 using drop_last = take<size<list_t> - i, list_t>;
392 
407 template <ptrdiff_t i, typename list_t>
409  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) && (i >= 0 && i <= size<list_t>)
411 using split_after = decltype(detail::split_after<i>(list_t{}));
412 
430 template <template <typename> typename trait_t, typename list_t>
432  requires seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>
434 using transform = decltype(detail::transform<trait_t>(list_t{}));
435 
451 template <typename replace_t, std::ptrdiff_t i, typename list_t>
453  requires (seqan3::detail::template_specialisation_of<list_t, seqan3::type_list>) && (i >= 0 && i < size<list_t>)
455 using replace_at = decltype(detail::replace_at<replace_t, i>(list_t{}));
456 
458 
459 } // namespace seqan3::list_traits
decltype(detail::split_after< i >(list_t{})) split_after
Split a seqan3::type_list into two parts returned as a pair of seqan3::type_list.
Definition: traits.hpp:411
typename decltype(detail::split_after< i >(list_t{}))::first_type take
Return a seqan3::type_list of the first n types in the input type list.
Definition: traits.hpp:331
meta::list< types... > type_list
Type that contains multiple types, an alias for meta::list.
Definition: type_list.hpp:31
decltype(detail::concat(lists_t{}...)) concat
Join two seqan3::type_list s into one.
Definition: traits.hpp:292
constexpr bool contains
Whether a type occurs in a type list or not.
Definition: traits.hpp:194
drop< size< list_t > - i, list_t > take_last
Return a seqan3::type_list of the last n types in the input type list.
Definition: traits.hpp:371
typename decltype(detail::front(list_t{}))::type front
Return the first type from the type list.
Definition: traits.hpp:242
take< size< list_t > - i, list_t > drop_last
Return a seqan3::type_list of the types the input type list, except the last n.
Definition: traits.hpp:391
decltype(detail::replace_at< replace_t, i >(list_t{})) replace_at
Replace the type at the given index with the given type.
Definition: traits.hpp:455
typename decltype(detail::split_after< i >(list_t{}))::second_type drop
Return a seqan3::type_list of the types in the input type list, except the first n.
Definition: traits.hpp:351
typename decltype(detail::at< idx >(list_t{}))::type at
Return the type at given index from the type list.
Definition: traits.hpp:223
decltype(detail::transform< trait_t >(list_t{})) transform
Apply a transformation trait to every type in the list and return a seqan3::type_list of the results.
Definition: traits.hpp:434
typename decltype(detail::back(list_t{}))::type back
Return the last type from the type list.
Definition: traits.hpp:264
decltype(detail::drop_front(list_t{})) drop_front
Return a seqan3::type_list of all the types in the type list, except the first.
Definition: traits.hpp:311
decltype(detail::replace_at< replace_t, i, pack_t... >(std::make_index_sequence< size< pack_t... > >{})) replace_at
Replace the type at the given index with the given type.
Definition: traits.hpp:469
typename decltype(detail::drop_front< pack_t... >())::type drop_front
Return a seqan3::type_list of all the types in the type pack, except the first.
Definition: traits.hpp:321
typename decltype((std::type_identity< pack_t >{},...))::type back
Return the last type from the type pack.
Definition: traits.hpp:296
constexpr ptrdiff_t count
Count the occurrences of a type in a pack.
Definition: traits.hpp:168
typename decltype(detail::at< idx, pack_t... >())::type at
Return the type at given index from the type pack.
Definition: traits.hpp:255
decltype(detail::split_after< i, pack_t... >(type_list<>{})) split_after
Split a type pack into two parts returned as a pair of seqan3::type_list.
Definition: traits.hpp:447
typename decltype(detail::front< pack_t... >())::type front
Return the first type from the type pack.
Definition: traits.hpp:274
constexpr size_t size
The size of a type pack.
Definition: traits.hpp:150
seqan3::type_list< trait_t< pack_t >... > transform
Apply a transformation trait to every type in the pack and return a seqan3::type_list of the results.
Definition: traits.hpp:341
Namespace containing traits for working on seqan3::type_list.
Provides C++20 additions to the type_traits header.
Provides seqan3::type_list.
Provides various traits for template packs.