[−]Struct primitive_types::H512
Fixed-size uninterpreted hash type with 64 bytes (512 bits) size.
Methods
impl H512
pub fn repeat_byte(byte: u8) -> H512
Returns a new fixed hash where all bits are set to the given byte.
pub fn zero() -> H512
Returns a new zero-initialized fixed hash.
pub 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 fn as_fixed_bytes(&self) -> &[u8; 64]
Extracts a reference to the byte array containing the entire fixed hash.
pub fn as_fixed_bytes_mut(&mut self) -> &mut [u8; 64]
Extracts a reference to the byte array containing the entire fixed hash.
pub fn to_fixed_bytes(self) -> [u8; 64]
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]) -> Self
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: &Self) -> 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 H512
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) -> Self
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) -> Self
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) -> Self
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 H512
Utilities using the rand crate.
pub fn randomize_using<R: ?Sized>(&mut self, rng: &mut R) where
R: Rng,
R: Rng,
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: ?Sized>(rng: &mut R) -> Self where
R: Rng,
R: Rng,
Create a new hash with cryptographically random content using the given random number generator.
pub fn random() -> Self
Create a new hash with cryptographically random content.
Trait Implementations
impl AsMut<[u8]> for H512
impl AsRef<[u8]> for H512
impl<'l, 'r> BitAnd<&'r H512> for &'l H512
type Output = H512
The resulting type after applying the & operator.
fn bitand(self, rhs: &'r H512) -> Self::Output
impl BitAnd<H512> for H512
type Output = H512
The resulting type after applying the & operator.
fn bitand(self, rhs: Self) -> Self::Output
impl<'r> BitAndAssign<&'r H512> for H512
fn bitand_assign(&mut self, rhs: &'r H512)
impl BitAndAssign<H512> for H512
fn bitand_assign(&mut self, rhs: H512)
impl<'l, 'r> BitOr<&'r H512> for &'l H512
type Output = H512
The resulting type after applying the | operator.
fn bitor(self, rhs: &'r H512) -> Self::Output
impl BitOr<H512> for H512
type Output = H512
The resulting type after applying the | operator.
fn bitor(self, rhs: Self) -> Self::Output
impl<'r> BitOrAssign<&'r H512> for H512
fn bitor_assign(&mut self, rhs: &'r H512)
impl BitOrAssign<H512> for H512
fn bitor_assign(&mut self, rhs: H512)
impl<'l, 'r> BitXor<&'r H512> for &'l H512
type Output = H512
The resulting type after applying the ^ operator.
fn bitxor(self, rhs: &'r H512) -> Self::Output
impl BitXor<H512> for H512
type Output = H512
The resulting type after applying the ^ operator.
fn bitxor(self, rhs: Self) -> Self::Output
impl<'r> BitXorAssign<&'r H512> for H512
fn bitxor_assign(&mut self, rhs: &'r H512)
impl BitXorAssign<H512> for H512
fn bitxor_assign(&mut self, rhs: H512)
impl Clone for H512
fn clone(&self) -> H512
fn clone_from(&mut self, source: &Self)1.0.0[src]
impl Copy for H512
impl Debug for H512
impl Decode for H512
impl Default for H512
fn default() -> Self
impl<'de> Deserialize<'de> for H512
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where
D: Deserializer<'de>,
D: Deserializer<'de>,
impl Display for H512
impl Distribution<H512> for Standard
fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> H512
fn sample_iter<R>(self, rng: R) -> DistIter<Self, R, T> where
R: Rng, [src]
R: Rng,
impl Encode for H512
fn using_encoded<R, F: FnOnce(&[u8]) -> R>(&self, f: F) -> R
fn size_hint(&self) -> usize[src]
fn encode_to<T>(&self, dest: &mut T) where
T: Output, [src]
T: Output,
fn encode(&self) -> Vec<u8>[src]
impl EncodeLike<H512> for H512
impl Eq for H512
impl<'a> From<&'a [u8; 64]> for H512
fn from(bytes: &'a [u8; 64]) -> Self
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; 64]> for H512
fn from(bytes: &'a mut [u8; 64]) -> Self
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; 64]> for H512
fn from(bytes: [u8; 64]) -> Self
Constructs a hash type from the given bytes array of fixed length.
Note
The given bytes are interpreted in big endian order.
impl From<H512> for [u8; 64]
impl FromStr for H512
type Err = FromHexError
The associated error which can be returned from parsing.
fn from_str(input: &str) -> Result<H512, FromHexError>
impl Hash for H512
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 H512 where
I: SliceIndex<[u8]>,
I: SliceIndex<[u8]>,
impl<I> IndexMut<I> for H512 where
I: SliceIndex<[u8], Output = [u8]>,
I: SliceIndex<[u8], Output = [u8]>,
impl LowerHex for H512
impl Ord for H512
fn cmp(&self, other: &Self) -> Ordering
fn max(self, other: Self) -> Self1.21.0[src]
fn min(self, other: Self) -> Self1.21.0[src]
fn clamp(self, min: Self, max: Self) -> Self[src]
impl PartialEq<H512> for H512
impl PartialOrd<H512> for H512
fn partial_cmp(&self, other: &Self) -> 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 H512
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where
S: Serializer,
S: Serializer,
impl UpperHex for H512
Auto Trait Implementations
impl RefUnwindSafe for H512
impl Send for H512
impl Sync for H512
impl Unpin for H512
impl UnwindSafe for H512
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized, [src]
T: 'static + ?Sized,
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, [src]
S: Encode + Decode,
impl<T, X> Decode for X where
T: Decode + Into<X>,
X: WrapperTypeDecode<Wrapped = T>, [src]
T: Decode + Into<X>,
X: WrapperTypeDecode<Wrapped = T>,
impl<T> DecodeAll for T where
T: Decode, [src]
T: Decode,
impl<T> DeserializeOwned for T where
T: Deserialize<'de>, [src]
T: Deserialize<'de>,
impl<T, X> Encode for X where
T: Encode + ?Sized,
X: WrapperTypeEncode<Target = T>, [src]
T: Encode + ?Sized,
X: WrapperTypeEncode<Target = T>,
fn size_hint(&self) -> usize[src]
fn using_encoded<R, F>(&self, f: F) -> R where
F: FnOnce(&[u8]) -> R, [src]
F: FnOnce(&[u8]) -> R,
fn encode(&self) -> Vec<u8>[src]
fn encode_to<W>(&self, dest: &mut W) where
W: Output, [src]
W: Output,
impl<'_, '_, T> EncodeLike<&'_ &'_ T> for T where
T: Encode, [src]
T: Encode,
impl<'_, T> EncodeLike<&'_ T> for T where
T: Encode, [src]
T: Encode,
impl<'_, T> EncodeLike<&'_ mut T> for T where
T: Encode, [src]
T: Encode,
impl<T> EncodeLike<Arc<T>> for T where
T: Encode, [src]
T: Encode,
impl<T> EncodeLike<Box<T>> for T where
T: Encode, [src]
T: Encode,
impl<'a, T> EncodeLike<Cow<'a, T>> for T where
T: Encode + ToOwned, [src]
T: Encode + ToOwned,
impl<T> EncodeLike<Rc<T>> for T where
T: Encode, [src]
T: Encode,
impl<T> From<T> for T[src]
impl<S> FullCodec for S where
S: Decode + FullEncode, [src]
S: Decode + FullEncode,
impl<S> FullEncode for S where
S: Encode + EncodeLike<S>, [src]
S: Encode + EncodeLike<S>,
impl<T, U> Into<U> for T where
U: From<T>, [src]
U: From<T>,
impl<T> KeyedVec for T where
T: Codec, [src]
T: Codec,
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, 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>, [src]
V: MultiLane<T>,