[−][src]Struct block_buffer::BlockBuffer
Buffer for block processing of data
Methods
impl<BlockSize: ArrayLength<u8>> BlockBuffer<BlockSize>
[src][−]
pub fn input<F>(&mut self, input: &[u8], f: F) where
F: FnMut(&GenericArray<u8, BlockSize>),
[src][−]
F: FnMut(&GenericArray<u8, BlockSize>),
Process data in input
in blocks of size BlockSize
using function f
.
pub fn input_lazy<F>(&mut self, input: &[u8], f: F) where
F: FnMut(&GenericArray<u8, BlockSize>),
[src][−]
F: FnMut(&GenericArray<u8, BlockSize>),
Variant that doesn't flush the buffer until there's additional data to be processed. Suitable for tweakable block ciphers like Threefish that need to know whether a block is the last data block before processing it.
pub fn len64_padding<B, F>(&mut self, data_len: u64, f: F) where
B: ByteOrder,
F: FnMut(&GenericArray<u8, BlockSize>),
[src][−]
B: ByteOrder,
F: FnMut(&GenericArray<u8, BlockSize>),
Pad message with 0x80, zeros and 64-bit message length
in a byte order specified by B
pub fn len128_padding_be<F>(&mut self, hi: u64, lo: u64, f: F) where
F: FnMut(&GenericArray<u8, BlockSize>),
[src][−]
F: FnMut(&GenericArray<u8, BlockSize>),
Pad message with 0x80, zeros and 128-bit message length in the big-endian byte order
pub fn pad_with<P: Padding>(
&mut self
) -> Result<&mut GenericArray<u8, BlockSize>, PadError>
[src][−]
&mut self
) -> Result<&mut GenericArray<u8, BlockSize>, PadError>
Pad message with a given padding P
Returns PadError
if internall buffer is full, which can only happen if
input_lazy
was used.
pub fn size(&self) -> usize
[src][−]
Return size of the internall buffer in bytes
pub fn position(&self) -> usize
[src][−]
Return current cursor position
pub fn remaining(&self) -> usize
[src][−]
Return number of remaining bytes in the internall buffer
pub fn reset(&mut self)
[src][−]
Reset buffer by setting cursor position to zero
Trait Implementations
impl<BlockSize: Clone + ArrayLength<u8>> Clone for BlockBuffer<BlockSize>
[src][+]
impl<BlockSize: Default + ArrayLength<u8>> Default for BlockBuffer<BlockSize>
[src][+]
Auto Trait Implementations
impl<BlockSize> RefUnwindSafe for BlockBuffer<BlockSize> where
<BlockSize as ArrayLength<u8>>::ArrayType: RefUnwindSafe,
<BlockSize as ArrayLength<u8>>::ArrayType: RefUnwindSafe,
impl<BlockSize> Send for BlockBuffer<BlockSize>
impl<BlockSize> Sync for BlockBuffer<BlockSize>
impl<BlockSize> Unpin for BlockBuffer<BlockSize> where
<BlockSize as ArrayLength<u8>>::ArrayType: Unpin,
<BlockSize as ArrayLength<u8>>::ArrayType: Unpin,
impl<BlockSize> UnwindSafe for BlockBuffer<BlockSize> where
<BlockSize as ArrayLength<u8>>::ArrayType: UnwindSafe,
<BlockSize as ArrayLength<u8>>::ArrayType: UnwindSafe,
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,
impl<T> From<T> for T
[src][+]
impl<T, U> Into<U> for T where
U: From<T>,
[src][+]
U: From<T>,
impl<T> Same<T> for T
[src]
type Output = T
Should always be Self
impl<T> ToOwned for T where
T: Clone,
[src][+]
T: Clone,
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>,