mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-01 03:02:16 +01:00
684b7a999f
* Dump: Use mholt/archive/v3 to support tar including many compressions Signed-off-by: Philipp Homann <homann.philipp@googlemail.com> * Dump: Allow dump output to stdout Signed-off-by: Philipp Homann <homann.philipp@googlemail.com> * Dump: Fixed bug present since #6677 where SessionConfig.Provider is never "file" Signed-off-by: Philipp Homann <homann.philipp@googlemail.com> * Dump: never pack RepoRootPath, LFS.ContentPath and LogRootPath when they are below AppDataPath Signed-off-by: Philipp Homann <homann.philipp@googlemail.com> * Dump: also dump LFS (fixes #10058) Signed-off-by: Philipp Homann <homann.philipp@googlemail.com> * Dump: never dump CustomPath if CustomPath is a subdir of or equal to AppDataPath (fixes #10365) Signed-off-by: Philipp Homann <homann.philipp@googlemail.com> * Use log.Info instead of fmt.Fprintf Signed-off-by: Philipp Homann <homann.philipp@googlemail.com> * import ordering * make fmt Co-authored-by: zeripath <art27@cantab.net> Co-authored-by: techknowlogick <techknowlogick@gitea.io> Co-authored-by: Matti R <matti@mdranta.net>
49 lines
1.4 KiB
Go
49 lines
1.4 KiB
Go
// Copyright 2014-2017 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 "fmt"
|
|
|
|
// directCodec allows the encoding and decoding of values with a fixed number
|
|
// of bits. The number of bits must be in the range [1,32].
|
|
type directCodec byte
|
|
|
|
// makeDirectCodec creates a directCodec. The function panics if the number of
|
|
// bits is not in the range [1,32].
|
|
func makeDirectCodec(bits int) directCodec {
|
|
if !(1 <= bits && bits <= 32) {
|
|
panic(fmt.Errorf("bits=%d out of range", bits))
|
|
}
|
|
return directCodec(bits)
|
|
}
|
|
|
|
// Bits returns the number of bits supported by this codec.
|
|
func (dc directCodec) Bits() int {
|
|
return int(dc)
|
|
}
|
|
|
|
// Encode uses the range encoder to encode a value with the fixed number of
|
|
// bits. The most-significant bit is encoded first.
|
|
func (dc directCodec) Encode(e *rangeEncoder, v uint32) error {
|
|
for i := int(dc) - 1; i >= 0; i-- {
|
|
if err := e.DirectEncodeBit(v >> uint(i)); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Decode uses the range decoder to decode a value with the given number of
|
|
// given bits. The most-significant bit is decoded first.
|
|
func (dc directCodec) Decode(d *rangeDecoder) (v uint32, err error) {
|
|
for i := int(dc) - 1; i >= 0; i-- {
|
|
x, err := d.DirectDecodeBit()
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
v = (v << 1) | x
|
|
}
|
|
return v, nil
|
|
}
|