55 template <std::
integral T>
88 template <std::ranges::input_range R, allocator A = default_allocator>
89 requires std::convertible_to<std::ranges::range_value_t<R>,
value_type>
110 template <
class A = default_allocator>
111 requires(not std::same_as<A, dynamic_bitset<T>> and
allocator<A>)
122 template <allocator A = default_allocator>
134 template <allocator A = default_allocator>
152 template <allocator A = default_allocator>
170 template <allocator A = default_allocator>
196 template <
std::integral T>
205 template <std::
integral T>
206 template <allocator A>
213 template <std::
integral T>
214 template <allocator A>
225 template <std::
integral T>
226 template <allocator A>
233 template <std::
integral T>
234 template <allocator A>
242 template <std::
integral T>
243 template <allocator A>
249 template <std::
integral T>
250 template <allocator A>
277 if (bitmap.
size() == 0)
286 if (bitmap.size() == 0)
288 bitmap.resize(size,
true);
290 return std::move(bitmap);
294 template <std::ranges::input_range R>
295 requires(std::same_as<std::ranges::range_value_t<R>,
bool>)
301 for (
auto value : range)
305 bitmap.
set(i,
false);
313 template <std::ranges::input_range R>
315 std::unsigned_integral<std::ranges::range_value_t<R>>
316 && !std::same_as<std::ranges::range_value_t<R>,
bool>
322 for (
auto index : range_of_indices)
324 bitmap.
set(index,
false);
345 || (std::ranges::input_range<T>
346 && std::same_as<std::ranges::range_value_t<T>,
bool>)
347 || (std::ranges::input_range<T>
348 && std::unsigned_integral<std::ranges::range_value_t<T>>) )
349 && (!std::same_as<std::remove_cvref_t<T>, std::string>
350 && !std::same_as<std::remove_cvref_t<T>, std::string_view>
351 && !std::same_as<std::decay_t<T>,
const char*>);
383 template <val
idity_bitmap_input R>
typename storage_type_without_cvrefpointer::value_type block_type
size_type count_non_null() const noexcept
typename storage_type_without_cvrefpointer::size_type size_type
constexpr void zero_unused_bits()
constexpr size_type null_count() const noexcept
static constexpr size_type compute_block_count(size_type bits_count) noexcept
constexpr size_type size() const noexcept
constexpr void set(size_type pos, value_type value)
constexpr dynamic_bitset_base(storage_type buffer, size_type size)
A dynamic size sequence of bits with efficient storage and manipulation operations.
constexpr void pop_back()
constexpr dynamic_bitset(dynamic_bitset &&) noexcept=default
typename storage_type::default_allocator default_allocator
Type of default allocator.
constexpr dynamic_bitset(block_type *p, size_type n, size_type null_count, const A &a=A())
Constructs a bitset using existing memory with null count tracking.
constexpr void clear() noexcept
constexpr void resize(size_type n, value_type b=false)
typename base_type::block_type block_type
Type of each storage block (same as T)
constexpr dynamic_bitset(const dynamic_bitset &)=default
constexpr dynamic_bitset(const R &r, const A &a=A())
Constructs a dynamic_bitset from an input range of convertible values.
constexpr dynamic_bitset(size_type n, const A &a=A())
Constructs a bitset with n bits, all initialized to false.
constexpr void push_back(value_type value)
constexpr dynamic_bitset(size_type n, value_type v, const A &a=A())
Constructs a bitset with n bits, all initialized to the specified value.
constexpr iterator erase(const_iterator pos)
dynamic_bitset_base< buffer< T > > base_type
Base class type.
typename base_type::storage_type storage_type
Underlying storage container type.
constexpr iterator insert(const_iterator pos, value_type value)
constexpr iterator emplace(const_iterator pos, value_type value)
constexpr dynamic_bitset(block_type *p, size_type n, const A &a=A())
Constructs a bitset using existing memory.
typename base_type::value_type value_type
Type of individual bit values (bool)
typename base_type::size_type size_type
Type used for sizes and indices.
constexpr dynamic_bitset(const A &a=A())
Default constructor.
constexpr ~dynamic_bitset()=default
#define SPARROW_ASSERT_TRUE(expr__)
sparrow::validity_bitmap validity_bitmap
validity_bitmap ensure_validity_bitmap_impl(std::size_t size, const validity_bitmap &bitmap)
constexpr std::size_t range_size(R &&r)
dynamic_bitset< std::uint8_t > validity_bitmap
Type alias for a validity bitmap using 8-bit storage blocks.
validity_bitmap ensure_validity_bitmap(std::size_t size, R &&validity_input)
Ensures a validity bitmap of the specified size from various input types.