Struct sp_core::U256

source ·
#[repr(C)]
pub struct U256(pub [u64; 4]);
Expand description

Little-endian large integer type 256-bit unsigned integer.

Tuple Fields§

§0: [u64; 4]

Implementations§

source§

impl U256

source

pub const MAX: U256 = _

Maximum value.

source

pub fn from_str_radix(txt: &str, radix: u32) -> Result<U256, FromStrRadixErr>

Converts a string slice in a given base to an integer. Only supports radixes of 10 and 16.

source

pub fn from_dec_str(value: &str) -> Result<U256, FromDecStrErr>

Convert from a decimal string.

source

pub const fn low_u32(&self) -> u32

Conversion to u32

source

pub const fn low_u64(&self) -> u64

Low word (u64)

source

pub fn as_u32(&self) -> u32

Conversion to u32 with overflow checking

§Panics

Panics if the number is larger than 2^32.

source

pub fn as_u64(&self) -> u64

Conversion to u64 with overflow checking

§Panics

Panics if the number is larger than u64::max_value().

source

pub fn as_usize(&self) -> usize

Conversion to usize with overflow checking

§Panics

Panics if the number is larger than usize::max_value().

source

pub const fn is_zero(&self) -> bool

Whether this is zero.

source

pub fn bits(&self) -> usize

Return the least number of bits needed to represent the number

source

pub const fn bit(&self, index: usize) -> bool

Return if specific bit is set.

§Panics

Panics if index exceeds the bit width of the number.

source

pub fn leading_zeros(&self) -> u32

Returns the number of leading zeros in the binary representation of self.

source

pub fn trailing_zeros(&self) -> u32

Returns the number of trailing zeros in the binary representation of self.

source

pub const fn byte(&self, index: usize) -> u8

Return specific byte.

§Panics

Panics if index exceeds the byte width of the number.

source

pub fn to_big_endian(&self, bytes: &mut [u8])

Write to the slice in big-endian format.

source

pub fn to_little_endian(&self, bytes: &mut [u8])

Write to the slice in little-endian format.

source

pub fn exp10(n: usize) -> U256

Create 10**n as this type.

§Panics

Panics if the result overflows the type.

source

pub const fn zero() -> U256

Zero (additive identity) of this type.

source

pub const fn one() -> U256

One (multiplicative identity) of this type.

source

pub const fn max_value() -> U256

The maximum value which can be inhabited by this type.

source

pub fn div_mod(self, other: U256) -> (U256, U256)

Returns a pair (self / other, self % other).

§Panics

Panics if other is zero.

source

pub fn integer_sqrt(&self) -> U256

Compute the highest n such that n * n <= self.

source

pub fn pow(self, expon: U256) -> U256

Fast exponentiation by squaring https://en.wikipedia.org/wiki/Exponentiation_by_squaring

§Panics

Panics if the result overflows the type.

source

pub fn overflowing_pow(self, expon: U256) -> (U256, bool)

Fast exponentiation by squaring. Returns result and overflow flag.

source

pub fn checked_pow(self, expon: U256) -> Option<U256>

Checked exponentiation. Returns None if overflow occurred.

source

pub fn overflowing_add(self, other: U256) -> (U256, bool)

Addition which overflows and returns a flag if it does.

source

pub fn saturating_add(self, other: U256) -> U256

Addition which saturates at the maximum value (Self::MAX).

source

pub fn checked_add(self, other: U256) -> Option<U256>

Checked addition. Returns None if overflow occurred.

source

pub fn overflowing_sub(self, other: U256) -> (U256, bool)

Subtraction which underflows and returns a flag if it does.

source

pub fn saturating_sub(self, other: U256) -> U256

Subtraction which saturates at zero.

source

pub fn checked_sub(self, other: U256) -> Option<U256>

Checked subtraction. Returns None if overflow occurred.

source

pub fn abs_diff(self, other: U256) -> U256

Computes the absolute difference between self and other.

source

pub fn overflowing_mul(self, other: U256) -> (U256, bool)

Multiply with overflow, returning a flag if it does.

source

pub fn saturating_mul(self, other: U256) -> U256

Multiplication which saturates at the maximum value..

source

pub fn checked_mul(self, other: U256) -> Option<U256>

Checked multiplication. Returns None if overflow occurred.

source

pub fn checked_div(self, other: U256) -> Option<U256>

Checked division. Returns None if other == 0.

source

pub fn checked_rem(self, other: U256) -> Option<U256>

Checked modulus. Returns None if other == 0.

source

