[−]Struct web3::types::H160
Fixed-size uninterpreted hash type with 20 bytes (160 bits) size.
Implementations
impl H160
pub const fn repeat_byte(byte: u8) -> H160
Returns a new fixed hash where all bits are set to the given byte.
pub const fn zero() -> H160
Returns a new zero-initialized fixed hash.
pub const fn len_bytes() -> usize
Returns the size of this hash in bytes.
pub fn as_bytes(&self) -> &[u8]
Extracts a byte slice containing the entire fixed hash.
pub fn as_bytes_mut(&mut self) -> &mut [u8]
Extracts a mutable byte slice containing the entire fixed hash.
pub const fn as_fixed_bytes(&self) -> &[u8; 20]
Extracts a reference to the byte array containing the entire fixed hash.
pub fn as_fixed_bytes_mut(&mut self) -> &mut [u8; 20]
Extracts a reference to the byte array containing the entire fixed hash.
pub const fn to_fixed_bytes(self) -> [u8; 20]
Returns the inner bytes array.
pub fn as_ptr(&self) -> *const u8
Returns a constant raw pointer to the value.
pub fn as_mut_ptr(&mut self) -> *mut u8
Returns a mutable raw pointer to the value.
pub fn assign_from_slice(&mut self, src: &[u8])
Assign the bytes from the byte slice src to self.
Note
The given bytes are interpreted in big endian order.
Panics
If the length of src and the number of bytes in self do not match.
pub fn from_slice(src: &[u8]) -> H160
Create a new fixed-hash from the given slice src.
Note
The given bytes are interpreted in big endian order.
Panics
If the length of src and the number of bytes in Self do not match.
pub fn covers(&self, b: &H160) -> bool
Returns true if all bits set in b are also set in self.
pub fn is_zero(&self) -> bool
Returns true if no bits are set.
impl H160
Utilities using the byteorder crate.
pub fn to_low_u64_be(&self) -> u64
Returns the lowest 8 bytes interpreted as big-endian.
Note
For hash type with less than 8 bytes the missing bytes are interpreted as being zero.
pub fn to_low_u64_le(&self) -> u64
Returns the lowest 8 bytes interpreted as little-endian.
Note
For hash type with less than 8 bytes the missing bytes are interpreted as being zero.
pub fn to_low_u64_ne(&self) -> u64
Returns the lowest 8 bytes interpreted as native-endian.
Note
For hash type with less than 8 bytes the missing bytes are interpreted as being zero.
pub fn from_low_u64_be(val: u64) -> H160
Creates a new hash type from the given u64 value.
Note
- The given
u64value is interpreted as big endian. - Ignores the most significant bits of the given value if the hash type has less than 8 bytes.
pub fn from_low_u64_le(val: u64) -> H160
Creates a new hash type from the given u64 value.
Note
- The given
u64value is interpreted as little endian. - Ignores the most significant bits of the given value if the hash type has less than 8 bytes.
pub fn from_low_u64_ne(val: u64) -> H160
Creates a new hash type from the given u64 value.
Note
- The given
u64value is interpreted as native endian. - Ignores the most significant bits of the given value if the hash type has less than 8 bytes.
impl H160
Utilities using the rand crate.
pub fn randomize_using<R>(&mut self, rng: &mut R) where
R: Rng + ?Sized,
R: Rng + ?Sized,
Assign self to a cryptographically random value using the
given random number generator.
pub fn randomize(&mut self)
Assign self to a cryptographically random value.
pub fn random_using<R>(rng: &mut R) -> H160 where
R: Rng + ?Sized,
R: Rng + ?Sized,
Create a new hash with cryptographically random content using the given random number generator.
pub fn random() -> H160
Create a new hash with cryptographically random content.
Trait Implementations
impl AsMut<[u8]> for H160
impl AsRef<[u8]> for H160
impl<'l, 'r> BitAnd<&'r H160> for &'l H160
type Output = H160
The resulting type after applying the & operator.
fn bitand(self, rhs: &'r H160) -> <&'l H160 as BitAnd<&'r H160>>::Output
impl BitAnd<H160> for H160
type Output = H160
The resulting type after applying the & operator.
fn bitand(self, rhs: H160) -> <H160 as BitAnd<H160>>::Output
impl<'r> BitAndAssign<&'r H160> for H160
fn bitand_assign(&mut self, rhs: &'r H160)
impl BitAndAssign<H160> for H160
fn bitand_assign(&mut self, rhs: H160)
impl<'l, 'r> BitOr<&'r H160> for &'l H160
type Output = H160
The resulting type after applying the | operator.
fn bitor(self, rhs: &'r H160) -> <&'l H160 as BitOr<&'r H160>>::Output
impl BitOr<H160> for H160
type Output = H160
The resulting type after applying the | operator.
fn bitor(self, rhs: H160) -> <H160 as BitOr<H160>>::Output
impl<'r> BitOrAssign<&'r H160> for H160
fn bitor_assign(&mut self, rhs: &'r H160)
impl BitOrAssign<H160> for H160
fn bitor_assign(&mut self, rhs: H160)
impl<'l, 'r> BitXor<&'r H160> for &'l H160
type Output = H160
The resulting type after applying the ^ operator.
fn bitxor(self, rhs: &'r H160) -> <&'l H160 as BitXor<&'r H160>>::Output
impl BitXor<H160> for H160
type Output = H160
The resulting type after applying the ^ operator.
fn bitxor(self, rhs: H160) -> <H160 as BitXor<H160>>::Output
impl<'r> BitXorAssign<&'r H160> for H160
fn bitxor_assign(&mut self, rhs: &'r H160)
impl BitXorAssign<H160> for H160
fn bitxor_assign(&mut self, rhs: H160)
impl Clone for H160
fn clone(&self) -> H160
fn clone_from(&mut self, source: &Self)1.0.0[src]
impl Copy for H160
impl Debug for H160
impl Decodable for H160
impl Decode for H160
impl Default for H160
impl<'de> Deserialize<'de> for H160
fn deserialize<D>(
deserializer: D
) -> Result<H160, <D as Deserializer<'de>>::Error> where
D: Deserializer<'de>,
deserializer: D
) -> Result<H160, <D as Deserializer<'de>>::Error> where
D: Deserializer<'de>,
impl Display for H160
impl Encodable for H160
fn rlp_append(&self, s: &mut RlpStream)
fn rlp_bytes(&self) -> Vec<u8>
impl Encode for H160
fn using_encoded<R, F>(&self, f: F) -> R where
F: FnOnce(&[u8]) -> R,
F: FnOnce(&[u8]) -> R,
fn size_hint(&self) -> usize
fn encode_to<T>(&self, dest: &mut T) where
T: Output,
T: Output,
fn encode(&self) -> Vec<u8>
impl EncodeLike<H160> for H160
impl Eq for H160
impl<'a> From<&'a [u8; 20]> for H160
fn from(bytes: &'a [u8; 20]) -> H160
Constructs a hash type from the given reference to the bytes array of fixed length.
Note
The given bytes are interpreted in big endian order.
impl<'a> From<&'a mut [u8; 20]> for H160
fn from(bytes: &'a mut [u8; 20]) -> H160
Constructs a hash type from the given reference to the mutable bytes array of fixed length.
Note
The given bytes are interpreted in big endian order.
impl From<[u8; 20]> for H160
fn from(bytes: [u8; 20]) -> H160
Constructs a hash type from the given bytes array of fixed length.
Note
The given bytes are interpreted in big endian order.
impl From<H160> for H256
impl From<H256> for H160
impl FromStr for H160
type Err = FromHexError
The associated error which can be returned from parsing.
fn from_str(input: &str) -> Result<H160, FromHexError>
impl Hash for H160
fn hash<H>(&self, state: &mut H) where
H: Hasher,
H: Hasher,
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher, 1.3.0[src]
H: Hasher,
impl<I> Index<I> for H160 where
I: SliceIndex<[u8]>,
I: SliceIndex<[u8]>,
type Output = <I as SliceIndex<[u8]>>::Output
The returned type after indexing.
fn index(&self, index: I) -> &<I as SliceIndex<[u8]>>::Output
impl<I> IndexMut<I> for H160 where
I: SliceIndex<[u8], Output = [u8]>,
I: SliceIndex<[u8], Output = [u8]>,
impl LowerHex for H160
impl Ord for H160
fn cmp(&self, other: &H160) -> Ordering
#[must_use]fn max(self, other: Self) -> Self1.21.0[src]
#[must_use]fn min(self, other: Self) -> Self1.21.0[src]
#[must_use]fn clamp(self, min: Self, max: Self) -> Self[src]
impl PartialEq<H160> for H160
impl PartialOrd<H160> for H160
fn partial_cmp(&self, other: &H160) -> Option<Ordering>
#[must_use]fn lt(&self, other: &Rhs) -> bool1.0.0[src]
#[must_use]fn le(&self, other: &Rhs) -> bool1.0.0[src]
#[must_use]fn gt(&self, other: &Rhs) -> bool1.0.0[src]
#[must_use]fn ge(&self, other: &Rhs) -> bool1.0.0[src]
impl Serialize for H160
fn serialize<S>(
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> where
S: Serializer,
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> where
S: Serializer,
impl UpperHex for H160
Auto Trait Implementations
impl RefUnwindSafe for H160
impl Send for H160
impl Sync for H160
impl Unpin for H160
impl UnwindSafe for H160
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized, [src]
T: 'static + ?Sized,
impl<T, U> AsByteSlice<T> for U where
T: ToByteSlice,
U: AsRef<[T]> + ?Sized,
T: ToByteSlice,
U: AsRef<[T]> + ?Sized,
fn as_byte_slice(&self) -> &[u8]
impl<T, U> AsMutByteSlice<T> for U where
T: ToMutByteSlice,
U: AsMut<[T]> + ?Sized,
T: ToMutByteSlice,
U: AsMut<[T]> + ?Sized,
fn as_mut_byte_slice(&mut self) -> &mut [u8]
impl<U> AsMutSliceOf for U where
U: AsMut<[u8]> + ?Sized,
U: AsMut<[u8]> + ?Sized,
fn as_mut_slice_of<T>(&mut self) -> Result<&mut [T], Error> where
T: FromByteSlice,
T: FromByteSlice,
impl<U> AsSliceOf for U where
U: AsRef<[u8]> + ?Sized,
U: AsRef<[u8]> + ?Sized,
fn as_slice_of<T>(&self) -> Result<&[T], Error> where
T: FromByteSlice,
T: FromByteSlice,
impl<T> Borrow<T> for T where
T: ?Sized, [src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized, [src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T[src]
impl<S> Codec for S where
S: Encode + Decode,
S: Encode + Decode,
impl<T, X> Decode for X where
T: Decode + Into<X>,
X: WrapperTypeDecode<Wrapped = T>,
T: Decode + Into<X>,
X: WrapperTypeDecode<Wrapped = T>,
impl<T> DecodeAll for T where
T: Decode,
T: Decode,
fn decode_all(input: &[u8]) -> Result<T, Error>
impl<T> DecodeLimit for T where
T: Decode,
T: Decode,
fn decode_all_with_depth_limit(limit: u32, input: &[u8]) -> Result<T, Error>
fn decode_with_depth_limit(limit: u32, input: &[u8]) -> Result<T, Error>
impl<T> DeserializeOwned for T where
T: for<'de> Deserialize<'de>, [src]
T: for<'de> Deserialize<'de>,
impl<T> Detokenize for T where
T: Tokenizable, [src]
T: Tokenizable,
fn from_tokens(Vec<Token>) -> Result<T, Error>[src]
impl<T, X> Encode for X where
T: Encode + ?Sized,
X: WrapperTypeEncode<Target = T>,
T: Encode + ?Sized,
X: WrapperTypeEncode<Target = T>,
fn size_hint(&self) -> usize
fn using_encoded<R, F>(&self, f: F) -> R where
F: FnOnce(&[u8]) -> R,
F: FnOnce(&[u8]) -> R,
fn encode(&self) -> Vec<u8>
fn encode_to<W>(&self, dest: &mut W) where
W: Output,
W: Output,
impl<'_, '_, T> EncodeLike<&'_ &'_ T> for T where
T: Encode,
T: Encode,
impl<'_, T> EncodeLike<&'_ T> for T where
T: Encode,
T: Encode,
impl<'_, T> EncodeLike<&'_ mut T> for T where
T: Encode,
T: Encode,
impl<T> EncodeLike<Arc<T>> for T where
T: Encode,
T: Encode,
impl<T> EncodeLike<Box<T>> for T where
T: Encode,
T: Encode,
impl<'a, T> EncodeLike<Cow<'a, T>> for T where
T: Encode + ToOwned,
T: Encode + ToOwned,
impl<T> EncodeLike<Rc<T>> for T where
T: Encode,
T: Encode,
impl<Q, K> Equivalent<K> for Q where
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized, [src]
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized,
fn equivalent(&self, key: &K) -> bool[src]
impl<T> From<T> for T[src]
impl<S> FullCodec for S where
S: Decode + FullEncode,
S: Decode + FullEncode,
impl<S> FullEncode for S where
S: Encode + EncodeLike<S>,
S: Encode + EncodeLike<S>,
impl<T> Instrument for T[src]
fn instrument(self, span: Span) -> Instrumented<Self>[src]
fn in_current_span(self) -> Instrumented<Self>[src]
impl<T> Instrument for T[src]
fn instrument(self, span: Span) -> Instrumented<Self>[src]
fn in_current_span(self) -> Instrumented<Self>[src]
impl<T, U> Into<U> for T where
U: From<T>, [src]
U: From<T>,
impl<T> KeyedVec for T where
T: Codec,
T: Codec,
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<T> ToHex for T where
T: AsRef<[u8]>, [src]
T: AsRef<[u8]>,
fn encode_hex<U>(&self) -> U where
U: FromIterator<char>, [src]
U: FromIterator<char>,
fn encode_hex_upper<U>(&self) -> U where
U: FromIterator<char>, [src]
U: FromIterator<char>,
impl<T> ToOwned for T where
T: Clone, [src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T[src]
fn clone_into(&self, target: &mut T)[src]
impl<T> ToString for T where
T: Display + ?Sized, [src]
T: Display + ?Sized,
impl<T> Tokenize for T where
T: Tokenizable, [src]
T: Tokenizable,
fn into_tokens(Self) -> Vec<Token>[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>, [src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>, [src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,