mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-11-04 08:21:11 +00:00 
			
		
		
		
	* update code.gitea.io/sdk/gitea v0.13.1 -> v0.13.2 * update github.com/go-swagger/go-swagger v0.25.0 -> v0.26.0 * update github.com/google/uuid v1.1.2 -> v1.2.0 * update github.com/klauspost/compress v1.11.3 -> v1.11.7 * update github.com/lib/pq 083382b7e6fc -> v1.9.0 * update github.com/markbates/goth v1.65.0 -> v1.66.1 * update github.com/mattn/go-sqlite3 v1.14.4 -> v1.14.6 * update github.com/mgechev/revive 246eac737dc7 -> v1.0.3 * update github.com/minio/minio-go/v7 v7.0.6 -> v7.0.7 * update github.com/niklasfasching/go-org v1.3.2 -> v1.4.0 * update github.com/olivere/elastic/v7 v7.0.21 -> v7.0.22 * update github.com/pquerna/otp v1.2.0 -> v1.3.0 * update github.com/xanzy/go-gitlab v0.39.0 -> v0.42.0 * update github.com/yuin/goldmark v1.2.1 -> v1.3.1
		
			
				
	
	
		
			156 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			156 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
// Package zstd provides decompression of zstandard files.
 | 
						|
//
 | 
						|
// For advanced usage and examples, go to the README: https://github.com/klauspost/compress/tree/master/zstd#zstd
 | 
						|
package zstd
 | 
						|
 | 
						|
import (
 | 
						|
	"bytes"
 | 
						|
	"errors"
 | 
						|
	"log"
 | 
						|
	"math"
 | 
						|
	"math/bits"
 | 
						|
)
 | 
						|
 | 
						|
// enable debug printing
 | 
						|
const debug = false
 | 
						|
 | 
						|
// Enable extra assertions.
 | 
						|
const debugAsserts = debug || false
 | 
						|
 | 
						|
// print sequence details
 | 
						|
const debugSequences = false
 | 
						|
 | 
						|
// print detailed matching information
 | 
						|
const debugMatches = false
 | 
						|
 | 
						|
// force encoder to use predefined tables.
 | 
						|
const forcePreDef = false
 | 
						|
 | 
						|
// zstdMinMatch is the minimum zstd match length.
 | 
						|
const zstdMinMatch = 3
 | 
						|
 | 
						|
// Reset the buffer offset when reaching this.
 | 
						|
const bufferReset = math.MaxInt32 - MaxWindowSize
 | 
						|
 | 
						|
var (
 | 
						|
	// ErrReservedBlockType is returned when a reserved block type is found.
 | 
						|
	// Typically this indicates wrong or corrupted input.
 | 
						|
	ErrReservedBlockType = errors.New("invalid input: reserved block type encountered")
 | 
						|
 | 
						|
	// ErrCompressedSizeTooBig is returned when a block is bigger than allowed.
 | 
						|
	// Typically this indicates wrong or corrupted input.
 | 
						|
	ErrCompressedSizeTooBig = errors.New("invalid input: compressed size too big")
 | 
						|
 | 
						|
	// ErrBlockTooSmall is returned when a block is too small to be decoded.
 | 
						|
	// Typically returned on invalid input.
 | 
						|
	ErrBlockTooSmall = errors.New("block too small")
 | 
						|
 | 
						|
	// ErrMagicMismatch is returned when a "magic" number isn't what is expected.
 | 
						|
	// Typically this indicates wrong or corrupted input.
 | 
						|
	ErrMagicMismatch = errors.New("invalid input: magic number mismatch")
 | 
						|
 | 
						|
	// ErrWindowSizeExceeded is returned when a reference exceeds the valid window size.
 | 
						|
	// Typically this indicates wrong or corrupted input.
 | 
						|
	ErrWindowSizeExceeded = errors.New("window size exceeded")
 | 
						|
 | 
						|
	// ErrWindowSizeTooSmall is returned when no window size is specified.
 | 
						|
	// Typically this indicates wrong or corrupted input.
 | 
						|
	ErrWindowSizeTooSmall = errors.New("invalid input: window size was too small")
 | 
						|
 | 
						|
	// ErrDecoderSizeExceeded is returned if decompressed size exceeds the configured limit.
 | 
						|
	ErrDecoderSizeExceeded = errors.New("decompressed size exceeds configured limit")
 | 
						|
 | 
						|
	// ErrUnknownDictionary is returned if the dictionary ID is unknown.
 | 
						|
	// For the time being dictionaries are not supported.
 | 
						|
	ErrUnknownDictionary = errors.New("unknown dictionary")
 | 
						|
 | 
						|
	// ErrFrameSizeExceeded is returned if the stated frame size is exceeded.
 | 
						|
	// This is only returned if SingleSegment is specified on the frame.
 | 
						|
	ErrFrameSizeExceeded = errors.New("frame size exceeded")
 | 
						|
 | 
						|
	// ErrCRCMismatch is returned if CRC mismatches.
 | 
						|
	ErrCRCMismatch = errors.New("CRC check failed")
 | 
						|
 | 
						|
	// ErrDecoderClosed will be returned if the Decoder was used after
 | 
						|
	// Close has been called.
 | 
						|
	ErrDecoderClosed = errors.New("decoder used after Close")
 | 
						|
 | 
						|
	// ErrDecoderNilInput is returned when a nil Reader was provided
 | 
						|
	// and an operation other than Reset/DecodeAll/Close was attempted.
 | 
						|
	ErrDecoderNilInput = errors.New("nil input provided as reader")
 | 
						|
)
 | 
						|
 | 
						|
