pub struct CompressorRefN<const N: usize = DEFAULT_NODICT_ENTRIES> { /* private fields */ }Expand description
A reusable no-dict block compressor with N hash-table entries.
CompressorRef is the standard-sized alias (8 KB table). Use this generic
form to pick a smaller table for memory-constrained (e.g. embedded) targets,
e.g. CompressorRefN::<512>::new() for a 2 KB table. N must be a power of
two (checked at compile time).
This is the no-alloc API. With alloc, use Compressor
instead. For one-shot compression, use compress_into instead.
§Example
use lz4rip_encode::{CompressorRef, get_maximum_output_size};
let mut comp = CompressorRef::new();
let input = b"hello world, hello world, hello!";
let mut output = vec![0u8; get_maximum_output_size(input.len())];
let compressed_len = comp.compress_into(input, &mut output).unwrap();Implementations§
Source§impl<const N: usize> CompressorRefN<N>
impl<const N: usize> CompressorRefN<N>
Sourcepub fn compress_into(
&mut self,
input: &[u8],
output: &mut [u8],
) -> Result<usize, CompressError>
pub fn compress_into( &mut self, input: &[u8], output: &mut [u8], ) -> Result<usize, CompressError>
Compress input into output, returning the number of compressed bytes.
output must be at least get_maximum_output_size(input.len()) bytes.
Trait Implementations§
Source§impl<const N: usize> Debug for CompressorRefN<N>
impl<const N: usize> Debug for CompressorRefN<N>
Auto Trait Implementations§
impl<const N: usize> Freeze for CompressorRefN<N>
impl<const N: usize> RefUnwindSafe for CompressorRefN<N>
impl<const N: usize> Send for CompressorRefN<N>
impl<const N: usize> Sync for CompressorRefN<N>
impl<const N: usize> Unpin for CompressorRefN<N>
impl<const N: usize> UnsafeUnpin for CompressorRefN<N>
impl<const N: usize> UnwindSafe for CompressorRefN<N>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more