brotli::enc::backward_references

Trait AnyHasher

Source
pub trait AnyHasher {
Show 14 methods // Required methods fn Opts(&self) -> H9Opts; fn GetHasherCommon(&mut self) -> &mut Struct1; fn HashBytes(&self, data: &[u8]) -> usize; fn HashTypeLength(&self) -> usize; fn StoreLookahead(&self) -> usize; fn PrepareDistanceCache(&self, distance_cache: &mut [i32]); fn FindLongestMatch( &mut self, dictionary: Option<&BrotliDictionary>, dictionary_hash: &[u16], data: &[u8], ring_buffer_mask: usize, distance_cache: &[i32], cur_ix: usize, max_length: usize, max_backward: usize, gap: usize, max_distance: usize, out: &mut HasherSearchResult, ) -> bool; fn Store(&mut self, data: &[u8], mask: usize, ix: usize); fn StoreRange( &mut self, data: &[u8], mask: usize, ix_start: usize, ix_end: usize, ); fn BulkStoreRange( &mut self, data: &[u8], mask: usize, ix_start: usize, ix_end: usize, ); fn Prepare( &mut self, one_shot: bool, input_size: usize, data: &[u8], ) -> HowPrepared; fn StitchToPreviousBlock( &mut self, num_bytes: usize, position: usize, ringbuffer: &[u8], ringbuffer_mask: usize, ); // Provided methods fn Store4Vec4(&mut self, data: &[u8], mask: usize, ix: usize) { ... } fn StoreEvenVec4(&mut self, data: &[u8], mask: usize, ix: usize) { ... }
}

Required Methods§

Source

fn Opts(&self) -> H9Opts

Source

fn GetHasherCommon(&mut self) -> &mut Struct1

Source

fn HashBytes(&self, data: &[u8]) -> usize

Source

fn HashTypeLength(&self) -> usize

Source

fn StoreLookahead(&self) -> usize

Source

fn PrepareDistanceCache(&self, distance_cache: &mut [i32])

Source

fn FindLongestMatch( &mut self, dictionary: Option<&BrotliDictionary>, dictionary_hash: &[u16], data: &[u8], ring_buffer_mask: usize, distance_cache: &[i32], cur_ix: usize, max_length: usize, max_backward: usize, gap: usize, max_distance: usize, out: &mut HasherSearchResult, ) -> bool

Source

fn Store(&mut self, data: &[u8], mask: usize, ix: usize)

Source

fn StoreRange( &mut self, data: &[u8], mask: usize, ix_start: usize, ix_end: usize, )

Source

fn BulkStoreRange( &mut self, data: &[u8], mask: usize, ix_start: usize, ix_end: usize, )

Source

fn Prepare( &mut self, one_shot: bool, input_size: usize, data: &[u8], ) -> HowPrepared

Source

fn StitchToPreviousBlock( &mut self, num_bytes: usize, position: usize, ringbuffer: &[u8], ringbuffer_mask: usize, )

Provided Methods§

Source

fn Store4Vec4(&mut self, data: &[u8], mask: usize, ix: usize)

Source

fn StoreEvenVec4(&mut self, data: &[u8], mask: usize, ix: usize)

Implementors§

Source§

impl<Alloc: Allocator<u16> + Allocator<u32>> AnyHasher for UnionHasher<Alloc>

Source§

impl<Alloc: Allocator<u16> + Allocator<u32>> AnyHasher for H9<Alloc>

Source§

impl<AllocU32: Allocator<u32>, Buckets, Params: H10Params> AnyHasher for H10<AllocU32, Buckets, Params>
where Buckets: PartialEq<Buckets> + Allocable<u32, AllocU32> + SliceWrapperMut<u32> + SliceWrapper<u32>,

Source§

impl<Specialization: AdvHashSpecialization + Clone, Alloc: Allocator<u16> + Allocator<u32>> AnyHasher for AdvHasher<Specialization, Alloc>

Source§

impl<T: SliceWrapperMut<u32> + SliceWrapper<u32> + BasicHashComputer> AnyHasher for BasicHasher<T>