3#include <absl/container/inlined_vector.h>
10template<
class T>
static constexpr size_t Default_Inlined_Size = std::max((
size_t)1, 4 *
sizeof(
size_t) /
sizeof(T));
16template<
class T,
size_t N = Default_Inlined_Size<T>,
class A = std::allocator<T>>
17class Vector :
public absl::InlinedVector<T, N, A> {
19 using Base = absl::InlinedVector<T, N, A>;
25 constexpr explicit Vector(
size_t size, F&& f)
noexcept(std::is_nothrow_invocable_r_v<T, F, size_t>
26 && std::is_nothrow_assignable_v<T&, T>)
27 requires(std::is_invocable_r_v<T, F, size_t>)
29 for (
size_t i = 0; i != size; ++i) (*
this)[i] = std::invoke(f, i);
32 template<std::ranges::forward_range R,
class F>
34 F&& f)
noexcept(std::is_nothrow_invocable_r_v<T, F,
decltype(*std::ranges::begin(range))>
35 && std::is_nothrow_assignable_v<T&, T>)
36 requires(std::is_invocable_r_v<T, F,
decltype(*std::ranges::begin(range))>
37 && !std::is_same_v<std::decay_t<R>,
Vector>)
38 :
Base(std::ranges::distance(range)) {
39 auto ri = std::ranges::begin(range);
40 for (
auto& elem : *
this) elem = std::invoke(f, *ri++);
46 constexpr auto span() noexcept {
return Span{Base::data(), Base::size()}; }
47 constexpr auto span() const noexcept {
return Span{Base::data(), Base::size()}; }
48 constexpr auto view() const noexcept {
return span(); }
51 friend void swap(
Vector& v1,
Vector& v2)
noexcept(
noexcept(v1.swap(v2))) { v1.swap(v2); }
54static_assert(std::ranges::contiguous_range<Vector<int>>);
58template<class I, class A = std::allocator<typename std::iterator_traits<I>::value_type>>
66template<
class T,
size_t N,
class A,
class U>
68 auto it = std::remove(c.begin(), c.end(), value);
69 auto r = c.end() - it;
74template<
class T,
size_t N,
class A,
class Pred>
76 auto it = std::remove_if(c.begin(), c.end(), pred);
77 auto r = c.end() - it;
This is a thin wrapper for std::span<T, N> with the following additional features:
This is a thin wrapper for absl::InlinedVector<T, N, A> which is a drop-in replacement for std::vecto...
constexpr Vector(size_t size, F &&f) noexcept(std::is_nothrow_invocable_r_v< T, F, size_t > &&std::is_nothrow_assignable_v< T &, T >)
absl::InlinedVector< const Def *, Default_Inlined_Size< const Def * >, std::allocator< const Def * > > Base
constexpr auto span() noexcept
constexpr auto span() const noexcept
constexpr auto view() const noexcept
friend void swap(Vector &v1, Vector &v2) noexcept(noexcept(v1.swap(v2)))
constexpr Vector(R &&range, F &&f) noexcept(std::is_nothrow_invocable_r_v< T, F, decltype(*std::ranges::begin(range))> &&std::is_nothrow_assignable_v< T &, T >)
Vector< T, N, A >::size_type erase_if(Vector< T, N, A > &c, Pred pred) noexcept
static constexpr size_t Default_Inlined_Size
Use up to 4 words (i.e., 4 * sizeof(size_t)) of inlined storage, rounded up.
Vector< T, N, A >::size_type erase(Vector< T, N, A > &c, const U &value) noexcept
Vector(I, I, A=A()) -> Vector< typename std::iterator_traits< I >::value_type, Default_Inlined_Size< typename std::iterator_traits< I >::value_type >, A >