teeworlds 2.5.3 → 2.5.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/huffman.js CHANGED
@@ -1,192 +1,186 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Huffman = void 0;
4
- var FREQ_TABLE = [
5
- 1 << 30, 4545, 2657, 431, 1950, 919, 444, 482, 2244, 617, 838, 542, 715, 1814, 304, 240, 754, 212, 647, 186,
6
- 283, 131, 146, 166, 543, 164, 167, 136, 179, 859, 363, 113, 157, 154, 204, 108, 137, 180, 202, 176,
7
- 872, 404, 168, 134, 151, 111, 113, 109, 120, 126, 129, 100, 41, 20, 16, 22, 18, 18, 17, 19,
8
- 16, 37, 13, 21, 362, 166, 99, 78, 95, 88, 81, 70, 83, 284, 91, 187, 77, 68, 52, 68,
9
- 59, 66, 61, 638, 71, 157, 50, 46, 69, 43, 11, 24, 13, 19, 10, 12, 12, 20, 14, 9,
10
- 20, 20, 10, 10, 15, 15, 12, 12, 7, 19, 15, 14, 13, 18, 35, 19, 17, 14, 8, 5,
11
- 15, 17, 9, 15, 14, 18, 8, 10, 2173, 134, 157, 68, 188, 60, 170, 60, 194, 62, 175, 71,
12
- 148, 67, 167, 78, 211, 67, 156, 69, 1674, 90, 174, 53, 147, 89, 181, 51, 174, 63, 163, 80,
13
- 167, 94, 128, 122, 223, 153, 218, 77, 200, 110, 190, 73, 174, 69, 145, 66, 277, 143, 141, 60,
14
- 136, 53, 180, 57, 142, 57, 158, 61, 166, 112, 152, 92, 26, 22, 21, 28, 20, 26, 30, 21,
15
- 32, 27, 20, 17, 23, 21, 30, 22, 22, 21, 27, 25, 17, 27, 23, 18, 39, 26, 15, 21,
16
- 12, 18, 18, 27, 20, 18, 15, 19, 11, 17, 33, 12, 18, 15, 19, 18, 16, 26, 17, 18,
17
- 9, 10, 25, 22, 22, 17, 20, 16, 6, 16, 15, 20, 14, 18, 24, 335, 1517
18
- ], HUFFMAN_EOF_SYMBOL = 256, HUFFMAN_MAX_SYMBOLS = HUFFMAN_EOF_SYMBOL + 1, HUFFMAN_MAX_NODES = HUFFMAN_MAX_SYMBOLS * 2 - 1, HUFFMAN_LUTBITS = 10, HUFFMAN_LUTSIZE = 1 << HUFFMAN_LUTBITS, HUFFMAN_LUTMASK = HUFFMAN_LUTSIZE - 1;
19
- var Huffman = /** @class */ (function () {
20
- function Huffman(frequencies) {
21
- if (frequencies === void 0) { frequencies = FREQ_TABLE; }
22
- this.nodes = new Array(HUFFMAN_MAX_NODES);
23
- for (var i = 0; i < HUFFMAN_MAX_NODES; i++) {
24
- this.nodes[i] = {};
25
- }
26
- this.decode_lut = new Array(HUFFMAN_LUTSIZE);
27
- this.num_nodes = 0;
28
- this.start_node_index = 0;
29
- this.construct_tree(frequencies);
30
- for (var i = 0; i < HUFFMAN_LUTSIZE; i++) {
31
- var bits = i;
32
- var broke = false;
33
- var index = this.start_node_index;
34
- for (var x = 0; x < HUFFMAN_LUTBITS; x++) {
35
- if (bits & 1)
36
- index = this.nodes[index].right;
37
- else
38
- index = this.nodes[index].left;
39
- bits >>= 1;
40
- if (this.nodes[index].numbits) {
41
- this.decode_lut[i] = index;
42
- broke = true;
43
- break;
44
- }
45
- }
46
- if (!broke) {
47
- this.decode_lut[i] = index;
48
- }
49
- }
50
- }
51
- Huffman.prototype.set_bits_r = function (node_index, bits, depth) {
52
- if (this.nodes[node_index].right != 0xffff)
53
- this.set_bits_r(this.nodes[node_index].right, bits | (1 << depth), depth + 1);
54
- if (this.nodes[node_index].left != 0xffff)
55
- this.set_bits_r(this.nodes[node_index].left, bits, depth + 1);
56
- if (this.nodes[node_index].numbits) {
57
- this.nodes[node_index].bits = bits;
58
- this.nodes[node_index].numbits = depth;
59
- }
60
- };
61
- Huffman.prototype.bubble_sort = function (index_list, node_list, size) {
62
- var changed = true;
63
- while (changed) {
64
- changed = false;
65
- for (var i = 0; i < size - 1; i++) {
66
- if (node_list[index_list[i]].frequency < node_list[index_list[i + 1]].frequency) {
67
- var temp = index_list[i];
68
- index_list[i] = index_list[i + 1];
69
- index_list[i + 1] = temp;
70
- changed = true;
71
- }
72
- }
73
- size--;
74
- }
75
- return index_list;
76
- };
77
- Huffman.prototype.construct_tree = function (frequencies) {
78
- if (frequencies === void 0) { frequencies = FREQ_TABLE; }
79
- var nodes_left_storage = new Array(HUFFMAN_MAX_SYMBOLS);
80
- for (var i = 0; i < HUFFMAN_MAX_SYMBOLS; i++) {
81
- nodes_left_storage[i] = {};
82
- }
83
- var nodes_left = new Array(HUFFMAN_MAX_SYMBOLS);
84
- var num_nodes_left = HUFFMAN_MAX_SYMBOLS;
85
- for (var i = 0; i < HUFFMAN_MAX_SYMBOLS; i++) {
86
- this.nodes[i].numbits = 0xFFFFFFFF;
87
- this.nodes[i].symbol = i;
88
- this.nodes[i].left = 0xFFFF;
89
- this.nodes[i].right = 0xFFFF;
90
- if (i == HUFFMAN_EOF_SYMBOL) {
91
- nodes_left_storage[i].frequency = 1;
92
- }
93
- else
94
- nodes_left_storage[i].frequency = frequencies[i];
95
- nodes_left_storage[i].node_id = i;
96
- nodes_left[i] = i;
97
- }
98
- this.num_nodes = HUFFMAN_MAX_SYMBOLS;
99
- while (num_nodes_left > 1) {
100
- nodes_left = this.bubble_sort(nodes_left, nodes_left_storage, num_nodes_left);
101
- this.nodes[this.num_nodes].numbits = 0;
102
- this.nodes[this.num_nodes].left = nodes_left_storage[nodes_left[num_nodes_left - 1]].node_id;
103
- this.nodes[this.num_nodes].right = nodes_left_storage[nodes_left[num_nodes_left - 2]].node_id;
104
- nodes_left_storage[nodes_left[num_nodes_left - 2]].node_id = this.num_nodes;
105
- nodes_left_storage[nodes_left[num_nodes_left - 2]].frequency = nodes_left_storage[nodes_left[num_nodes_left - 1]].frequency
106
- + nodes_left_storage[nodes_left[num_nodes_left - 2]].frequency;
107
- this.num_nodes++;
108
- num_nodes_left--;
109
- }
110
- this.start_node_index = this.num_nodes - 1;
111
- this.set_bits_r(this.start_node_index, 0, 0);
112
- };
113
- Huffman.prototype.compress = function (inp_buffer, start_index, size) {
114
- if (start_index === void 0) { start_index = 0; }
115
- if (size === void 0) { size = 0; }
116
- var output = [];
117
- var bits = 0;
118
- var bitcount = 0;
119
- if (size == 0)
120
- size = inp_buffer.byteLength;
121
- inp_buffer = inp_buffer.slice(start_index, start_index + size);
122
- for (var i = 0; i < size; i++) {
123
- var x = inp_buffer[i];
124
- bits |= this.nodes[x].bits << bitcount;
125
- bitcount += this.nodes[x].numbits;
126
- while (bitcount >= 8) {
127
- output.push(bits & 0xff);
128
- bits >>= 8;
129
- bitcount -= 8;
130
- }
131
- }
132
- bits |= this.nodes[HUFFMAN_EOF_SYMBOL].bits << bitcount;
133
- bitcount += this.nodes[HUFFMAN_EOF_SYMBOL].numbits;
134
- while (bitcount >= 8) {
135
- output.push(bits & 0xff);
136
- bits >>= 8;
137
- bitcount -= 8;
138
- }
139
- output.push(bits);
140
- return Buffer.from(output);
141
- };
142
- Huffman.prototype.decompress = function (inp_buffer, size) {
143
- if (size === void 0) { size = 0; }
144
- var bits = 0;
145
- var bitcount = 0;
146
- var eof = this.nodes[HUFFMAN_EOF_SYMBOL];
147
- var output = [];
148
- if (size == 0)
149
- size = inp_buffer.byteLength;
150
- inp_buffer = inp_buffer.slice(0, size);
151
- var src_index = 0;
152
- while (true) {
153
- var node_i = -1;
154
- if (bitcount >= HUFFMAN_LUTBITS)
155
- node_i = this.decode_lut[bits & HUFFMAN_LUTMASK];
156
- while (bitcount < 24 && src_index != size) {
157
- bits |= inp_buffer[src_index] << bitcount;
158
- bitcount += 8;
159
- src_index++;
160
- }
161
- if (node_i == -1)
162
- node_i = this.decode_lut[bits & HUFFMAN_LUTMASK];
163
- if (this.nodes[node_i].numbits) {
164
- bits >>= this.nodes[node_i].numbits;
165
- bitcount -= this.nodes[node_i].numbits;
166
- }
167
- else {
168
- bits >>= HUFFMAN_LUTBITS;
169
- bitcount -= HUFFMAN_LUTBITS;
170
- while (true) {
171
- if (bits & 1) {
172
- node_i = this.nodes[node_i].right;
173
- }
174
- else
175
- node_i = this.nodes[node_i].left;
176
- bitcount -= 1;
177
- bits >>= 1;
178
- if (this.nodes[node_i].numbits)
179
- break;
180
- if (bitcount == 0)
181
- throw new Error("No more bits, decoding error");
182
- }
183
- }
184
- if (this.nodes[node_i] == eof)
185
- break;
186
- output.push(this.nodes[node_i].symbol);
187
- }
188
- return Buffer.from(output);
189
- };
190
- return Huffman;
191
- }());
192
- exports.Huffman = Huffman;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Huffman = void 0;
4
+ let FREQ_TABLE = [
5
+ 1 << 30, 4545, 2657, 431, 1950, 919, 444, 482, 2244, 617, 838, 542, 715, 1814, 304, 240, 754, 212, 647, 186,
6
+ 283, 131, 146, 166, 543, 164, 167, 136, 179, 859, 363, 113, 157, 154, 204, 108, 137, 180, 202, 176,
7
+ 872, 404, 168, 134, 151, 111, 113, 109, 120, 126, 129, 100, 41, 20, 16, 22, 18, 18, 17, 19,
8
+ 16, 37, 13, 21, 362, 166, 99, 78, 95, 88, 81, 70, 83, 284, 91, 187, 77, 68, 52, 68,
9
+ 59, 66, 61, 638, 71, 157, 50, 46, 69, 43, 11, 24, 13, 19, 10, 12, 12, 20, 14, 9,
10
+ 20, 20, 10, 10, 15, 15, 12, 12, 7, 19, 15, 14, 13, 18, 35, 19, 17, 14, 8, 5,
11
+ 15, 17, 9, 15, 14, 18, 8, 10, 2173, 134, 157, 68, 188, 60, 170, 60, 194, 62, 175, 71,
12
+ 148, 67, 167, 78, 211, 67, 156, 69, 1674, 90, 174, 53, 147, 89, 181, 51, 174, 63, 163, 80,
13
+ 167, 94, 128, 122, 223, 153, 218, 77, 200, 110, 190, 73, 174, 69, 145, 66, 277, 143, 141, 60,
14
+ 136, 53, 180, 57, 142, 57, 158, 61, 166, 112, 152, 92, 26, 22, 21, 28, 20, 26, 30, 21,
15
+ 32, 27, 20, 17, 23, 21, 30, 22, 22, 21, 27, 25, 17, 27, 23, 18, 39, 26, 15, 21,
16
+ 12, 18, 18, 27, 20, 18, 15, 19, 11, 17, 33, 12, 18, 15, 19, 18, 16, 26, 17, 18,
17
+ 9, 10, 25, 22, 22, 17, 20, 16, 6, 16, 15, 20, 14, 18, 24, 335, 1517
18
+ ], HUFFMAN_EOF_SYMBOL = 256, HUFFMAN_MAX_SYMBOLS = HUFFMAN_EOF_SYMBOL + 1, HUFFMAN_MAX_NODES = HUFFMAN_MAX_SYMBOLS * 2 - 1, HUFFMAN_LUTBITS = 10, HUFFMAN_LUTSIZE = 1 << HUFFMAN_LUTBITS, HUFFMAN_LUTMASK = HUFFMAN_LUTSIZE - 1;
19
+ class Huffman {
20
+ constructor(frequencies = FREQ_TABLE) {
21
+ this.nodes = new Array(HUFFMAN_MAX_NODES);
22
+ for (let i = 0; i < HUFFMAN_MAX_NODES; i++) {
23
+ this.nodes[i] = {};
24
+ }
25
+ this.decode_lut = new Array(HUFFMAN_LUTSIZE);
26
+ this.num_nodes = 0;
27
+ this.start_node_index = 0;
28
+ this.construct_tree(frequencies);
29
+ for (let i = 0; i < HUFFMAN_LUTSIZE; i++) {
30
+ let bits = i;
31
+ let broke = false;
32
+ let index = this.start_node_index;
33
+ for (let x = 0; x < HUFFMAN_LUTBITS; x++) {
34
+ if (bits & 1)
35
+ index = this.nodes[index].right;
36
+ else
37
+ index = this.nodes[index].left;
38
+ bits >>= 1;
39
+ if (this.nodes[index].numbits) {
40
+ this.decode_lut[i] = index;
41
+ broke = true;
42
+ break;
43
+ }
44
+ }
45
+ if (!broke) {
46
+ this.decode_lut[i] = index;
47
+ }
48
+ }
49
+ }
50
+ set_bits_r(node_index, bits, depth) {
51
+ if (this.nodes[node_index].right != 0xffff)
52
+ this.set_bits_r(this.nodes[node_index].right, bits | (1 << depth), depth + 1);
53
+ if (this.nodes[node_index].left != 0xffff)
54
+ this.set_bits_r(this.nodes[node_index].left, bits, depth + 1);
55
+ if (this.nodes[node_index].numbits) {
56
+ this.nodes[node_index].bits = bits;
57
+ this.nodes[node_index].numbits = depth;
58
+ }
59
+ }
60
+ bubble_sort(index_list, node_list, size) {
61
+ let changed = true;
62
+ while (changed) {
63
+ changed = false;
64
+ for (let i = 0; i < size - 1; i++) {
65
+ if (node_list[index_list[i]].frequency < node_list[index_list[i + 1]].frequency) {
66
+ let temp = index_list[i];
67
+ index_list[i] = index_list[i + 1];
68
+ index_list[i + 1] = temp;
69
+ changed = true;
70
+ }
71
+ }
72
+ size--;
73
+ }
74
+ return index_list;
75
+ }
76
+ construct_tree(frequencies = FREQ_TABLE) {
77
+ let nodes_left_storage = new Array(HUFFMAN_MAX_SYMBOLS);
78
+ for (let i = 0; i < HUFFMAN_MAX_SYMBOLS; i++) {
79
+ nodes_left_storage[i] = {};
80
+ }
81
+ let nodes_left = new Array(HUFFMAN_MAX_SYMBOLS);
82
+ let num_nodes_left = HUFFMAN_MAX_SYMBOLS;
83
+ for (let i = 0; i < HUFFMAN_MAX_SYMBOLS; i++) {
84
+ this.nodes[i].numbits = 0xFFFFFFFF;
85
+ this.nodes[i].symbol = i;
86
+ this.nodes[i].left = 0xFFFF;
87
+ this.nodes[i].right = 0xFFFF;
88
+ if (i == HUFFMAN_EOF_SYMBOL) {
89
+ nodes_left_storage[i].frequency = 1;
90
+ }
91
+ else
92
+ nodes_left_storage[i].frequency = frequencies[i];
93
+ nodes_left_storage[i].node_id = i;
94
+ nodes_left[i] = i;
95
+ }
96
+ this.num_nodes = HUFFMAN_MAX_SYMBOLS;
97
+ while (num_nodes_left > 1) {
98
+ nodes_left = this.bubble_sort(nodes_left, nodes_left_storage, num_nodes_left);
99
+ this.nodes[this.num_nodes].numbits = 0;
100
+ this.nodes[this.num_nodes].left = nodes_left_storage[nodes_left[num_nodes_left - 1]].node_id;
101
+ this.nodes[this.num_nodes].right = nodes_left_storage[nodes_left[num_nodes_left - 2]].node_id;
102
+ nodes_left_storage[nodes_left[num_nodes_left - 2]].node_id = this.num_nodes;
103
+ nodes_left_storage[nodes_left[num_nodes_left - 2]].frequency = nodes_left_storage[nodes_left[num_nodes_left - 1]].frequency
104
+ + nodes_left_storage[nodes_left[num_nodes_left - 2]].frequency;
105
+ this.num_nodes++;
106
+ num_nodes_left--;
107
+ }
108
+ this.start_node_index = this.num_nodes - 1;
109
+ this.set_bits_r(this.start_node_index, 0, 0);
110
+ }
111
+ compress(inp_buffer, start_index = 0, size = 0) {
112
+ let output = [];
113
+ let bits = 0;
114
+ let bitcount = 0;
115
+ if (size == 0)
116
+ size = inp_buffer.byteLength;
117
+ inp_buffer = inp_buffer.slice(start_index, start_index + size);
118
+ for (let i = 0; i < size; i++) {
119
+ let x = inp_buffer[i];
120
+ bits |= this.nodes[x].bits << bitcount;
121
+ bitcount += this.nodes[x].numbits;
122
+ while (bitcount >= 8) {
123
+ output.push(bits & 0xff);
124
+ bits >>= 8;
125
+ bitcount -= 8;
126
+ }
127
+ }
128
+ bits |= this.nodes[HUFFMAN_EOF_SYMBOL].bits << bitcount;
129
+ bitcount += this.nodes[HUFFMAN_EOF_SYMBOL].numbits;
130
+ while (bitcount >= 8) {
131
+ output.push(bits & 0xff);
132
+ bits >>= 8;
133
+ bitcount -= 8;
134
+ }
135
+ output.push(bits);
136
+ return Buffer.from(output);
137
+ }
138
+ decompress(inp_buffer, size = 0) {
139
+ let bits = 0;
140
+ let bitcount = 0;
141
+ let eof = this.nodes[HUFFMAN_EOF_SYMBOL];
142
+ let output = [];
143
+ if (size == 0)
144
+ size = inp_buffer.byteLength;
145
+ inp_buffer = inp_buffer.slice(0, size);
146
+ let src_index = 0;
147
+ while (true) {
148
+ let node_i = -1;
149
+ if (bitcount >= HUFFMAN_LUTBITS)
150
+ node_i = this.decode_lut[bits & HUFFMAN_LUTMASK];
151
+ while (bitcount < 24 && src_index != size) {
152
+ bits |= inp_buffer[src_index] << bitcount;
153
+ bitcount += 8;
154
+ src_index++;
155
+ }
156
+ if (node_i == -1)
157
+ node_i = this.decode_lut[bits & HUFFMAN_LUTMASK];
158
+ if (this.nodes[node_i].numbits) {
159
+ bits >>= this.nodes[node_i].numbits;
160
+ bitcount -= this.nodes[node_i].numbits;
161
+ }
162
+ else {
163
+ bits >>= HUFFMAN_LUTBITS;
164
+ bitcount -= HUFFMAN_LUTBITS;
165
+ while (true) {
166
+ if (bits & 1) {
167
+ node_i = this.nodes[node_i].right;
168
+ }
169
+ else
170
+ node_i = this.nodes[node_i].left;
171
+ bitcount -= 1;
172
+ bits >>= 1;
173
+ if (this.nodes[node_i].numbits)
174
+ break;
175
+ if (bitcount == 0)
176
+ throw new Error("No more bits, decoding error");
177
+ }
178
+ }
179
+ if (this.nodes[node_i] == eof)
180
+ break;
181
+ output.push(this.nodes[node_i].symbol);
182
+ }
183
+ return Buffer.from(output);
184
+ }
185
+ }
186
+ exports.Huffman = Huffman;