@gmod/cram 6.0.0 → 7.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 +2 -2
- package/dist/craiIndex.js.map +1 -1
- package/dist/cram-bundle.js +1 -1
- package/dist/cramFile/file.d.ts +2 -2
- package/dist/cramFile/file.js +9 -13
- package/dist/cramFile/file.js.map +1 -1
- package/dist/htscodecs/index.d.ts +1 -5
- package/dist/htscodecs/index.js +11 -72
- package/dist/htscodecs/index.js.map +1 -1
- package/dist/htscodecs-wasm.d.ts +7 -0
- package/dist/htscodecs-wasm.js +183 -0
- package/dist/htscodecs-wasm.js.map +1 -0
- package/dist/unzip.d.ts +1 -1
- package/dist/unzip.js +3 -3
- package/dist/unzip.js.map +1 -1
- package/dist/wasm/htscodecs.d.ts +5 -0
- package/dist/wasm/htscodecs.js +0 -0
- package/dist/wasm/htscodecs.js.map +1 -0
- package/esm/craiIndex.js +2 -2
- package/esm/craiIndex.js.map +1 -1
- package/esm/cramFile/file.d.ts +2 -2
- package/esm/cramFile/file.js +7 -11
- package/esm/cramFile/file.js.map +1 -1
- package/esm/htscodecs/index.d.ts +1 -5
- package/esm/htscodecs/index.js +3 -31
- package/esm/htscodecs/index.js.map +1 -1
- package/esm/htscodecs-wasm.d.ts +7 -0
- package/esm/htscodecs-wasm.js +171 -0
- package/esm/htscodecs-wasm.js.map +1 -0
- package/esm/unzip.d.ts +1 -1
- package/esm/unzip.js +3 -3
- package/esm/unzip.js.map +1 -1
- package/esm/wasm/htscodecs.d.ts +5 -0
- package/esm/wasm/htscodecs.js +0 -0
- package/esm/wasm/htscodecs.js.map +1 -0
- package/package.json +9 -9
- package/src/craiIndex.ts +4 -2
- package/src/cramFile/file.ts +7 -11
- package/src/htscodecs/index.ts +12 -38
- package/src/htscodecs-wasm.ts +210 -0
- package/src/unzip.ts +3 -3
- package/src/wasm/htscodecs.d.ts +58 -0
- package/src/wasm/htscodecs.js +0 -0
- package/dist/htscodecs/arith_gen.d.ts +0 -16
- package/dist/htscodecs/arith_gen.js +0 -323
- package/dist/htscodecs/arith_gen.js.map +0 -1
- package/dist/htscodecs/arith_sh.d.ts +0 -9
- package/dist/htscodecs/arith_sh.js +0 -134
- package/dist/htscodecs/arith_sh.js.map +0 -1
- package/dist/htscodecs/byte_model.d.ts +0 -6
- package/dist/htscodecs/byte_model.js +0 -121
- package/dist/htscodecs/byte_model.js.map +0 -1
- package/dist/htscodecs/fqzcomp.d.ts +0 -1
- package/dist/htscodecs/fqzcomp.js +0 -346
- package/dist/htscodecs/fqzcomp.js.map +0 -1
- package/dist/htscodecs/iostream.d.ts +0 -16
- package/dist/htscodecs/iostream.js +0 -148
- package/dist/htscodecs/iostream.js.map +0 -1
- package/dist/htscodecs/rans.d.ts +0 -1
- package/dist/htscodecs/rans.js +0 -224
- package/dist/htscodecs/rans.js.map +0 -1
- package/dist/htscodecs/rans4x16.d.ts +0 -1
- package/dist/htscodecs/rans4x16.js +0 -445
- package/dist/htscodecs/rans4x16.js.map +0 -1
- package/dist/htscodecs/tok3.d.ts +0 -1
- package/dist/htscodecs/tok3.js +0 -206
- package/dist/htscodecs/tok3.js.map +0 -1
- package/dist/rans/constants.d.ts +0 -4
- package/dist/rans/constants.js +0 -10
- package/dist/rans/constants.js.map +0 -1
- package/dist/rans/d04.d.ts +0 -1
- package/dist/rans/d04.js +0 -100
- package/dist/rans/d04.js.map +0 -1
- package/dist/rans/d14.d.ts +0 -1
- package/dist/rans/d14.js +0 -96
- package/dist/rans/d14.js.map +0 -1
- package/dist/rans/decoding.d.ts +0 -27
- package/dist/rans/decoding.js +0 -119
- package/dist/rans/decoding.js.map +0 -1
- package/dist/rans/frequencies.d.ts +0 -2
- package/dist/rans/frequencies.js +0 -112
- package/dist/rans/frequencies.js.map +0 -1
- package/dist/rans/index.d.ts +0 -1
- package/dist/rans/index.js +0 -198
- package/dist/rans/index.js.map +0 -1
- package/dist/seek-bzip/bitreader.d.ts +0 -27
- package/dist/seek-bzip/bitreader.js +0 -101
- package/dist/seek-bzip/bitreader.js.map +0 -1
- package/dist/seek-bzip/crc32.d.ts +0 -26
- package/dist/seek-bzip/crc32.js +0 -115
- package/dist/seek-bzip/crc32.js.map +0 -1
- package/dist/seek-bzip/index.d.ts +0 -9
- package/dist/seek-bzip/index.js +0 -585
- package/dist/seek-bzip/index.js.map +0 -1
- package/dist/seek-bzip/stream.d.ts +0 -8
- package/dist/seek-bzip/stream.js +0 -37
- package/dist/seek-bzip/stream.js.map +0 -1
- package/dist/seek-bzip/toHex.d.ts +0 -1
- package/dist/seek-bzip/toHex.js +0 -36
- package/dist/seek-bzip/toHex.js.map +0 -1
- package/esm/htscodecs/arith_gen.d.ts +0 -16
- package/esm/htscodecs/arith_gen.js +0 -317
- package/esm/htscodecs/arith_gen.js.map +0 -1
- package/esm/htscodecs/arith_sh.d.ts +0 -9
- package/esm/htscodecs/arith_sh.js +0 -131
- package/esm/htscodecs/arith_sh.js.map +0 -1
- package/esm/htscodecs/byte_model.d.ts +0 -6
- package/esm/htscodecs/byte_model.js +0 -118
- package/esm/htscodecs/byte_model.js.map +0 -1
- package/esm/htscodecs/fqzcomp.d.ts +0 -1
- package/esm/htscodecs/fqzcomp.js +0 -340
- package/esm/htscodecs/fqzcomp.js.map +0 -1
- package/esm/htscodecs/iostream.d.ts +0 -16
- package/esm/htscodecs/iostream.js +0 -145
- package/esm/htscodecs/iostream.js.map +0 -1
- package/esm/htscodecs/rans.d.ts +0 -1
- package/esm/htscodecs/rans.js +0 -218
- package/esm/htscodecs/rans.js.map +0 -1
- package/esm/htscodecs/rans4x16.d.ts +0 -1
- package/esm/htscodecs/rans4x16.js +0 -439
- package/esm/htscodecs/rans4x16.js.map +0 -1
- package/esm/htscodecs/tok3.d.ts +0 -1
- package/esm/htscodecs/tok3.js +0 -167
- package/esm/htscodecs/tok3.js.map +0 -1
- package/esm/rans/constants.d.ts +0 -4
- package/esm/rans/constants.js +0 -5
- package/esm/rans/constants.js.map +0 -1
- package/esm/rans/d04.d.ts +0 -1
- package/esm/rans/d04.js +0 -94
- package/esm/rans/d04.js.map +0 -1
- package/esm/rans/d14.d.ts +0 -1
- package/esm/rans/d14.js +0 -93
- package/esm/rans/d14.js.map +0 -1
- package/esm/rans/decoding.d.ts +0 -27
- package/esm/rans/decoding.js +0 -117
- package/esm/rans/decoding.js.map +0 -1
- package/esm/rans/frequencies.d.ts +0 -2
- package/esm/rans/frequencies.js +0 -105
- package/esm/rans/frequencies.js.map +0 -1
- package/esm/rans/index.d.ts +0 -1
- package/esm/rans/index.js +0 -192
- package/esm/rans/index.js.map +0 -1
- package/esm/seek-bzip/bitreader.d.ts +0 -27
- package/esm/seek-bzip/bitreader.js +0 -98
- package/esm/seek-bzip/bitreader.js.map +0 -1
- package/esm/seek-bzip/crc32.d.ts +0 -26
- package/esm/seek-bzip/crc32.js +0 -112
- package/esm/seek-bzip/crc32.js.map +0 -1
- package/esm/seek-bzip/index.d.ts +0 -9
- package/esm/seek-bzip/index.js +0 -579
- package/esm/seek-bzip/index.js.map +0 -1
- package/esm/seek-bzip/stream.d.ts +0 -8
- package/esm/seek-bzip/stream.js +0 -34
- package/esm/seek-bzip/stream.js.map +0 -1
- package/esm/seek-bzip/toHex.d.ts +0 -1
- package/esm/seek-bzip/toHex.js +0 -33
- package/esm/seek-bzip/toHex.js.map +0 -1
- package/src/htscodecs/arith_gen.ts +0 -371
- package/src/htscodecs/arith_sh.ts +0 -146
- package/src/htscodecs/byte_model.ts +0 -136
- package/src/htscodecs/fqzcomp.ts +0 -394
- package/src/htscodecs/iostream.ts +0 -159
- package/src/htscodecs/rans.ts +0 -250
- package/src/htscodecs/rans4x16.ts +0 -521
- package/src/htscodecs/tok3.ts +0 -197
- package/src/rans/README.md +0 -1
- package/src/rans/constants.ts +0 -5
- package/src/rans/d04.ts +0 -112
- package/src/rans/d14.ts +0 -106
- package/src/rans/decoding.ts +0 -138
- package/src/rans/frequencies.ts +0 -115
- package/src/rans/index.ts +0 -245
- package/src/seek-bzip/README.md +0 -6
- package/src/seek-bzip/bitreader.ts +0 -113
- package/src/seek-bzip/crc32.ts +0 -121
- package/src/seek-bzip/index.ts +0 -615
- package/src/seek-bzip/stream.ts +0 -33
- package/src/seek-bzip/toHex.ts +0 -33
package/dist/cramFile/file.d.ts
CHANGED
|
@@ -72,7 +72,7 @@ export default class CramFile {
|
|
|
72
72
|
_endPosition: number;
|
|
73
73
|
_size: number;
|
|
74
74
|
}>;
|
|
75
|
-
_uncompressPre(compressionMethod: CompressionMethod, inputBuffer: Uint8Array, uncompressedSize: number): Promise<
|
|
76
|
-
_uncompress(compressionMethod: CompressionMethod, inputBuffer: Uint8Array, uncompressedSize: number): Promise<
|
|
75
|
+
_uncompressPre(compressionMethod: CompressionMethod, inputBuffer: Uint8Array, uncompressedSize: number): Promise<Uint8Array<ArrayBufferLike>>;
|
|
76
|
+
_uncompress(compressionMethod: CompressionMethod, inputBuffer: Uint8Array, uncompressedSize: number): Promise<Uint8Array<ArrayBufferLike>>;
|
|
77
77
|
readBlock(position: number): Promise<CramFileBlock>;
|
|
78
78
|
}
|
package/dist/cramFile/file.js
CHANGED
|
@@ -41,12 +41,10 @@ const quick_lru_1 = __importDefault(require("quick-lru"));
|
|
|
41
41
|
const errors_ts_1 = require("../errors.js");
|
|
42
42
|
const htscodecs = __importStar(require("../htscodecs/index.js"));
|
|
43
43
|
const io_ts_1 = require("../io.js");
|
|
44
|
-
const index_ts_1 = __importDefault(require("../rans/index.js"));
|
|
45
44
|
const sam_ts_1 = require("../sam.js");
|
|
46
45
|
const util_ts_1 = require("./util.js");
|
|
47
|
-
const index_ts_2 = require("../seek-bzip/index.js");
|
|
48
46
|
const unzip_ts_1 = require("../unzip.js");
|
|
49
|
-
const
|
|
47
|
+
const index_ts_1 = __importDefault(require("./container/index.js"));
|
|
50
48
|
const sectionParsers_ts_1 = require("./sectionParsers.js");
|
|
51
49
|
const xz_decompress_ts_1 = require("../xz-decompress/xz-decompress.js");
|
|
52
50
|
// source: https://abdulapopoola.com/2019/01/20/check-endianness-with-javascript/
|
|
@@ -206,7 +204,7 @@ class CramFile {
|
|
|
206
204
|
return containerCount;
|
|
207
205
|
}
|
|
208
206
|
getContainerAtPosition(position) {
|
|
209
|
-
return new
|
|
207
|
+
return new index_ts_1.default(this, position);
|
|
210
208
|
}
|
|
211
209
|
async readBlockHeader(position) {
|
|
212
210
|
if (!this._sectionParsers) {
|
|
@@ -228,30 +226,28 @@ class CramFile {
|
|
|
228
226
|
async _uncompressPre(compressionMethod, inputBuffer, uncompressedSize) {
|
|
229
227
|
// console.log({ compressionMethod })
|
|
230
228
|
if (compressionMethod === 'gzip') {
|
|
231
|
-
return (0, unzip_ts_1.unzip)(inputBuffer);
|
|
229
|
+
return await (0, unzip_ts_1.unzip)(inputBuffer);
|
|
232
230
|
}
|
|
233
231
|
else if (compressionMethod === 'bzip2') {
|
|
234
|
-
return
|
|
232
|
+
return await htscodecs.bz2_uncompress(inputBuffer, uncompressedSize);
|
|
235
233
|
}
|
|
236
234
|
else if (compressionMethod === 'lzma') {
|
|
237
235
|
return (0, xz_decompress_ts_1.xzDecompress)(inputBuffer);
|
|
238
236
|
}
|
|
239
237
|
else if (compressionMethod === 'rans') {
|
|
240
|
-
|
|
241
|
-
(0, index_ts_1.default)(inputBuffer, outputBuffer);
|
|
242
|
-
return outputBuffer;
|
|
238
|
+
return await htscodecs.rans_uncompress(inputBuffer);
|
|
243
239
|
}
|
|
244
240
|
else if (compressionMethod === 'rans4x16') {
|
|
245
|
-
return htscodecs.r4x16_uncompress(inputBuffer);
|
|
241
|
+
return await htscodecs.r4x16_uncompress(inputBuffer);
|
|
246
242
|
}
|
|
247
243
|
else if (compressionMethod === 'arith') {
|
|
248
|
-
return htscodecs.arith_uncompress(inputBuffer);
|
|
244
|
+
return await htscodecs.arith_uncompress(inputBuffer);
|
|
249
245
|
}
|
|
250
246
|
else if (compressionMethod === 'fqzcomp') {
|
|
251
|
-
return htscodecs.fqzcomp_uncompress(inputBuffer);
|
|
247
|
+
return await htscodecs.fqzcomp_uncompress(inputBuffer);
|
|
252
248
|
}
|
|
253
249
|
else if (compressionMethod === 'tok3') {
|
|
254
|
-
return htscodecs.tok3_uncompress(inputBuffer);
|
|
250
|
+
return await htscodecs.tok3_uncompress(inputBuffer);
|
|
255
251
|
}
|
|
256
252
|
else {
|
|
257
253
|
throw new errors_ts_1.CramUnimplementedError(`${compressionMethod} decompression not yet implemented`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"file.js","sourceRoot":"","sources":["../../src/cramFile/file.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,kEAAyC;AACzC,0DAAgC;AAEhC,4CAAyE;AACzE,iEAAkD;AAClD,oCAA+B;AAC/B,
|
|
1
|
+
{"version":3,"file":"file.js","sourceRoot":"","sources":["../../src/cramFile/file.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1 @@
|
|
|
1
|
-
export
|
|
2
|
-
export declare function r4x16_uncompress(inputBuffer: Uint8Array): any;
|
|
3
|
-
export declare function arith_uncompress(inputBuffer: Uint8Array): Uint8Array<any>;
|
|
4
|
-
export declare function fqzcomp_uncompress(inputBuffer: Uint8Array): Uint8Array<ArrayBuffer> | undefined;
|
|
5
|
-
export declare function tok3_uncompress(inputBuffer: Uint8Array): Uint8Array<ArrayBuffer>;
|
|
1
|
+
export { rans_uncompress, rans_uncompress as r4x8_uncompress, r4x16_uncompress, arith_uncompress, fqzcomp_uncompress, tok3_uncompress, bz2_uncompress, } from '../htscodecs-wasm.ts';
|
package/dist/htscodecs/index.js
CHANGED
|
@@ -1,6 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
// @ts-nocheck
|
|
3
|
-
//
|
|
4
2
|
/*
|
|
5
3
|
* Copyright (c) 2020 Genome Research Ltd.
|
|
6
4
|
* Author(s): James Bonfield
|
|
@@ -33,75 +31,16 @@
|
|
|
33
31
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
34
32
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
35
33
|
*/
|
|
36
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
37
|
-
if (k2 === undefined) k2 = k;
|
|
38
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
39
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
40
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
41
|
-
}
|
|
42
|
-
Object.defineProperty(o, k2, desc);
|
|
43
|
-
}) : (function(o, m, k, k2) {
|
|
44
|
-
if (k2 === undefined) k2 = k;
|
|
45
|
-
o[k2] = m[k];
|
|
46
|
-
}));
|
|
47
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
48
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
49
|
-
}) : function(o, v) {
|
|
50
|
-
o["default"] = v;
|
|
51
|
-
});
|
|
52
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
53
|
-
var ownKeys = function(o) {
|
|
54
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
55
|
-
var ar = [];
|
|
56
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
57
|
-
return ar;
|
|
58
|
-
};
|
|
59
|
-
return ownKeys(o);
|
|
60
|
-
};
|
|
61
|
-
return function (mod) {
|
|
62
|
-
if (mod && mod.__esModule) return mod;
|
|
63
|
-
var result = {};
|
|
64
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
65
|
-
__setModuleDefault(result, mod);
|
|
66
|
-
return result;
|
|
67
|
-
};
|
|
68
|
-
})();
|
|
69
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
70
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
71
|
-
};
|
|
72
34
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
73
|
-
exports.r4x8_uncompress =
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
exports.
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
const r4x8 = __importStar(require("./rans.js"));
|
|
85
|
-
const r4x16 = __importStar(require("./rans4x16.js"));
|
|
86
|
-
const tok3 = __importStar(require("./tok3.js"));
|
|
87
|
-
function r4x8_uncompress(inputBuffer) {
|
|
88
|
-
return r4x8.decode(inputBuffer);
|
|
89
|
-
}
|
|
90
|
-
function r4x16_uncompress(inputBuffer) {
|
|
91
|
-
return r4x16.decode(inputBuffer);
|
|
92
|
-
}
|
|
93
|
-
function arith_uncompress(inputBuffer) {
|
|
94
|
-
// fix by @cmdcolin for CRAM 3.1
|
|
95
|
-
// xref https://github.com/jkbonfield/htscodecs/pull/1/files
|
|
96
|
-
return new arith_gen_ts_1.default().decode(inputBuffer);
|
|
97
|
-
}
|
|
98
|
-
function fqzcomp_uncompress(inputBuffer) {
|
|
99
|
-
const q_lens = [];
|
|
100
|
-
return fqzcomp.decode(inputBuffer, q_lens);
|
|
101
|
-
}
|
|
102
|
-
function tok3_uncompress(inputBuffer) {
|
|
103
|
-
// Returns in string form instead of buffer
|
|
104
|
-
const out = tok3.decode(inputBuffer, 0, '\0');
|
|
105
|
-
return Uint8Array.from(Array.from(out).map(letter => letter.charCodeAt(0)));
|
|
106
|
-
}
|
|
35
|
+
exports.bz2_uncompress = exports.tok3_uncompress = exports.fqzcomp_uncompress = exports.arith_uncompress = exports.r4x16_uncompress = exports.r4x8_uncompress = exports.rans_uncompress = void 0;
|
|
36
|
+
// This is an interface to the htscodecs library compiled to WASM.
|
|
37
|
+
// The WASM module is built from the official samtools/htscodecs C library.
|
|
38
|
+
var htscodecs_wasm_ts_1 = require("../htscodecs-wasm.js");
|
|
39
|
+
Object.defineProperty(exports, "rans_uncompress", { enumerable: true, get: function () { return htscodecs_wasm_ts_1.rans_uncompress; } });
|
|
40
|
+
Object.defineProperty(exports, "r4x8_uncompress", { enumerable: true, get: function () { return htscodecs_wasm_ts_1.rans_uncompress; } });
|
|
41
|
+
Object.defineProperty(exports, "r4x16_uncompress", { enumerable: true, get: function () { return htscodecs_wasm_ts_1.r4x16_uncompress; } });
|
|
42
|
+
Object.defineProperty(exports, "arith_uncompress", { enumerable: true, get: function () { return htscodecs_wasm_ts_1.arith_uncompress; } });
|
|
43
|
+
Object.defineProperty(exports, "fqzcomp_uncompress", { enumerable: true, get: function () { return htscodecs_wasm_ts_1.fqzcomp_uncompress; } });
|
|
44
|
+
Object.defineProperty(exports, "tok3_uncompress", { enumerable: true, get: function () { return htscodecs_wasm_ts_1.tok3_uncompress; } });
|
|
45
|
+
Object.defineProperty(exports, "bz2_uncompress", { enumerable: true, get: function () { return htscodecs_wasm_ts_1.bz2_uncompress; } });
|
|
107
46
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/htscodecs/index.ts"],"names":[],"mappings":";AAAA
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/htscodecs/index.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+BG;;;AAEH,kEAAkE;AAClE,2EAA2E;AAE3E,0DAQ6B;AAP3B,oHAAA,eAAe,OAAA;AACf,oHAAA,eAAe,OAAmB;AAClC,qHAAA,gBAAgB,OAAA;AAChB,qHAAA,gBAAgB,OAAA;AAChB,uHAAA,kBAAkB,OAAA;AAClB,oHAAA,eAAe,OAAA;AACf,mHAAA,cAAc,OAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export declare function rans_uncompress(input: Uint8Array): Promise<Uint8Array<ArrayBuffer>>;
|
|
2
|
+
export declare function r4x16_uncompress(input: Uint8Array): Promise<Uint8Array<ArrayBuffer>>;
|
|
3
|
+
export declare function arith_uncompress(input: Uint8Array): Promise<Uint8Array<ArrayBuffer>>;
|
|
4
|
+
export declare function fqzcomp_uncompress(input: Uint8Array): Promise<Uint8Array<ArrayBuffer>>;
|
|
5
|
+
export declare function zlib_uncompress(input: Uint8Array): Promise<Uint8Array<ArrayBuffer>>;
|
|
6
|
+
export declare function bz2_uncompress(input: Uint8Array, expectedSize: number): Promise<Uint8Array<ArrayBuffer>>;
|
|
7
|
+
export declare function tok3_uncompress(input: Uint8Array): Promise<Uint8Array<ArrayBuffer>>;
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.rans_uncompress = rans_uncompress;
|
|
7
|
+
exports.r4x16_uncompress = r4x16_uncompress;
|
|
8
|
+
exports.arith_uncompress = arith_uncompress;
|
|
9
|
+
exports.fqzcomp_uncompress = fqzcomp_uncompress;
|
|
10
|
+
exports.zlib_uncompress = zlib_uncompress;
|
|
11
|
+
exports.bz2_uncompress = bz2_uncompress;
|
|
12
|
+
exports.tok3_uncompress = tok3_uncompress;
|
|
13
|
+
const htscodecs_js_1 = __importDefault(require("./wasm/htscodecs.js"));
|
|
14
|
+
let moduleInstance = null;
|
|
15
|
+
let modulePromise = null;
|
|
16
|
+
async function getModule() {
|
|
17
|
+
if (moduleInstance) {
|
|
18
|
+
return moduleInstance;
|
|
19
|
+
}
|
|
20
|
+
if (!modulePromise) {
|
|
21
|
+
modulePromise = (0, htscodecs_js_1.default)().then(m => {
|
|
22
|
+
moduleInstance = m;
|
|
23
|
+
return m;
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
return modulePromise;
|
|
27
|
+
}
|
|
28
|
+
function copyToWasm(module, data) {
|
|
29
|
+
const ptr = module._malloc(data.length);
|
|
30
|
+
module.HEAPU8.set(data, ptr);
|
|
31
|
+
return ptr;
|
|
32
|
+
}
|
|
33
|
+
function copyFromWasm(module, ptr, size) {
|
|
34
|
+
const result = new Uint8Array(size);
|
|
35
|
+
result.set(module.HEAPU8.subarray(ptr, ptr + size));
|
|
36
|
+
return result;
|
|
37
|
+
}
|
|
38
|
+
async function rans_uncompress(input) {
|
|
39
|
+
// Handle empty input - C implementation returns NULL for in_size < 9
|
|
40
|
+
if (input.length === 0) {
|
|
41
|
+
return new Uint8Array(0);
|
|
42
|
+
}
|
|
43
|
+
const module = await getModule();
|
|
44
|
+
const inPtr = copyToWasm(module, input);
|
|
45
|
+
const outSizePtr = module._malloc(4);
|
|
46
|
+
try {
|
|
47
|
+
const outPtr = module._rans_uncompress(inPtr, input.length, outSizePtr);
|
|
48
|
+
if (outPtr === 0) {
|
|
49
|
+
throw new Error('rans_uncompress failed');
|
|
50
|
+
}
|
|
51
|
+
const outSize = module.getValue(outSizePtr, 'i32');
|
|
52
|
+
const result = copyFromWasm(module, outPtr, outSize);
|
|
53
|
+
module._free(outPtr);
|
|
54
|
+
return result;
|
|
55
|
+
}
|
|
56
|
+
finally {
|
|
57
|
+
module._free(inPtr);
|
|
58
|
+
module._free(outSizePtr);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
async function r4x16_uncompress(input) {
|
|
62
|
+
const module = await getModule();
|
|
63
|
+
const inPtr = copyToWasm(module, input);
|
|
64
|
+
const outSizePtr = module._malloc(4);
|
|
65
|
+
try {
|
|
66
|
+
const outPtr = module._rans_uncompress_4x16(inPtr, input.length, outSizePtr);
|
|
67
|
+
if (outPtr === 0) {
|
|
68
|
+
throw new Error('rans_uncompress_4x16 failed');
|
|
69
|
+
}
|
|
70
|
+
const outSize = module.getValue(outSizePtr, 'i32');
|
|
71
|
+
const result = copyFromWasm(module, outPtr, outSize);
|
|
72
|
+
module._free(outPtr);
|
|
73
|
+
return result;
|
|
74
|
+
}
|
|
75
|
+
finally {
|
|
76
|
+
module._free(inPtr);
|
|
77
|
+
module._free(outSizePtr);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
async function arith_uncompress(input) {
|
|
81
|
+
const module = await getModule();
|
|
82
|
+
const inPtr = copyToWasm(module, input);
|
|
83
|
+
const outSizePtr = module._malloc(4);
|
|
84
|
+
try {
|
|
85
|
+
const outPtr = module._arith_uncompress(inPtr, input.length, outSizePtr);
|
|
86
|
+
if (outPtr === 0) {
|
|
87
|
+
throw new Error('arith_uncompress failed');
|
|
88
|
+
}
|
|
89
|
+
const outSize = module.getValue(outSizePtr, 'i32');
|
|
90
|
+
const result = copyFromWasm(module, outPtr, outSize);
|
|
91
|
+
module._free(outPtr);
|
|
92
|
+
return result;
|
|
93
|
+
}
|
|
94
|
+
finally {
|
|
95
|
+
module._free(inPtr);
|
|
96
|
+
module._free(outSizePtr);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
async function fqzcomp_uncompress(input) {
|
|
100
|
+
const module = await getModule();
|
|
101
|
+
const inPtr = copyToWasm(module, input);
|
|
102
|
+
const outSizePtr = module._malloc(4);
|
|
103
|
+
const lenPtr = module._malloc(4);
|
|
104
|
+
try {
|
|
105
|
+
const outPtr = module._fqz_decompress(inPtr, input.length, outSizePtr, lenPtr);
|
|
106
|
+
if (outPtr === 0) {
|
|
107
|
+
throw new Error('fqz_decompress failed');
|
|
108
|
+
}
|
|
109
|
+
const outSize = module.getValue(outSizePtr, 'i32');
|
|
110
|
+
const result = copyFromWasm(module, outPtr, outSize);
|
|
111
|
+
module._free(outPtr);
|
|
112
|
+
return result;
|
|
113
|
+
}
|
|
114
|
+
finally {
|
|
115
|
+
module._free(inPtr);
|
|
116
|
+
module._free(outSizePtr);
|
|
117
|
+
module._free(lenPtr);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
async function zlib_uncompress(input) {
|
|
121
|
+
if (input.length === 0) {
|
|
122
|
+
return new Uint8Array(0);
|
|
123
|
+
}
|
|
124
|
+
const module = await getModule();
|
|
125
|
+
const inPtr = copyToWasm(module, input);
|
|
126
|
+
const outSizePtr = module._malloc(4);
|
|
127
|
+
try {
|
|
128
|
+
const outPtr = module._zlib_uncompress(inPtr, input.length, outSizePtr);
|
|
129
|
+
if (outPtr === 0) {
|
|
130
|
+
throw new Error('zlib_uncompress failed');
|
|
131
|
+
}
|
|
132
|
+
const outSize = module.getValue(outSizePtr, 'i32');
|
|
133
|
+
const result = copyFromWasm(module, outPtr, outSize);
|
|
134
|
+
module._free(outPtr);
|
|
135
|
+
return result;
|
|
136
|
+
}
|
|
137
|
+
finally {
|
|
138
|
+
module._free(inPtr);
|
|
139
|
+
module._free(outSizePtr);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
async function bz2_uncompress(input, expectedSize) {
|
|
143
|
+
if (input.length === 0) {
|
|
144
|
+
return new Uint8Array(0);
|
|
145
|
+
}
|
|
146
|
+
const module = await getModule();
|
|
147
|
+
const inPtr = copyToWasm(module, input);
|
|
148
|
+
const outSizePtr = module._malloc(4);
|
|
149
|
+
try {
|
|
150
|
+
const outPtr = module._bz2_uncompress(inPtr, input.length, expectedSize, outSizePtr);
|
|
151
|
+
if (outPtr === 0) {
|
|
152
|
+
throw new Error('bz2_uncompress failed');
|
|
153
|
+
}
|
|
154
|
+
const outSize = module.getValue(outSizePtr, 'i32');
|
|
155
|
+
const result = copyFromWasm(module, outPtr, outSize);
|
|
156
|
+
module._free(outPtr);
|
|
157
|
+
return result;
|
|
158
|
+
}
|
|
159
|
+
finally {
|
|
160
|
+
module._free(inPtr);
|
|
161
|
+
module._free(outSizePtr);
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
async function tok3_uncompress(input) {
|
|
165
|
+
const module = await getModule();
|
|
166
|
+
const inPtr = copyToWasm(module, input);
|
|
167
|
+
const outSizePtr = module._malloc(4);
|
|
168
|
+
try {
|
|
169
|
+
const outPtr = module._tok3_decode_names(inPtr, input.length, outSizePtr);
|
|
170
|
+
if (outPtr === 0) {
|
|
171
|
+
throw new Error('tok3_decode_names failed');
|
|
172
|
+
}
|
|
173
|
+
const outSize = module.getValue(outSizePtr, 'i32');
|
|
174
|
+
const result = copyFromWasm(module, outPtr, outSize);
|
|
175
|
+
module._free(outPtr);
|
|
176
|
+
return result;
|
|
177
|
+
}
|
|
178
|
+
finally {
|
|
179
|
+
module._free(inPtr);
|
|
180
|
+
module._free(outSizePtr);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
//# sourceMappingURL=htscodecs-wasm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htscodecs-wasm.js","sourceRoot":"","sources":["../src/htscodecs-wasm.ts"],"names":[],"mappings":"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"}
|
package/dist/unzip.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare function unzip(input: Uint8Array): Uint8Array
|
|
1
|
+
export declare function unzip(input: Uint8Array): Promise<Uint8Array>;
|
package/dist/unzip.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.unzip = unzip;
|
|
4
|
-
const
|
|
5
|
-
function unzip(input) {
|
|
6
|
-
return (0,
|
|
4
|
+
const htscodecs_wasm_ts_1 = require("./htscodecs-wasm.js");
|
|
5
|
+
async function unzip(input) {
|
|
6
|
+
return (0, htscodecs_wasm_ts_1.zlib_uncompress)(input);
|
|
7
7
|
}
|
|
8
8
|
//# sourceMappingURL=unzip.js.map
|
package/dist/unzip.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"unzip.js","sourceRoot":"","sources":["../src/unzip.ts"],"names":[],"mappings":";;AAEA,sBAEC;AAJD,
|
|
1
|
+
{"version":3,"file":"unzip.js","sourceRoot":"","sources":["../src/unzip.ts"],"names":[],"mappings":";;AAEA,sBAEC;AAJD,2DAAqD;AAE9C,KAAK,UAAU,KAAK,CAAC,KAAiB;IAC3C,OAAO,IAAA,mCAAe,EAAC,KAAK,CAAC,CAAA;AAC/B,CAAC"}
|
|
Binary file
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htscodecs.js","sourceRoot":"","sources":["../../src/wasm/htscodecs.js"],"names":[],"mappings":"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"}
|
package/esm/craiIndex.js
CHANGED
|
@@ -16,7 +16,7 @@ function addRecordToIndex(index, record) {
|
|
|
16
16
|
sliceBytes: sliceBytes,
|
|
17
17
|
});
|
|
18
18
|
}
|
|
19
|
-
function maybeUnzip(data) {
|
|
19
|
+
async function maybeUnzip(data) {
|
|
20
20
|
return data[0] === 31 && data[1] === 139 ? unzip(data) : data;
|
|
21
21
|
}
|
|
22
22
|
export default class CraiIndex {
|
|
@@ -32,7 +32,7 @@ export default class CraiIndex {
|
|
|
32
32
|
}
|
|
33
33
|
async parseIndex() {
|
|
34
34
|
const index = {};
|
|
35
|
-
const uncompressedBuffer = maybeUnzip(await this.filehandle.readFile());
|
|
35
|
+
const uncompressedBuffer = await maybeUnzip(await this.filehandle.readFile());
|
|
36
36
|
const dataView = new DataView(uncompressedBuffer.buffer);
|
|
37
37
|
if (uncompressedBuffer.length > 4 &&
|
|
38
38
|
dataView.getUint32(0, true) === BAI_MAGIC) {
|
package/esm/craiIndex.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"craiIndex.js","sourceRoot":"","sources":["../src/craiIndex.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AAC9B,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAIlC,MAAM,SAAS,GAAG,UAAU,CAAA,CAAC,QAAQ;AAYrC,SAAS,gBAAgB,CAAC,KAAkB,EAAE,MAAgB;IAC5D,MAAM,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,cAAc,EAAE,UAAU,EAAE,UAAU,CAAC,GAAG,MAAM,CAAA;IAE3E,MAAM,CAAC,GAAG,KAAM,CAAA;IAChB,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QACd,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAA;IACf,CAAC;IAED,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACZ,KAAK,EAAE,KAAM;QACb,IAAI,EAAE,IAAK;QACX,cAAc,EAAE,cAAe;QAC/B,UAAU,EAAE,UAAW;QACvB,UAAU,EAAE,UAAW;KACxB,CAAC,CAAA;AACJ,CAAC;AAED,
|
|
1
|
+
{"version":3,"file":"craiIndex.js","sourceRoot":"","sources":["../src/craiIndex.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AAC9B,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAIlC,MAAM,SAAS,GAAG,UAAU,CAAA,CAAC,QAAQ;AAYrC,SAAS,gBAAgB,CAAC,KAAkB,EAAE,MAAgB;IAC5D,MAAM,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,cAAc,EAAE,UAAU,EAAE,UAAU,CAAC,GAAG,MAAM,CAAA;IAE3E,MAAM,CAAC,GAAG,KAAM,CAAA;IAChB,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QACd,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAA;IACf,CAAC;IAED,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACZ,KAAK,EAAE,KAAM;QACb,IAAI,EAAE,IAAK;QACX,cAAc,EAAE,cAAe;QAC/B,UAAU,EAAE,UAAW;QACvB,UAAU,EAAE,UAAW;KACxB,CAAC,CAAA;AACJ,CAAC;AAED,KAAK,UAAU,UAAU,CAAC,IAAgB;IACxC,OAAO,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;AAC/D,CAAC;AAED,MAAM,CAAC,OAAO,OAAO,SAAS;IAiB5B;;;;;;OAMG;IACH,YAAY,IAAoB;QAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,CAAA;IAC9D,CAAC;IAED,KAAK,CAAC,UAAU;QACd,MAAM,KAAK,GAAgB,EAAE,CAAA;QAC7B,MAAM,kBAAkB,GAAG,MAAM,UAAU,CACzC,MAAM,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CACjC,CAAA;QACD,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAA;QACxD,IACE,kBAAkB,CAAC,MAAM,GAAG,CAAC;YAC7B,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,SAAS,EACzC,CAAC;YACD,MAAM,IAAI,kBAAkB,CAC1B,+IAA+I,CAChJ,CAAA;QACH,CAAC;QACD,uEAAuE;QACvE,qEAAqE;QACrE,qEAAqE;QACrE,gBAAgB;QAChB,IAAI,aAAa,GAAa,EAAE,CAAA;QAChC,IAAI,aAAa,GAAG,EAAE,CAAA;QACtB,KAAK,MAAM,QAAQ,IAAI,kBAAkB,EAAE,CAAC;YAC1C,IACE,CAAC,QAAQ,IAAI,EAAE,IAAI,QAAQ,IAAI,EAAE,CAAC,CAAC,SAAS;gBAC5C,CAAC,CAAC,aAAa,IAAI,QAAQ,KAAK,EAAE,CAAC,CAAC,eAAe,EACnD,CAAC;gBACD,aAAa,IAAI,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAA;YAChD,CAAC;iBAAM,IAAI,QAAQ,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACnC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC,CAAA;gBACtD,aAAa,GAAG,EAAE,CAAA;YACpB,CAAC;iBAAM,IAAI,QAAQ,KAAK,EAAE,CAAC,QAAQ,EAAE,CAAC;gBACpC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC,CAAA;gBACtD,aAAa,GAAG,EAAE,CAAA;gBAClB,gBAAgB,CAAC,KAAK,EAAE,aAAa,CAAC,CAAA;gBACtC,aAAa,GAAG,EAAE,CAAA;YACpB,CAAC;iBAAM,IAAI,QAAQ,KAAK,EAAE,CAAC,QAAQ,IAAI,QAAQ,KAAK,EAAE,CAAC,WAAW,EAAE,CAAC;gBACnE,oDAAoD;gBACpD,oCAAoC;gBACpC,MAAM,IAAI,kBAAkB,CAAC,0BAA0B,CAAC,CAAA;YAC1D,CAAC;QACH,CAAC;QAED,8DAA8D;QAC9D,IAAI,aAAa,EAAE,CAAC;YAClB,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC,CAAA;QACxD,CAAC;QACD,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC/B,gBAAgB,CAAC,KAAK,EAAE,aAAa,CAAC,CAAA;QACxC,CAAC;QAED,6BAA6B;QAC7B,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,GAAG,CAAC,EAAE,EAAE;YAC7C,MAAM,EAAE,GAAG,GAAI,CAAA;YACf,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,CAAA;QACxE,CAAC,CAAC,CAAA;QACF,OAAO,KAAK,CAAA;IACd,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC,CAAU,EAAE,EAAE;gBACxD,IAAI,CAAC,WAAW,GAAG,SAAS,CAAA;gBAC5B,MAAM,CAAC,CAAA;YACT,CAAC,CAAC,CAAA;QACJ,CAAC;QACD,OAAO,IAAI,CAAC,WAAW,CAAA;IACzB,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,2BAA2B,CAAC,KAAa;QAC7C,OAAO,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,CAAA;IACzC,CAAC;IAED;;;;;;;;;;OAUG;IACH,KAAK,CAAC,kBAAkB,CACtB,KAAa,EACb,UAAkB,EAClB,QAAgB;QAEhB,MAAM,UAAU,GAAG,CAAC,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,CAAA;QACjD,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO,EAAE,CAAA;QACX,CAAC;QAED,MAAM,OAAO,GAAG,CAAC,KAAY,EAAE,EAAE;YAC/B,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAA;YAC9B,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAA;YACzC,IAAI,UAAU,GAAG,QAAQ,EAAE,CAAC;gBAC1B,OAAO,CAAC,CAAC,CAAA;YACX,CAAC,CAAC,0BAA0B;YAC5B,IAAI,QAAQ,IAAI,UAAU,EAAE,CAAC;gBAC3B,OAAO,CAAC,CAAA;YACV,CAAC,CAAC,wBAAwB;YAC1B,OAAO,CAAC,CAAA,CAAC,uBAAuB;QAClC,CAAC,CAAA;QACD,MAAM,IAAI,GAAG,EAAa,CAAA;QAC1B,KAAK,MAAM,KAAK,IAAI,UAAU,EAAE,CAAC;YAC/B,IAAI,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;gBACzB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAClB,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAA;IACb,CAAC;CACF"}
|
package/esm/cramFile/file.d.ts
CHANGED
|
@@ -72,7 +72,7 @@ export default class CramFile {
|
|
|
72
72
|
_endPosition: number;
|
|
73
73
|
_size: number;
|
|
74
74
|
}>;
|
|
75
|
-
_uncompressPre(compressionMethod: CompressionMethod, inputBuffer: Uint8Array, uncompressedSize: number): Promise<
|
|
76
|
-
_uncompress(compressionMethod: CompressionMethod, inputBuffer: Uint8Array, uncompressedSize: number): Promise<
|
|
75
|
+
_uncompressPre(compressionMethod: CompressionMethod, inputBuffer: Uint8Array, uncompressedSize: number): Promise<Uint8Array<ArrayBufferLike>>;
|
|
76
|
+
_uncompress(compressionMethod: CompressionMethod, inputBuffer: Uint8Array, uncompressedSize: number): Promise<Uint8Array<ArrayBufferLike>>;
|
|
77
77
|
readBlock(position: number): Promise<CramFileBlock>;
|
|
78
78
|
}
|
package/esm/cramFile/file.js
CHANGED
|
@@ -3,10 +3,8 @@ import QuickLRU from 'quick-lru';
|
|
|
3
3
|
import { CramMalformedError, CramUnimplementedError } from "../errors.js";
|
|
4
4
|
import * as htscodecs from "../htscodecs/index.js";
|
|
5
5
|
import { open } from "../io.js";
|
|
6
|
-
import ransuncompress from "../rans/index.js";
|
|
7
6
|
import { parseHeaderText } from "../sam.js";
|
|
8
7
|
import { parseItem, tinyMemoize } from "./util.js";
|
|
9
|
-
import { decode } from "../seek-bzip/index.js";
|
|
10
8
|
import { unzip } from "../unzip.js";
|
|
11
9
|
import CramContainer from "./container/index.js";
|
|
12
10
|
import { cramFileDefinition, getSectionParsers, } from "./sectionParsers.js";
|
|
@@ -190,30 +188,28 @@ export default class CramFile {
|
|
|
190
188
|
async _uncompressPre(compressionMethod, inputBuffer, uncompressedSize) {
|
|
191
189
|
// console.log({ compressionMethod })
|
|
192
190
|
if (compressionMethod === 'gzip') {
|
|
193
|
-
return unzip(inputBuffer);
|
|
191
|
+
return await unzip(inputBuffer);
|
|
194
192
|
}
|
|
195
193
|
else if (compressionMethod === 'bzip2') {
|
|
196
|
-
return
|
|
194
|
+
return await htscodecs.bz2_uncompress(inputBuffer, uncompressedSize);
|
|
197
195
|
}
|
|
198
196
|
else if (compressionMethod === 'lzma') {
|
|
199
197
|
return xzDecompress(inputBuffer);
|
|
200
198
|
}
|
|
201
199
|
else if (compressionMethod === 'rans') {
|
|
202
|
-
|
|
203
|
-
ransuncompress(inputBuffer, outputBuffer);
|
|
204
|
-
return outputBuffer;
|
|
200
|
+
return await htscodecs.rans_uncompress(inputBuffer);
|
|
205
201
|
}
|
|
206
202
|
else if (compressionMethod === 'rans4x16') {
|
|
207
|
-
return htscodecs.r4x16_uncompress(inputBuffer);
|
|
203
|
+
return await htscodecs.r4x16_uncompress(inputBuffer);
|
|
208
204
|
}
|
|
209
205
|
else if (compressionMethod === 'arith') {
|
|
210
|
-
return htscodecs.arith_uncompress(inputBuffer);
|
|
206
|
+
return await htscodecs.arith_uncompress(inputBuffer);
|
|
211
207
|
}
|
|
212
208
|
else if (compressionMethod === 'fqzcomp') {
|
|
213
|
-
return htscodecs.fqzcomp_uncompress(inputBuffer);
|
|
209
|
+
return await htscodecs.fqzcomp_uncompress(inputBuffer);
|
|
214
210
|
}
|
|
215
211
|
else if (compressionMethod === 'tok3') {
|
|
216
|
-
return htscodecs.tok3_uncompress(inputBuffer);
|
|
212
|
+
return await htscodecs.tok3_uncompress(inputBuffer);
|
|
217
213
|
}
|
|
218
214
|
else {
|
|
219
215
|
throw new CramUnimplementedError(`${compressionMethod} decompression not yet implemented`);
|