DoxigAlpha

clone

Creates a duplicate of this bit set, using the new allocator.

Function parameters

Parameters

#
self:*const Self

A bit set with runtime-known size, backed by an allocated slice

Types

#
DynamicBitSetUnmanaged
A bit set with runtime-known size, backed by an allocated slice
DynamicBitSet
A bit set with runtime-known size, backed by an allocated slice
IteratorOptions
Options for configuring an iterator over a bit set
Range
A range of indices within a bitset.

Returns the optimal static bit set type for the specified number

Functions

#
StaticBitSet
Returns the optimal static bit set type for the specified number
IntegerBitSet
A bit set with static size, which is backed by a single integer.
ArrayBitSet
A bit set with static size, which is backed by an array of usize.

Source

Implementation

#
pub fn clone(self: *const Self, new_allocator: Allocator) !Self {
    const num_masks = numMasks(self.bit_length);
    var copy = Self{};
    try copy.resize(new_allocator, self.bit_length, false);
    @memcpy(copy.masks[0..num_masks], self.masks[0..num_masks]);
    return copy;
}