| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- /*
- * SPDX-FileCopyrightText: © Hypermode Inc. <hello@hypermode.com>
- * SPDX-License-Identifier: Apache-2.0
- */
- package y
- import (
- "sync"
- "github.com/klauspost/compress/zstd"
- )
- var (
- decoder *zstd.Decoder
- encoder *zstd.Encoder
- encOnce, decOnce sync.Once
- )
- // ZSTDDecompress decompresses a block using ZSTD algorithm.
- func ZSTDDecompress(dst, src []byte) ([]byte, error) {
- decOnce.Do(func() {
- var err error
- decoder, err = zstd.NewReader(nil)
- Check(err)
- })
- return decoder.DecodeAll(src, dst[:0])
- }
- // ZSTDCompress compresses a block using ZSTD algorithm.
- func ZSTDCompress(dst, src []byte, compressionLevel int) ([]byte, error) {
- encOnce.Do(func() {
- var err error
- level := zstd.EncoderLevelFromZstd(compressionLevel)
- encoder, err = zstd.NewWriter(nil, zstd.WithEncoderLevel(level))
- Check(err)
- })
- return encoder.EncodeAll(src, dst[:0]), nil
- }
- // ZSTDCompressBound returns the worst case size needed for a destination buffer.
- // Klauspost ZSTD library does not provide any API for Compression Bound. This
- // calculation is based on the DataDog ZSTD library.
- // See https://pkg.go.dev/github.com/DataDog/zstd#CompressBound
- func ZSTDCompressBound(srcSize int) int {
- lowLimit := 128 << 10 // 128 kB
- var margin int
- if srcSize < lowLimit {
- margin = (lowLimit - srcSize) >> 11
- }
- return srcSize + (srcSize >> 8) + margin
- }
|