pub struct PackUsize<T = usize, F = ()> { /* private fields */ }
Expand description
A spec for packing values into selected bit ranges of usize
values.
See the module-level documentation for details on using packing specs.
Implementations§
Source§impl PackUsize<usize>
impl PackUsize<usize>
Sourcepub const fn pack_in(value: usize) -> PackingUsize
pub const fn pack_in(value: usize) -> PackingUsize
Wrap a usize
to add methods for packing bit ranges using PackUsize
.
This is equivalent to calling PackingUsize::new
, but only requires importing the packer type.
Sourcepub const fn least_significant(n: u32) -> Self
pub const fn least_significant(n: u32) -> Self
Returns a packer for packing a value into the first bits
bits.
Sourcepub const fn from_mask(mask: usize) -> Self
pub const fn from_mask(mask: usize) -> Self
Returns a packer that will pack a value into the provided mask.
Sourcepub const fn from_const_range(range: Range<u32>) -> Self
pub const fn from_const_range(range: Range<u32>) -> Self
This is a const fn
-compatible equivalent of
Self::from_range
. Note that it can only be used with
core::ops::Range
s, and not with
core::ops::RangeInclusive
, core::ops::RangeTo
,
core::ops::RangeFrom
, core::ops::RangeToInclusive
. :(
Sourcepub fn from_range(range: impl RangeBounds<u32>) -> Self
pub fn from_range(range: impl RangeBounds<u32>) -> Self
Construct a bit packing spec from a range of bits.
§Panics
- If the range does not fit within the integer type packed by this packing spec.
- If the range’s start > the range’s end (although most range types should prevent this).
Source§impl<T, F> PackUsize<T, F>
impl<T, F> PackUsize<T, F>
Sourcepub const fn max_value(&self) -> usize
pub const fn max_value(&self) -> usize
Returns the maximum value of this packing spec (i.e. a value with all the bits set)
Sourcepub const fn first_bit(&self) -> usize
pub const fn first_bit(&self) -> usize
Returns a value with the first bit in this packing spec set.
Sourcepub const fn raw_mask(&self) -> usize
pub const fn raw_mask(&self) -> usize
Returns a raw, shifted mask for unpacking this packing spec.
Sourcepub const fn pack_truncating(&self, value: usize, base: usize) -> usize
pub const fn pack_truncating(&self, value: usize, base: usize) -> usize
Pack the self.bits()
least-significant bits from value
into base
.
Any bits more significant than the self.bits()
-th bit are ignored.
Sourcepub fn pack_into_truncating<'base>(
&self,
value: usize,
base: &'base mut usize,
) -> &'base mut usize
pub fn pack_into_truncating<'base>( &self, value: usize, base: &'base mut usize, ) -> &'base mut usize
Pack the self.bits()
least-significant bits from value
into base
, mutating base
.
Any bits more significant than the self.bits()
-th bit are ignored.
Sourcepub const fn then<T2>(&self) -> PackUsize<T2, F>
pub const fn then<T2>(&self) -> PackUsize<T2, F>
Returns a new packer for packing a T2
-typed value in the
next T2::BITS
bits after self
.
Sourcepub const fn next(&self, n: u32) -> PackUsize<usize, F>
pub const fn next(&self, n: u32) -> PackUsize<usize, F>
Returns a packer for packing a value into the next more-significant
n
from self
.
Sourcepub const fn remaining(&self) -> PackUsize<usize, F>
pub const fn remaining(&self) -> PackUsize<usize, F>
Returns a packer for packing a value into all the remaining
more-significant bits after self
.
Sourcepub const fn set_all(&self, base: usize) -> usize
pub const fn set_all(&self, base: usize) -> usize
Set all bits packed by this packer to 1.
This is a convenience function for
self.pack(self.max_value(), base)
Sourcepub fn set_all_in<'base>(&self, base: &'base mut usize) -> &'base mut usize
pub fn set_all_in<'base>(&self, base: &'base mut usize) -> &'base mut usize
Set all bits packed by this packer to 1 in base
.
This is a convenience function for
self.pack_into(self.max_value(), base)
Sourcepub fn unset_all_in<'base>(&self, base: &'base mut usize) -> &'base mut usize
pub fn unset_all_in<'base>(&self, base: &'base mut usize) -> &'base mut usize
Set all bits packed by this packer to 0.
This is a convenience function for
self.pack_into(0, base)
Sourcepub const fn unpack_bits(&self, src: usize) -> usize
pub const fn unpack_bits(&self, src: usize) -> usize
Unpack this packer’s bits from source
.
Sourcepub const fn contained_in_any(&self, bits: usize) -> bool
pub const fn contained_in_any(&self, bits: usize) -> bool
Returns true
if any bits specified by this packing spec
are set in src
.
Sourcepub const fn contained_in_all(&self, bits: usize) -> bool
pub const fn contained_in_all(&self, bits: usize) -> bool
Returns true
if all bits specified by this packing spec
are set in src
.
Sourcepub fn assert_valid(&self)
pub fn assert_valid(&self)
Asserts that this packing spec is valid.
Because assertions cannot be made in const fn
, this
performs validating assertions that would ideally be made
when constructing a new instance of this type. When packing
specs are declared as const
s, this method can be called in
a unit test to ensure that the spec is valid.
Sourcepub fn assert_all_valid(specs: &[(&str, Self)])
pub fn assert_all_valid(specs: &[(&str, Self)])
Assert all of a set of packing specs are valid for packing and unpacking values into the same bitfield.
This asserts that each individual packing spec is valid (by
calling assert_valid
on that spec),
and asserts that no two packing specs in specs
overlap
(indicating that they can safely represent a single
bitfield’s subranges).
This function takes a slice of (&str, Self)
tuples, with
the &str
s providing a name for each packing spec. This name
is used to refer to that packing spec in panic messages.
Sourcepub const fn least_significant_index(&self) -> u32
pub const fn least_significant_index(&self) -> u32
Returns the index of the least-significant bit of this packing spec (i.e. the bit position of the start of the packed range).
Sourcepub const fn most_significant_index(&self) -> u32
pub const fn most_significant_index(&self) -> u32
Returns the index of the most-significant bit of this packing spec (i.e. the bit position of the end of the packed range).
This will always be greater than the value returned by
least_significant_index
.
Source§impl<T, F> PackUsize<T, F>
impl<T, F> PackUsize<T, F>
Sourcepub const fn first() -> Self
pub const fn first() -> Self
Returns a packing spec for packing a T
-typed value in the
first T::BITS
least-significant bits.
Sourcepub const fn starting_at(bit: u32, n: u32) -> Self
pub const fn starting_at(bit: u32, n: u32) -> Self
Returns a packer for packing a value into the next n
more-significant
after the bit
th bit.
Sourcepub const fn pair_at(&self, at: u32) -> PairUsize<T>
pub const fn pair_at(&self, at: u32) -> PairUsize<T>
Returns a pair type for packing bits from the range
specified by self
at the specified offset at
, which may
differ from self
’s offset.
The packing pair can be used to pack bits from one location into another location, and vice versa.
Sourcepub const fn pair_after(&self, after: Self) -> PairUsize<T>
pub const fn pair_after(&self, after: Self) -> PairUsize<T>
Returns a pair type for packing bits from the range
specified by self
after the specified packing spec.
Sourcepub const fn pair_with<F2>(&self, dst: PackUsize<T, F2>) -> PairUsize<T>
pub const fn pair_with<F2>(&self, dst: PackUsize<T, F2>) -> PairUsize<T>
Returns a pair type for packing bits from the range
specified by self
into the range specified by with
.
§Note
The two ranges must be the same size. This can be asserted
by the assert_valid
method on the returned pair type.
Sourcepub fn pack(&self, value: T, base: usize) -> usize
pub fn pack(&self, value: T, base: usize) -> usize
Pack the self.bits()
least-significant bits from value
into base
.
§Panics
Panics if any other bits outside of self.bits()
are set
in value
.
Sourcepub fn pack_into<'base>(
&self,
value: T,
base: &'base mut usize,
) -> &'base mut usize
pub fn pack_into<'base>( &self, value: T, base: &'base mut usize, ) -> &'base mut usize
Pack the self.bits()
least-significant bits from value
into base
, mutating base
.
§Panics
Panics if any other bits outside of self.bits()
are set
in value
.
Sourcepub fn try_unpack(&self, src: usize) -> Result<T, T::Error>
pub fn try_unpack(&self, src: usize) -> Result<T, T::Error>
Attempts to unpack a T
-typed value from src
.
§Returns
Ok(T)
if aT
-typed value could be constructed from the bits insrc
Err(T::Error)
ifsrc
does not contain a valid bit pattern for aT
-typed value, as determined byT
’sFromBits::try_from_bits
implementation.