27 template <std::ranges::range R>
28 requires std::ranges::sized_range<std::ranges::range_value_t<R>>
31 using value_type = std::ranges::range_value_t<std::ranges::range_value_t<R>>;
32 return std::transform_reduce(
36 std::plus<std::size_t>(),
39 return range.size() * sizeof(value_type);
44 template <std::ranges::range R>
45 requires(std::ranges::sized_range<std::ranges::range_value_t<R>>)
48 using range_value_type = std::ranges::range_value_t<R>;
49 using atomic_element_type = std::ranges::range_value_t<range_value_type>;
56 for (
auto&&
string : strings)
58 if constexpr (std::is_rvalue_reference_v<R>)
60 std::ranges::move(
string, iter);
66 std::advance(iter,
string.size());
72 template <std::ranges::range R>
73 requires(std::is_arithmetic_v<std::ranges::range_value_t<R>>)
76 const size_t values_byte_count = std::ranges::size(range) *
sizeof(std::ranges::range_value_t<R>);
79 if constexpr (std::is_rvalue_reference_v<R>)
Class which have internally a reference to a contiguous container of a certain type and provides an A...
constexpr iterator begin() noexcept
Object that owns a piece of contiguous memory.
constexpr std::ranges::copy_result< std::ranges::borrowed_iterator_t< R >, O > copy(R &&r, O result)
buffer< uint8_t > range_to_buffer(R &&range)
buffer< uint8_t > strings_to_buffer(R &&strings)
auto make_buffer_adaptor(FromBufferRef &buf)
size_t number_of_bytes(const R &ranges)