55 template <std::
integral T>
85 template <std::ranges::input_range R>
86 requires std::convertible_to<std::ranges::range_value_t<R>,
value_type>
181 template <
std::integral T>
188 template <std::
integral T>
195 template <std::
integral T>
206 template <std::
integral T>
213 template <std::
integral T>
242 if (bitmap.
size() == 0)
251 if (bitmap.size() == 0)
253 bitmap.resize(size,
true);
255 return std::move(bitmap);
259 template <std::ranges::input_range R>
260 requires(std::same_as<std::ranges::range_value_t<R>,
bool>)
266 for (
auto value : range)
270 bitmap.
set(i,
false);
278 template <std::ranges::input_range R>
280 std::unsigned_integral<std::ranges::range_value_t<R>>
281 && !std::same_as<std::ranges::range_value_t<R>,
bool>
287 for (
auto index : range_of_indices)
289 bitmap.
set(index,
false);
310 || (std::ranges::input_range<T>
311 && std::same_as<std::ranges::range_value_t<T>,
bool>)
312 || (std::ranges::input_range<T>
313 && std::unsigned_integral<std::ranges::range_value_t<T>>) )
314 && (!std::same_as<std::remove_cvref_t<T>, std::string>
315 && !std::same_as<std::remove_cvref_t<T>, std::string_view>
316 && !std::same_as<std::decay_t<T>,
const char*>);
348 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 dynamic_bitset(const R &r)
Constructs a dynamic_bitset from an input range of convertible values.
constexpr void pop_back()
constexpr dynamic_bitset(dynamic_bitset &&) noexcept=default
constexpr void clear() noexcept
constexpr dynamic_bitset(size_type n)
Constructs a bitset with n bits, all initialized to false.
constexpr dynamic_bitset(size_type n, value_type v)
Constructs a bitset with n bits, all initialized to the specified value.
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()
Default constructor.
constexpr void push_back(value_type value)
constexpr iterator erase(const_iterator pos)
constexpr dynamic_bitset(block_type *p, size_type n, size_type null_count)
Constructs a bitset using existing memory with null count tracking.
dynamic_bitset_base< buffer< T > > base_type
Base class type.
typename base_type::storage_type storage_type
Underlying storage container type.
constexpr dynamic_bitset(block_type *p, size_type n)
Constructs a bitset using existing memory.
constexpr iterator insert(const_iterator pos, value_type value)
constexpr iterator emplace(const_iterator pos, value_type value)
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()=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.