Struct bit_struct::i48

source ·
pub struct i48(_);
Expand description

An unsigned integer which contains 48 bits

Implementations§

source§

impl i48

source

pub const unsafe fn new_unchecked(value: i64) -> Self

Create a new $name from value

Safety
  • value must fit within the number of bits defined in the type
source

pub fn new(value: i64) -> Option<Self>

Create a new $name from value

Safety
  • value must fit within the number of bits defined in the type
source

pub const MAX: i64 = 140_737_488_355_327i64

The largest value this type can hold

source

pub const MIN: i64 = -140_737_488_355_328i64

The smallest value this type can hold

source

pub const fn value(self) -> i64

Get the value stored in here, as a signed integer

source§

impl i48

source

pub fn from_be_bytes(bytes: [u8; 6]) -> Self

Convert from an array of bytes, in big-endian order

source

pub fn to_be_bytes(self) -> [u8; 6]

Convert self into an array of bytes, in big-endian order

source

pub fn from_le_bytes(bytes: [u8; 6]) -> Self

Convert from an array of bytes, in little-endian order

source

pub fn to_le_bytes(self) -> [u8; 6]

Convert self into an array of bytes, in little-endian order

Trait Implementations§

source§

impl Add<i48> for i48

§

type Output = i48

The resulting type after applying the + operator.
source§

fn add(self, rhs: Self) -> Self::Output

Performs the + operation. Read more
source§

impl BitAnd<i48> for i48

§

type Output = i48

The resulting type after applying the & operator.
source§

fn bitand(self, rhs: Self) -> Self::Output

Performs the & operation. Read more
source§

impl BitAndAssign<i48> for i48

source§

fn bitand_assign(&mut self, rhs: Self)

Performs the &= operation. Read more
source§

impl BitCount for i48

source§

const COUNT: usize = 48usize

The number of bits associated with this type
source§

impl BitOr<i48> for i48

§

type Output = i48

The resulting type after applying the | operator.
source§

fn bitor(self, rhs: Self) -> Self::Output

Performs the | operation. Read more
source§

impl BitOrAssign<i48> for i48

source§

fn bitor_assign(&mut self, rhs: Self)

Performs the |= operation. Read more
source§

impl BitXor<i48> for i48

§

type Output = i48

The resulting type after applying the ^ operator.
source§

fn bitxor(self, rhs: Self) -> Self::Output

Performs the ^ operation. Read more
source§

impl BitXorAssign<i48> for i48

source§

fn bitxor_assign(&mut self, rhs: Self)

Performs the ^= operation. Read more
source§

impl BitsFitIn<u49> for i48

source§

fn fit(self) -> u49

Fits self into the target type
source§

impl BitsFitIn<u50> for i48

source§

fn fit(self) -> u50

Fits self into the target type
source§

impl BitsFitIn<u51> for i48

source§

fn fit(self) -> u51

Fits self into the target type
source§

impl BitsFitIn<u52> for i48

source§

fn fit(self) -> u52

Fits self into the target type
source§

impl BitsFitIn<u53> for i48

source§

fn fit(self) -> u53

Fits self into the target type
source§

impl BitsFitIn<u54> for i48

source§

fn fit(self) -> u54

Fits self into the target type
source§

impl BitsFitIn<u55> for i48

source§

fn fit(self) -> u55

Fits self into the target type
source§

impl BitsFitIn<u56> for i48

source§

fn fit(self) -> u56

Fits self into the target type
source§

impl BitsFitIn<u57> for i48

source§

fn fit(self) -> u57

Fits self into the target type
source§

impl BitsFitIn<u58> for i48

source§

fn fit(self) -> u58

Fits self into the target type
source§

impl BitsFitIn<u59> for i48

source§

fn fit(self) -> u59

Fits self into the target type
source§

impl BitsFitIn<u60> for i48

source§

fn fit(self) -> u60

Fits self into the target type
source§

impl BitsFitIn<u61> for i48

source§

fn fit(self) -> u61

Fits self into the target type
source§

impl BitsFitIn<u62> for i48

source§

fn fit(self) -> u62

Fits self into the target type
source§

impl BitsFitIn<u63> for i48

source§

fn fit(self) -> u63

Fits self into the target type
source§

impl BitsFitIn<u64> for i48

source§

fn fit(self) -> u64

Fits self into the target type
source§

impl Bounded for i48

source§

fn min_value() -> Self

Returns the smallest finite number this type can represent
source§

fn max_value() -> Self

Returns the largest finite number this type can represent
source§

impl Clone for i48

source§

fn clone(&self) -> i48

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 i48

source§

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

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

impl Default for i48

source§

fn default() -> Self

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

impl<'de> Deserialize<'de> for i48

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 Display for i48

