node-pkware 2.0.0 → 3.0.0

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.
Files changed (69) hide show
  1. package/README.md +42 -40
  2. package/dist/ExpandingBuffer.d.ts +53 -0
  3. package/dist/ExpandingBuffer.js +134 -0
  4. package/dist/ExpandingBuffer.js.map +1 -0
  5. package/dist/Explode.d.ts +8 -0
  6. package/dist/Explode.js +309 -0
  7. package/dist/Explode.js.map +1 -0
  8. package/dist/Implode.d.ts +11 -0
  9. package/dist/Implode.js +305 -0
  10. package/dist/Implode.js.map +1 -0
  11. package/dist/bin/explode.d.ts +2 -0
  12. package/dist/bin/explode.js +59 -0
  13. package/dist/bin/explode.js.map +1 -0
  14. package/dist/bin/helpers.d.ts +8 -0
  15. package/dist/bin/helpers.js +65 -0
  16. package/dist/bin/helpers.js.map +1 -0
  17. package/dist/bin/implode.d.ts +2 -0
  18. package/dist/bin/implode.js +79 -0
  19. package/dist/bin/implode.js.map +1 -0
  20. package/dist/constants.d.ts +32 -0
  21. package/dist/constants.js +114 -0
  22. package/dist/constants.js.map +1 -0
  23. package/{types → dist}/errors.d.ts +13 -11
  24. package/dist/errors.js +52 -0
  25. package/dist/errors.js.map +1 -0
  26. package/dist/functions.d.ts +11 -0
  27. package/dist/functions.js +73 -0
  28. package/dist/functions.js.map +1 -0
  29. package/dist/index.d.ts +20 -0
  30. package/dist/index.js +54 -0
  31. package/dist/index.js.map +1 -0
  32. package/{types/helpers → dist}/stream.d.ts +13 -34
  33. package/dist/stream.js +205 -0
  34. package/dist/stream.js.map +1 -0
  35. package/dist/tsconfig.tsbuildinfo +1 -0
  36. package/dist/types.d.ts +25 -0
  37. package/dist/types.js +3 -0
  38. package/dist/types.js.map +1 -0
  39. package/package.json +14 -45
  40. package/src/ExpandingBuffer.ts +148 -0
  41. package/src/Explode.ts +404 -0
  42. package/src/Implode.ts +368 -0
  43. package/{bin/explode.js → src/bin/explode.ts} +35 -33
  44. package/src/bin/helpers.ts +65 -0
  45. package/src/bin/implode.ts +116 -0
  46. package/src/{constants.js → constants.ts} +31 -50
  47. package/src/errors.ts +47 -0
  48. package/src/functions.ts +73 -0
  49. package/src/index.ts +30 -0
  50. package/src/stream.ts +220 -0
  51. package/src/types.ts +26 -0
  52. package/bin/implode.js +0 -116
  53. package/src/errors.js +0 -50
  54. package/src/explode.js +0 -411
  55. package/src/helpers/ExpandingBuffer.js +0 -123
  56. package/src/helpers/functions.js +0 -150
  57. package/src/helpers/stream.js +0 -190
  58. package/src/helpers/testing.js +0 -80
  59. package/src/implode.js +0 -364
  60. package/src/index.js +0 -18
  61. package/tsconfig.json +0 -20
  62. package/types/constants.d.ts +0 -41
  63. package/types/explode.d.ts +0 -56
  64. package/types/helpers/ExpandingBuffer.d.ts +0 -25
  65. package/types/helpers/Shared.d.ts +0 -46
  66. package/types/helpers/functions.d.ts +0 -15
  67. package/types/helpers/testing.d.ts +0 -6
  68. package/types/implode.d.ts +0 -63
  69. package/types/index.d.ts +0 -8
