#[repr(C)]
pub(crate) struct PackedRefCount { bytes: [u8; 8], }
Expand description

hold a big RefCount while leaving room for extra bits to be used for things like ‘Occupied’

Fields§

§bytes: [u8; 8]

Implementations§

source§

impl PackedRefCount

source

pub const fn new() -> Self

Returns an instance with zero initialized data.

source§

impl PackedRefCount

source

pub const fn into_bytes(self) -> [u8; 8]

Returns the underlying bits.

Layout

The returned byte array is layed out in the same way as described here.

source

pub const fn from_bytes(bytes: [u8; 8]) -> Self

Converts the given bytes directly into the bitfield struct.

source§

impl PackedRefCount

source

pub(crate) fn occupied(&self) -> <B1 as Specifier>::InOut

Returns the value of occupied. whether this entry in the data file is occupied or not

source

pub(crate) fn occupied_or_err( &self ) -> Result<<B1 as Specifier>::InOut, InvalidBitPattern<<B1 as Specifier>::Bytes>>

Returns the value of occupied.

#Errors

If the returned value contains an invalid bit pattern for occupied. whether this entry in the data file is occupied or not

source

pub(crate) fn with_occupied(self, new_val: <B1 as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of occupied set to the given value.

#Panics

If the given value is out of bounds for occupied. whether this entry in the data file is occupied or not

source

pub(crate) fn with_occupied_checked( self, new_val: <B1 as Specifier>::InOut ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of occupied set to the given value.

#Errors

If the given value is out of bounds for occupied. whether this entry in the data file is occupied or not

source

pub(crate) fn set_occupied(&mut self, new_val: <B1 as Specifier>::InOut)

Sets the value of occupied to the given value.

#Panics

If the given value is out of bounds for occupied. whether this entry in the data file is occupied or not

source

pub(crate) fn set_occupied_checked( &mut self, new_val: <B1 as Specifier>::InOut ) -> Result<(), OutOfBounds>

Sets the value of occupied to the given value.

#Errors

If the given value is out of bounds for occupied. whether this entry in the data file is occupied or not

source

pub(crate) fn ref_count(&self) -> <B63 as Specifier>::InOut

Returns the value of ref_count. ref_count of this entry. We don’t need any where near 63 bits for this value

source

pub(crate) fn ref_count_or_err( &self ) -> Result<<B63 as Specifier>::InOut, InvalidBitPattern<<B63 as Specifier>::Bytes>>

Returns the value of ref_count.

#Errors

If the returned value contains an invalid bit pattern for ref_count. ref_count of this entry. We don’t need any where near 63 bits for this value

source

pub(crate) fn with_ref_count(self, new_val: <B63 as Specifier>::InOut) -> Self

Returns a copy of the bitfield with the value of ref_count set to the given value.

#Panics

If the given value is out of bounds for ref_count. ref_count of this entry. We don’t need any where near 63 bits for this value

source

pub(crate) fn with_ref_count_checked( self, new_val: <B63 as Specifier>::InOut ) -> Result<Self, OutOfBounds>

Returns a copy of the bitfield with the value of ref_count set to the given value.

#Errors

If the given value is out of bounds for ref_count. ref_count of this entry. We don’t need any where near 63 bits for this value

source

pub(crate) fn set_ref_count(&mut self, new_val: <B63 as Specifier>::InOut)

Sets the value of ref_count to the given value.

#Panics

If the given value is out of bounds for ref_count. ref_count of this entry. We don’t need any where near 63 bits for this value

source

pub(crate) fn set_ref_count_checked( &mut self, new_val: <B63 as Specifier>::InOut ) -> Result<(), OutOfBounds>

Sets the value of ref_count to the given value.

#Errors

If the given value is out of bounds for ref_count. ref_count of this entry. We don’t need any where near 63 bits for this value

Trait Implementations§

source§

impl CheckFillsUnalignedBits for PackedRefCount

§

type CheckType = [(); 1]

source§

impl Clone for PackedRefCount

source§

fn clone(&self) -> PackedRefCount

Returns a copy 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 Debug for PackedRefCount

source§

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

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

impl Default for PackedRefCount

source§

fn default() -> PackedRefCount

Returns the “default value” for a type. Read more
source§

impl PartialEq<PackedRefCount> for PackedRefCount

source§

fn eq(&self, other: &PackedRefCount) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Copy for PackedRefCount

source§

impl Eq for PackedRefCount

source§

impl StructuralEq for PackedRefCount

source§

impl StructuralPartialEq for PackedRefCount

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> AbiExample for T

§

default fn example() -> T

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
§

impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. 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 Twhere 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.

§

impl<T> Pointable for T

§

const ALIGN: usize = mem::align_of::<T>()

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V