Struct deranged::OptionRangedU128
source · #[repr(transparent)]pub struct OptionRangedU128<const MIN: u128, const MAX: u128>(pub(crate) u128);
Expand description
A RangedU128
that is optional. Equivalent to Option<RangedU128>
with niche value optimization.
If MIN
is u128::MIN
and MAX
is u128::MAX
then compilation will fail. This is because there is no way to represent the niche value.
This type is useful when you need to store an optional ranged value in a struct, but
do not want the overhead of an Option
type. This reduces the size of the struct
overall, and is particularly useful when you have a large number of optional fields.
Note that most operations must still be performed on the Option
type, which is
obtained with OptionRangedU128::get
.
Tuple Fields§
§0: u128
Implementations§
source§impl<const MIN: u128, const MAX: u128> OptionRangedU128<MIN, MAX>
impl<const MIN: u128, const MAX: u128> OptionRangedU128<MIN, MAX>
sourcepub(crate) const NICHE: u128 = _
pub(crate) const NICHE: u128 = _
The value used as the niche. Must not be in the range MIN..=MAX
.
sourcepub const fn Some(value: RangedU128<MIN, MAX>) -> Self
pub const fn Some(value: RangedU128<MIN, MAX>) -> Self
Creates an optional ranged value that is present.
sourcepub const fn get(self) -> Option<RangedU128<MIN, MAX>>
pub const fn get(self) -> Option<RangedU128<MIN, MAX>>
Returns the value as the standard library’s Option
type.
sourcepub const unsafe fn some_unchecked(value: u128) -> Self
pub const unsafe fn some_unchecked(value: u128) -> Self
Creates an optional ranged integer without checking the value.
§Safety
The value must be within the range MIN..=MAX
. As the value used for niche
value optimization is unspecified, the provided value must not be the niche
value.
sourcepub(crate) const fn inner(self) -> u128
pub(crate) const fn inner(self) -> u128
Obtain the inner value of the struct. This is useful for comparisons.
pub const fn get_primitive(self) -> Option<u128>
Trait Implementations§
source§impl<const MIN: u128, const MAX: u128> Clone for OptionRangedU128<MIN, MAX>
impl<const MIN: u128, const MAX: u128> Clone for OptionRangedU128<MIN, MAX>
source§fn clone(&self) -> OptionRangedU128<MIN, MAX>
fn clone(&self) -> OptionRangedU128<MIN, MAX>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<'de, const MIN: u128, const MAX: u128> Deserialize<'de> for OptionRangedU128<MIN, MAX>
impl<'de, const MIN: u128, const MAX: u128> Deserialize<'de> for OptionRangedU128<MIN, MAX>
source§fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error>
fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error>
source§impl<const MIN: u128, const MAX: u128> From<Option<RangedU128<MIN, MAX>>> for OptionRangedU128<MIN, MAX>
impl<const MIN: u128, const MAX: u128> From<Option<RangedU128<MIN, MAX>>> for OptionRangedU128<MIN, MAX>
source§fn from(value: Option<RangedU128<MIN, MAX>>) -> Self
fn from(value: Option<RangedU128<MIN, MAX>>) -> Self
source§impl<const MIN: u128, const MAX: u128> From<OptionRangedU128<MIN, MAX>> for Option<RangedU128<MIN, MAX>>
impl<const MIN: u128, const MAX: u128> From<OptionRangedU128<MIN, MAX>> for Option<RangedU128<MIN, MAX>>
source§fn from(value: OptionRangedU128<MIN, MAX>) -> Self
fn from(value: OptionRangedU128<MIN, MAX>) -> Self
source§impl<const MIN: u128, const MAX: u128> From<RangedU128<MIN, MAX>> for OptionRangedU128<MIN, MAX>
impl<const MIN: u128, const MAX: u128> From<RangedU128<MIN, MAX>> for OptionRangedU128<MIN, MAX>
source§fn from(value: RangedU128<MIN, MAX>) -> Self
fn from(value: RangedU128<MIN, MAX>) -> Self
source§impl<const MIN: u128, const MAX: u128> Ord for OptionRangedU128<MIN, MAX>
impl<const MIN: u128, const MAX: u128> Ord for OptionRangedU128<MIN, MAX>
source§impl<const MIN_A: u128, const MAX_A: u128, const MIN_B: u128, const MAX_B: u128> PartialEq<OptionRangedU128<MIN_B, MAX_B>> for OptionRangedU128<MIN_A, MAX_A>
impl<const MIN_A: u128, const MAX_A: u128, const MIN_B: u128, const MAX_B: u128> PartialEq<OptionRangedU128<MIN_B, MAX_B>> for OptionRangedU128<MIN_A, MAX_A>
source§fn eq(&self, other: &OptionRangedU128<MIN_B, MAX_B>) -> bool
fn eq(&self, other: &OptionRangedU128<MIN_B, MAX_B>) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl<const MIN_A: u128, const MAX_A: u128, const MIN_B: u128, const MAX_B: u128> PartialOrd<OptionRangedU128<MIN_B, MAX_B>> for OptionRangedU128<MIN_A, MAX_A>
impl<const MIN_A: u128, const MAX_A: u128, const MIN_B: u128, const MAX_B: u128> PartialOrd<OptionRangedU128<MIN_B, MAX_B>> for OptionRangedU128<MIN_A, MAX_A>
source§fn partial_cmp(
&self,
other: &OptionRangedU128<MIN_B, MAX_B>,
) -> Option<Ordering>
fn partial_cmp( &self, other: &OptionRangedU128<MIN_B, MAX_B>, ) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read more