pub fn overflowing_neg(self) -> (U256, bool)

Negation with overflow.

source

pub fn checked_neg(self) -> Option<U256>

Checked negation. Returns None unless self == 0.

source

pub fn from_big_endian(slice: &[u8]) -> U256

Converts from big endian representation bytes in memory.

source

pub fn from_little_endian(slice: &[u8]) -> U256

Converts from little endian representation bytes in memory.

source§

impl U256

source

pub const fn low_u128(&self) -> u128

Low 2 words (u128)

source

pub fn as_u128(&self) -> u128

Conversion to u128 with overflow checking

§Panics

Panics if the number is larger than 2^128.

source§

impl U256

source

pub fn full_mul(self, other: U256) -> U512

Multiplies two 256-bit integers to produce full 512-bit integer. Overflow is not possible.

Trait Implementations§

source§

impl<'a, T> Add<T> for &'a U256
where T: Into<U256>,

§

type Output = U256

The resulting type after applying the + operator.
source§

fn add(self, other: T) -> U256

Performs the + operation. Read more
source§

impl<T> Add<T> for U256
where T: Into<U256>,

§

type Output = U256

The resulting type after applying the + operator.
source§

fn add(self, other: T) -> U256

Performs the + operation. Read more
source§

impl AddAssign for U256

source§

fn add_assign(&mut self, other: U256)

Performs the += operation. Read more
source§

impl AsRef<[u64]> for U256

Get a reference to the underlying little-endian words.

source§

fn as_ref(&self) -> &[u64]

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl BitAnd for U256

§

type Output = U256

The resulting type after applying the & operator.
source§

fn bitand(self, other: U256) -> U256

Performs the & operation. Read more
source§

impl BitAndAssign for U256

source§

fn bitand_assign(&mut self, rhs: U256)

Performs the &= operation. Read more
source§

impl BitOr for U256

§

type Output = U256

The resulting type after applying the | operator.
source§

fn bitor(self, other: U256) -> U256

Performs the | operation. Read more
source§

impl BitOrAssign for U256

source§

fn bitor_assign(&mut self, rhs: U256)

Performs the |= operation. Read more
source§

impl BitXor for U256

§

type Output = U256

The resulting type after applying the ^ operator.
source§

fn bitxor(self, other: U256) -> U256

Performs the ^ operation. Read more
source§

impl BitXorAssign for U256

source§

fn bitxor_assign(&mut self, rhs: U256)

Performs the ^= operation. Read more
source§

impl Clone for U256

source§

fn clone(&self) -> U256

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 U256

source§

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

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

impl Decode for U256

source§

fn decode<I>(input: &mut I) -> Result<U256, Error>
where I: Input,

Attempt to deserialise the value from input.
source§

fn decode_into<I>( input: &mut I, dst: &mut MaybeUninit<Self>, ) -> Result<DecodeFinished, Error>
where I: Input,

Attempt to deserialize the value from input into a pre-allocated piece of memory. Read more
source§

fn skip<I>(input: &mut I) -> Result<(), Error>
where I: Input,

Attempt to skip the encoded value from input. Read more
source§

fn encoded_fixed_size() -> Option<usize>

Returns the fixed encoded size of the type. Read more
source§

impl Default for U256

source§

fn default() -> U256

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

impl<'de> Deserialize<'de> for U256

source§

fn deserialize<D>( deserializer: D, ) -> Result<U256, <D as Deserializer<'de>>::Error>
where D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Display for U256

source§

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

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

impl<'a, T> Div<T> for &'a U256
where T: Into<U256>,

§

type Output = U256

The resulting type after applying the / operator.
source§

fn div(self, other: T) -> U256

Performs the / operation. Read more
source§

impl<T> Div<T> for U256
where T: Into<U256>,

§

type Output = U256

The resulting type after applying the / operator.
source§

fn div(self, other: T) -> U256

Performs the / operation. Read more
source§

impl<T> DivAssign<T> for U256
where T: Into<U256>,

source§

fn div_assign(&mut self, other: T)

Performs the /= operation. Read more
source§

impl Encode for U256

source§

fn using_encoded<R, F>(&self, f: F) -> R
where F: FnOnce(&[u8]) -> R,

Convert self to a slice and then invoke the given closure with it.
source§

fn size_hint(&self) -> usize

If possible give a hint of expected size of the encoding. Read more
source§

fn encode_to<T>(&self, dest: &mut T)
where T: Output + ?Sized,

Convert self to a slice and append it to the destination.
source§

