mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	* update github.com/alecthomas/chroma v0.8.0 -> v0.8.1 * github.com/blevesearch/bleve v1.0.10 -> v1.0.12 * editorconfig-core-go v2.1.1 -> v2.3.7 * github.com/gliderlabs/ssh v0.2.2 -> v0.3.1 * migrate editorconfig.ParseBytes to Parse * github.com/shurcooL/vfsgen to 0d455de96546 * github.com/go-git/go-git/v5 v5.1.0 -> v5.2.0 * github.com/google/uuid v1.1.1 -> v1.1.2 * github.com/huandu/xstrings v1.3.0 -> v1.3.2 * github.com/klauspost/compress v1.10.11 -> v1.11.1 * github.com/markbates/goth v1.61.2 -> v1.65.0 * github.com/mattn/go-sqlite3 v1.14.0 -> v1.14.4 * github.com/mholt/archiver v3.3.0 -> v3.3.2 * github.com/microcosm-cc/bluemonday 4f7140c49acb -> v1.0.4 * github.com/minio/minio-go v7.0.4 -> v7.0.5 * github.com/olivere/elastic v7.0.9 -> v7.0.20 * github.com/urfave/cli v1.20.0 -> v1.22.4 * github.com/prometheus/client_golang v1.1.0 -> v1.8.0 * github.com/xanzy/go-gitlab v0.37.0 -> v0.38.1 * mvdan.cc/xurls v2.1.0 -> v2.2.0 Co-authored-by: Lauris BH <lauris@nix.lv>
		
			
				
	
	
		
			130 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| // Copyright 2014-2019 Ulrich Kunitz. All rights reserved.
 | |
| // Use of this source code is governed by a BSD-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package lzma
 | |
| 
 | |
| import "errors"
 | |
| 
 | |
| // maxPosBits defines the number of bits of the position value that are used to
 | |
| // to compute the posState value. The value is used to select the tree codec
 | |
| // for length encoding and decoding.
 | |
| const maxPosBits = 4
 | |
| 
 | |
| // minMatchLen and maxMatchLen give the minimum and maximum values for
 | |
| // encoding and decoding length values. minMatchLen is also used as base
 | |
| // for the encoded length values.
 | |
| const (
 | |
| 	minMatchLen = 2
 | |
| 	maxMatchLen = minMatchLen + 16 + 256 - 1
 | |
| )
 | |
| 
 | |
| // lengthCodec support the encoding of the length value.
 | |
| type lengthCodec struct {
 | |
| 	choice [2]prob
 | |
| 	low    [1 << maxPosBits]treeCodec
 | |
| 	mid    [1 << maxPosBits]treeCodec
 | |
| 	high   treeCodec
 | |
| }
 | |
| 
 | |
| // deepcopy initializes the lc value as deep copy of the source value.
 | |
| func (lc *lengthCodec) deepcopy(src *lengthCodec) {
 | |
| 	if lc == src {
 | |
| 		return
 | |
| 	}
 | |
| 	lc.choice = src.choice
 | |
| 	for i := range lc.low {
 | |
| 		lc.low[i].deepcopy(&src.low[i])
 | |
| 	}
 | |
| 	for i := range lc.mid {
 | |
| 		lc.mid[i].deepcopy(&src.mid[i])
 | |
| 	}
 | |
| 	lc.high.deepcopy(&src.high)
 | |
| }
 | |
| 
 | |
| // init initializes a new length codec.
 | |
| func (lc *lengthCodec) init() {
 | |
| 	for i := range lc.choice {
 | |
| 		lc.choice[i] = probInit
 | |
| 	}
 | |
| 	for i := range lc.low {
 | |
| 		lc.low[i] = makeTreeCodec(3)
 | |
| 	}
 | |
| 	for i := range lc.mid {
 | |
| 		lc.mid[i] = makeTreeCodec(3)
 | |
| 	}
 | |
| 	lc.high = makeTreeCodec(8)
 | |
| }
 | |
| 
 | |
| // lBits gives the number of bits used for the encoding of the l value
 | |
| // provided to the range encoder.
 | |
| func lBits(l uint32) int {
 | |
| 	switch {
 | |
| 	case l < 8:
 | |
| 		return 4
 | |
| 	case l < 16:
 | |
| 		return 5
 | |
| 	default:
 | |
| 		return 10
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Encode encodes the length offset. The length offset l can be compute by
 | |
| // subtracting minMatchLen (2) from the actual length.
 | |
| //
 | |
| //   l = length - minMatchLen
 | |
| //
 | |
| func (lc *lengthCodec) Encode(e *rangeEncoder, l uint32, posState uint32,
 | |
| ) (err error) {
 | |
| 	if l > maxMatchLen-minMatchLen {
 | |
| 		return errors.New("lengthCodec.Encode: l out of range")
 | |
| 	}
 | |
| 	if l < 8 {
 | |
| 		if err = lc.choice[0].Encode(e, 0); err != nil {
 | |
| 			return
 | |
| 		}
 | |
| 		return lc.low[posState].Encode(e, l)
 | |
| 	}
 | |
| 	if err = lc.choice[0].Encode(e, 1); err != nil {
 | |
| 		return
 | |
| 	}
 | |
| 	if l < 16 {
 | |
| 		if err = lc.choice[1].Encode(e, 0); err != nil {
 | |
| 			return
 | |
| 		}
 | |
| 		return lc.mid[posState].Encode(e, l-8)
 | |
| 	}
 | |
| 	if err = lc.choice[1].Encode(e, 1); err != nil {
 | |
| 		return
 | |
| 	}
 | |
| 	if err = lc.high.Encode(e, l-16); err != nil {
 | |
| 		return
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // Decode reads the length offset. Add minMatchLen to compute the actual length
 | |
| // to the length offset l.
 | |
| func (lc *lengthCodec) Decode(d *rangeDecoder, posState uint32,
 | |
| ) (l uint32, err error) {
 | |
| 	var b uint32
 | |
| 	if b, err = lc.choice[0].Decode(d); err != nil {
 | |
| 		return
 | |
| 	}
 | |
| 	if b == 0 {
 | |
| 		l, err = lc.low[posState].Decode(d)
 | |
| 		return
 | |
| 	}
 | |
| 	if b, err = lc.choice[1].Decode(d); err != nil {
 | |
| 		return
 | |
| 	}
 | |
| 	if b == 0 {
 | |
| 		l, err = lc.mid[posState].Decode(d)
 | |
| 		l += 8
 | |
| 		return
 | |
| 	}
 | |
| 	l, err = lc.high.Decode(d)
 | |
| 	l += 16
 | |
| 	return
 | |
| }
 |