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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
| // Copyright 2009 The Go Authors. All rights reserved.
| // Use of this source code is governed by a BSD-style
| // license that can be found in the LICENSE file.
|
| package flate
|
| const (
| // 2 bits: type 0 = literal 1=EOF 2=Match 3=Unused
| // 8 bits: xlength = length - MIN_MATCH_LENGTH
| // 22 bits xoffset = offset - MIN_OFFSET_SIZE, or literal
| lengthShift = 22
| offsetMask = 1<<lengthShift - 1
| typeMask = 3 << 30
| literalType = 0 << 30
| matchType = 1 << 30
| )
|
| // The length code for length X (MIN_MATCH_LENGTH <= X <= MAX_MATCH_LENGTH)
| // is lengthCodes[length - MIN_MATCH_LENGTH]
| var lengthCodes = [...]uint32{
| 0, 1, 2, 3, 4, 5, 6, 7, 8, 8,
| 9, 9, 10, 10, 11, 11, 12, 12, 12, 12,
| 13, 13, 13, 13, 14, 14, 14, 14, 15, 15,
| 15, 15, 16, 16, 16, 16, 16, 16, 16, 16,
| 17, 17, 17, 17, 17, 17, 17, 17, 18, 18,
| 18, 18, 18, 18, 18, 18, 19, 19, 19, 19,
| 19, 19, 19, 19, 20, 20, 20, 20, 20, 20,
| 20, 20, 20, 20, 20, 20, 20, 20, 20, 20,
| 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
| 21, 21, 21, 21, 21, 21, 22, 22, 22, 22,
| 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
| 22, 22, 23, 23, 23, 23, 23, 23, 23, 23,
| 23, 23, 23, 23, 23, 23, 23, 23, 24, 24,
| 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
| 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
| 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
| 25, 25, 25, 25, 25, 25, 25, 25, 25, 25,
| 25, 25, 25, 25, 25, 25, 25, 25, 25, 25,
| 25, 25, 25, 25, 25, 25, 25, 25, 25, 25,
| 25, 25, 26, 26, 26, 26, 26, 26, 26, 26,
| 26, 26, 26, 26, 26, 26, 26, 26, 26, 26,
| 26, 26, 26, 26, 26, 26, 26, 26, 26, 26,
| 26, 26, 26, 26, 27, 27, 27, 27, 27, 27,
| 27, 27, 27, 27, 27, 27, 27, 27, 27, 27,
| 27, 27, 27, 27, 27, 27, 27, 27, 27, 27,
| 27, 27, 27, 27, 27, 28,
| }
|
| var offsetCodes = [...]uint32{
| 0, 1, 2, 3, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7,
| 8, 8, 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 9,
| 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
| 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11,
| 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
| 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
| 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13,
| 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13,
| 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
| 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
| 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
| 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
| 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
| 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
| 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
| 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
| }
|
| type token uint32
|
| // Convert a literal into a literal token.
| func literalToken(literal uint32) token { return token(literalType + literal) }
|
| // Convert a < xlength, xoffset > pair into a match token.
| func matchToken(xlength uint32, xoffset uint32) token {
| return token(matchType + xlength<<lengthShift + xoffset)
| }
|
| // Returns the literal of a literal token
| func (t token) literal() uint32 { return uint32(t - literalType) }
|
| // Returns the extra offset of a match token
| func (t token) offset() uint32 { return uint32(t) & offsetMask }
|
| func (t token) length() uint32 { return uint32((t - matchType) >> lengthShift) }
|
| func lengthCode(len uint32) uint32 { return lengthCodes[len] }
|
| // Returns the offset code corresponding to a specific offset
| func offsetCode(off uint32) uint32 {
| if off < uint32(len(offsetCodes)) {
| return offsetCodes[off]
| }
| if off>>7 < uint32(len(offsetCodes)) {
| return offsetCodes[off>>7] + 14
| }
| return offsetCodes[off>>14] + 28
| }
|
|