fn encode(&self) -> Vec<u8>

Convert self to an owned vector.
source§

fn encoded_size(&self) -> usize

Calculates the encoded size. Read more
source§

impl<'a> From<&'a [u8]> for U256

source§

fn from(bytes: &[u8]) -> U256

Converts to this type from the input type.
source§

impl<'a> From<&'a [u8; 32]> for U256

source§

fn from(bytes: &[u8; 32]) -> U256

Converts to this type from the input type.
source§

impl<'a> From<&'a U256> for U256

source§

fn from(x: &'a U256) -> U256

Converts to this type from the input type.
source§

impl<'a> From<&'a U256> for U512

source§

fn from(value: &'a U256) -> U512

Converts to this type from the input type.
source§

impl From<&'static str> for U256

source§

fn from(s: &'static str) -> U256

Converts to this type from the input type.
source§

impl From<[u8; 32]> for U256

source§

fn from(bytes: [u8; 32]) -> U256

Converts to this type from the input type.
source§

impl From<U128> for U256

source§

fn from(value: U128) -> U256

Converts to this type from the input type.
source§

impl From<U256> for U512

source§

fn from(value: U256) -> U512

Converts to this type from the input type.
source§

impl From<i128> for U256

source§

fn from(value: i128) -> U256

Converts to this type from the input type.
source§

impl From<i16> for U256

source§

fn from(value: i16) -> U256

Converts to this type from the input type.
source§

impl From<i32> for U256

source§

fn from(value: i32) -> U256

Converts to this type from the input type.
source§

impl From<i64> for U256

source§

fn from(value: i64) -> U256

Converts to this type from the input type.
source§

impl From<i8> for U256

source§

fn from(value: i8) -> U256

Converts to this type from the input type.
source§

impl From<isize> for U256

source§

fn from(value: isize) -> U256

Converts to this type from the input type.
source§

impl From<u128> for U256

source§

fn from(value: u128) -> U256

Converts to this type from the input type.
source§

impl From<u16> for U256

source§

fn from(value: u16) -> U256

Converts to this type from the input type.
source§

impl From<u32> for U256

source§

fn from(value: u32) -> U256

Converts to this type from the input type.
source§

impl From<u64> for U256

source§

fn from(value: u64) -> U256

Converts to this type from the input type.
source§

impl From<u8> for U256

source§

fn from(value: u8) -> U256

Converts to this type from the input type.
source§

impl From<usize> for U256

source§

fn from(value: usize) -> U256

Converts to this type from the input type.
source§

impl FromStr for U256

§

type Err = FromHexError

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

fn from_str(value: &str) -> Result<U256, <U256 as FromStr>::Err>

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

impl Hash for U256

source§

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

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 LowerHex for U256

source§

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

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

impl MaxEncodedLen for U256

source§

fn max_encoded_len() -> usize

Upper bound, in bytes, of the maximum encoded size of this item.
source§

impl<'a> Mul<&'a U256> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a U256) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i16> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a i16) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i16> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a i16) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i32> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a i32) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i32> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a i32) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i64> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a i64) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i64> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a i64) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i8> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a i8) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a i8> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a i8) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a isize> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a isize) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a isize> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a isize) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u16> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a u16) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u16> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a u16) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u32> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a u32) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u32> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a u32) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u64> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a u64) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u64> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a u64) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u8> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a u8) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a u8> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a u8) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a usize> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a usize) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<&'a usize> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a usize) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<U256> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: U256) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<i16> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: i16) -> U256

Performs the * operation. Read more
source§

impl Mul<i16> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: i16) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<i32> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: i32) -> U256

Performs the * operation. Read more
source§

impl Mul<i32> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: i32) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<i64> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: i64) -> U256

Performs the * operation. Read more
source§

impl Mul<i64> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: i64) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<i8> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: i8) -> U256

Performs the * operation. Read more
source§

impl Mul<i8> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: i8) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<isize> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: isize) -> U256

Performs the * operation. Read more
source§

impl Mul<isize> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: isize) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<u16> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: u16) -> U256

Performs the * operation. Read more
source§

impl Mul<u16> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: u16) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<u32> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: u32) -> U256

Performs the * operation. Read more
source§

impl Mul<u32> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: u32) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<u64> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: u64) -> U256

Performs the * operation. Read more
source§

impl Mul<u64> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: u64) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<u8> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: u8) -> U256

Performs the * operation. Read more
source§

impl Mul<u8> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: u8) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul<usize> for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: usize) -> U256

Performs the * operation. Read more
source§