@@ -0,0 +1,309 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Explode = void 0;
4
+ const node_buffer_1 = require("node:buffer");
5
+ const constants_1 = require("./constants");
6
+ const errors_1 = require("./errors");
7
+ const ExpandingBuffer_1 = require("./ExpandingBuffer");
8
+ const functions_1 = require("./functions");
9
+ /**
10
+ * This function assumes there are at least 2 bytes of data in the buffer
11
+ */
12
+ const readHeader = (buffer) => {
13
+ const compressionType = buffer.readUInt8(0);
14
+ const dictionarySize = buffer.readUInt8(1);
15
+ if (!(compressionType in constants_1.Compression) || compressionType === constants_1.Compression.Unknown) {
16
+ throw new errors_1.InvalidCompressionTypeError();
17
+ }
18
+ if (!(dictionarySize in constants_1.DictionarySize) || dictionarySize === constants_1.DictionarySize.Unknown) {
19
+ throw new errors_1.InvalidDictionarySizeError();
20
+ }
21
+ return {
22
+ compressionType: compressionType,
23
+ dictionarySize: dictionarySize,
24
+ };
25
+ };
26
+ const generateDecodeTables = (startIndexes, lengthBits) => {
27
+ const codes = (0, functions_1.repeat)(0, 0x100);
28
+ lengthBits.forEach((lengthBit, i) => {
29
+ for (let index = startIndexes[i]; index < 0x100; index += 1 << lengthBit) {
30
+ codes[index] = i;
31
+ }
32
+ });
33
+ return codes;
34
+ };
35
+ /**
36
+ * PAT = populate ascii table
37
+ */
38
+ const createPATIterator = (limit, stepper) => {
39
+ return (n) => {
40
+ return n >= limit ? false : [n, n + (1 << stepper)];
41
+ };
42
+ };
43
+ const populateAsciiTable = (value, index, bits, limit) => {
44
+ const iterator = createPATIterator(limit, value - bits);
45
+ const seed = constants_1.ChCodeAsc[index] >> bits;
46
+ const idxs = (0, functions_1.unfold)(iterator, seed);
47
+ const table = [];
48
+ idxs.forEach((idx) => {
49
+ table[idx] = index;
50
+ });
51
+ return table;
52
+ };
53
+ class Explode {
54
+ #verbose;
55
+ #needMoreInput = true;
56
+ #isFirstChunk = true;
57
+ #extraBits = 0;
58
+ #bitBuffer = 0;
59
+ #backupData = {
60
+ extraBits: -1,
61
+ bitBuffer: -1,
62
+ };
63
+ #lengthCodes = generateDecodeTables(constants_1.LenCode, constants_1.LenBits);
64
+ #distPosCodes = generateDecodeTables(constants_1.DistCode, constants_1.DistBits);
65
+ #inputBuffer;
66
+ #outputBuffer;
67
+ #stats = { chunkCounter: 0 };
68
+ #compressionType = constants_1.Compression.Unknown;
69
+ #dictionarySize = constants_1.DictionarySize.Unknown;
70
+ #dictionarySizeMask = 0;
71
+ #chBitsAsc = (0, functions_1.repeat)(0, 0x100);
72
+ #asciiTable2C34 = (0, functions_1.repeat)(0, 0x100);
73
+ #asciiTable2D34 = (0, functions_1.repeat)(0, 0x100);
74
+ #asciiTable2E34 = (0, functions_1.repeat)(0, 0x80);
75
+ #asciiTable2EB4 = (0, functions_1.repeat)(0, 0x100);
76
+ constructor(config = {}) {
77
+ this.#verbose = config?.verbose ?? false;
78
+ this.#inputBuffer = new ExpandingBuffer_1.ExpandingBuffer(config?.inputBufferSize ?? 0);
79
+ this.#outputBuffer = new ExpandingBuffer_1.ExpandingBuffer(config?.outputBufferSize ?? 0);
80
+ }
81
+ getHandler() {
82
+ const instance = this;
83
+ return function (chunk, encoding, callback) {
84
+ instance.#needMoreInput = true;
85
+ try {
86
+ instance.#inputBuffer.append(chunk);
87
+ if (instance.#isFirstChunk) {
88
+ instance.#isFirstChunk = false;
89
+ this._flush = instance.#onInputFinished.bind(instance);
90
+ }
91
+ if (instance.#verbose) {
92
+ instance.#stats.chunkCounter++;
93
+ console.log(`explode: reading ${(0, functions_1.toHex)(chunk.length)} bytes from chunk #${instance.#stats.chunkCounter}`);
94
+ }
95
+ instance.#processChunkData();
96
+ const blockSize = 0x1000;
97
+ if (instance.#outputBuffer.size() <= blockSize) {
98
+ callback(null, node_buffer_1.Buffer.from([]));
99
+ return;
100
+ }
101
+ let [numberOfBlocks] = (0, functions_1.evenAndRemainder)(instance.#outputBuffer.size(), blockSize);
102
+ // making sure to leave one block worth of data for lookback when processing chunk data
103
+ numberOfBlocks--;
104
+ const numberOfBytes = numberOfBlocks * blockSize;
105
+ // make sure to create a copy of the output buffer slice as it will get flushed in the next line
106
+ const output = node_buffer_1.Buffer.from(instance.#outputBuffer.read(0, numberOfBytes));
107
+ instance.#outputBuffer.flushStart(numberOfBytes);
108
+ callback(null, output);
109
+ }
110
+ catch (e) {
111
+ callback(e);
112
+ }
113
+ };
114
+ }
115
+ #generateAsciiTables() {
116
+ this.#chBitsAsc = constants_1.ChBitsAsc.map((value, index) => {
117
+ if (value <= 8) {
118
+ this.#asciiTable2C34 = (0, functions_1.mergeSparseArrays)(populateAsciiTable(value, index, 0, 0x100), this.#asciiTable2C34);
119
+ return value - 0;
120
+ }
121
+ const acc = (0, functions_1.getLowestNBits)(8, constants_1.ChCodeAsc[index]);
122
+ if (acc === 0) {
123
+ this.#asciiTable2EB4 = (0, functions_1.mergeSparseArrays)(populateAsciiTable(value, index, 8, 0x100), this.#asciiTable2EB4);
124
+ return value - 8;
125
+ }
126
+ this.#asciiTable2C34[acc] = 0xff;
127
+ if ((0, functions_1.getLowestNBits)(6, acc) === 0) {
128
+ this.#asciiTable2E34 = (0, functions_1.mergeSparseArrays)(populateAsciiTable(value, index, 6, 0x80), this.#asciiTable2E34);
129
+ return value - 6;
130
+ }
131
+ this.#asciiTable2D34 = (0, functions_1.mergeSparseArrays)(populateAsciiTable(value, index, 4, 0x100), this.#asciiTable2D34);
132
+ return value - 4;
133
+ });
134
+ }
135
+ #onInputFinished(callback) {
136
+ if (this.#verbose) {
137
+ console.log('---------------');
138
+ console.log('explode: total number of chunks read:', this.#stats.chunkCounter);
139
+ console.log('explode: inputBuffer heap size', (0, functions_1.toHex)(this.#inputBuffer.heapSize()));
140
+ console.log('explode: outputBuffer heap size', (0, functions_1.toHex)(this.#outputBuffer.heapSize()));
141
+ }
142
+ if (this.#needMoreInput) {
143
+ callback(new errors_1.AbortedError());
144
+ return;
145
+ }
146
+ callback(null, this.#outputBuffer.read());
147
+ }
148
+ /**
149
+ * @throws {@link AbortedError} when there isn't enough data to be wasted
150
+ */
151
+ #wasteBits(numberOfBits) {
152
+ if (numberOfBits > this.#extraBits && this.#inputBuffer.isEmpty()) {
153
+ throw new errors_1.AbortedError();
154
+ }
155
+ if (numberOfBits <= this.#extraBits) {
156
+ this.#bitBuffer = this.#bitBuffer >> numberOfBits;
157
+ this.#extraBits = this.#extraBits - numberOfBits;
158
+ return;
159
+ }
160
+ const nextByte = this.#inputBuffer.readByte(0);
161
+ this.#inputBuffer.dropStart(1);
162
+ this.#bitBuffer = ((this.#bitBuffer >> this.#extraBits) | (nextByte << 8)) >> (numberOfBits - this.#extraBits);
163
+ this.#extraBits = this.#extraBits + 8 - numberOfBits;
164
+ }
165
+ /**
166
+ * @throws {@link AbortedError}
167
+ */
168
+ #decodeNextLiteral() {
169
+ const lastBit = (0, functions_1.getLowestNBits)(1, this.#bitBuffer);
170
+ this.#wasteBits(1);
171
+ if (lastBit) {
172
+ let lengthCode = this.#lengthCodes[(0, functions_1.getLowestNBits)(8, this.#bitBuffer)];
173
+ this.#wasteBits(constants_1.LenBits[lengthCode]);
174
+ const extraLenghtBits = constants_1.ExLenBits[lengthCode];
175
+ if (extraLenghtBits !== 0) {
176
+ const extraLength = (0, functions_1.getLowestNBits)(extraLenghtBits, this.#bitBuffer);
177
+ try {
178
+ this.#wasteBits(extraLenghtBits);
179
+ }
180
+ catch (e) {
181
+ if (lengthCode + extraLength !== 0x10e) {
182
+ throw new errors_1.AbortedError();
183
+ }
184
+ }
185
+ lengthCode = constants_1.LenBase[lengthCode] + extraLength;
186
+ }
187
+ return lengthCode + 0x100;
188
+ }
189
+ const lastByte = (0, functions_1.getLowestNBits)(8, this.#bitBuffer);
190
+ if (this.#compressionType === constants_1.Compression.Binary) {
191
+ this.#wasteBits(8);
192
+ return lastByte;
193
+ }
194
+ let value;
195
+ if (lastByte > 0) {
196
+ value = this.#asciiTable2C34[lastByte];
197
+ if (value === 0xff) {
198
+ if ((0, functions_1.getLowestNBits)(6, this.#bitBuffer)) {
199
+ this.#wasteBits(4);
200
+ value = this.#asciiTable2D34[(0, functions_1.getLowestNBits)(8, this.#bitBuffer)];
201
+ }
202
+ else {
203
+ this.#wasteBits(6);
204
+ value = this.#asciiTable2E34[(0, functions_1.getLowestNBits)(7, this.#bitBuffer)];
205
+ }
206
+ }
207
+ }
208
+ else {
209
+ this.#wasteBits(8);
210
+ value = this.#asciiTable2EB4[(0, functions_1.getLowestNBits)(8, this.#bitBuffer)];
211
+ }
212
+ this.#wasteBits(this.#chBitsAsc[value]);
213
+ return value;
214
+ }
215
+ /**
216
+ * @throws {@link AbortedError}
217
+ */
218
+ #decodeDistance(repeatLength) {
219
+ const distPosCode = this.#distPosCodes[(0, functions_1.getLowestNBits)(8, this.#bitBuffer)];
220
+ const distPosBits = constants_1.DistBits[distPosCode];
221
+ this.#wasteBits(distPosBits);
222
+ let distance;
223
+ let bitsToWaste;
224
+ if (repeatLength === 2) {
225
+ distance = (distPosCode << 2) | (0, functions_1.getLowestNBits)(2, this.#bitBuffer);
226
+ bitsToWaste = 2;
227
+ }
228
+ else {
229
+ distance = (distPosCode << this.#dictionarySize) | (this.#bitBuffer & this.#dictionarySizeMask);
230
+ bitsToWaste = this.#dictionarySize;
231
+ }
232
+ this.#wasteBits(bitsToWaste);
233
+ return distance + 1;
234
+ }
235
+ #processChunkData() {
236
+ if (this.#inputBuffer.isEmpty()) {
237
+ return;
238
+ }
239
+ if (this.#compressionType === constants_1.Compression.Unknown) {
240
+ const headerParsedSuccessfully = this.#parseInitialData();
241
+ if (!headerParsedSuccessfully || this.#inputBuffer.isEmpty()) {
242
+ return;
243
+ }
244
+ }
245
+ this.#needMoreInput = false;
246
+ this.#backup();
247
+ try {
248
+ let nextLiteral = this.#decodeNextLiteral();
249
+ while (nextLiteral !== constants_1.LITERAL_END_STREAM) {
250
+ let addition;
251
+ if (nextLiteral >= 0x100) {
252
+ const repeatLength = nextLiteral - 0xfe;
253
+ const minusDistance = this.#decodeDistance(repeatLength);
254
+ const availableData = this.#outputBuffer.read(this.#outputBuffer.size() - minusDistance, repeatLength);
255
+ if (repeatLength > minusDistance) {
256
+ const multipliedData = (0, functions_1.repeat)(availableData, Math.ceil(repeatLength / availableData.length));
257
+ addition = node_buffer_1.Buffer.concat(multipliedData).subarray(0, repeatLength);
258
+ }
259
+ else {
260
+ addition = availableData;
261
+ }
262
+ }
263
+ else {
264
+ addition = node_buffer_1.Buffer.from([nextLiteral]);
265
+ }
266
+ this.#outputBuffer.append(addition);
267
+ this.#backup();
268
+ nextLiteral = this.#decodeNextLiteral();
269
+ }
270
+ }
271
+ catch (e) {
272
+ this.#needMoreInput = true;
273
+ }
274
+ if (this.#needMoreInput) {
275
+ this.#restore();
276
+ }
277
+ }
278
+ #parseInitialData() {
279
+ if (this.#inputBuffer.size() < 4) {
280
+ return false;
281
+ }
282
+ const { compressionType, dictionarySize } = readHeader(this.#inputBuffer.read(0, 2));
283
+ this.#compressionType = compressionType;
284
+ this.#dictionarySize = dictionarySize;
285
+ this.#bitBuffer = this.#inputBuffer.readByte(2);
286
+ this.#inputBuffer.dropStart(3);
287
+ this.#dictionarySizeMask = (0, functions_1.nBitsOfOnes)(dictionarySize);
288
+ if (this.#compressionType === constants_1.Compression.Ascii) {
289
+ this.#generateAsciiTables();
290
+ }
291
+ if (this.#verbose) {
292
+ console.log(`explode: compression type: ${constants_1.Compression[this.#compressionType]}`);
293
+ console.log(`explode: compression level: ${constants_1.DictionarySize[this.#dictionarySize]}`);
294
+ }
295
+ return true;
296
+ }
297
+ #backup() {
298
+ this.#backupData.extraBits = this.#extraBits;
299
+ this.#backupData.bitBuffer = this.#bitBuffer;
300
+ this.#inputBuffer.saveIndices();
301
+ }
302
+ #restore() {
303
+ this.#extraBits = this.#backupData.extraBits;
304
+ this.#bitBuffer = this.#backupData.bitBuffer;
305
+ this.#inputBuffer.restoreIndices();
306
+ }
307
+ }
308
+ exports.Explode = Explode;
309
+ //# sourceMappingURL=Explode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Explode.js","sourceRoot":"","sources":["../src/Explode.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ /// <reference types="node" />
2
+ import { Buffer } from 'node:buffer';
3
+ import { Transform, TransformCallback } from 'node:stream';
4
+ import { Compression, DictionarySize } from './constants';
5
+ import { Config } from './types';
6
+ export declare const getSizeOfMatching: (inputBytes: Buffer, a: number, b: number) => number;
7
+ export declare class Implode {
8
+ #private;
9
+ constructor(compressionType: Compression, dictionarySize: DictionarySize, config: Config);
10
+ getHandler(): (this: Transform, chunk: Buffer, encoding: BufferEncoding, callback: TransformCallback) => void;
11
+ }
@@ -0,0 +1,305 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Implode = exports.getSizeOfMatching = void 0;
4
+ const node_buffer_1 = require("node:buffer");
5
+ const constants_1 = require("./constants");
6
+ const errors_1 = require("./errors");
7
+ const ExpandingBuffer_1 = require("./ExpandingBuffer");
8
+ const functions_1 = require("./functions");
9
+ const getSizeOfMatching = (inputBytes, a, b) => {
10
+ const limit = (0, functions_1.clamp)(2, constants_1.LONGEST_ALLOWED_REPETITION, b - a);
11
+ for (let i = 2; i <= limit; i++) {
12
+ if (inputBytes[a + i] !== inputBytes[b + i]) {
13
+ return i;
14
+ }
15
+ }
16
+ return limit;
17
+ };
18
+ exports.getSizeOfMatching = getSizeOfMatching;
19
+ /**
20
+ * TODO: make sure that we find the most recent one,
21
+ * which in turn allows us to store backward length in less amount of bits
22
+ * currently the code goes from the furthest point
23
+ */
24
+ const findRepetitions = (inputBytes, endOfLastMatch, cursor) => {
25
+ const notEnoughBytes = inputBytes.length - cursor < 2;
26
+ const tooClose = cursor === endOfLastMatch || cursor - endOfLastMatch < 2;
27
+ if (notEnoughBytes || tooClose) {
28
+ return { size: 0, distance: 0 };
29
+ }
30
+ const haystack = inputBytes.subarray(endOfLastMatch, cursor);
31
+ const needle = inputBytes.subarray(cursor, cursor + 2);
32
+ const matchIndex = haystack.indexOf(needle);
33
+ if (matchIndex !== -1) {
34
+ const distance = cursor - endOfLastMatch - matchIndex;
35
+ return {
36
+ distance: distance - 1,
37
+ size: distance > 2 ? (0, exports.getSizeOfMatching)(inputBytes, endOfLastMatch + matchIndex, cursor) : 2,
38
+ };
39
+ }
40
+ return { size: 0, distance: 0 };
41
+ };
42
+ class Implode {
43
+ #verbose;
44
+ #isFirstChunk = true;
45
+ #inputBuffer;
46
+ #outputBuffer;
47
+ #stats = { chunkCounter: 0 };
48
+ #compressionType = constants_1.Compression.Unknown;
49
+ #dictionarySize = constants_1.DictionarySize.Unknown;
50
+ #dictionarySizeMask = -1;
51
+ #streamEnded = false;
52
+ #distCodes = (0, functions_1.clone)(constants_1.DistCode);
53
+ #distBits = (0, functions_1.clone)(constants_1.DistBits);
54
+ #startIndex = 0;
55
+ #handledFirstTwoBytes = false;
56
+ #outBits = 0;
57
+ #nChBits = (0, functions_1.repeat)(0, 0x306);
58
+ #nChCodes = (0, functions_1.repeat)(0, 0x306);
59
+ constructor(compressionType, dictionarySize, config) {
60
+ if (!(compressionType in constants_1.Compression) || compressionType === constants_1.Compression.Unknown) {
61
+ throw new errors_1.InvalidCompressionTypeError();
62
+ }
63
+ if (!(dictionarySize in constants_1.DictionarySize) || dictionarySize === constants_1.DictionarySize.Unknown) {
64
+ throw new errors_1.InvalidDictionarySizeError();
65
+ }
66
+ this.#compressionType = compressionType;
67
+ this.#dictionarySize = dictionarySize;
68
+ this.#verbose = config?.verbose ?? false;
69
+ this.#inputBuffer = new ExpandingBuffer_1.ExpandingBuffer(config?.inputBufferSize ?? 0);
70
+ this.#outputBuffer = new ExpandingBuffer_1.ExpandingBuffer(config?.outputBufferSize ?? 0);
71
+ }
72
+ getHandler() {
73
+ const instance = this;
74
+ return function (chunk, encoding, callback) {
75
+ try {
76
+ instance.#inputBuffer.append(chunk);
77
+ if (instance.#isFirstChunk) {
78
+ instance.#isFirstChunk = false;
79
+ this._flush = instance.#onInputFinished.bind(instance);
80
+ }
81
+ if (instance.#verbose) {
82
+ instance.#stats.chunkCounter++;
83
+ console.log(`implode: reading ${(0, functions_1.toHex)(chunk.length)} bytes from chunk #${instance.#stats.chunkCounter}`);
84
+ }
85
+ instance.#processChunkData();
86
+ const blockSize = 0x800;
87
+ if (instance.#outputBuffer.size() <= blockSize) {
88
+ callback(null, node_buffer_1.Buffer.from([]));
89
+ return;
90
+ }
91
+ let [numberOfBlocks] = (0, functions_1.evenAndRemainder)(instance.#outputBuffer.size(), blockSize);
92
+ // making sure to leave one block worth of data for lookback when processing chunk data
93
+ numberOfBlocks--;
94
+ const numberOfBytes = numberOfBlocks * blockSize;
95
+ // make sure to create a copy of the output buffer slice as it will get flushed in the next line
96
+ const output = node_buffer_1.Buffer.from(instance.#outputBuffer.read(0, numberOfBytes));
97
+ instance.#outputBuffer.flushStart(numberOfBytes);
98
+ if (instance.#outBits === 0) {
99
+ // set last byte to 0
100
+ instance.#outputBuffer.dropEnd(1);
101
+ instance.#outputBuffer.append(node_buffer_1.Buffer.from([0]));
102
+ }
103
+ callback(null, output);
104
+ }
105
+ catch (e) {
106
+ callback(e);
107
+ }
108
+ };
109
+ }
110
+ #onInputFinished(callback) {
111
+ this.#streamEnded = true;
112
+ try {
113
+ this.#processChunkData();
114
+ if (this.#verbose) {
115
+ console.log('---------------');
116
+ console.log('implode: total number of chunks read:', this.#stats.chunkCounter);
117
+ console.log('implode: inputBuffer heap size', (0, functions_1.toHex)(this.#inputBuffer.heapSize()));
118
+ console.log('implode: outputBuffer heap size', (0, functions_1.toHex)(this.#outputBuffer.heapSize()));
119
+ }
120
+ callback(null, this.#outputBuffer.read());
121
+ }
122
+ catch (e) {
123
+ callback(e);
124
+ }
125
+ }
126
+ #processChunkData() {
127
+ if (this.#dictionarySizeMask === -1) {
128
+ this.#setup();
129
+ }
130
+ if (!this.#inputBuffer.isEmpty()) {
131
+ this.#startIndex = 0;
132
+ if (!this.#handledFirstTwoBytes) {
133
+ if (this.#inputBuffer.size() < 3) {
134
+ return;
135
+ }
136
+ this.#handledFirstTwoBytes = true;
137
+ this.#handleFirstTwoBytes();
138
+ }
139
+ // -------------------------------
140
+ let endOfLastMatch = 0; // used when searching for longer repetitions later
141
+ while (this.#startIndex < this.#inputBuffer.size()) {
142
+ let { size, distance } = findRepetitions(this.#inputBuffer.read(endOfLastMatch), endOfLastMatch, this.#startIndex);
143
+ let isFlushable = this.#isRepetitionFlushable(size, distance);
144
+ if (isFlushable === false) {
145
+ const byte = this.#inputBuffer.readByte(this.#startIndex);
146
+ this.#outputBits(this.#nChBits[byte], this.#nChCodes[byte]);
147
+ this.#startIndex += 1;
148
+ }
149
+ else {
150
+ if (isFlushable === null) {
151
+ /*
152
+ // Try to find better repetition 1 byte later.
153
+ // stormlib/implode.c L517
154
+ let cursor = this.#startIndex
155
+ let newSize = size
156
+ let newDistance = distance
157
+ let currentSize
158
+ let currentDistance
159
+ while (newSize <= currentSize && this.#isRepetitionFlushable(newSize, newDistance)) {
160
+ currentSize = newSize
161
+ currentDistance = newDistance
162
+ const reps = findRepetitions(this.#inputBuffer.read(endOfLastMatch), endOfLastMatch, ++cursor)
163
+ newSize = reps.size
164
+ newDistance = reps.distance
165
+ }
166
+ size = newSize
167
+ distance = currentDistance
168
+ */
169
+ }
170
+ const byte = size + 0xfe;
171
+ this.#outputBits(this.#nChBits[byte], this.#nChCodes[byte]);
172
+ if (size === 2) {
173
+ const byte = distance >> 2;
174
+ this.#outputBits(this.#distBits[byte], this.#distCodes[byte]);
175
+ this.#outputBits(2, distance & 3);
176
+ }
177
+ else {
178
+ const byte = distance >> this.#dictionarySize;
179
+ this.#outputBits(this.#distBits[byte], this.#distCodes[byte]);
180
+ this.#outputBits(this.#dictionarySize, this.#dictionarySizeMask & distance);
181
+ }
182
+ this.#startIndex += size;
183
+ }
184
+ /*
185
+ this.#inputBuffer.dropStart(endOfLastMatch)
186
+ this.#startIndex -= endOfLastMatch
187
+ endOfLastMatch = 0
188
+ */
189
+ if (this.#dictionarySize === constants_1.DictionarySize.Small && this.#startIndex >= 0x400) {
190
+ this.#inputBuffer.dropStart(0x400);
191
+ this.#startIndex -= 0x400;
192
+ }
193
+ else if (this.#dictionarySize === constants_1.DictionarySize.Medium && this.#startIndex >= 0x800) {
194
+ this.#inputBuffer.dropStart(0x800);
195
+ this.#startIndex -= 0x800;
196
+ }
197
+ else if (this.#dictionarySize === constants_1.DictionarySize.Large && this.#startIndex >= 0x1000) {
198
+ this.#inputBuffer.dropStart(0x1000);
199
+ this.#startIndex -= 0x1000;
200
+ }
201
+ }
202
+ // -------------------------------
203
+ this.#inputBuffer.dropStart(this.#inputBuffer.size());
204
+ }
205
+ if (this.#streamEnded) {
206
+ // Write the termination literal
207
+ this.#outputBits((0, functions_1.last)(this.#nChBits), (0, functions_1.last)(this.#nChCodes));
208
+ }
209
+ }
210
+ /**
211
+ * @returns false - non flushable
212
+ * @returns true - flushable
213
+ * @returns null - flushable, but there might be a better repetition
214
+ */
215
+ #isRepetitionFlushable(size, distance) {
216
+ if (size === 0) {
217
+ return false;
218
+ }
219
+ // If we found repetition of 2 bytes, that is 0x100 or further back,
220
+ // don't bother. Storing the distance of 0x100 bytes would actually
221
+ // take more space than storing the 2 bytes as-is.
222
+ if (size === 2 && distance >= 0x100) {
223
+ return false;
224
+ }
225
+ if (size >= 8 || this.#startIndex + 1 >= this.#inputBuffer.size()) {
226
+ return true;
227
+ }
228
+ return null;
229
+ }
230
+ /**
231
+ * repetitions are at least 2 bytes long,
232
+ * so the initial 2 bytes can be moved to the output as is
233
+ */
234
+ #handleFirstTwoBytes() {
235
+ const byte1 = this.#inputBuffer.readByte(0);
236
+ const byte2 = this.#inputBuffer.readByte(1);
237
+ this.#outputBits(this.#nChBits[byte1], this.#nChCodes[byte1]);
238
+ this.#outputBits(this.#nChBits[byte2], this.#nChCodes[byte2]);
239
+ this.#startIndex += 2;
240
+ }
241
+ #setup() {
242
+ switch (this.#dictionarySize) {
243
+ case constants_1.DictionarySize.Large:
244
+ this.#dictionarySizeMask = (0, functions_1.nBitsOfOnes)(6);
245
+ break;
246
+ case constants_1.DictionarySize.Medium:
247
+ this.#dictionarySizeMask = (0, functions_1.nBitsOfOnes)(5);
248
+ break;
249
+ case constants_1.DictionarySize.Small:
250
+ this.#dictionarySizeMask = (0, functions_1.nBitsOfOnes)(4);
251
+ break;
252
+ }
253
+ switch (this.#compressionType) {
254
+ case constants_1.Compression.Binary:
255
+ let nChCode = 0;
256
+ for (let nCount = 0; nCount < 0x100; nCount++) {
257
+ this.#nChBits[nCount] = 9;
258
+ this.#nChCodes[nCount] = nChCode;
259
+ nChCode = (0, functions_1.getLowestNBits)(16, nChCode) + 2;
260
+ }
261
+ break;
262
+ case constants_1.Compression.Ascii:
263
+ for (let nCount = 0; nCount < 0x100; nCount++) {
264
+ this.#nChBits[nCount] = constants_1.ChBitsAsc[nCount] + 1;
265
+ this.#nChCodes[nCount] = constants_1.ChCodeAsc[nCount] * 2;
266
+ }
267
+ break;
268
+ }
269
+ let nCount = 0x100;
270
+ for (let i = 0; i < 0x10; i++) {
271
+ for (let nCount2 = 0; nCount2 < 1 << constants_1.ExLenBits[i]; nCount2++) {
272
+ this.#nChBits[nCount] = constants_1.ExLenBits[i] + constants_1.LenBits[i] + 1;
273
+ this.#nChCodes[nCount] = (nCount2 << (constants_1.LenBits[i] + 1)) | (constants_1.LenCode[i] * 2) | 1;
274
+ nCount++;
275
+ }
276
+ }
277
+ this.#outputBuffer.append(node_buffer_1.Buffer.from([this.#compressionType, this.#dictionarySize, 0]));
278
+ this.#outBits = 0;
279
+ }
280
+ #outputBits(nBits, bitBuffer) {
281
+ if (nBits > 8) {
282
+ this.#outputBits(8, bitBuffer);
283
+ bitBuffer = bitBuffer >> 8;
284
+ nBits = nBits - 8;
285
+ }
286
+ const outBits = this.#outBits;
287
+ const lastBytes = this.#outputBuffer.readByte(this.#outputBuffer.size() - 1);
288
+ this.#outputBuffer.dropEnd(1);
289
+ this.#outputBuffer.append(node_buffer_1.Buffer.from([lastBytes | (0, functions_1.getLowestNBits)(8, bitBuffer << outBits)]));
290
+ this.#outBits = this.#outBits + nBits;
291
+ if (this.#outBits > 8) {
292
+ bitBuffer = bitBuffer >> (8 - outBits);
293
+ this.#outputBuffer.append(node_buffer_1.Buffer.from([(0, functions_1.getLowestNBits)(8, bitBuffer)]));
294
+ this.#outBits = (0, functions_1.getLowestNBits)(3, this.#outBits);
295
+ }
296
+ else {
297
+ this.#outBits = (0, functions_1.getLowestNBits)(3, this.#outBits);
298
+ if (this.#outBits === 0) {
299
+ this.#outputBuffer.append(node_buffer_1.Buffer.from([0]));
300
+ }
301
+ }
302
+ }
303
+ }
304
+ exports.Implode = Implode;
305
+ //# sourceMappingURL=Implode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Implode.js","sourceRoot":"","sources":["../src/Implode.ts"],"names":[],"mappings":"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"}