package brotli /* NOTE: this hasher does not search in the dictionary. It is used as backup-hasher, the main hasher already searches in it. */ /* NOLINT(build/header_guard) */ /* Copyright 2018 Google Inc. All Rights Reserved. Distributed under MIT license. See file LICENSE for detail or copy at https://opensource.org/licenses/MIT */ /* Composite hasher: This hasher allows to combine two other hashers, HASHER_A and HASHER_B. */ func (h *H35) HashTypeLength() uint { var a uint = h.ha.HashTypeLength() var b uint = h.hb.HashTypeLength() if a > b { return a } else { return b } } func (h *H35) StoreLookahead() uint { var a uint = h.ha.StoreLookahead() var b uint = h.hb.StoreLookahead() if a > b { return a } else { return b } } type H35 struct { HasherCommon ha HasherHandle hb HasherHandle params *BrotliEncoderParams } func SelfH35(handle HasherHandle) *H35 { return handle.(*H35) } func (h *H35) Initialize(params *BrotliEncoderParams) { h.ha = nil h.hb = nil h.params = params } /* TODO: Initialize of the hashers is defered to Prepare (and params remembered here) because we don't get the one_shot and input_size params here that are needed to know the memory size of them. Instead provide those params to all hashers InitializeH35 */ func (h *H35) Prepare(one_shot bool, input_size uint, data []byte) { if h.ha == nil { var common_a *HasherCommon var common_b *HasherCommon h.ha = newHasher(3) common_a = h.ha.Common() common_a.params = h.params.hasher common_a.is_prepared_ = false common_a.dict_num_lookups = 0 common_a.dict_num_matches = 0 h.ha.Initialize(h.params) h.hb = new(HROLLING_FAST) common_b = h.hb.Common() common_b.params = h.params.hasher common_b.is_prepared_ = false common_b.dict_num_lookups = 0 common_b.dict_num_matches = 0 h.hb.Initialize(h.params) } h.ha.Prepare(one_shot, input_size, data) h.hb.Prepare(one_shot, input_size, data) } func (h *H35) Store(data []byte, mask uint, ix uint) { h.ha.Store(data, mask, ix) h.hb.Store(data, mask, ix) } func (h *H35) StoreRange(data []byte, mask uint, ix_start uint, ix_end uint) { h.ha.StoreRange(data, mask, ix_start, ix_end) h.hb.StoreRange(data, mask, ix_start, ix_end) } func (h *H35) StitchToPreviousBlock(num_bytes uint, position uint, ringbuffer []byte, ring_buffer_mask uint) { h.ha.StitchToPreviousBlock(num_bytes, position, ringbuffer, ring_buffer_mask) h.hb.StitchToPreviousBlock(num_bytes, position, ringbuffer, ring_buffer_mask) } func (h *H35) PrepareDistanceCache(distance_cache []int) { h.ha.PrepareDistanceCache(distance_cache) h.hb.PrepareDistanceCache(distance_cache) } func (h *H35) FindLongestMatch(dictionary *BrotliEncoderDictionary, data []byte, ring_buffer_mask uint, distance_cache []int, cur_ix uint, max_length uint, max_backward uint, gap uint, max_distance uint, out *HasherSearchResult) { h.ha.FindLongestMatch(dictionary, data, ring_buffer_mask, distance_cache, cur_ix, max_length, max_backward, gap, max_distance, out) h.hb.FindLongestMatch(dictionary, data, ring_buffer_mask, distance_cache, cur_ix, max_length, max_backward, gap, max_distance, out) }