Struct evm_state::Bloom [−][src]
Bloom hash type with 256 bytes (2048 bits) size.
Implementations
impl Bloom[src][−]
pub fn is_empty(&self) -> bool[src]
pub fn contains_input(&self, input: Input<'_>) -> bool[src]
pub fn contains_bloom<'a, B>(&self, bloom: B) -> bool where
BloomRef<'a>: From<B>, [src]
BloomRef<'a>: From<B>,
pub fn accrue(&mut self, input: Input<'_>)[src]
pub fn accrue_bloom<'a, B>(&mut self, bloom: B) where
BloomRef<'a>: From<B>, [src]
BloomRef<'a>: From<B>,
pub fn data(&self) -> &[u8; 256][src]
impl Bloom[src][−]
pub const fn repeat_byte(byte: u8) -> Bloom[src][−]
Returns a new fixed hash where all bits are set to the given byte.
pub const fn zero() -> Bloom[src][−]
Returns a new zero-initialized fixed hash.
pub const fn len_bytes() -> usize[src][−]
Returns the size of this hash in bytes.
pub fn as_bytes(&self) -> &[u8][src][−]
Extracts a byte slice containing the entire fixed hash.
pub fn as_bytes_mut(&mut self) -> &mut [u8][src][−]
Extracts a mutable byte slice containing the entire fixed hash.
pub const fn as_fixed_bytes(&self) -> &[u8; 256][src][−]
Extracts a reference to the byte array containing the entire fixed hash.
pub fn as_fixed_bytes_mut(&mut self) -> &mut [u8; 256][src][−]
Extracts a reference to the byte array containing the entire fixed hash.
pub const fn to_fixed_bytes(self) -> [u8; 256][src][−]
Returns the inner bytes array.
pub fn as_ptr(&self) -> *const u8[src][−]
Returns a constant raw pointer to the value.
pub fn as_mut_ptr(&mut self) -> *mut u8[src][−]
Returns a mutable raw pointer to the value.
pub fn assign_from_slice(&mut self, src: &[u8])[src][−]
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]) -> Bloom[src][−]
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: &Bloom) -> bool[src][−]
Returns true if all bits set in b are also set in self.
pub fn is_zero(&self) -> bool[src][−]
Returns true if no bits are set.
impl Bloom[src][−]
Utilities using the byteorder crate.
pub fn to_low_u64_be(&self) -> u64[src][−]
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[src][−]
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[src][−]
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) -> Bloom[src][−]
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) -> Bloom[src][−]
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) -> Bloom[src][−]
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 Bloom[src][−]
Utilities using the rand crate.
pub fn randomize_using<R>(&mut self, rng: &mut R) where
R: Rng + ?Sized, [src][−]
R: Rng + ?Sized,
Assign self to a cryptographically random value using the
given random number generator.
pub fn randomize(&mut self)[src][−]
Assign self to a cryptographically random value.
pub fn random_using<R>(rng: &mut R) -> Bloom where
R: Rng + ?Sized, [src][−]
R: Rng + ?Sized,
Create a new hash with cryptographically random content using the given random number generator.
pub fn random() -> Bloom[src][−]
Create a new hash with cryptographically random content.
Trait Implementations
impl AsMut<[u8]> for Bloom[src][+]
impl AsRef<[u8]> for Bloom[src][+]
impl<'l, 'r> BitAnd<&'r Bloom> for &'l Bloom[src][+]
impl BitAnd<Bloom> for Bloom[src][+]
impl<'r> BitAndAssign<&'r Bloom> for Bloom[src][+]
impl BitAndAssign<Bloom> for Bloom[src][+]
impl<'l, 'r> BitOr<&'r Bloom> for &'l Bloom[src][+]
impl BitOr<Bloom> for Bloom[src][+]
impl<'r> BitOrAssign<&'r Bloom> for Bloom[src][+]
impl BitOrAssign<Bloom> for Bloom[src][+]
impl<'l, 'r> BitXor<&'r Bloom> for &'l Bloom[src][+]
impl BitXor<Bloom> for Bloom[src][+]
impl<'r> BitXorAssign<&'r Bloom> for Bloom[src][+]
impl BitXorAssign<Bloom> for Bloom[src][+]
impl Clone for Bloom[src][+]
impl Copy for Bloom[src]
impl Debug for Bloom[src][+]
impl Decodable for Bloom[src][+]
impl Default for Bloom[src][+]
impl<'de> Deserialize<'de> for Bloom[src][+]
impl Display for Bloom[src][+]
impl Encodable for Bloom[src][+]
impl Eq for Bloom[src]
impl<'a> From<&'a [u8; 256]> for Bloom[src][+]
impl<'a> From<&'a mut [u8; 256]> for Bloom[src][+]
impl From<[u8; 256]> for Bloom[src][+]
impl<'a> From<Input<'a>> for Bloom[src][+]
impl FromStr for Bloom[src][+]
impl Hash for Bloom[src][+]
impl<I> Index<I> for Bloom where
I: SliceIndex<[u8]>, [src][+]
I: SliceIndex<[u8]>,
impl<I> IndexMut<I> for Bloom where
I: SliceIndex<[u8], Output = [u8]>, [src][+]
I: SliceIndex<[u8], Output = [u8]>,
impl LowerHex for Bloom[src][+]
impl Ord for Bloom[src][+]
impl PartialEq<Bloom> for Bloom[src][+]
impl<'a> PartialEq<BloomRef<'a>> for Bloom[src][+]
impl PartialOrd<Bloom> for Bloom[src][+]
impl Serialize for Bloom[src][+]
impl UpperHex for Bloom[src][+]
Auto Trait Implementations
impl RefUnwindSafe for Bloom
impl Send for Bloom
impl Sync for Bloom
impl Unpin for Bloom
impl UnwindSafe for Bloom
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, [src][+]
T: ToByteSlice,
U: AsRef<[T]> + ?Sized,
impl<T, U> AsMutByteSlice<T> for U where
T: ToMutByteSlice,
U: AsMut<[T]> + ?Sized, [src][+]
T: ToMutByteSlice,
U: AsMut<[T]> + ?Sized,
impl<U> AsMutSliceOf for U where
U: AsMut<[u8]> + ?Sized, [src][+]
U: AsMut<[u8]> + ?Sized,
impl<U> AsSliceOf for U where
U: AsRef<[u8]> + ?Sized, [src][+]
U: AsRef<[u8]> + ?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,
impl<T> DeserializeOwned for T where
T: for<'de> Deserialize<'de>, [src]
T: for<'de> Deserialize<'de>,
impl<T> From<T> for T[src][+]
impl<T, U> Into<U> for T where
U: From<T>, [src][+]
U: From<T>,
impl<T> MaybeDebug for T where
T: Debug, [src]
T: Debug,
impl<T> Same<T> for T[src]
type Output = T
Should always be Self
impl<T> ToHex for T where
T: AsRef<[u8]>, [src][+]
T: AsRef<[u8]>,
impl<T> ToOwned for T where
T: Clone, [src][+]
T: Clone,
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>,
impl<T, U> TryInto<U> for T where
U: TryFrom<T>, [src][+]
U: TryFrom<T>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>, [src][+]
V: MultiLane<T>,