aboutsummaryrefslogtreecommitdiffsponsor
path: root/vendor/github.com/xi2/xz/dec_delta.go
blob: 19df590862602fa83b59c472471a0dbc9cc96aaf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
 * Delta decoder
 *
 * Author: Lasse Collin <lasse.collin@tukaani.org>
 *
 * Translation to Go: Michael Cross <https://github.com/xi2>
 *
 * This file has been put into the public domain.
 * You can do whatever you want with this file.
 */

package xz

type xzDecDelta struct {
	delta    [256]byte
	pos      byte
	distance int // in range [1, 256]
}

/*
 * Decode raw stream which has a delta filter as the first filter.
 */
func xzDecDeltaRun(s *xzDecDelta, b *xzBuf, chain func(*xzBuf) xzRet) xzRet {
	outStart := b.outPos
	ret := chain(b)
	for i := outStart; i < b.outPos; i++ {
		tmp := b.out[i] + s.delta[byte(s.distance+int(s.pos))]
		s.delta[s.pos] = tmp
		b.out[i] = tmp
		s.pos--
	}
	return ret
}

/*
 * Allocate memory for a delta decoder. xzDecDeltaReset must be used
 * before calling xzDecDeltaRun.
 */
func xzDecDeltaCreate() *xzDecDelta {
	return new(xzDecDelta)
}

/*
 * Returns xzOK if the given distance is valid. Otherwise
 * xzOptionsError is returned.
 */
func xzDecDeltaReset(s *xzDecDelta, distance int) xzRet {
	if distance < 1 || distance > 256 {
		return xzOptionsError
	}
	s.delta = [256]byte{}
	s.pos = 0
	s.distance = distance
	return xzOK
}