22#if defined(__cpp_lib_format)
33 template <std::ranges::input_range R>
34 requires(std::ranges::sized_range<R>)
37 return static_cast<std::size_t
>(std::ranges::size(r));
40 template <std::ranges::input_range R>
41 requires(!std::ranges::sized_range<R>)
44 return static_cast<std::size_t
>(std::ranges::distance(r));
47 template <std::ranges::range Range>
48 requires std::ranges::sized_range<std::ranges::range_value_t<Range>>
59 if (std::ranges::empty(range))
64 const std::size_t first_size = range.front().size();
65 return std::ranges::all_of(
67 [first_size](
const auto& element)
69 return element.size() == first_size;
77 template <
typename InputRange,
typename OutputIterator>
80 std::ranges::copy(input, output)
81 } -> std::same_as<std::ranges::copy_result<std::ranges::iterator_t<InputRange>, OutputIterator>>;
91 template <std::input_iterator I, std::sentinel_for<I> S, std::weakly_incrementable O>
92 requires std::indirectly_copyable<I, O>
93 constexpr std::ranges::copy_result<I, O>
operator()(I first, S last, O result)
const
95 for (; first != last; ++first, (void) ++result)
97#if defined(__GNUC__) && __GNUC__ < 12
98# pragma GCC diagnostic push
99# pragma GCC diagnostic ignored "-Wnull-dereference"
102#if defined(__GNUC__) && __GNUC__ < 12
103# pragma GCC diagnostic pop
106 return {std::move(first), std::move(result)};
109 template <std::ranges::input_range R, std::weakly_incrementable O>
110 requires std::indirectly_copyable<std::ranges::iterator_t<R>, O>
111 constexpr std::ranges::copy_result<std::ranges::borrowed_iterator_t<R>, O>
114 return (*
this)(std::ranges::begin(r), std::ranges::end(r), std::move(result));
118 template <std::ranges::input_range R, std::weakly_incrementable O>
119 requires std::indirectly_copyable<std::ranges::iterator_t<R>, O>
120 constexpr std::ranges::copy_result<std::ranges::borrowed_iterator_t<R>, O>
copy(R&& r, O result)
124 return std::ranges::copy(std::forward<R>(r), std::move(result));
128 return copy_fn{}(std::forward<R>(r), std::move(result));
132 template <std::ranges::input_range R,
class T>
135 return std::accumulate(r.begin(), r.end(), init);
138 template <std::ranges::input_range R,
class T, std::copy_constructible Op>
141 return std::accumulate(r.begin(), r.end(), init, op);
146#if defined(__cpp_lib_format)
148template <
typename T, std::
size_t N>
149struct std::formatter<
std::array<T, N>>
151 constexpr auto parse(std::format_parse_context& ctx)
153 return m_spec.parse(ctx.begin(), ctx.end());
156 auto format(
const std::array<T, N>& array, std::format_context& ctx)
const
158 std::string core = m_spec.build_core(array);
159 std::string out_str = m_spec.apply_alignment(std::move(core));
160 return std::ranges::copy(out_str, ctx.out()).out;
165 sparrow::detail::sequence_format_spec m_spec;
169struct std::formatter<
std::vector<T>>
171 constexpr auto parse(std::format_parse_context& ctx)
173 return m_spec.parse(ctx.begin(), ctx.end());
176 auto format(
const std::vector<T>& vector, std::format_context& ctx)
const
178 std::string core = m_spec.build_core(vector);
179 std::string out_str = m_spec.apply_alignment(std::move(core));
180 return std::ranges::copy(out_str, ctx.out()).out;
185 sparrow::detail::sequence_format_spec m_spec;
188template <std::
size_t T>
189struct std::formatter<
std::bitset<T>>
191 constexpr auto parse(std::format_parse_context& ctx)
193 return m_spec.parse(ctx.begin(), ctx.end());
196 auto format(
const std::bitset<T>& vector, std::format_context& ctx)
const
198 std::string core = m_spec.build_core(vector);
199 std::string out_str = m_spec.apply_alignment(std::move(core));
200 return std::ranges::copy(out_str, ctx.out()).out;
205 sparrow::detail::sequence_format_spec m_spec;
Concept for std::array types.
constexpr T accumulate(R &&r, T init)
constexpr std::ranges::copy_result< std::ranges::borrowed_iterator_t< R >, O > copy(R &&r, O result)
constexpr bool all_same_size(const Range &range)
constexpr std::size_t range_size(R &&r)
Extensions to the C++ standard library.
Copies the elements from the input range to the output iterator.
constexpr std::ranges::copy_result< I, O > operator()(I first, S last, O result) const
constexpr std::ranges::copy_result< std::ranges::borrowed_iterator_t< R >, O > operator()(R &&r, O result) const