Struct DataBlock

Source
pub struct DataBlock<Block> { /* private fields */ }
Expand description

Traversable bit block with offset.

Implementations§

Source§

impl<Block: BitBlock> DataBlock<Block>

Source

pub fn new(start_index: usize, bit_block: Block) -> DataBlock<Block>

§Panics

Panics if start_index does not match Block align.

Source

pub unsafe fn new_unchecked( start_index: usize, bit_block: Block, ) -> DataBlock<Block>

§Safety

start_index must match Block align.

Source

pub fn into_parts(self) -> (usize, Block)

Destruct DataBlock into (start_index, bit_block).

Source

pub fn traverse<F, B>(&self, f: F) -> ControlFlow<B>
where F: FnMut(usize) -> ControlFlow<B>,

traverse approx. 15% faster then iterator

Source

pub fn for_each<F>(&self, f: F)
where F: FnMut(usize),

Source

pub fn iter(&self) -> DataBlockIter<Block>

Source

pub fn len(&self) -> usize

Calculate elements count in DataBlock.

On most platforms, this should be faster then manually traversing DataBlock and counting elements. It use hardware accelerated “popcnt”, whenever possible.

Source

pub fn is_empty(&self) -> bool

Trait Implementations§

Source§

impl<Block: Clone> Clone for DataBlock<Block>

Source§

fn clone(&self) -> DataBlock<Block>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<Block: Debug> Debug for DataBlock<Block>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de, Block> Deserialize<'de> for DataBlock<Block>
where Block: Deserialize<'de>,

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl<Conf: Config> Extend<DataBlock<<Conf as Config>::DataBitBlock>> for BitSet<Conf>

Source§

fn extend<T: IntoIterator<Item = DataBlock<Conf::DataBitBlock>>>( &mut self, iter: T, )

It is allowed for blocks with the same range to repeat in iterator. Like ([1,42], [15,27,61]). Their data will be merged.

Source§

fn extend_one(&mut self, item: A)

🔬This is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
Source§

fn extend_reserve(&mut self, additional: usize)

🔬This is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
Source§

impl<Conf: Config> From<&DataBlock<<Conf as Config>::DataBitBlock>> for BlockCursor<Conf>

Source§

fn from(block: &DataBlock<Conf::DataBitBlock>) -> Self

Build cursor that points to the block.

Source§

impl<Conf: Config> From<&DataBlock<<Conf as Config>::DataBitBlock>> for IndexCursor<Conf>

Source§

fn from(block: &DataBlock<Conf::DataBitBlock>) -> Self

Build cursor that points to the block start index.

Source§

impl<Conf: Config> FromIterator<DataBlock<<Conf as Config>::DataBitBlock>> for BitSet<Conf>

Source§

fn from_iter<T: IntoIterator<Item = DataBlock<Conf::DataBitBlock>>>( iter: T, ) -> Self

It is allowed for blocks with the same range to repeat in iterator. Like ([1,42], [15,27,61]). Their data will be merged.

Source§

impl<Block: BitBlock> IntoIterator for DataBlock<Block>

Source§

fn into_iter(self) -> Self::IntoIter

This is actually no-op fast.

Source§

type Item = usize

The type of the elements being iterated over.
Source§

type IntoIter = DataBlockIter<Block>

Which kind of iterator are we turning this into?
Source§

impl<Block: PartialEq> PartialEq for DataBlock<Block>

Source§

fn eq(&self, other: &DataBlock<Block>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<Block> Serialize for DataBlock<Block>
where Block: Serialize,

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl<Block: Eq> Eq for DataBlock<Block>

Source§

impl<Block> StructuralPartialEq for DataBlock<Block>

Auto Trait Implementations§

§

impl<Block> Freeze for DataBlock<Block>
where Block: Freeze,

§

impl<Block> RefUnwindSafe for DataBlock<Block>
where Block: RefUnwindSafe,

§

impl<Block> Send for DataBlock<Block>
where Block: Send,

§

impl<Block> Sync for DataBlock<Block>
where Block: Sync,

§

impl<Block> Unpin for DataBlock<Block>
where Block: Unpin,

§

impl<Block> UnwindSafe for DataBlock<Block>
where Block: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,