#[repr(C)]pub struct U128(pub [u64; 2]);
Expand description
Little-endian large integer type 128-bit unsigned integer.
Tuple Fields§
§0: [u64; 2]
Implementations§
§impl U128
impl U128
pub fn from_dec_str(value: &str) -> Result<U128, FromDecStrErr>
pub fn from_dec_str(value: &str) -> Result<U128, FromDecStrErr>
Convert from a decimal string.
pub fn as_u64(&self) -> u64
pub fn as_u64(&self) -> u64
Conversion to u64 with overflow checking
§Panics
Panics if the number is larger than u64::max_value().
pub fn as_usize(&self) -> usize
pub fn as_usize(&self) -> usize
Conversion to usize with overflow checking
§Panics
Panics if the number is larger than usize::max_value().
pub fn leading_zeros(&self) -> u32
pub fn leading_zeros(&self) -> u32
Returns the number of leading zeros in the binary representation of self.
pub fn trailing_zeros(&self) -> u32
pub fn trailing_zeros(&self) -> u32
Returns the number of leading zeros in the binary representation of self.
pub fn to_big_endian(&self, bytes: &mut [u8])
pub fn to_big_endian(&self, bytes: &mut [u8])
Write to the slice in big-endian format.
pub fn to_little_endian(&self, bytes: &mut [u8])
pub fn to_little_endian(&self, bytes: &mut [u8])
Write to the slice in little-endian format.
pub fn pow(self, expon: U128) -> U128
pub fn pow(self, expon: U128) -> U128
Fast exponentiation by squaring https://en.wikipedia.org/wiki/Exponentiation_by_squaring
§Panics
Panics if the result overflows the type.
pub fn overflowing_pow(self, expon: U128) -> (U128, bool)
pub fn overflowing_pow(self, expon: U128) -> (U128, bool)
Fast exponentiation by squaring. Returns result and overflow flag.
pub fn checked_pow(self, expon: U128) -> Option<U128>
pub fn checked_pow(self, expon: U128) -> Option<U128>
Checked exponentiation. Returns None
if overflow occurred.
pub fn overflowing_add(self, other: U128) -> (U128, bool)
pub fn overflowing_add(self, other: U128) -> (U128, bool)
Add with overflow.
pub fn saturating_add(self, other: U128) -> U128
pub fn saturating_add(self, other: U128) -> U128
Addition which saturates at the maximum value (Self::max_value()).
pub fn checked_add(self, other: U128) -> Option<U128>
pub fn checked_add(self, other: U128) -> Option<U128>
Checked addition. Returns None
if overflow occurred.
pub fn overflowing_sub(self, other: U128) -> (U128, bool)
pub fn overflowing_sub(self, other: U128) -> (U128, bool)
Subtraction which underflows and returns a flag if it does.
pub fn saturating_sub(self, other: U128) -> U128
pub fn saturating_sub(self, other: U128) -> U128
Subtraction which saturates at zero.
pub fn checked_sub(self, other: U128) -> Option<U128>
pub fn checked_sub(self, other: U128) -> Option<U128>
Checked subtraction. Returns None
if overflow occurred.
pub fn overflowing_mul(self, other: U128) -> (U128, bool)
pub fn overflowing_mul(self, other: U128) -> (U128, bool)
Multiply with overflow, returning a flag if it does.
pub fn saturating_mul(self, other: U128) -> U128
pub fn saturating_mul(self, other: U128) -> U128
Multiplication which saturates at the maximum value..
pub fn checked_mul(self, other: U128) -> Option<U128>
pub fn checked_mul(self, other: U128) -> Option<U128>
Checked multiplication. Returns None
if overflow occurred.
pub fn checked_div(self, other: U128) -> Option<U128>
pub fn checked_div(self, other: U128) -> Option<U128>
Checked division. Returns None
if other == 0
.
pub fn checked_rem(self, other: U128) -> Option<U128>
pub fn checked_rem(self, other: U128) -> Option<U128>
Checked modulus. Returns None
if other == 0
.
pub fn overflowing_neg(self) -> (U128, bool)
pub fn overflowing_neg(self) -> (U128, bool)
Negation with overflow.
pub fn checked_neg(self) -> Option<U128>
pub fn checked_neg(self) -> Option<U128>
Checked negation. Returns None
unless self == 0
.
pub fn from_big_endian(slice: &[u8]) -> U128
pub fn from_big_endian(slice: &[u8]) -> U128
Converts from big endian representation bytes in memory.
pub fn from_little_endian(slice: &[u8]) -> U128
pub fn from_little_endian(slice: &[u8]) -> U128
Converts from little endian representation bytes in memory.
Trait Implementations§
§impl<'de> Deserialize<'de> for U128
impl<'de> Deserialize<'de> for U128
§fn deserialize<D>(
deserializer: D
) -> Result<U128, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
fn deserialize<D>(
deserializer: D
) -> Result<U128, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
§impl<T> DivAssign<T> for U128
impl<T> DivAssign<T> for U128
§fn div_assign(&mut self, other: T)
fn div_assign(&mut self, other: T)
/=
operation. Read more§impl Encode for U128
impl Encode for U128
§fn using_encoded<R, F>(&self, f: F) -> R
fn using_encoded<R, F>(&self, f: F) -> R
§impl MulAssign<i16> for U128
impl MulAssign<i16> for U128
§fn mul_assign(&mut self, other: i16)
fn mul_assign(&mut self, other: i16)
*=
operation. Read more§impl MulAssign<i32> for U128
impl MulAssign<i32> for U128
§fn mul_assign(&mut self, other: i32)
fn mul_assign(&mut self, other: i32)
*=
operation. Read more§impl MulAssign<i64> for U128
impl MulAssign<i64> for U128
§fn mul_assign(&mut self, other: i64)
fn mul_assign(&mut self, other: i64)
*=
operation. Read more§impl MulAssign<i8> for U128
impl MulAssign<i8> for U128
§fn mul_assign(&mut self, other: i8)
fn mul_assign(&mut self, other: i8)
*=
operation. Read more§impl MulAssign<isize> for U128
impl MulAssign<isize> for U128
§fn mul_assign(&mut self, other: isize)
fn mul_assign(&mut self, other: isize)
*=
operation. Read more§impl MulAssign<u16> for U128
impl MulAssign<u16> for U128
§fn mul_assign(&mut self, other: u16)
fn mul_assign(&mut self, other: u16)
*=
operation. Read more§impl MulAssign<u32> for U128
impl MulAssign<u32> for U128
§fn mul_assign(&mut self, other: u32)
fn mul_assign(&mut self, other: u32)
*=
operation. Read more§impl MulAssign<u64> for U128
impl MulAssign<u64> for U128
§fn mul_assign(&mut self, other: u64)
fn mul_assign(&mut self, other: u64)
*=
operation. Read more§impl MulAssign<u8> for U128
impl MulAssign<u8> for U128
§fn mul_assign(&mut self, other: u8)
fn mul_assign(&mut self, other: u8)
*=
operation. Read more§impl MulAssign<usize> for U128
impl MulAssign<usize> for U128
§fn mul_assign(&mut self, other: usize)
fn mul_assign(&mut self, other: usize)
*=
operation. Read more§impl Ord for U128
impl Ord for U128
§impl PartialOrd for U128
impl PartialOrd for U128
§fn partial_cmp(&self, other: &U128) -> Option<Ordering>
fn partial_cmp(&self, other: &U128) -> 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§impl<T> RemAssign<T> for U128
impl<T> RemAssign<T> for U128
§fn rem_assign(&mut self, other: T)
fn rem_assign(&mut self, other: T)
%=
operation. Read more§impl Serialize for U128
impl Serialize for U128
§fn serialize<S>(
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
fn serialize<S>(
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
§impl<T> ShlAssign<T> for U128
impl<T> ShlAssign<T> for U128
§fn shl_assign(&mut self, shift: T)
fn shl_assign(&mut self, shift: T)
<<=
operation. Read more§impl<T> ShrAssign<T> for U128
impl<T> ShrAssign<T> for U128
§fn shr_assign(&mut self, shift: T)
fn shr_assign(&mut self, shift: T)
>>=
operation. Read moreimpl Copy for U128
impl EncodeLike for U128
impl Eq for U128
impl StructuralPartialEq for U128
Auto Trait Implementations§
impl RefUnwindSafe for U128
impl Send for U128
impl Sync for U128
impl Unpin for U128
impl UnwindSafe for U128
Blanket Implementations§
§impl<T, U> AsByteSlice<T> for U
impl<T, U> AsByteSlice<T> for U
fn as_byte_slice(&self) -> &[u8] ⓘ
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> DecodeAll for Twhere
T: Decode,
impl<T> DecodeAll for Twhere
T: Decode,
§fn decode_all(input: &[u8]) -> Result<T, Error>
fn decode_all(input: &[u8]) -> Result<T, Error>
Self
and consume all of the given input data. If not all data is consumed, an error
is returned.§impl<T> DecodeLimit for Twhere
T: Decode,
impl<T> DecodeLimit for Twhere
T: Decode,
§fn decode_all_with_depth_limit(limit: u32, input: &[u8]) -> Result<T, Error>
fn decode_all_with_depth_limit(limit: u32, input: &[u8]) -> Result<T, Error>
Self
and consume all of the given input data. If not all data is consumed, an error
is returned.§fn decode_with_depth_limit(limit: u32, input: &[u8]) -> Result<T, Error>
fn decode_with_depth_limit(limit: u32, input: &[u8]) -> Result<T, Error>
Self
with given maximum recursion depth.
is returned.§impl<T> KeyedVec for Twhere
T: Codec,
impl<T> KeyedVec for Twhere
T: Codec,
§fn to_keyed_vec(&self, prepend_key: &[u8]) -> Vec<u8>
fn to_keyed_vec(&self, prepend_key: &[u8]) -> Vec<u8>
Self
prepended by given slice.