Skip to main content

CShake

Struct CShake 

Source
pub struct CShake<const RATE: usize> { /* private fields */ }
Expand description

cSHAKE hasher generic over rate.

Rate MUST be either 168 or 136 for cSHAKE128 and cSHAKE256 respectively.

Implementations§

Source§

impl<const RATE: usize> CShake<RATE>

Source

pub fn new_with_function_name( function_name: &[u8], customization: &[u8], ) -> Self

Creates a new cSHAKE instance with the given function name and customization.

Note that the function name is intended for use by NIST and should only be set to values defined by NIST. You probably don’t need to use this function.

Trait Implementations§

Source§

impl<const RATE: usize> AlgorithmName for CShake<RATE>

Source§

fn write_alg_name(f: &mut Formatter<'_>) -> Result

Write algorithm name into f. Read more
Source§

impl<const RATE: usize> Clone for CShake<RATE>

Source§

fn clone(&self) -> CShake<RATE>

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<const RATE: usize> CustomizedInit for CShake<RATE>

Source§

fn new_customized(customization: &[u8]) -> Self

Create new hasher instance with the given customization string.
Source§

impl<const RATE: usize> Debug for CShake<RATE>

Source§

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

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

impl<const RATE: usize> Default for CShake<RATE>

Source§

fn default() -> Self

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

impl<const RATE: usize> Drop for CShake<RATE>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

fn pin_drop(self: Pin<&mut Self>)

🔬This is a nightly-only experimental API. (pin_ergonomics)
Execute the destructor for this type, but different to Drop::drop, it requires self to be pinned. Read more
Source§

impl<const RATE: usize> ExtendableOutput for CShake<RATE>

Source§

type Reader = CShakeReader<RATE>

Reader
Source§

fn finalize_xof(self) -> Self::Reader

Retrieve XOF reader and consume hasher instance.
Source§

fn finalize_xof_into(self, out: &mut [u8])

Finalize XOF and write result into out.
Source§

fn digest_xof(input: impl AsRef<[u8]>, output: &mut [u8])
where Self: Default,

Compute hash of data and write it into output.
Source§

fn finalize_boxed(self, output_size: usize) -> Box<[u8]>

Available on crate feature alloc only.
Retrieve result into a boxed slice of the specified size and consume the hasher. Read more
Source§

impl<const RATE: usize> Update for CShake<RATE>

Source§

fn update(&mut self, data: &[u8])

Update state using the provided data.
Source§

fn chain(self, data: impl AsRef<[u8]>) -> Self
where Self: Sized,

Digest input data in a chained manner.
Source§

impl<const RATE: usize> HashMarker for CShake<RATE>

Source§

impl<const RATE: usize> ZeroizeOnDrop for CShake<RATE>

Available on crate feature zeroize only.

Auto Trait Implementations§

§

impl<const RATE: usize> Freeze for CShake<RATE>

§

impl<const RATE: usize> RefUnwindSafe for CShake<RATE>

§

impl<const RATE: usize> Send for CShake<RATE>

§

impl<const RATE: usize> Sync for CShake<RATE>

§

impl<const RATE: usize> Unpin for CShake<RATE>

§

impl<const RATE: usize> UnsafeUnpin for CShake<RATE>

§

impl<const RATE: usize> UnwindSafe for CShake<RATE>

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> 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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

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> TryCustomizedInit for T
where T: CustomizedInit,

Source§

type Error = Infallible

Error returned for invalid customization strings.
Source§

fn try_new_customized( customization: &[u8], ) -> Result<T, <T as TryCustomizedInit>::Error>

Create new hasher instance with the given customization string. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

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>,

Source§

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.