func println(a ...interface{}) {
 | 
						|
	if debug {
 | 
						|
		log.Println(a...)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func printf(format string, a ...interface{}) {
 | 
						|
	if debug {
 | 
						|
		log.Printf(format, a...)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// matchLenFast does matching, but will not match the last up to 7 bytes.
 | 
						|
func matchLenFast(a, b []byte) int {
 | 
						|
	endI := len(a) & (math.MaxInt32 - 7)
 | 
						|
	for i := 0; i < endI; i += 8 {
 | 
						|
		if diff := load64(a, i) ^ load64(b, i); diff != 0 {
 | 
						|
			return i + bits.TrailingZeros64(diff)>>3
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return endI
 | 
						|
}
 | 
						|
 | 
						|
// matchLen returns the maximum length.
 | 
						|
// a must be the shortest of the two.
 | 
						|
// The function also returns whether all bytes matched.
 | 
						|
func matchLen(a, b []byte) int {
 | 
						|
	b = b[:len(a)]
 | 
						|
	for i := 0; i < len(a)-7; i += 8 {
 | 
						|
		if diff := load64(a, i) ^ load64(b, i); diff != 0 {
 | 
						|
			return i + (bits.TrailingZeros64(diff) >> 3)
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	checked := (len(a) >> 3) << 3
 | 
						|
	a = a[checked:]
 | 
						|
	b = b[checked:]
 | 
						|
	for i := range a {
 | 
						|
		if a[i] != b[i] {
 | 
						|
			return i + checked
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return len(a) + checked
 | 
						|
}
 | 
						|
 | 
						|
func load3232(b []byte, i int32) uint32 {
 | 
						|
	// Help the compiler eliminate bounds checks on the read so it can be done in a single read.
 | 
						|
	b = b[i:]
 | 
						|
	b = b[:4]
 | 
						|
	return uint32(b[0]) | uint32(b[1])<<8 | uint32(b[2])<<16 | uint32(b[3])<<24
 | 
						|
}
 | 
						|
 | 
						|
func load6432(b []byte, i int32) uint64 {
 | 
						|
	// Help the compiler eliminate bounds checks on the read so it can be done in a single read.
 | 
						|
	b = b[i:]
 | 
						|
	b = b[:8]
 | 
						|
	return uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 |
 | 
						|
		uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56
 | 
						|
}
 | 
						|
 | 
						|
func load64(b []byte, i int) uint64 {
 | 
						|
	// Help the compiler eliminate bounds checks on the read so it can be done in a single read.
 | 
						|
	b = b[i:]
 | 
						|
	b = b[:8]
 | 
						|
	return uint64(b[0]) | uint64(b[1])<<8 | uint64(b[2])<<16 | uint64(b[3])<<24 |
 | 
						|
		uint64(b[4])<<32 | uint64(b[5])<<40 | uint64(b[6])<<48 | uint64(b[7])<<56
 | 
						|
}
 | 
						|
 | 
						|
type byter interface {
 | 
						|
	Bytes() []byte
 | 
						|
	Len() int
 | 
						|
}
 | 
						|
 | 
						|
var _ byter = &bytes.Buffer{}
 |