@gmod/cram 3.0.7 → 4.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.
- package/dist/craiIndex.js +70 -87
- package/dist/craiIndex.js.map +1 -1
- package/dist/cram-bundle.js +1 -1
- package/dist/cramFile/codecs/_base.d.ts +1 -1
- package/dist/cramFile/codecs/beta.d.ts +2 -2
- package/dist/cramFile/codecs/beta.js +1 -1
- package/dist/cramFile/codecs/beta.js.map +1 -1
- package/dist/cramFile/codecs/byteArrayLength.d.ts +2 -2
- package/dist/cramFile/codecs/byteArrayStop.d.ts +4 -4
- package/dist/cramFile/codecs/byteArrayStop.js +1 -1
- package/dist/cramFile/codecs/byteArrayStop.js.map +1 -1
- package/dist/cramFile/codecs/external.d.ts +1 -1
- package/dist/cramFile/codecs/external.js +1 -1
- package/dist/cramFile/codecs/external.js.map +1 -1
- package/dist/cramFile/codecs/gamma.d.ts +1 -1
- package/dist/cramFile/codecs/gamma.js +1 -1
- package/dist/cramFile/codecs/gamma.js.map +1 -1
- package/dist/cramFile/codecs/getBits.d.ts +1 -1
- package/dist/cramFile/codecs/getBits.js.map +1 -1
- package/dist/cramFile/codecs/huffman.d.ts +1 -1
- package/dist/cramFile/codecs/huffman.js +1 -1
- package/dist/cramFile/codecs/huffman.js.map +1 -1
- package/dist/cramFile/codecs/index.d.ts +1 -1
- package/dist/cramFile/codecs/index.js +5 -5
- package/dist/cramFile/codecs/index.js.map +1 -1
- package/dist/cramFile/codecs/subexp.d.ts +2 -2
- package/dist/cramFile/codecs/subexp.js +1 -1
- package/dist/cramFile/codecs/subexp.js.map +1 -1
- package/dist/cramFile/container/compressionScheme.d.ts +2 -2
- package/dist/cramFile/container/compressionScheme.js +1 -1
- package/dist/cramFile/container/compressionScheme.js.map +1 -1
- package/dist/cramFile/container/index.d.ts +1 -2
- package/dist/cramFile/container/index.js +62 -79
- package/dist/cramFile/container/index.js.map +1 -1
- package/dist/cramFile/file.d.ts +9 -13
- package/dist/cramFile/file.js +218 -247
- package/dist/cramFile/file.js.map +1 -1
- package/dist/cramFile/record.js +2 -2
- package/dist/cramFile/record.js.map +1 -1
- package/dist/cramFile/sectionParsers.d.ts +16 -16
- package/dist/cramFile/sectionParsers.js +12 -9
- package/dist/cramFile/sectionParsers.js.map +1 -1
- package/dist/cramFile/slice/decodeRecord.d.ts +3 -3
- package/dist/cramFile/slice/decodeRecord.js +11 -11
- package/dist/cramFile/slice/decodeRecord.js.map +1 -1
- package/dist/cramFile/slice/index.d.ts +2 -2
- package/dist/cramFile/slice/index.js +241 -262
- package/dist/cramFile/slice/index.js.map +1 -1
- package/dist/cramFile/util.d.ts +4 -2
- package/dist/cramFile/util.js +29 -6
- package/dist/cramFile/util.js.map +1 -1
- package/dist/htscodecs/arith_gen.d.ts +9 -17
- package/dist/htscodecs/arith_gen.js +32 -272
- package/dist/htscodecs/arith_gen.js.map +1 -1
- package/dist/htscodecs/fqzcomp.d.ts +1 -2
- package/dist/htscodecs/fqzcomp.js +2 -421
- package/dist/htscodecs/fqzcomp.js.map +1 -1
- package/dist/htscodecs/index.d.ts +5 -5
- package/dist/htscodecs/index.js +10 -10
- package/dist/htscodecs/index.js.map +1 -1
- package/dist/htscodecs/iostream.d.ts +2 -1
- package/dist/htscodecs/iostream.js +3 -2
- package/dist/htscodecs/iostream.js.map +1 -1
- package/dist/htscodecs/rans.d.ts +1 -2
- package/dist/htscodecs/rans.js +3 -270
- package/dist/htscodecs/rans.js.map +1 -1
- package/dist/htscodecs/rans4x16.d.ts +0 -1
- package/dist/htscodecs/rans4x16.js +6 -497
- package/dist/htscodecs/rans4x16.js.map +1 -1
- package/dist/htscodecs/tok3.js +17 -1
- package/dist/htscodecs/tok3.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/dist/indexedCramFile.d.ts +4 -4
- package/dist/indexedCramFile.js +97 -108
- package/dist/indexedCramFile.js.map +1 -1
- package/dist/io/index.d.ts +2 -2
- package/dist/io/index.js +6 -6
- package/dist/io/index.js.map +1 -1
- package/dist/rans/constants.d.ts +1 -1
- package/dist/rans/constants.js +1 -1
- package/dist/rans/constants.js.map +1 -1
- package/dist/rans/d04.js.map +1 -1
- package/dist/rans/decoding.js.map +1 -1
- package/dist/rans/frequencies.js.map +1 -1
- package/dist/rans/index.js +5 -5
- package/dist/rans/index.js.map +1 -1
- package/dist/unzip.d.ts +1 -1
- package/dist/unzip.js +5 -3
- package/dist/unzip.js.map +1 -1
- package/esm/craiIndex.js +10 -12
- package/esm/craiIndex.js.map +1 -1
- package/esm/cramFile/codecs/_base.d.ts +1 -1
- package/esm/cramFile/codecs/beta.d.ts +2 -2
- package/esm/cramFile/codecs/beta.js +1 -1
- package/esm/cramFile/codecs/beta.js.map +1 -1
- package/esm/cramFile/codecs/byteArrayLength.d.ts +2 -2
- package/esm/cramFile/codecs/byteArrayStop.d.ts +4 -4
- package/esm/cramFile/codecs/byteArrayStop.js +1 -1
- package/esm/cramFile/codecs/byteArrayStop.js.map +1 -1
- package/esm/cramFile/codecs/external.d.ts +1 -1
- package/esm/cramFile/codecs/external.js +1 -1
- package/esm/cramFile/codecs/external.js.map +1 -1
- package/esm/cramFile/codecs/gamma.d.ts +1 -1
- package/esm/cramFile/codecs/gamma.js +1 -1
- package/esm/cramFile/codecs/gamma.js.map +1 -1
- package/esm/cramFile/codecs/getBits.d.ts +1 -1
- package/esm/cramFile/codecs/getBits.js.map +1 -1
- package/esm/cramFile/codecs/huffman.d.ts +1 -1
- package/esm/cramFile/codecs/huffman.js +1 -1
- package/esm/cramFile/codecs/huffman.js.map +1 -1
- package/esm/cramFile/codecs/index.d.ts +1 -1
- package/esm/cramFile/codecs/index.js +5 -5
- package/esm/cramFile/codecs/index.js.map +1 -1
- package/esm/cramFile/codecs/subexp.d.ts +2 -2
- package/esm/cramFile/codecs/subexp.js +1 -1
- package/esm/cramFile/codecs/subexp.js.map +1 -1
- package/esm/cramFile/container/compressionScheme.d.ts +2 -2
- package/esm/cramFile/container/compressionScheme.js +1 -1
- package/esm/cramFile/container/compressionScheme.js.map +1 -1
- package/esm/cramFile/container/index.d.ts +1 -2
- package/esm/cramFile/container/index.js +4 -7
- package/esm/cramFile/container/index.js.map +1 -1
- package/esm/cramFile/file.d.ts +9 -13
- package/esm/cramFile/file.js +47 -52
- package/esm/cramFile/file.js.map +1 -1
- package/esm/cramFile/record.js +2 -2
- package/esm/cramFile/record.js.map +1 -1
- package/esm/cramFile/sectionParsers.d.ts +16 -16
- package/esm/cramFile/sectionParsers.js +7 -7
- package/esm/cramFile/sectionParsers.js.map +1 -1
- package/esm/cramFile/slice/decodeRecord.d.ts +3 -3
- package/esm/cramFile/slice/decodeRecord.js +11 -11
- package/esm/cramFile/slice/decodeRecord.js.map +1 -1
- package/esm/cramFile/slice/index.d.ts +2 -2
- package/esm/cramFile/slice/index.js +7 -6
- package/esm/cramFile/slice/index.js.map +1 -1
- package/esm/cramFile/util.d.ts +4 -2
- package/esm/cramFile/util.js +19 -2
- package/esm/cramFile/util.js.map +1 -1
- package/esm/htscodecs/arith_gen.d.ts +9 -17
- package/esm/htscodecs/arith_gen.js +32 -272
- package/esm/htscodecs/arith_gen.js.map +1 -1
- package/esm/htscodecs/fqzcomp.d.ts +1 -2
- package/esm/htscodecs/fqzcomp.js +2 -421
- package/esm/htscodecs/fqzcomp.js.map +1 -1
- package/esm/htscodecs/index.d.ts +5 -5
- package/esm/htscodecs/index.js +10 -10
- package/esm/htscodecs/index.js.map +1 -1
- package/esm/htscodecs/iostream.d.ts +2 -1
- package/esm/htscodecs/iostream.js +3 -2
- package/esm/htscodecs/iostream.js.map +1 -1
- package/esm/htscodecs/rans.d.ts +1 -2
- package/esm/htscodecs/rans.js +3 -270
- package/esm/htscodecs/rans.js.map +1 -1
- package/esm/htscodecs/rans4x16.d.ts +0 -1
- package/esm/htscodecs/rans4x16.js +6 -497
- package/esm/htscodecs/rans4x16.js.map +1 -1
- package/esm/htscodecs/tok3.js +17 -1
- package/esm/htscodecs/tok3.js.map +1 -1
- package/esm/index.d.ts +1 -1
- package/esm/index.js +1 -1
- package/esm/index.js.map +1 -1
- package/esm/indexedCramFile.d.ts +4 -4
- package/esm/indexedCramFile.js +10 -10
- package/esm/indexedCramFile.js.map +1 -1
- package/esm/io/index.d.ts +2 -2
- package/esm/io/index.js +1 -1
- package/esm/io/index.js.map +1 -1
- package/esm/rans/constants.d.ts +1 -1
- package/esm/rans/constants.js +1 -1
- package/esm/rans/constants.js.map +1 -1
- package/esm/rans/d04.js.map +1 -1
- package/esm/rans/decoding.js.map +1 -1
- package/esm/rans/frequencies.js.map +1 -1
- package/esm/rans/index.js +5 -5
- package/esm/rans/index.js.map +1 -1
- package/esm/unzip.d.ts +1 -1
- package/esm/unzip.js +4 -1
- package/esm/unzip.js.map +1 -1
- package/package.json +7 -9
- package/src/craiIndex.ts +17 -16
- package/src/cramFile/codecs/_base.ts +1 -1
- package/src/cramFile/codecs/beta.ts +3 -3
- package/src/cramFile/codecs/byteArrayLength.ts +1 -1
- package/src/cramFile/codecs/byteArrayStop.ts +3 -4
- package/src/cramFile/codecs/external.ts +3 -3
- package/src/cramFile/codecs/gamma.ts +2 -2
- package/src/cramFile/codecs/getBits.ts +1 -1
- package/src/cramFile/codecs/huffman.ts +2 -3
- package/src/cramFile/codecs/index.ts +7 -8
- package/src/cramFile/codecs/subexp.ts +3 -3
- package/src/cramFile/container/compressionScheme.ts +3 -3
- package/src/cramFile/container/index.ts +7 -10
- package/src/cramFile/file.ts +71 -77
- package/src/cramFile/record.ts +3 -3
- package/src/cramFile/sectionParsers.ts +27 -22
- package/src/cramFile/slice/decodeRecord.ts +17 -17
- package/src/cramFile/slice/index.ts +8 -9
- package/src/cramFile/util.ts +24 -5
- package/src/htscodecs/arith_gen.js +33 -296
- package/src/htscodecs/fqzcomp.js +2 -476
- package/src/htscodecs/index.js +9 -11
- package/src/htscodecs/iostream.js +3 -2
- package/src/htscodecs/rans.js +3 -315
- package/src/htscodecs/rans4x16.js +6 -557
- package/src/htscodecs/tok3.js +18 -1
- package/src/index.ts +1 -1
- package/src/indexedCramFile.ts +6 -5
- package/src/io/index.ts +5 -4
- package/src/rans/constants.ts +1 -1
- package/src/rans/d04.ts +0 -1
- package/src/rans/decoding.ts +0 -1
- package/src/rans/frequencies.ts +0 -1
- package/src/rans/index.ts +5 -7
- package/src/unzip.ts +5 -1
- package/dist/cramFile/filehandle.d.ts +0 -1
- package/dist/cramFile/filehandle.js +0 -3
- package/dist/cramFile/filehandle.js.map +0 -1
- package/dist/htscodecs/main_arith_gen.d.ts +0 -1
- package/dist/htscodecs/main_arith_gen.js +0 -86
- package/dist/htscodecs/main_arith_gen.js.map +0 -1
- package/dist/htscodecs/main_fqzcomp.d.ts +0 -1
- package/dist/htscodecs/main_fqzcomp.js +0 -112
- package/dist/htscodecs/main_fqzcomp.js.map +0 -1
- package/dist/htscodecs/main_rans.d.ts +0 -1
- package/dist/htscodecs/main_rans.js +0 -83
- package/dist/htscodecs/main_rans.js.map +0 -1
- package/dist/htscodecs/main_rans4x16.d.ts +0 -1
- package/dist/htscodecs/main_rans4x16.js +0 -82
- package/dist/htscodecs/main_rans4x16.js.map +0 -1
- package/dist/htscodecs/main_tok3.d.ts +0 -1
- package/dist/htscodecs/main_tok3.js +0 -84
- package/dist/htscodecs/main_tok3.js.map +0 -1
- package/dist/unzip-pako.d.ts +0 -2
- package/dist/unzip-pako.js +0 -9
- package/dist/unzip-pako.js.map +0 -1
- package/esm/cramFile/filehandle.d.ts +0 -1
- package/esm/cramFile/filehandle.js +0 -2
- package/esm/cramFile/filehandle.js.map +0 -1
- package/esm/htscodecs/main_arith_gen.d.ts +0 -1
- package/esm/htscodecs/main_arith_gen.js +0 -86
- package/esm/htscodecs/main_arith_gen.js.map +0 -1
- package/esm/htscodecs/main_fqzcomp.d.ts +0 -1
- package/esm/htscodecs/main_fqzcomp.js +0 -112
- package/esm/htscodecs/main_fqzcomp.js.map +0 -1
- package/esm/htscodecs/main_rans.d.ts +0 -1
- package/esm/htscodecs/main_rans.js +0 -83
- package/esm/htscodecs/main_rans.js.map +0 -1
- package/esm/htscodecs/main_rans4x16.d.ts +0 -1
- package/esm/htscodecs/main_rans4x16.js +0 -82
- package/esm/htscodecs/main_rans4x16.js.map +0 -1
- package/esm/htscodecs/main_tok3.d.ts +0 -1
- package/esm/htscodecs/main_tok3.js +0 -84
- package/esm/htscodecs/main_tok3.js.map +0 -1
- package/esm/unzip-pako.d.ts +0 -2
- package/esm/unzip-pako.js +0 -6
- package/esm/unzip-pako.js.map +0 -1
- package/src/cramFile/filehandle.ts +0 -1
- package/src/htscodecs/Makefile +0 -142
- package/src/htscodecs/README.md +0 -64
- package/src/htscodecs/main_arith_gen.js +0 -96
- package/src/htscodecs/main_fqzcomp.js +0 -113
- package/src/htscodecs/main_rans.js +0 -88
- package/src/htscodecs/main_rans4x16.js +0 -87
- package/src/htscodecs/main_tok3.js +0 -86
- package/src/unzip-pako.ts +0 -6
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/cramFile/slice/index.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/cramFile/slice/index.ts"],"names":[],"mappings":"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"}
|
package/dist/cramFile/util.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export declare function itf8Size(v: number): 1 | 2 | 3 | 4 | 5;
|
|
2
2
|
export declare function parseItf8(buffer: Uint8Array, initialOffset: number): readonly [number, number];
|
|
3
|
-
export declare function parseLtf8(buffer:
|
|
4
|
-
export declare function parseItem<T>(buffer:
|
|
3
|
+
export declare function parseLtf8(buffer: Uint8Array, initialOffset: number): readonly [number, number];
|
|
4
|
+
export declare function parseItem<T>(buffer: Uint8Array, parser: (buffer: Uint8Array, offset: number) => {
|
|
5
5
|
offset: number;
|
|
6
6
|
value: T;
|
|
7
7
|
}, startBufferPosition?: number, startFilePosition?: number): T & {
|
|
@@ -10,3 +10,5 @@ export declare function parseItem<T>(buffer: Buffer, parser: (buffer: Buffer, of
|
|
|
10
10
|
};
|
|
11
11
|
export declare function tinyMemoize(_class: any, methodName: any): void;
|
|
12
12
|
export declare function sequenceMD5(seq: string): string;
|
|
13
|
+
export declare function sum(array: Uint8Array[]): number;
|
|
14
|
+
export declare function concatUint8Array(args: Uint8Array[]): Uint8Array<ArrayBuffer>;
|
package/dist/cramFile/util.js
CHANGED
|
@@ -9,8 +9,10 @@ exports.parseLtf8 = parseLtf8;
|
|
|
9
9
|
exports.parseItem = parseItem;
|
|
10
10
|
exports.tinyMemoize = tinyMemoize;
|
|
11
11
|
exports.sequenceMD5 = sequenceMD5;
|
|
12
|
-
|
|
12
|
+
exports.sum = sum;
|
|
13
|
+
exports.concatUint8Array = concatUint8Array;
|
|
13
14
|
const long_1 = __importDefault(require("long"));
|
|
15
|
+
const md5_1 = __importDefault(require("md5"));
|
|
14
16
|
const getBits_1 = require("./codecs/getBits");
|
|
15
17
|
function itf8Size(v) {
|
|
16
18
|
if (!(v & ~0x7f)) {
|
|
@@ -71,6 +73,7 @@ function parseItf8(buffer, initialOffset) {
|
|
|
71
73
|
return [result, offset - initialOffset];
|
|
72
74
|
}
|
|
73
75
|
function parseLtf8(buffer, initialOffset) {
|
|
76
|
+
const dataView = new DataView(buffer.buffer);
|
|
74
77
|
let offset = initialOffset;
|
|
75
78
|
const countFlags = buffer[offset];
|
|
76
79
|
let n;
|
|
@@ -88,7 +91,7 @@ function parseLtf8(buffer, initialOffset) {
|
|
|
88
91
|
(buffer[offset + 1] << 8) |
|
|
89
92
|
buffer[offset + 2]) &
|
|
90
93
|
0x1fffff;
|
|
91
|
-
n = ((countFlags & 63) << 16) |
|
|
94
|
+
n = ((countFlags & 63) << 16) | dataView.getUint16(offset + 1, true);
|
|
92
95
|
offset += 3;
|
|
93
96
|
}
|
|
94
97
|
else if (countFlags < 0xf0) {
|
|
@@ -102,7 +105,7 @@ function parseLtf8(buffer, initialOffset) {
|
|
|
102
105
|
}
|
|
103
106
|
else if (countFlags < 0xf8) {
|
|
104
107
|
n =
|
|
105
|
-
((buffer[offset] & 15) *
|
|
108
|
+
((buffer[offset] & 15) * 2 ** 32 + (buffer[offset + 1] << 24)) |
|
|
106
109
|
((buffer[offset + 2] << 16) |
|
|
107
110
|
(buffer[offset + 3] << 8) |
|
|
108
111
|
buffer[offset + 4]);
|
|
@@ -111,7 +114,7 @@ function parseLtf8(buffer, initialOffset) {
|
|
|
111
114
|
}
|
|
112
115
|
else if (countFlags < 0xfc) {
|
|
113
116
|
n =
|
|
114
|
-
((((buffer[offset] & 7) << 8) | buffer[offset + 1]) *
|
|
117
|
+
((((buffer[offset] & 7) << 8) | buffer[offset + 1]) * 2 ** 32 +
|
|
115
118
|
(buffer[offset + 2] << 24)) |
|
|
116
119
|
((buffer[offset + 3] << 16) |
|
|
117
120
|
(buffer[offset + 4] << 8) |
|
|
@@ -123,7 +126,7 @@ function parseLtf8(buffer, initialOffset) {
|
|
|
123
126
|
((((buffer[offset] & 3) << 16) |
|
|
124
127
|
(buffer[offset + 1] << 8) |
|
|
125
128
|
buffer[offset + 2]) *
|
|
126
|
-
|
|
129
|
+
2 ** 32 +
|
|
127
130
|
(buffer[offset + 3] << 24)) |
|
|
128
131
|
((buffer[offset + 4] << 16) |
|
|
129
132
|
(buffer[offset + 5] << 8) |
|
|
@@ -152,7 +155,11 @@ function parseLtf8(buffer, initialOffset) {
|
|
|
152
155
|
}
|
|
153
156
|
function parseItem(buffer, parser, startBufferPosition = 0, startFilePosition = 0) {
|
|
154
157
|
const { offset, value } = parser(buffer, startBufferPosition);
|
|
155
|
-
return
|
|
158
|
+
return {
|
|
159
|
+
...value,
|
|
160
|
+
_endPosition: offset + startFilePosition,
|
|
161
|
+
_size: offset - startBufferPosition,
|
|
162
|
+
};
|
|
156
163
|
}
|
|
157
164
|
// this would be nice as a decorator, but i'm a little worried about babel
|
|
158
165
|
// support for it going away or changing. memoizes a method in the stupidest
|
|
@@ -175,4 +182,20 @@ function tinyMemoize(_class, methodName) {
|
|
|
175
182
|
function sequenceMD5(seq) {
|
|
176
183
|
return (0, md5_1.default)(seq.toUpperCase().replaceAll(/[^\u0021-\u007e]/g, ''));
|
|
177
184
|
}
|
|
185
|
+
function sum(array) {
|
|
186
|
+
let sum = 0;
|
|
187
|
+
for (const entry of array) {
|
|
188
|
+
sum += entry.length;
|
|
189
|
+
}
|
|
190
|
+
return sum;
|
|
191
|
+
}
|
|
192
|
+
function concatUint8Array(args) {
|
|
193
|
+
const mergedArray = new Uint8Array(sum(args));
|
|
194
|
+
let offset = 0;
|
|
195
|
+
for (const entry of args) {
|
|
196
|
+
mergedArray.set(entry, offset);
|
|
197
|
+
offset += entry.length;
|
|
198
|
+
}
|
|
199
|
+
return mergedArray;
|
|
200
|
+
}
|
|
178
201
|
//# sourceMappingURL=util.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/cramFile/util.ts"],"names":[],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/cramFile/util.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,26 +1,18 @@
|
|
|
1
1
|
export = RangeCoderGen;
|
|
2
2
|
declare class RangeCoderGen {
|
|
3
|
-
decode(src: any): any
|
|
3
|
+
decode(src: any): Uint8Array<any>;
|
|
4
4
|
stream: IOStream | undefined;
|
|
5
|
-
decodeStream(stream: any, n_out?: number): any
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
decodeExt(stream: any, n_out: any): any;
|
|
12
|
-
encodeExt(stream: any, n_out: any): void;
|
|
13
|
-
decodeRLE0(stream: any, n_out: any): any;
|
|
14
|
-
encodeRLE0(src: any, n_in: any, out: any): any;
|
|
15
|
-
decodeRLE1(stream: any, n_out: any): any;
|
|
16
|
-
encodeRLE1(src: any, n_in: any, out: any): any;
|
|
5
|
+
decodeStream(stream: any, n_out?: number): Uint8Array<any>;
|
|
6
|
+
decode0(stream: any, n_out: any): Uint8Array<any>;
|
|
7
|
+
decode1(stream: any, n_out: any): Uint8Array<any>;
|
|
8
|
+
decodeExt(stream: any, n_out: any): Uint8Array<ArrayBuffer>;
|
|
9
|
+
decodeRLE0(stream: any, n_out: any): Uint8Array<any>;
|
|
10
|
+
decodeRLE1(stream: any, n_out: any): Uint8Array<any>;
|
|
17
11
|
decodePackMeta(stream: any): any[];
|
|
18
12
|
nsym: any;
|
|
19
13
|
decodePack(data: any, M: any, len: any): any;
|
|
20
14
|
packMeta(src: any): (number | any[] | IOStream)[];
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
decodeStripe(stream: any, len: any): any;
|
|
24
|
-
decodeCat(stream: any, len: any): any;
|
|
15
|
+
decodeStripe(stream: any, len: any): Uint8Array<any>;
|
|
16
|
+
decodeCat(stream: any, len: any): Uint8Array<any>;
|
|
25
17
|
}
|
|
26
18
|
import IOStream = require("./iostream");
|
|
@@ -35,6 +35,22 @@ const RangeCoder = require('./arith_sh');
|
|
|
35
35
|
const IOStream = require('./iostream');
|
|
36
36
|
const ByteModel = require('./byte_model');
|
|
37
37
|
const bzip2 = require('bzip2');
|
|
38
|
+
function sum(array) {
|
|
39
|
+
let sum = 0;
|
|
40
|
+
for (const entry of array) {
|
|
41
|
+
sum += entry.length;
|
|
42
|
+
}
|
|
43
|
+
return sum;
|
|
44
|
+
}
|
|
45
|
+
function concatUint8Array(args) {
|
|
46
|
+
const mergedArray = new Uint8Array(sum(args));
|
|
47
|
+
let offset = 0;
|
|
48
|
+
for (const entry of args) {
|
|
49
|
+
mergedArray.set(entry, offset);
|
|
50
|
+
offset += entry.length;
|
|
51
|
+
}
|
|
52
|
+
return mergedArray;
|
|
53
|
+
}
|
|
38
54
|
const ARITH_ORDER = 1;
|
|
39
55
|
const ARITH_EXT = 4;
|
|
40
56
|
const ARITH_STRIPE = 8;
|
|
@@ -83,41 +99,10 @@ module.exports = class RangeCoderGen {
|
|
|
83
99
|
data = this.decodePack(data, P, n_out);
|
|
84
100
|
return data;
|
|
85
101
|
}
|
|
86
|
-
encode(src, flags) {
|
|
87
|
-
this.stream = new IOStream('', 0, src.length * 1.1 + 100); // guestimate worst case!
|
|
88
|
-
this.stream.WriteByte(flags);
|
|
89
|
-
if (!(flags & ARITH_NOSIZE))
|
|
90
|
-
this.stream.WriteUint7(src.length);
|
|
91
|
-
if (flags & ARITH_STRIPE)
|
|
92
|
-
return Buffer.concat([
|
|
93
|
-
this.stream.buf.slice(0, this.stream.pos),
|
|
94
|
-
this.encodeStripe(this.stream, src, flags >> 8),
|
|
95
|
-
]);
|
|
96
|
-
var order = flags & ARITH_ORDER;
|
|
97
|
-
var e_len = src.length;
|
|
98
|
-
// step 1: Encode meta-data
|
|
99
|
-
var pack_meta;
|
|
100
|
-
if (flags & ARITH_PACK)
|
|
101
|
-
[pack_meta, src, e_len] = this.encodePack(src);
|
|
102
|
-
// step 2: Write any meta data
|
|
103
|
-
if (flags & ARITH_PACK)
|
|
104
|
-
this.stream.WriteStream(pack_meta);
|
|
105
|
-
// step 3: arith encoding below
|
|
106
|
-
if (flags & ARITH_RLE) {
|
|
107
|
-
return order
|
|
108
|
-
? this.encodeRLE1(src, e_len, this.stream)
|
|
109
|
-
: this.encodeRLE0(src, e_len, this.stream);
|
|
110
|
-
}
|
|
111
|
-
else {
|
|
112
|
-
return order
|
|
113
|
-
? this.encode1(src, e_len, this.stream)
|
|
114
|
-
: this.encode0(src, e_len, this.stream);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
102
|
//----------------------------------------------------------------------
|
|
118
103
|
// Order-0 codec
|
|
119
104
|
decode0(stream, n_out) {
|
|
120
|
-
var output = new
|
|
105
|
+
var output = new Uint8Array(n_out);
|
|
121
106
|
var max_sym = stream.ReadByte();
|
|
122
107
|
if (max_sym == 0)
|
|
123
108
|
max_sym = 256;
|
|
@@ -128,25 +113,10 @@ module.exports = class RangeCoderGen {
|
|
|
128
113
|
output[i] = byte_model.ModelDecode(stream, rc);
|
|
129
114
|
return output;
|
|
130
115
|
}
|
|
131
|
-
encode0(src, n_in, out) {
|
|
132
|
-
// Count the maximum symbol present
|
|
133
|
-
var max_sym = 0;
|
|
134
|
-
for (var i = 0; i < n_in; i++)
|
|
135
|
-
if (max_sym < src[i])
|
|
136
|
-
max_sym = src[i];
|
|
137
|
-
max_sym++; // FIXME not what spec states!?
|
|
138
|
-
var byte_model = new ByteModel(max_sym);
|
|
139
|
-
out.WriteByte(max_sym);
|
|
140
|
-
var rc = new RangeCoder(out);
|
|
141
|
-
for (var i = 0; i < n_in; i++)
|
|
142
|
-
byte_model.ModelEncode(out, rc, src[i]);
|
|
143
|
-
rc.RangeFinishEncode(out);
|
|
144
|
-
return out.buf.slice(0, out.pos);
|
|
145
|
-
}
|
|
146
116
|
//----------------------------------------------------------------------
|
|
147
117
|
// Order-1 codec
|
|
148
118
|
decode1(stream, n_out) {
|
|
149
|
-
var output = new
|
|
119
|
+
var output = new Uint8Array(n_out);
|
|
150
120
|
var max_sym = stream.ReadByte();
|
|
151
121
|
if (max_sym == 0)
|
|
152
122
|
max_sym = 256;
|
|
@@ -162,53 +132,26 @@ module.exports = class RangeCoderGen {
|
|
|
162
132
|
}
|
|
163
133
|
return output;
|
|
164
134
|
}
|
|
165
|
-
encode1(src, n_in, out) {
|
|
166
|
-
// Count the maximum symbol present
|
|
167
|
-
var max_sym = 0;
|
|
168
|
-
for (var i = 0; i < n_in; i++)
|
|
169
|
-
if (max_sym < src[i])
|
|
170
|
-
max_sym = src[i];
|
|
171
|
-
max_sym++; // FIXME not what spec states!
|
|
172
|
-
var byte_model = new Array(max_sym);
|
|
173
|
-
for (var i = 0; i < max_sym; i++)
|
|
174
|
-
byte_model[i] = new ByteModel(max_sym);
|
|
175
|
-
out.WriteByte(max_sym);
|
|
176
|
-
var rc = new RangeCoder(out);
|
|
177
|
-
var last = 0;
|
|
178
|
-
for (var i = 0; i < n_in; i++) {
|
|
179
|
-
byte_model[last].ModelEncode(out, rc, src[i]);
|
|
180
|
-
last = src[i];
|
|
181
|
-
}
|
|
182
|
-
rc.RangeFinishEncode(out);
|
|
183
|
-
return out.buf.slice(0, out.pos);
|
|
184
|
-
}
|
|
185
135
|
//----------------------------------------------------------------------
|
|
186
136
|
// External codec
|
|
187
137
|
decodeExt(stream, n_out) {
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
var j = 0;
|
|
138
|
+
const bits = bzip2.array(stream.buf.slice(stream.pos));
|
|
139
|
+
let size = bzip2.header(bits);
|
|
140
|
+
let chunk;
|
|
141
|
+
const chunks = [];
|
|
193
142
|
do {
|
|
194
|
-
|
|
195
|
-
if (chunk
|
|
196
|
-
|
|
197
|
-
j += chunk.length;
|
|
143
|
+
chunk = bzip2.decompress(bits, size);
|
|
144
|
+
if (chunk !== -1) {
|
|
145
|
+
chunks.push(chunk);
|
|
198
146
|
size -= chunk.length;
|
|
199
147
|
}
|
|
200
|
-
} while (chunk
|
|
201
|
-
return
|
|
202
|
-
}
|
|
203
|
-
encodeExt(stream, n_out) {
|
|
204
|
-
// We cannot compress using Bzip2 now as it's
|
|
205
|
-
// absent from bzip2.js, but consider using
|
|
206
|
-
// https://github.com/cscott/compressjs
|
|
148
|
+
} while (chunk !== -1);
|
|
149
|
+
return concatUint8Array(chunks);
|
|
207
150
|
}
|
|
208
151
|
//----------------------------------------------------------------------
|
|
209
152
|
// Order-0 RLE codec
|
|
210
153
|
decodeRLE0(stream, n_out) {
|
|
211
|
-
var output = new
|
|
154
|
+
var output = new Uint8Array(n_out);
|
|
212
155
|
var max_sym = stream.ReadByte();
|
|
213
156
|
if (max_sym == 0)
|
|
214
157
|
max_sym = 256;
|
|
@@ -235,47 +178,10 @@ module.exports = class RangeCoderGen {
|
|
|
235
178
|
}
|
|
236
179
|
return output;
|
|
237
180
|
}
|
|
238
|
-
encodeRLE0(src, n_in, out) {
|
|
239
|
-
// Count the maximum symbol present
|
|
240
|
-
var max_sym = 0;
|
|
241
|
-
for (var i = 0; i < n_in; i++)
|
|
242
|
-
if (max_sym < src[i])
|
|
243
|
-
max_sym = src[i];
|
|
244
|
-
max_sym++; // FIXME not what spec states!
|
|
245
|
-
var model_lit = new ByteModel(max_sym);
|
|
246
|
-
var model_run = new Array(258);
|
|
247
|
-
for (var i = 0; i <= 257; i++)
|
|
248
|
-
model_run[i] = new ByteModel(4);
|
|
249
|
-
out.WriteByte(max_sym);
|
|
250
|
-
var rc = new RangeCoder(out);
|
|
251
|
-
var i = 0;
|
|
252
|
-
while (i < n_in) {
|
|
253
|
-
model_lit.ModelEncode(out, rc, src[i]);
|
|
254
|
-
var run = 1;
|
|
255
|
-
while (i + run < n_in && src[i + run] == src[i])
|
|
256
|
-
run++;
|
|
257
|
-
run--;
|
|
258
|
-
var rctx = src[i];
|
|
259
|
-
var last = src[i];
|
|
260
|
-
i += run + 1;
|
|
261
|
-
var part = run >= 3 ? 3 : run;
|
|
262
|
-
model_run[rctx].ModelEncode(out, rc, part);
|
|
263
|
-
run -= part;
|
|
264
|
-
rctx = 256;
|
|
265
|
-
while (part == 3) {
|
|
266
|
-
part = run >= 3 ? 3 : run;
|
|
267
|
-
model_run[rctx].ModelEncode(out, rc, part);
|
|
268
|
-
rctx = 257;
|
|
269
|
-
run -= part;
|
|
270
|
-
}
|
|
271
|
-
}
|
|
272
|
-
rc.RangeFinishEncode(out);
|
|
273
|
-
return out.buf.slice(0, out.pos);
|
|
274
|
-
}
|
|
275
181
|
//----------------------------------------------------------------------
|
|
276
182
|
// Order-1 RLE codec
|
|
277
183
|
decodeRLE1(stream, n_out) {
|
|
278
|
-
var output = new
|
|
184
|
+
var output = new Uint8Array(n_out);
|
|
279
185
|
var max_sym = stream.ReadByte();
|
|
280
186
|
if (max_sym == 0)
|
|
281
187
|
max_sym = 256;
|
|
@@ -306,46 +212,6 @@ module.exports = class RangeCoderGen {
|
|
|
306
212
|
}
|
|
307
213
|
return output;
|
|
308
214
|
}
|
|
309
|
-
encodeRLE1(src, n_in, out) {
|
|
310
|
-
// Count the maximum symbol present
|
|
311
|
-
var max_sym = 0;
|
|
312
|
-
for (var i = 0; i < n_in; i++)
|
|
313
|
-
if (max_sym < src[i])
|
|
314
|
-
max_sym = src[i];
|
|
315
|
-
max_sym++; // FIXME not what spec states!
|
|
316
|
-
var model_lit = new Array(max_sym);
|
|
317
|
-
for (var i = 0; i < max_sym; i++)
|
|
318
|
-
model_lit[i] = new ByteModel(max_sym);
|
|
319
|
-
var model_run = new Array(258);
|
|
320
|
-
for (var i = 0; i <= 257; i++)
|
|
321
|
-
model_run[i] = new ByteModel(4);
|
|
322
|
-
out.WriteByte(max_sym);
|
|
323
|
-
var rc = new RangeCoder(out);
|
|
324
|
-
var i = 0;
|
|
325
|
-
var last = 0;
|
|
326
|
-
while (i < n_in) {
|
|
327
|
-
model_lit[last].ModelEncode(out, rc, src[i]);
|
|
328
|
-
var run = 1;
|
|
329
|
-
while (i + run < n_in && src[i + run] == src[i])
|
|
330
|
-
run++;
|
|
331
|
-
run--;
|
|
332
|
-
var rctx = src[i];
|
|
333
|
-
last = src[i];
|
|
334
|
-
i += run + 1;
|
|
335
|
-
var part = run >= 3 ? 3 : run;
|
|
336
|
-
model_run[rctx].ModelEncode(out, rc, part);
|
|
337
|
-
run -= part;
|
|
338
|
-
rctx = 256;
|
|
339
|
-
while (part == 3) {
|
|
340
|
-
part = run >= 3 ? 3 : run;
|
|
341
|
-
model_run[rctx].ModelEncode(out, rc, part);
|
|
342
|
-
rctx = 257;
|
|
343
|
-
run -= part;
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
|
-
rc.RangeFinishEncode(out);
|
|
347
|
-
return out.buf.slice(0, out.pos);
|
|
348
|
-
}
|
|
349
215
|
//----------------------------------------------------------------------
|
|
350
216
|
// Pack method
|
|
351
217
|
decodePackMeta(stream) {
|
|
@@ -357,7 +223,7 @@ module.exports = class RangeCoderGen {
|
|
|
357
223
|
return [M, e_len];
|
|
358
224
|
}
|
|
359
225
|
decodePack(data, M, len) {
|
|
360
|
-
var out = new
|
|
226
|
+
var out = new Uint8Array(len);
|
|
361
227
|
if (this.nsym <= 1) {
|
|
362
228
|
// Constant value
|
|
363
229
|
for (var i = 0; i < len; i++)
|
|
@@ -418,112 +284,6 @@ module.exports = class RangeCoderGen {
|
|
|
418
284
|
}
|
|
419
285
|
return [stream, M, nsym];
|
|
420
286
|
}
|
|
421
|
-
encodePack(data) {
|
|
422
|
-
var meta, M, nsym;
|
|
423
|
-
[meta, M, nsym] = this.packMeta(data);
|
|
424
|
-
var len = data.length;
|
|
425
|
-
var i = 0;
|
|
426
|
-
if (nsym <= 1) {
|
|
427
|
-
// Constant values
|
|
428
|
-
meta.WriteUint7(0);
|
|
429
|
-
return [meta, new Buffer.allocUnsafe(0), 0];
|
|
430
|
-
}
|
|
431
|
-
if (nsym <= 2) {
|
|
432
|
-
// 1 bit per value
|
|
433
|
-
var out = new Buffer.allocUnsafe(Math.floor((len + 7) / 8));
|
|
434
|
-
for (var i = 0, j = 0; i < (len & ~7); i += 8, j++)
|
|
435
|
-
out[j] =
|
|
436
|
-
(M[data[i + 0]] << 0) +
|
|
437
|
-
(M[data[i + 1]] << 1) +
|
|
438
|
-
(M[data[i + 2]] << 2) +
|
|
439
|
-
(M[data[i + 3]] << 3) +
|
|
440
|
-
(M[data[i + 4]] << 4) +
|
|
441
|
-
(M[data[i + 5]] << 5) +
|
|
442
|
-
(M[data[i + 6]] << 6) +
|
|
443
|
-
(M[data[i + 7]] << 7);
|
|
444
|
-
if (i < len) {
|
|
445
|
-
out[j] = 0;
|
|
446
|
-
var v = 0;
|
|
447
|
-
while (i < len) {
|
|
448
|
-
out[j] |= M[data[i++]] << v;
|
|
449
|
-
v++;
|
|
450
|
-
}
|
|
451
|
-
j++;
|
|
452
|
-
}
|
|
453
|
-
meta.WriteUint7(j);
|
|
454
|
-
return [meta, out, out.length];
|
|
455
|
-
}
|
|
456
|
-
if (nsym <= 4) {
|
|
457
|
-
// 2 bits per value
|
|
458
|
-
var out = new Buffer.allocUnsafe(Math.floor((len + 3) / 4));
|
|
459
|
-
for (var i = 0, j = 0; i < (len & ~3); i += 4, j++)
|
|
460
|
-
out[j] =
|
|
461
|
-
(M[data[i + 0]] << 0) +
|
|
462
|
-
(M[data[i + 1]] << 2) +
|
|
463
|
-
(M[data[i + 2]] << 4) +
|
|
464
|
-
(M[data[i + 3]] << 6);
|
|
465
|
-
if (i < len) {
|
|
466
|
-
out[j] = 0;
|
|
467
|
-
var v = 0;
|
|
468
|
-
while (i < len) {
|
|
469
|
-
out[j] |= M[data[i++]] << v;
|
|
470
|
-
v += 2;
|
|
471
|
-
}
|
|
472
|
-
j++;
|
|
473
|
-
}
|
|
474
|
-
meta.WriteUint7(j);
|
|
475
|
-
return [meta, out, out.length];
|
|
476
|
-
}
|
|
477
|
-
if (nsym <= 16) {
|
|
478
|
-
// 4 bits per value
|
|
479
|
-
var out = new Buffer.allocUnsafe(Math.floor((len + 1) / 2));
|
|
480
|
-
for (var i = 0, j = 0; i < (len & ~1); i += 2, j++)
|
|
481
|
-
out[j] = (M[data[i + 0]] << 0) + (M[data[i + 1]] << 4);
|
|
482
|
-
if (i < len)
|
|
483
|
-
out[j++] = M[data[i++]];
|
|
484
|
-
meta.WriteUint7(j);
|
|
485
|
-
return [meta, out, out.length];
|
|
486
|
-
}
|
|
487
|
-
// Otherwise an expensive NOP
|
|
488
|
-
meta.WriteUint7(data.length);
|
|
489
|
-
return [meta, data, data.length];
|
|
490
|
-
}
|
|
491
|
-
//----------------------------------------------------------------------
|
|
492
|
-
// STRIPE method
|
|
493
|
-
encodeStripe(hdr, src, N) {
|
|
494
|
-
if (N == 0)
|
|
495
|
-
N = 4; // old default
|
|
496
|
-
// Split into multiple streams
|
|
497
|
-
var part = new Array(N);
|
|
498
|
-
var ulen = new Array(N);
|
|
499
|
-
for (var s = 0; s < N; s++) {
|
|
500
|
-
ulen[s] = Math.floor(src.length / N) + (src.length % N > s);
|
|
501
|
-
part[s] = new Array(ulen[s]);
|
|
502
|
-
}
|
|
503
|
-
for (var x = 0, i = 0; i < src.length; i += N, x++) {
|
|
504
|
-
for (var j = 0; j < N; j++)
|
|
505
|
-
if (x < part[j].length)
|
|
506
|
-
part[j][x] = src[i + j];
|
|
507
|
-
}
|
|
508
|
-
// Compress each part
|
|
509
|
-
var comp = new Array(N);
|
|
510
|
-
var total = 0;
|
|
511
|
-
for (var s = 0; s < N; s++) {
|
|
512
|
-
// Example: try O0 and O1 and choose best
|
|
513
|
-
var comp0 = this.encode(part[s], 0);
|
|
514
|
-
var comp1 = this.encode(part[s], 1);
|
|
515
|
-
comp[s] = comp1.length < comp0.length ? comp1 : comp0;
|
|
516
|
-
total += comp[s].length;
|
|
517
|
-
}
|
|
518
|
-
// Serialise
|
|
519
|
-
var out = new IOStream('', 0, total + 5 * N + 1);
|
|
520
|
-
out.WriteByte(N);
|
|
521
|
-
for (var s = 0; s < N; s++)
|
|
522
|
-
out.WriteUint7(comp[s].length);
|
|
523
|
-
for (var s = 0; s < N; s++)
|
|
524
|
-
out.WriteData(comp[s], comp[s].length);
|
|
525
|
-
return out.buf.slice(0, out.buf.pos);
|
|
526
|
-
}
|
|
527
287
|
decodeStripe(stream, len) {
|
|
528
288
|
var N = stream.ReadByte();
|
|
529
289
|
// Retrieve lengths
|
|
@@ -538,7 +298,7 @@ module.exports = class RangeCoderGen {
|
|
|
538
298
|
T[j] = this.decodeStream(stream, ulen[j]);
|
|
539
299
|
}
|
|
540
300
|
// Transpose
|
|
541
|
-
var out = new
|
|
301
|
+
var out = new Uint8Array(len);
|
|
542
302
|
for (var j = 0; j < N; j++) {
|
|
543
303
|
for (var i = 0; i < ulen[j]; i++) {
|
|
544
304
|
out[i * N + j] = T[j][i];
|
|
@@ -549,7 +309,7 @@ module.exports = class RangeCoderGen {
|
|
|
549
309
|
//----------------------------------------------------------------------
|
|
550
310
|
// Cat method
|
|
551
311
|
decodeCat(stream, len) {
|
|
552
|
-
var out = new
|
|
312
|
+
var out = new Uint8Array(len);
|
|
553
313
|
for (var i = 0; i < len; i++)
|
|
554
314
|
out[i] = stream.ReadByte();
|
|
555
315
|
return out;
|