binius_hash::hasher

Trait Hasher

Source
pub trait Hasher<T>: Sync + Send {
    type Digest;

    // Required methods
    fn new() -> Self;
    fn update(&mut self, data: impl AsRef<[T]>);
    fn chain_update(self, data: impl AsRef<[T]>) -> Self;
    fn finalize(self) -> Self::Digest;
    fn finalize_into(self, out: &mut MaybeUninit<Self::Digest>);
    fn finalize_reset(&mut self) -> Self::Digest;
    fn finalize_into_reset(&mut self, out: &mut MaybeUninit<Self::Digest>);
    fn reset(&mut self);
}
Expand description

Trait representing cryptographic hash functions which is generic over the input type.

This interface is largely based on RustCrypto’s Digest trait, except that instead of requiring byte strings as input and byte arrays as output, this is generic over the input values and has a less constrained output digest type.

Required Associated Types§

Source

type Digest

The hash function output type.

Required Methods§

Source

fn new() -> Self

Source

fn update(&mut self, data: impl AsRef<[T]>)

Source

fn chain_update(self, data: impl AsRef<[T]>) -> Self

Source

fn finalize(self) -> Self::Digest

Source

fn finalize_into(self, out: &mut MaybeUninit<Self::Digest>)

Source

fn finalize_reset(&mut self) -> Self::Digest

Source

fn finalize_into_reset(&mut self, out: &mut MaybeUninit<Self::Digest>)

Source

fn reset(&mut self)

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§

Source§

impl<P, F> Hasher<P> for Groestl256<P, F>
where F: BinaryField + From<AESTowerField8b> + Into<AESTowerField8b>, P: PackedExtension<F, PackedSubfield: PackedFieldIndexable>, P::Scalar: ExtensionField<F>, OptimalUnderlier256b: PackScalar<F> + Divisible<F::Underlier>, Self: UpdateOverSlice<Elem = F>,