12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- package zstd
- import (
- "github.com/klauspost/compress/huff0"
- )
- type history struct {
- b []byte
- huffTree *huff0.Scratch
- recentOffsets [3]int
- decoders sequenceDecs
- windowSize int
- maxSize int
- error bool
- }
- func (h *history) reset() {
- h.b = h.b[:0]
- h.error = false
- h.recentOffsets = [3]int{1, 4, 8}
- if f := h.decoders.litLengths.fse; f != nil && !f.preDefined {
- fseDecoderPool.Put(f)
- }
- if f := h.decoders.offsets.fse; f != nil && !f.preDefined {
- fseDecoderPool.Put(f)
- }
- if f := h.decoders.matchLengths.fse; f != nil && !f.preDefined {
- fseDecoderPool.Put(f)
- }
- h.decoders = sequenceDecs{}
- if h.huffTree != nil {
- huffDecoderPool.Put(h.huffTree)
- }
- h.huffTree = nil
-
- }
- func (h *history) append(b []byte) {
- if len(b) >= h.windowSize {
-
- h.b = h.b[:h.windowSize]
- copy(h.b, b[len(b)-h.windowSize:])
- return
- }
-
- if len(b) < cap(h.b)-len(h.b) {
- h.b = append(h.b, b...)
- return
- }
-
-
- discard := len(b) + len(h.b) - h.windowSize
- copy(h.b, h.b[discard:])
- h.b = h.b[:h.windowSize]
- copy(h.b[h.windowSize-len(b):], b)
- }
- func (h *history) appendKeep(b []byte) {
- h.b = append(h.b, b...)
- }
|