100 template <
typename underlying_adaptor_t>
114 constexpr
deep() noexcept = default;
117 constexpr
deep & operator=(
deep const &) noexcept = default;
118 constexpr
deep & operator=(
deep &&) noexcept = default;
136 template <
std::ranges::input_range urng_t, typename underlying_adaptor_t_>
137 static constexpr auto
impl(urng_t && urange, underlying_adaptor_t_ && deep_adaptor)
139 static_assert(std::same_as<underlying_adaptor_t_, underlying_adaptor_t>,
140 "Internally stored deep-adaptor does not match!");
142 constexpr
size_t range_dimension = range_dimension_v<urng_t>;
147 return recursive_adaptor<range_dimension>(std::forward<underlying_adaptor_t_>(deep_adaptor))(urange);
171 template <std::
size_t range_dimension>
174 if constexpr (range_dimension > 1u)
177 = [adaptor =
recursive_adaptor<range_dimension - 1u>(std::forward<underlying_adaptor_t>(deep_adaptor))]
178 (
auto && inner_range)
182 return adaptor(
std::forward<decltype(inner_range)>(inner_range));
207 template <
typename first_arg_t,
typename ...stored_arg_types>
209 requires (!std::ranges::input_range<first_arg_t>)
211 constexpr auto operator()(first_arg_t && first, stored_arg_types && ...args)
const
216 auto adaptor_closure = std::get<0>(this->
arguments)(std::forward<first_arg_t>(first),
217 std::forward<stored_arg_types>(args)...);
219 return deep<decltype(adaptor_closure)>{
std::move(adaptor_closure)};
228 auto adaptor_closure = std::get<0>(this->
arguments)();
230 return deep<decltype(adaptor_closure)>{
std::move(adaptor_closure)};
245 template <std::ranges::input_range urng_t,
typename ...stored_arg_types>
247 requires (
sizeof...(stored_arg_types) > 0)
249 constexpr auto operator()(urng_t && urange, stored_arg_types && ...args)
const
251 auto adaptor_closure = std::get<0>(this->
arguments)(std::forward<stored_arg_types>(args)...);
252 deep<decltype(adaptor_closure)> deep_adaptor{
std::move(adaptor_closure)};
253 return deep_adaptor(std::forward<urng_t>(urange));
262 template <
typename underlying_adaptor_t>
CRTP-base to simplify the definition of range adaptor closure objects and similar types.
Definition: detail.hpp:79
std::tuple< stored_args_ts... > arguments
Stores the arguments.
Definition: detail.hpp:82
A wrapper type around an existing view adaptor that enables "deep view" behaviour for that view.
Definition: deep.hpp:102
deep(underlying_adaptor_t &&inner) -> deep< underlying_adaptor_t >
Template argument deduction helper that preserves lvalue references and turns rvalue references into ...
static constexpr auto impl(urng_t &&urange, underlying_adaptor_t_ &&deep_adaptor)
Unwrap the internal adaptor closure object and pipe the range into it.
Definition: deep.hpp:137
constexpr auto operator()() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
Definition: deep.hpp:223
friend base_type
Befriend the base class so it can call impl().
Definition: deep.hpp:108
static constexpr decltype(auto) recursive_adaptor(underlying_adaptor_t deep_adaptor)
recursively construct the deep adaptor
Definition: deep.hpp:172
constexpr deep() noexcept=default
Defaulted.
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
auto const move
A view that turns lvalue-references into rvalue-references.
Definition: move.hpp:70
The SeqAn namespace for views.
Definition: async_input_buffer.hpp:343
SeqAn specific customisations in the standard namespace.
Auxiliary header for the views submodule .
Adaptations of concepts from the Ranges TS.