impl Mul<usize> for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: usize) -> U256

Performs the * operation. Read more
source§

impl<'a> Mul for &'a U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: &'a U256) -> U256

Performs the * operation. Read more
source§

impl Mul for U256

§

type Output = U256

The resulting type after applying the * operator.
source§

fn mul(self, other: U256) -> U256

Performs the * operation. Read more
source§

impl MulAssign<i16> for U256

source§

fn mul_assign(&mut self, other: i16)

Performs the *= operation. Read more
source§

impl MulAssign<i32> for U256

source§

fn mul_assign(&mut self, other: i32)

Performs the *= operation. Read more
source§

impl MulAssign<i64> for U256

source§

fn mul_assign(&mut self, other: i64)

Performs the *= operation. Read more
source§

impl MulAssign<i8> for U256

source§

fn mul_assign(&mut self, other: i8)

Performs the *= operation. Read more
source§

impl MulAssign<isize> for U256

source§

fn mul_assign(&mut self, other: isize)

Performs the *= operation. Read more
source§

impl MulAssign<u16> for U256

source§

fn mul_assign(&mut self, other: u16)

Performs the *= operation. Read more
source§

impl MulAssign<u32> for U256

source§

fn mul_assign(&mut self, other: u32)

Performs the *= operation. Read more
source§

impl MulAssign<u64> for U256

source§

fn mul_assign(&mut self, other: u64)

Performs the *= operation. Read more
source§

impl MulAssign<u8> for U256

source§

fn mul_assign(&mut self, other: u8)

Performs the *= operation. Read more
source§

impl MulAssign<usize> for U256

source§

fn mul_assign(&mut self, other: usize)

Performs the *= operation. Read more
source§

impl MulAssign for U256

source§

fn mul_assign(&mut self, other: U256)

Performs the *= operation. Read more
source§

impl Not for U256

§

type Output = U256

The resulting type after applying the ! operator.
source§

fn not(self) -> U256

Performs the unary ! operation. Read more
source§

impl Ord for U256

source§

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

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

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

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

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

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

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

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

impl PartialEq for U256

source§

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

source§

fn partial_cmp(&self, other: &U256) -> 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<'a, T> Rem<T> for &'a U256
where T: Into<U256> + Copy,

§

type Output = U256

The resulting type after applying the % operator.
source§

fn rem(self, other: T) -> U256

Performs the % operation. Read more
source§

impl<T> Rem<T> for U256
where T: Into<U256> + Copy,

§

type Output = U256

The resulting type after applying the % operator.
source§

fn rem(self, other: T) -> U256

Performs the % operation. Read more
source§

impl<T> RemAssign<T> for U256
where T: Into<U256> + Copy,

source§

fn rem_assign(&mut self, other: T)

Performs the %= operation. Read more
source§

impl Serialize for U256

source§

fn serialize<S>( &self, serializer: S, ) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>
where S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl<'a, T> Shl<T> for &'a U256
where T: Into<U256>,

§

type Output = U256

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

fn shl(self, shift: T) -> U256

Performs the << operation. Read more
source§

impl<T> Shl<T> for U256
where T: Into<U256>,

§

type Output = U256

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

fn shl(self, shift: T) -> U256

Performs the << operation. Read more
source§

impl<T> ShlAssign<T> for U256
where T: Into<U256>,

source§

fn shl_assign(&mut self, shift: T)

Performs the <<= operation. Read more
source§

impl<'a, T> Shr<T> for &'a U256
where T: Into<U256>,

§

type Output = U256

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

fn shr(self, shift: T) -> U256

Performs the >> operation. Read more
source§

impl<T> Shr<T> for U256
where T: Into<U256>,

§

type Output = U256

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

fn shr(self, shift: T) -> U256

Performs the >> operation. Read more
source§

impl<T> ShrAssign<T> for U256
where T: Into<U256>,

source§

fn shr_assign(&mut self, shift: T)

Performs the >>= operation. Read more
source§

impl<'a, T> Sub<T> for &'a U256
where T: Into<U256>,

§

type Output = U256

The resulting type after applying the - operator.
source§

fn sub(self, other: T) -> U256

Performs the - operation. Read more
source§

impl<T> Sub<T> for U256
where T: Into<U256>,

§

type Output = U256

The resulting type after applying the - operator.
source§

fn sub(self, other: T) -> U256

Performs the - operation. Read more
source§

impl SubAssign for U256

source§

fn sub_assign(&mut self, other: U256)

Performs the -= operation. Read more
source§

