32namespace seqan3::detail
40template <std::ranges::range urng_t>
41class async_input_buffer_view :
public std::ranges::view_interface<async_input_buffer_view<urng_t>>
44 static_assert(std::ranges::input_range<urng_t>,
45 "The range parameter to async_input_buffer_view must be at least a std::ranges::input_range.");
46 static_assert(std::ranges::view<urng_t>,
47 "The range parameter to async_input_buffer_view must model std::ranges::view.");
48 static_assert(std::movable<std::ranges::range_value_t<urng_t>>,
49 "The range parameter to async_input_buffer_view must have a value_type that is std::movable.");
51 std::constructible_from<std::ranges::range_value_t<urng_t>,
53 "The range parameter to async_input_buffer_view must have a value_type that is constructible by a moved "
54 "value of its reference type.");
57 using urng_iterator_type = std::ranges::iterator_t<urng_t>;
66 contrib::fixed_buffer_queue<std::ranges::range_value_t<urng_t>> buffer;
82 async_input_buffer_view() =
default;
83 async_input_buffer_view(async_input_buffer_view
const &) =
default;
84 async_input_buffer_view(async_input_buffer_view &&) =
default;
85 async_input_buffer_view & operator=(async_input_buffer_view
const &) =
default;
86 async_input_buffer_view & operator=(async_input_buffer_view &&) =
default;
87 ~async_input_buffer_view() =
default;
90 async_input_buffer_view(urng_t _urng,
size_t const buffer_size)
92 auto deleter = [](state * p)
103 new state{std::move(_urng),
104 contrib::fixed_buffer_queue<std::ranges::range_value_t<urng_t>>{buffer_size},
108 auto runner = [&state = *state_ptr]()
110 for (
auto && val : state.urange)
111 if (state.buffer.wait_push(
std::
move(val)) == contrib::queue_op_status::closed)
114 state.buffer.close();
121 template <
typename other_urng_t>
122 requires (!std::same_as<std::remove_cvref_t<other_urng_t>, async_input_buffer_view>)
124 std::ranges::viewable_range<other_urng_t>
126 async_input_buffer_view(other_urng_t && _urng,
size_t const buffer_size) :
127 async_input_buffer_view{std::views::all(_urng), buffer_size}
147 assert(state_ptr !=
nullptr);
148 return {state_ptr->buffer};
152 iterator
begin()
const =
delete;
155 std::default_sentinel_t
end()
157 return std::default_sentinel;
161 std::default_sentinel_t
end()
const =
delete;
166template <std::ranges::range urng_t>
167class async_input_buffer_view<urng_t>::iterator
170 using sentinel_type = std::default_sentinel_t;
173 contrib::fixed_buffer_queue<std::ranges::range_value_t<urng_t>> * buffer_ptr =
nullptr;
176 mutable std::ranges::range_value_t<urng_t> cached_value;
190 using pointer = detail::iter_pointer_t<urng_iterator_type>;
196 using iterator_concept = iterator_category;
203 iterator() =
default;
205 iterator(iterator
const & rhs) =
default;
206 iterator(iterator && rhs) =
default;
208 iterator & operator=(iterator
const & rhs) =
default;
209 iterator & operator=(iterator && rhs) =
default;
210 ~iterator() noexcept = default;
213 iterator(contrib::fixed_buffer_queue<
std::ranges::range_value_t<urng_t>> & buffer) noexcept : buffer_ptr{&buffer}
223 reference operator*() const noexcept
229 pointer operator->() const noexcept
239 iterator & operator++() noexcept
244 assert(buffer_ptr !=
nullptr);
246 if (buffer_ptr->wait_pop(cached_value) == contrib::queue_op_status::closed)
253 void operator++(
int)
noexcept
263 friend constexpr bool operator==(iterator
const & lhs, std::default_sentinel_t
const &)
noexcept
269 friend constexpr bool operator==(std::default_sentinel_t
const &, iterator
const & rhs)
noexcept
271 return rhs == std::default_sentinel_t{};
275 friend constexpr bool operator!=(iterator
const & lhs, std::default_sentinel_t
const &)
noexcept
277 return !(lhs == std::default_sentinel_t{});
281 friend constexpr bool operator!=(std::default_sentinel_t
const &, iterator
const & rhs)
noexcept
283 return rhs != std::default_sentinel_t{};
294template <std::ranges::viewable_range urng_t>
295async_input_buffer_view(urng_t &&,
size_t const buffer_size) -> async_input_buffer_view<std::views::all_t<urng_t>>;
303struct async_input_buffer_fn
306 constexpr auto operator()(
size_t const buffer_size)
const
308 return detail::adaptor_from_functor{*
this, buffer_size};
316 template <std::ranges::range urng_t>
317 constexpr auto operator()(urng_t && urange,
size_t const buffer_size)
const
319 static_assert(std::ranges::input_range<urng_t>,
320 "The range parameter to views::async_input_buffer must be at least a std::ranges::input_range.");
321 static_assert(std::ranges::viewable_range<urng_t>,
322 "The range parameter to views::async_input_buffer cannot be a temporary of a non-view range.");
323 static_assert(std::movable<std::ranges::range_value_t<urng_t>>,
324 "The range parameter to views::async_input_buffer must have a value_type that is std::movable.");
326 std::constructible_from<std::ranges::range_value_t<urng_t>,
328 "The range parameter to views::async_input_buffer must have a value_type that is constructible by a moved "
329 "value of its reference type.");
331 if (buffer_size == 0)
334 return detail::async_input_buffer_view{std::forward<urng_t>(urange), buffer_size};
Provides seqan3::detail::adaptor_from_functor.
Provides seqan3::buffer_queue.
constexpr auto async_input_buffer
A view adapter that returns a concurrent-queue-like view over the underlying range.
Definition async_input_buffer.hpp:481
The SeqAn namespace for views.
Definition char_strictly_to.hpp:22
SeqAn specific customisations in the standard namespace.