source§

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

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

impl Div<i48> for i48

§

type Output = i48

The resulting type after applying the / operator.
source§

fn div(self, rhs: Self) -> Self::Output

Performs the / operation. Read more
source§

impl FieldStorage for i48

§

type StoredType = u64

The type this field stores as
source§

fn inner_raw(self) -> Self::StoredType

Get the raw representation of this value
source§

impl From<u8> for i48

source§

fn from(byte: u8) -> Self

Converts to this type from the input type.
source§

impl FromStr for i48

§

type Err = <i48 as Num>::FromStrRadixErr

The associated error which can be returned from parsing.
source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more
source§

impl Hash for i48

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)where
H: Hasher,
Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl Mul<i48> for i48

§

type Output = i48

The resulting type after applying the * operator.
source§

fn mul(self, rhs: Self) -> Self::Output

Performs the * operation. Read more
source§

impl Num for i48

§

type FromStrRadixErr = ()

source§

fn from_str_radix(str: &str, radix: u32) -> Result<Self, Self::FromStrRadixErr>

Convert from a string and radix (typically 2..=36). Read more
source§

impl One for i48

source§

fn one() -> Self

Returns the multiplicative identity element of Self, 1. Read more
source§

fn set_one(&mut self)

Sets self to the multiplicative identity element of Self, 1.
source§

fn is_one(&self) -> boolwhere
Self: PartialEq<Self>,

Returns true if self is equal to the multiplicative identity. Read more
source§

impl Ord for i48

source§

fn cmp(&self, other: &Self) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Selfwhere
Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Selfwhere
Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Selfwhere
Self: Sized + PartialOrd<Self>,

Restrict a value to a certain interval. Read more
source§

impl PartialEq<i48> for i48

source§

fn eq(&self, other: &i48) -> 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 PartialOrd<i48> for i48

source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

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

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

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

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

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

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

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

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl Rem<i48> for i48

§

type Output = i48

The resulting type after applying the % operator.
source§

fn rem(self, rhs: Self) -> Self::Output

Performs the % operation. Read more
source§

impl Serialize for i48

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 Shl<usize> for i48

§

type Output = i48

The resulting type after applying the << operator.
source§

fn shl(self, rhs: usize) -> Self::Output

Performs the << operation. Read more
source§

impl ShlAssign<usize> for i48

source§

fn shl_assign(&mut self, rhs: usize)

Performs the <<= operation. Read more
source§

impl Shr<usize> for i48

§

type Output = i48

The resulting type after applying the >> operator.
source§

fn shr(self, rhs: usize) -> Self::Output

Performs the >> operation. Read more
source§

impl ShrAssign<usize> for i48

source§

fn shr_assign(&mut self, rhs: usize)

Performs the >>= operation. Read more
source§

impl Sub<i48> for i48

§

type Output = i48

The resulting type after applying the - operator.
source§

fn sub(self, rhs: Self) -> Self::Output

Performs the - operation. Read more
source§

impl<P> ValidCheck<P> for i48

source§

const ALWAYS_VALID: bool = true

Set this to true if, at compile-time, we can tell that all bit representations which contain the appropriate number of bits are valid representations of this type
source§

fn is_valid(_input: P) -> bool

Return whether or not the underlying bits of P are valid representation of this type
source§

impl Zero for i48

source§

fn zero() -> Self

Returns the additive identity element of Self, 0. Read more
source§

fn is_zero(&self) -> bool

Returns true if self is equal to the additive identity.
source§

fn set_zero(&mut self)

Sets self to the additive identity element of Self, 0.
source§

impl Copy for i48

source§

impl Eq for i48

source§

impl StructuralEq for i48

source§

impl StructuralPartialEq for i48

Auto Trait Implementations§

§

impl RefUnwindSafe for i48

§

impl Send for i48

§

impl Sync for i48

§

impl Unpin for i48

§

impl UnwindSafe for i48

Blanket Implementations§

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> BitStructZero for Twhere
T: Zero,

source§

fn bs_zero() -> Self

Get a zero value for this bit struct
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

const: unstable · 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> LowerBounded for Twhere
T: Bounded,

source§

fn min_value() -> T

Returns the smallest finite number this type can represent
source§

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

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · 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.
const: unstable · source§

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

Performs the conversion.
source§

impl<T> UpperBounded for Twhere
T: Bounded,

source§

fn max_value() -> T

Returns the largest finite number this type can represent
source§

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

source§

impl<T, Rhs, Output> NumOps<Rhs, Output> for Twhere
T: Sub<Rhs, Output = Output> + Mul<Rhs, Output = Output> + Div<Rhs, Output = Output> + Add<Rhs, Output = Output> + Rem<Rhs, Output = Output>,