impl<'a> TryFrom<&'a U512> for U256

§

type Error = Error

The type returned in the event of a conversion error.
source§

fn try_from(value: &'a U512) -> Result<U256, Error>

Performs the conversion.
source§

impl TryFrom<U512> for U256

§

type Error = Error

The type returned in the event of a conversion error.
source§

fn try_from(value: U512) -> Result<U256, Error>

Performs the conversion.
source§

impl TypeInfo for U256

§

type Identity = U256

The type identifying for which type info is provided. Read more
source§

fn type_info() -> Type

Returns the static type identifier for Self.
source§

impl UpperHex for U256

source§

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

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

impl Copy for U256

source§

impl EncodeLike for U256

source§

impl Eq for U256

source§

impl StructuralPartialEq for U256

Auto Trait Implementations§

§

impl Freeze for U256

§

impl RefUnwindSafe for U256

§

impl Send for U256

§

impl Sync for U256

§

impl Unpin for U256

§

impl UnwindSafe for U256

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T, U> AsByteSlice<T> for U
where T: ToByteSlice, U: AsRef<[T]> + ?Sized,

source§

fn as_byte_slice(&self) -> &[u8]

source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> CallHasher for T
where T: Hash + ?Sized,

source§

default fn get_hash<H, B>(value: &H, build_hasher: &B) -> u64
where H: Hash + ?Sized, B: BuildHasher,

source§

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> CloneToUninit for T
where T: Copy,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> DecodeAll for T
where T: Decode,

source§

fn decode_all(input: &mut &[u8]) -> Result<T, Error>

Decode Self and consume all of the given input data. Read more
source§

impl<T> DecodeLimit for T
where T: Decode,

source§

fn decode_all_with_depth_limit( limit: u32, input: &mut &[u8], ) -> Result<T, Error>

Decode Self and consume all of the given input data. Read more
source§

fn decode_with_depth_limit<I>(limit: u32, input: &mut I) -> Result<T, Error>
where I: Input,

Decode Self with the given maximum recursion depth and advance input by the number of bytes consumed. Read more
source§

impl<T> Downcast for T
where T: Any,

source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<T> DynClone for T
where T: Clone,

source§

fn __clone_box(&self, _: Private) -> *mut ()

source§

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

source§

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

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where 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.

source§

impl<T, Outer> IsWrappedBy<Outer> for T
where Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,

source§

fn from_ref(outer: &Outer) -> &T

Get a reference to the inner from the outer.

source§

fn from_mut(outer: &mut Outer) -> &mut T

Get a mutable reference to the inner from the outer.

source§

impl<T> KeyedVec for T
where T: Codec,

source§

fn to_keyed_vec(&self, prepend_key: &[u8]) -> Vec<u8>

Return an encoding of Self prepended by given slice.
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where 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> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for T
where 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 T
where 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.
source§

impl<S, T> UncheckedInto<T> for S
where T: UncheckedFrom<S>,

source§

fn unchecked_into(self) -> T

The counterpart to unchecked_from.
source§

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

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<S> Codec for S
where S: Decode + Encode,

source§

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

source§

impl<T> EncodeLike<&&T> for T
where T: Encode,

source§

impl<T> EncodeLike<&T> for T
where T: Encode,

source§

impl<T> EncodeLike<&mut T> for T
where T: Encode,

source§

impl<T> EncodeLike<Arc<T>> for T
where T: Encode,

source§

impl<T> EncodeLike<Box<T>> for T
where T: Encode,

source§

impl<'a, T> EncodeLike<Cow<'a, T>> for T
where T: ToOwned + Encode,

source§

impl<T> EncodeLike<Rc<T>> for T
where T: Encode,

source§

impl<S> FullCodec for S
where S: Decode + FullEncode,

source§

impl<S> FullEncode for S
where S: Encode + EncodeLike,

source§

impl<T> JsonSchemaMaybe for T

source§

impl<T> MaybeDebug for T
where T: Debug,

source§

impl<T> MaybeRefUnwindSafe for T
where T: RefUnwindSafe,

source§

impl<T, Rhs> NumAssignOps<Rhs> for T
where T: AddAssign<Rhs> + SubAssign<Rhs> + MulAssign<Rhs> + DivAssign<Rhs> + RemAssign<Rhs>,

source§

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

source§

impl<T, Base> RefNum<Base> for T
where T: NumOps<Base, Base> + for<'r> NumOps<&'r Base, Base>,

source§

impl<T> StaticTypeInfo for T
where T: TypeInfo + 'static,