@gmod/cram 1.6.3 → 1.7.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/CHANGELOG.md +9 -0
- package/dist/craiIndex.d.ts +19 -12
- package/dist/craiIndex.js +63 -123
- package/dist/craiIndex.js.map +1 -1
- package/dist/cram-bundle.js +2 -17
- package/dist/cram-bundle.js.LICENSE.txt +17 -0
- package/dist/cramFile/codecs/_base.d.ts +26 -5
- package/dist/cramFile/codecs/_base.js +3 -39
- package/dist/cramFile/codecs/_base.js.map +1 -1
- package/dist/cramFile/codecs/beta.d.ts +7 -3
- package/dist/cramFile/codecs/beta.js +13 -31
- package/dist/cramFile/codecs/beta.js.map +1 -1
- package/dist/cramFile/codecs/byteArrayLength.d.ts +13 -7
- package/dist/cramFile/codecs/byteArrayLength.js +22 -41
- package/dist/cramFile/codecs/byteArrayLength.js.map +1 -1
- package/dist/cramFile/codecs/byteArrayStop.d.ts +9 -5
- package/dist/cramFile/codecs/byteArrayStop.js +25 -46
- package/dist/cramFile/codecs/byteArrayStop.js.map +1 -1
- package/dist/cramFile/codecs/dataSeriesTypes.d.ts +4 -0
- package/dist/cramFile/codecs/dataSeriesTypes.js +3 -0
- package/dist/cramFile/codecs/dataSeriesTypes.js.map +1 -0
- package/dist/cramFile/codecs/external.d.ts +10 -6
- package/dist/cramFile/codecs/external.js +26 -44
- package/dist/cramFile/codecs/external.js.map +1 -1
- package/dist/cramFile/codecs/gamma.d.ts +7 -3
- package/dist/cramFile/codecs/gamma.js +16 -34
- package/dist/cramFile/codecs/gamma.js.map +1 -1
- package/dist/cramFile/codecs/getBits.d.ts +7 -0
- package/dist/cramFile/codecs/getBits.js +26 -0
- package/dist/cramFile/codecs/getBits.js.map +1 -0
- package/dist/cramFile/codecs/huffman.d.ts +17 -13
- package/dist/cramFile/codecs/huffman.js +76 -85
- package/dist/cramFile/codecs/huffman.js.map +1 -1
- package/dist/cramFile/codecs/index.d.ts +4 -2
- package/dist/cramFile/codecs/index.js +12 -13
- package/dist/cramFile/codecs/index.js.map +1 -1
- package/dist/cramFile/codecs/subexp.d.ts +7 -3
- package/dist/cramFile/codecs/subexp.js +19 -36
- package/dist/cramFile/codecs/subexp.js.map +1 -1
- package/dist/cramFile/constants.d.ts +35 -35
- package/dist/cramFile/constants.js +1 -1
- package/dist/cramFile/constants.js.map +1 -1
- package/dist/cramFile/container/compressionScheme.d.ts +57 -11
- package/dist/cramFile/container/compressionScheme.js +37 -32
- package/dist/cramFile/container/compressionScheme.js.map +1 -1
- package/dist/cramFile/container/index.d.ts +23 -9
- package/dist/cramFile/container/index.js +74 -144
- package/dist/cramFile/container/index.js.map +1 -1
- package/dist/cramFile/encoding.d.ts +78 -0
- package/dist/cramFile/encoding.js +3 -0
- package/dist/cramFile/encoding.js.map +1 -0
- package/dist/cramFile/file.d.ts +91 -41
- package/dist/cramFile/file.js +234 -368
- package/dist/cramFile/file.js.map +1 -1
- package/dist/cramFile/filehandle.d.ts +2 -0
- package/dist/cramFile/filehandle.js +3 -0
- package/dist/cramFile/filehandle.js.map +1 -0
- package/dist/cramFile/index.d.ts +1 -1
- package/dist/cramFile/index.js +1 -1
- package/dist/cramFile/index.js.map +1 -1
- package/dist/cramFile/record.d.ts +61 -17
- package/dist/cramFile/record.js +153 -77
- package/dist/cramFile/record.js.map +1 -1
- package/dist/cramFile/sectionParsers.d.ts +99 -8
- package/dist/cramFile/sectionParsers.js +70 -80
- package/dist/cramFile/sectionParsers.js.map +1 -1
- package/dist/cramFile/slice/decodeRecord.d.ts +30 -2
- package/dist/cramFile/slice/decodeRecord.js +148 -118
- package/dist/cramFile/slice/decodeRecord.js.map +1 -1
- package/dist/cramFile/slice/index.d.ts +21 -14
- package/dist/cramFile/slice/index.js +286 -381
- package/dist/cramFile/slice/index.js.map +1 -1
- package/dist/cramFile/util.d.ts +11 -5
- package/dist/cramFile/util.js +19 -97
- package/dist/cramFile/util.js.map +1 -1
- package/dist/errors.d.ts +5 -10
- package/dist/errors.js +11 -62
- package/dist/errors.js.map +1 -1
- package/dist/index.d.ts +3 -3
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/indexedCramFile.d.ts +37 -12
- package/dist/indexedCramFile.js +114 -154
- package/dist/indexedCramFile.js.map +1 -1
- package/dist/io/index.d.ts +5 -5
- package/dist/io/index.js +9 -9
- package/dist/io/index.js.map +1 -1
- package/dist/rans/constants.js +3 -3
- package/dist/rans/constants.js.map +1 -1
- package/dist/rans/d04.js +15 -15
- package/dist/rans/d04.js.map +1 -1
- package/dist/rans/d14.js +21 -21
- package/dist/rans/d14.js.map +1 -1
- package/dist/rans/decoding.js +27 -30
- package/dist/rans/decoding.js.map +1 -1
- package/dist/rans/frequencies.js +11 -11
- package/dist/rans/frequencies.js.map +1 -1
- package/dist/rans/index.js +46 -49
- package/dist/rans/index.js.map +1 -1
- package/dist/sam.d.ts +8 -1
- package/dist/sam.js +7 -7
- package/dist/sam.js.map +1 -1
- package/dist/typescript.d.ts +3 -0
- package/dist/typescript.js +11 -0
- package/dist/typescript.js.map +1 -0
- package/dist/unzip-pako.js +1 -1
- package/dist/unzip-pako.js.map +1 -1
- package/dist/unzip.js +1 -1
- package/dist/unzip.js.map +1 -1
- package/errors.js +11 -62
- package/esm/craiIndex.d.ts +19 -12
- package/esm/craiIndex.js +8 -24
- package/esm/craiIndex.js.map +1 -1
- package/esm/cramFile/codecs/_base.d.ts +26 -5
- package/esm/cramFile/codecs/_base.js +1 -35
- package/esm/cramFile/codecs/_base.js.map +1 -1
- package/esm/cramFile/codecs/beta.d.ts +7 -3
- package/esm/cramFile/codecs/beta.js +4 -3
- package/esm/cramFile/codecs/beta.js.map +1 -1
- package/esm/cramFile/codecs/byteArrayLength.d.ts +13 -7
- package/esm/cramFile/codecs/byteArrayLength.js +1 -1
- package/esm/cramFile/codecs/byteArrayLength.js.map +1 -1
- package/esm/cramFile/codecs/byteArrayStop.d.ts +9 -5
- package/esm/cramFile/codecs/byteArrayStop.js +7 -9
- package/esm/cramFile/codecs/byteArrayStop.js.map +1 -1
- package/esm/cramFile/codecs/dataSeriesTypes.d.ts +4 -0
- package/esm/cramFile/codecs/dataSeriesTypes.js +2 -0
- package/esm/cramFile/codecs/dataSeriesTypes.js.map +1 -0
- package/esm/cramFile/codecs/external.d.ts +10 -6
- package/esm/cramFile/codecs/external.js +4 -3
- package/esm/cramFile/codecs/external.js.map +1 -1
- package/esm/cramFile/codecs/gamma.d.ts +7 -3
- package/esm/cramFile/codecs/gamma.js +5 -4
- package/esm/cramFile/codecs/gamma.js.map +1 -1
- package/esm/cramFile/codecs/getBits.d.ts +7 -0
- package/esm/cramFile/codecs/getBits.js +21 -0
- package/esm/cramFile/codecs/getBits.js.map +1 -0
- package/esm/cramFile/codecs/huffman.d.ts +17 -13
- package/esm/cramFile/codecs/huffman.js +22 -9
- package/esm/cramFile/codecs/huffman.js.map +1 -1
- package/esm/cramFile/codecs/index.d.ts +4 -2
- package/esm/cramFile/codecs/index.js +1 -1
- package/esm/cramFile/codecs/index.js.map +1 -1
- package/esm/cramFile/codecs/subexp.d.ts +7 -3
- package/esm/cramFile/codecs/subexp.js +7 -5
- package/esm/cramFile/codecs/subexp.js.map +1 -1
- package/esm/cramFile/constants.d.ts +35 -35
- package/esm/cramFile/constants.js.map +1 -1
- package/esm/cramFile/container/compressionScheme.d.ts +57 -11
- package/esm/cramFile/container/compressionScheme.js +15 -8
- package/esm/cramFile/container/compressionScheme.js.map +1 -1
- package/esm/cramFile/container/index.d.ts +23 -9
- package/esm/cramFile/container/index.js +11 -9
- package/esm/cramFile/container/index.js.map +1 -1
- package/esm/cramFile/encoding.d.ts +78 -0
- package/esm/cramFile/encoding.js +2 -0
- package/esm/cramFile/encoding.js.map +1 -0
- package/esm/cramFile/file.d.ts +91 -41
- package/esm/cramFile/file.js +59 -47
- package/esm/cramFile/file.js.map +1 -1
- package/esm/cramFile/filehandle.d.ts +2 -0
- package/esm/cramFile/filehandle.js +2 -0
- package/esm/cramFile/filehandle.js.map +1 -0
- package/esm/cramFile/index.d.ts +1 -1
- package/esm/cramFile/index.js.map +1 -1
- package/esm/cramFile/record.d.ts +61 -17
- package/esm/cramFile/record.js +83 -5
- package/esm/cramFile/record.js.map +1 -1
- package/esm/cramFile/sectionParsers.d.ts +99 -8
- package/esm/cramFile/sectionParsers.js +7 -17
- package/esm/cramFile/sectionParsers.js.map +1 -1
- package/esm/cramFile/slice/decodeRecord.d.ts +30 -2
- package/esm/cramFile/slice/decodeRecord.js +102 -70
- package/esm/cramFile/slice/decodeRecord.js.map +1 -1
- package/esm/cramFile/slice/index.d.ts +21 -14
- package/esm/cramFile/slice/index.js +77 -38
- package/esm/cramFile/slice/index.js.map +1 -1
- package/esm/cramFile/util.d.ts +11 -5
- package/esm/cramFile/util.js +11 -82
- package/esm/cramFile/util.js.map +1 -1
- package/esm/errors.d.ts +5 -10
- package/esm/errors.js +0 -5
- package/esm/errors.js.map +1 -1
- package/esm/index.d.ts +3 -3
- package/esm/index.js.map +1 -1
- package/esm/indexedCramFile.d.ts +37 -12
- package/esm/indexedCramFile.js +19 -8
- package/esm/indexedCramFile.js.map +1 -1
- package/esm/io/index.d.ts +5 -5
- package/esm/io/index.js +3 -3
- package/esm/io/index.js.map +1 -1
- package/esm/sam.d.ts +8 -1
- package/esm/sam.js.map +1 -1
- package/esm/typescript.d.ts +3 -0
- package/esm/typescript.js +7 -0
- package/esm/typescript.js.map +1 -0
- package/package.json +18 -11
- package/src/{craiIndex.js → craiIndex.ts} +37 -31
- package/src/cramFile/codecs/_base.ts +45 -0
- package/src/cramFile/codecs/beta.ts +34 -0
- package/src/cramFile/codecs/{byteArrayLength.js → byteArrayLength.ts} +27 -5
- package/src/cramFile/codecs/{byteArrayStop.js → byteArrayStop.ts} +25 -12
- package/src/cramFile/codecs/dataSeriesTypes.ts +39 -0
- package/src/cramFile/codecs/{external.js → external.ts} +28 -12
- package/src/cramFile/codecs/gamma.ts +42 -0
- package/src/cramFile/codecs/getBits.ts +28 -0
- package/src/cramFile/codecs/{huffman.js → huffman.ts} +48 -15
- package/src/cramFile/codecs/{index.js → index.ts} +9 -3
- package/src/cramFile/codecs/subexp.ts +45 -0
- package/src/cramFile/{constants.js → constants.ts} +0 -0
- package/src/cramFile/container/{compressionScheme.js → compressionScheme.ts} +50 -18
- package/src/cramFile/container/{index.js → index.ts} +13 -13
- package/src/cramFile/encoding.ts +98 -0
- package/src/cramFile/{file.js → file.ts} +136 -62
- package/src/cramFile/filehandle.ts +3 -0
- package/src/cramFile/{index.js → index.ts} +0 -0
- package/src/cramFile/{record.js → record.ts} +185 -14
- package/src/cramFile/{sectionParsers.js → sectionParsers.ts} +148 -20
- package/src/cramFile/slice/{decodeRecord.js → decodeRecord.ts} +158 -105
- package/src/cramFile/slice/{index.js → index.ts} +138 -63
- package/src/cramFile/{util.js → util.ts} +28 -17
- package/src/{errors.js → errors.ts} +0 -5
- package/src/{index.js → index.ts} +0 -0
- package/src/{indexedCramFile.js → indexedCramFile.ts} +79 -19
- package/src/io/{index.js → index.ts} +10 -5
- package/src/{sam.js → sam.ts} +7 -2
- package/src/typescript.ts +17 -0
- package/src/typings/binary-parser.d.ts +44 -0
- package/src/typings/bzip2.d.ts +7 -0
- package/src/typings/htscodecs.d.ts +6 -0
- package/dist/io/bufferCache.d.ts +0 -12
- package/dist/io/bufferCache.js +0 -112
- package/dist/io/bufferCache.js.map +0 -1
- package/dist/io/localFile.d.ts +0 -10
- package/dist/io/localFile.js +0 -108
- package/dist/io/localFile.js.map +0 -1
- package/dist/io/remoteFile.d.ts +0 -16
- package/dist/io/remoteFile.js +0 -143
- package/dist/io/remoteFile.js.map +0 -1
- package/esm/io/bufferCache.d.ts +0 -12
- package/esm/io/bufferCache.js +0 -54
- package/esm/io/bufferCache.js.map +0 -1
- package/esm/io/localFile.d.ts +0 -10
- package/esm/io/localFile.js +0 -31
- package/esm/io/localFile.js.map +0 -1
- package/esm/io/remoteFile.d.ts +0 -16
- package/esm/io/remoteFile.js +0 -64
- package/esm/io/remoteFile.js.map +0 -1
- package/src/cramFile/codecs/_base.js +0 -49
- package/src/cramFile/codecs/beta.js +0 -23
- package/src/cramFile/codecs/gamma.js +0 -30
- package/src/cramFile/codecs/subexp.js +0 -32
- package/src/io/bufferCache.js +0 -66
- package/src/io/localFile.js +0 -35
- package/src/io/remoteFile.js +0 -71
package/esm/craiIndex.js
CHANGED
|
@@ -4,14 +4,6 @@ import { unzip } from './unzip';
|
|
|
4
4
|
import { open } from './io';
|
|
5
5
|
import { CramMalformedError } from './errors';
|
|
6
6
|
const BAI_MAGIC = 21578050; // BAI\1
|
|
7
|
-
class Slice {
|
|
8
|
-
constructor(args) {
|
|
9
|
-
Object.assign(this, args);
|
|
10
|
-
}
|
|
11
|
-
toString() {
|
|
12
|
-
return `${this.start}:${this.span}:${this.containerStart}:${this.sliceStart}:${this.sliceBytes}`;
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
7
|
function addRecordToIndex(index, record) {
|
|
16
8
|
if (record.some(el => el === undefined)) {
|
|
17
9
|
throw new CramMalformedError('invalid .crai index file');
|
|
@@ -20,23 +12,15 @@ function addRecordToIndex(index, record) {
|
|
|
20
12
|
if (!index[seqId]) {
|
|
21
13
|
index[seqId] = [];
|
|
22
14
|
}
|
|
23
|
-
index[seqId].push(
|
|
15
|
+
index[seqId].push({
|
|
24
16
|
start,
|
|
25
17
|
span,
|
|
26
18
|
containerStart,
|
|
27
19
|
sliceStart,
|
|
28
20
|
sliceBytes,
|
|
29
|
-
})
|
|
21
|
+
});
|
|
30
22
|
}
|
|
31
23
|
export default class CraiIndex {
|
|
32
|
-
// A CRAM index (.crai) is a gzipped tab delimited file containing the following columns:
|
|
33
|
-
// 1. Sequence id
|
|
34
|
-
// 2. Alignment start
|
|
35
|
-
// 3. Alignment span
|
|
36
|
-
// 4. Container start byte position in the file
|
|
37
|
-
// 5. Slice start byte position in the container data (‘blocks’)
|
|
38
|
-
// 6. Slice size in bytes
|
|
39
|
-
// Each line represents a slice in the CRAM file. Please note that all slices must be listed in index file.
|
|
40
24
|
/**
|
|
41
25
|
*
|
|
42
26
|
* @param {object} args
|
|
@@ -45,16 +29,16 @@ export default class CraiIndex {
|
|
|
45
29
|
* @param {FileHandle} [args.filehandle]
|
|
46
30
|
*/
|
|
47
31
|
constructor(args) {
|
|
48
|
-
|
|
32
|
+
this.filehandle = open(args.url, args.path, args.filehandle);
|
|
49
33
|
this._parseCache = new AbortablePromiseCache({
|
|
50
34
|
cache: new QuickLRU({ maxSize: 1 }),
|
|
51
|
-
fill: (data, signal) => this.parseIndex(
|
|
35
|
+
fill: (data, signal) => this.parseIndex(),
|
|
52
36
|
});
|
|
53
|
-
this.readFile = filehandle.readFile.bind(filehandle);
|
|
54
37
|
}
|
|
55
38
|
parseIndex() {
|
|
56
39
|
const index = {};
|
|
57
|
-
return this.
|
|
40
|
+
return this.filehandle
|
|
41
|
+
.readFile()
|
|
58
42
|
.then(data => {
|
|
59
43
|
if (data[0] === 31 && data[1] === 139) {
|
|
60
44
|
return unzip(data);
|
|
@@ -135,10 +119,10 @@ export default class CraiIndex {
|
|
|
135
119
|
if (!seqEntries) {
|
|
136
120
|
return [];
|
|
137
121
|
}
|
|
138
|
-
const compare = entry => {
|
|
122
|
+
const compare = (entry) => {
|
|
139
123
|
const entryStart = entry.start;
|
|
140
124
|
const entryEnd = entry.start + entry.span;
|
|
141
|
-
if (entryStart
|
|
125
|
+
if (entryStart > queryEnd) {
|
|
142
126
|
return -1;
|
|
143
127
|
} // entry is ahead of query
|
|
144
128
|
if (entryEnd <= queryStart) {
|
package/esm/craiIndex.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"craiIndex.js","sourceRoot":"","sources":["../src/craiIndex.
|
|
1
|
+
{"version":3,"file":"craiIndex.js","sourceRoot":"","sources":["../src/craiIndex.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,27 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import CramSlice from '../slice';
|
|
2
|
+
import { CramFileBlock } from '../file';
|
|
3
|
+
import { DataType } from './dataSeriesTypes';
|
|
4
|
+
export declare type DataTypeMapping = {
|
|
5
|
+
byte: number;
|
|
6
|
+
int: number;
|
|
7
|
+
long: number;
|
|
8
|
+
byteArray: Uint8Array;
|
|
9
|
+
};
|
|
10
|
+
export declare type Cursor = {
|
|
11
|
+
bitPosition: 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7;
|
|
12
|
+
bytePosition: number;
|
|
13
|
+
};
|
|
14
|
+
export declare type Cursors = {
|
|
15
|
+
lastAlignmentStart: number;
|
|
16
|
+
coreBlock: Cursor;
|
|
17
|
+
externalBlocks: {
|
|
18
|
+
map: Map<any, any>;
|
|
19
|
+
getCursor: (contentId: number) => Cursor;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
export default abstract class CramCodec<TResult extends DataType = DataType, TParameters = unknown> {
|
|
23
|
+
parameters: TParameters;
|
|
24
|
+
dataType: DataType;
|
|
25
|
+
constructor(parameters: TParameters, dataType: TResult);
|
|
26
|
+
abstract decode(slice: CramSlice, coreDataBlock: CramFileBlock, blocksByContentId: Record<number, CramFileBlock>, cursors: Cursors): DataTypeMapping[TResult];
|
|
6
27
|
}
|
|
@@ -1,42 +1,8 @@
|
|
|
1
|
-
import { CramBufferOverrunError } from '../../errors';
|
|
2
|
-
const validDataTypes = {
|
|
3
|
-
int: true,
|
|
4
|
-
byte: true,
|
|
5
|
-
long: true,
|
|
6
|
-
byteArray: true,
|
|
7
|
-
byteArrayBlock: true,
|
|
8
|
-
};
|
|
9
1
|
// codec base class
|
|
10
2
|
export default class CramCodec {
|
|
11
|
-
constructor(parameters
|
|
3
|
+
constructor(parameters, dataType) {
|
|
12
4
|
this.parameters = parameters;
|
|
13
5
|
this.dataType = dataType;
|
|
14
|
-
if (!dataType) {
|
|
15
|
-
throw new TypeError('must provide a data type to codec constructor');
|
|
16
|
-
}
|
|
17
|
-
if (!validDataTypes[dataType]) {
|
|
18
|
-
throw new TypeError(`invalid data type ${dataType}`);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
// decode(slice, coreDataBlock, blocksByContentId, cursors) {
|
|
22
|
-
// }
|
|
23
|
-
_getBits(data, cursor, numBits) {
|
|
24
|
-
let val = 0;
|
|
25
|
-
if (cursor.bytePosition + (7 - cursor.bitPosition + numBits) / 8 >
|
|
26
|
-
data.length) {
|
|
27
|
-
throw new CramBufferOverrunError('read error during decoding. the file seems to be truncated.');
|
|
28
|
-
}
|
|
29
|
-
for (let dlen = numBits; dlen; dlen -= 1) {
|
|
30
|
-
// get the next `dlen` bits in the input, put them in val
|
|
31
|
-
val <<= 1;
|
|
32
|
-
val |= (data[cursor.bytePosition] >> cursor.bitPosition) & 1;
|
|
33
|
-
cursor.bitPosition -= 1;
|
|
34
|
-
if (cursor.bitPosition < 0) {
|
|
35
|
-
cursor.bytePosition += 1;
|
|
36
|
-
}
|
|
37
|
-
cursor.bitPosition &= 7;
|
|
38
|
-
}
|
|
39
|
-
return val;
|
|
40
6
|
}
|
|
41
7
|
}
|
|
42
8
|
//# sourceMappingURL=_base.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"_base.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/_base.
|
|
1
|
+
{"version":3,"file":"_base.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/_base.ts"],"names":[],"mappings":"AAyBA,mBAAmB;AACnB,MAAM,CAAC,OAAO,OAAgB,SAAS;IAOrC,YAAY,UAAuB,EAAE,QAAiB;QACpD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;IAC1B,CAAC;CAQF"}
|
|
@@ -1,4 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import CramCodec, { Cursors } from './_base';
|
|
2
|
+
import CramSlice from '../slice';
|
|
3
|
+
import { CramFileBlock } from '../file';
|
|
4
|
+
import { BetaEncoding } from '../encoding';
|
|
5
|
+
export default class BetaCodec extends CramCodec<'int', BetaEncoding['parameters']> {
|
|
6
|
+
constructor(parameters: BetaEncoding['parameters'], dataType: 'int');
|
|
7
|
+
decode(slice: CramSlice, coreDataBlock: CramFileBlock, blocksByContentId: Record<number, CramFileBlock>, cursors: Cursors): number;
|
|
3
8
|
}
|
|
4
|
-
import CramCodec from "./_base";
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import { CramUnimplementedError } from '../../errors';
|
|
2
2
|
import CramCodec from './_base';
|
|
3
|
+
import { getBits } from './getBits';
|
|
3
4
|
export default class BetaCodec extends CramCodec {
|
|
4
|
-
constructor(parameters
|
|
5
|
+
constructor(parameters, dataType) {
|
|
5
6
|
super(parameters, dataType);
|
|
6
7
|
if (this.dataType !== 'int') {
|
|
7
8
|
throw new CramUnimplementedError(`${this.dataType} decoding not yet implemented by BETA codec`);
|
|
8
9
|
}
|
|
9
10
|
}
|
|
10
11
|
decode(slice, coreDataBlock, blocksByContentId, cursors) {
|
|
11
|
-
const
|
|
12
|
-
return
|
|
12
|
+
const fromBits = getBits(coreDataBlock.content, cursors.coreBlock, this.parameters.length);
|
|
13
|
+
return fromBits - this.parameters.offset;
|
|
13
14
|
}
|
|
14
15
|
}
|
|
15
16
|
//# sourceMappingURL=beta.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"beta.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/beta.
|
|
1
|
+
{"version":3,"file":"beta.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/beta.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAA;AACrD,OAAO,SAAsB,MAAM,SAAS,CAAA;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAKnC,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,SAGtC;IACC,YAAY,UAAsC,EAAE,QAAe;QACjE,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAC3B,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;YAC3B,MAAM,IAAI,sBAAsB,CAC9B,GAAG,IAAI,CAAC,QAAQ,6CAA6C,CAC9D,CAAA;SACF;IACH,CAAC;IAED,MAAM,CACJ,KAAgB,EAChB,aAA4B,EAC5B,iBAAgD,EAChD,OAAgB;QAEhB,MAAM,QAAQ,GAAG,OAAO,CACtB,aAAa,CAAC,OAAO,EACrB,OAAO,CAAC,SAAS,EACjB,IAAI,CAAC,UAAU,CAAC,MAAM,CACvB,CAAA;QACD,OAAO,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAA;IAC1C,CAAC;CACF"}
|
|
@@ -1,8 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import CramCodec, { Cursors } from './_base';
|
|
2
|
+
import { ByteArrayLengthEncoding, CramEncoding } from '../encoding';
|
|
3
|
+
import CramSlice from '../slice';
|
|
4
|
+
import { CramFileBlock } from '../file';
|
|
5
|
+
import { DataType } from './dataSeriesTypes';
|
|
6
|
+
declare type CramCodecFactory = <TData extends DataType = DataType>(encodingData: CramEncoding, dataType: TData | 'ignore') => CramCodec<TData>;
|
|
7
|
+
export default class ByteArrayStopCodec extends CramCodec<'byteArray', ByteArrayLengthEncoding['parameters']> {
|
|
8
|
+
private instantiateCodec;
|
|
9
|
+
constructor(parameters: ByteArrayLengthEncoding['parameters'], dataType: 'byteArray', instantiateCodec: CramCodecFactory);
|
|
10
|
+
decode(slice: CramSlice, coreDataBlock: CramFileBlock, blocksByContentId: Record<number, CramFileBlock>, cursors: Cursors): Uint8Array;
|
|
11
|
+
_getLengthCodec(): CramCodec<"int", unknown>;
|
|
12
|
+
_getDataCodec(): CramCodec<"byte", unknown>;
|
|
7
13
|
}
|
|
8
|
-
|
|
14
|
+
export {};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { tinyMemoize } from '../util';
|
|
2
2
|
import CramCodec from './_base';
|
|
3
3
|
export default class ByteArrayStopCodec extends CramCodec {
|
|
4
|
-
constructor(parameters
|
|
4
|
+
constructor(parameters, dataType, instantiateCodec) {
|
|
5
5
|
super(parameters, dataType);
|
|
6
6
|
this.instantiateCodec = instantiateCodec;
|
|
7
7
|
if (dataType !== 'byteArray') {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"byteArrayLength.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/byteArrayLength.
|
|
1
|
+
{"version":3,"file":"byteArrayLength.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/byteArrayLength.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAErC,OAAO,SAAsB,MAAM,SAAS,CAAA;AAW5C,MAAM,CAAC,OAAO,OAAO,kBAAmB,SAAQ,SAG/C;IAGC,YACE,UAAiD,EACjD,QAAqB,EACrB,gBAAkC;QAElC,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAC3B,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAA;QACxC,IAAI,QAAQ,KAAK,WAAW,EAAE;YAC5B,MAAM,IAAI,SAAS,CACjB,8CAA8C,QAAQ,EAAE,CACzD,CAAA;SACF;IACH,CAAC;IAED,MAAM,CACJ,KAAgB,EAChB,aAA4B,EAC5B,iBAAgD,EAChD,OAAgB;QAEhB,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,EAAE,CAAA;QAC1C,MAAM,WAAW,GAAG,WAAW,CAAC,MAAM,CACpC,KAAK,EACL,aAAa,EACb,iBAAiB,EACjB,OAAO,CACR,CAAA;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,EAAE,CAAA;QACtC,MAAM,IAAI,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC,CAAA;QACxC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,EAAE,CAAC,IAAI,CAAC,EAAE;YACvC,IAAI,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,CACxB,KAAK,EACL,aAAa,EACb,iBAAiB,EACjB,OAAO,CACR,CAAA;SACF;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED,UAAU;IACV,eAAe;QACb,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAA;QACtD,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,KAAK,CAAC,CAAA;IACrD,CAAC;IAED,UAAU;IACV,aAAa;QACX,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,cAAc,CAAA;QACrD,OAAO,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,MAAM,CAAC,CAAA;IACtD,CAAC;CACF;AAED,+BAA+B;KAC5B,KAAK,CAAC,GAAG,CAAC;KACV,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,WAAW,CAAC,kBAAkB,EAAE,MAAM,CAAC,CAAC,CAAA"}
|
|
@@ -1,6 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import CramCodec, { Cursor, Cursors } from './_base';
|
|
3
|
+
import CramSlice from '../slice';
|
|
4
|
+
import { CramFileBlock } from '../file';
|
|
5
|
+
import { ByteArrayStopCramEncoding } from '../encoding';
|
|
6
|
+
export default class ByteArrayStopCodec extends CramCodec<'byteArray', ByteArrayStopCramEncoding['parameters']> {
|
|
7
|
+
constructor(parameters: ByteArrayStopCramEncoding['parameters'], dataType: 'byteArray');
|
|
8
|
+
decode(slice: CramSlice, coreDataBlock: CramFileBlock, blocksByContentId: Record<number, CramFileBlock>, cursors: Cursors): Buffer;
|
|
9
|
+
_decodeByteArray(contentBlock: CramFileBlock, cursor: Cursor): Buffer;
|
|
5
10
|
}
|
|
6
|
-
import CramCodec from "./_base";
|
|
@@ -1,12 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { CramMalformedError } from '../../errors';
|
|
2
2
|
import CramCodec from './_base';
|
|
3
|
+
import { CramBufferOverrunError } from './getBits';
|
|
3
4
|
export default class ByteArrayStopCodec extends CramCodec {
|
|
4
|
-
constructor(parameters
|
|
5
|
+
constructor(parameters, dataType) {
|
|
5
6
|
super(parameters, dataType);
|
|
6
|
-
if (dataType
|
|
7
|
-
this._decode = this._decodeByteArray;
|
|
8
|
-
}
|
|
9
|
-
else {
|
|
7
|
+
if (dataType !== 'byteArray') {
|
|
10
8
|
throw new TypeError(`byteArrayStop codec does not support data type ${dataType}`);
|
|
11
9
|
}
|
|
12
10
|
}
|
|
@@ -17,7 +15,7 @@ export default class ByteArrayStopCodec extends CramCodec {
|
|
|
17
15
|
throw new CramMalformedError(`no block found with content ID ${blockContentId}`);
|
|
18
16
|
}
|
|
19
17
|
const cursor = cursors.externalBlocks.getCursor(blockContentId);
|
|
20
|
-
return this.
|
|
18
|
+
return this._decodeByteArray(contentBlock, cursor);
|
|
21
19
|
}
|
|
22
20
|
_decodeByteArray(contentBlock, cursor) {
|
|
23
21
|
const dataBuffer = contentBlock.content;
|
|
@@ -30,10 +28,10 @@ export default class ByteArrayStopCodec extends CramCodec {
|
|
|
30
28
|
if (stopPosition === dataBuffer.length) {
|
|
31
29
|
throw new CramBufferOverrunError(`byteArrayStop reading beyond length of data buffer?`);
|
|
32
30
|
}
|
|
33
|
-
stopPosition
|
|
31
|
+
stopPosition = stopPosition + 1;
|
|
34
32
|
}
|
|
35
33
|
cursor.bytePosition = stopPosition + 1;
|
|
36
|
-
return dataBuffer.
|
|
34
|
+
return dataBuffer.subarray(startPosition, stopPosition);
|
|
37
35
|
}
|
|
38
36
|
}
|
|
39
37
|
//# sourceMappingURL=byteArrayStop.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"byteArrayStop.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/byteArrayStop.
|
|
1
|
+
{"version":3,"file":"byteArrayStop.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/byteArrayStop.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAA;AAEjD,OAAO,SAA8B,MAAM,SAAS,CAAA;AAIpD,OAAO,EAAE,sBAAsB,EAAE,MAAM,WAAW,CAAA;AAElD,MAAM,CAAC,OAAO,OAAO,kBAAmB,SAAQ,SAG/C;IACC,YACE,UAAmD,EACnD,QAAqB;QAErB,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAC3B,IAAI,QAAQ,KAAK,WAAW,EAAE;YAC5B,MAAM,IAAI,SAAS,CACjB,kDAAkD,QAAQ,EAAE,CAC7D,CAAA;SACF;IACH,CAAC;IAED,MAAM,CACJ,KAAgB,EAChB,aAA4B,EAC5B,iBAAgD,EAChD,OAAgB;QAEhB,MAAM,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,UAAU,CAAA;QAC1C,MAAM,YAAY,GAAG,iBAAiB,CAAC,cAAc,CAAC,CAAA;QACtD,IAAI,CAAC,YAAY,EAAE;YACjB,MAAM,IAAI,kBAAkB,CAC1B,kCAAkC,cAAc,EAAE,CACnD,CAAA;SACF;QACD,MAAM,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,SAAS,CAAC,cAAc,CAAC,CAAA;QAC/D,OAAO,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,MAAM,CAAC,CAAA;IACpD,CAAC;IAED,gBAAgB,CAAC,YAA2B,EAAE,MAAc;QAC1D,MAAM,UAAU,GAAG,YAAY,CAAC,OAAO,CAAA;QACvC,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,UAAU,CAAA;QACpC,6BAA6B;QAC7B,MAAM,aAAa,GAAG,MAAM,CAAC,YAAY,CAAA;QACzC,IAAI,YAAY,GAAG,MAAM,CAAC,YAAY,CAAA;QACtC,OACE,UAAU,CAAC,YAAY,CAAC,KAAK,QAAQ;YACrC,YAAY,GAAG,UAAU,CAAC,MAAM,EAChC;YACA,IAAI,YAAY,KAAK,UAAU,CAAC,MAAM,EAAE;gBACtC,MAAM,IAAI,sBAAsB,CAC9B,qDAAqD,CACtD,CAAA;aACF;YACD,YAAY,GAAG,YAAY,GAAG,CAAC,CAAA;SAChC;QACD,MAAM,CAAC,YAAY,GAAG,YAAY,GAAG,CAAC,CAAA;QACtC,OAAO,UAAU,CAAC,QAAQ,CAAC,aAAa,EAAE,YAAY,CAAC,CAAA;IACzD,CAAC;CACF"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { CramEncoding } from '../encoding';
|
|
2
|
+
export declare type DataType = 'int' | 'byte' | 'long' | 'byteArray';
|
|
3
|
+
export declare type DataSeriesEncodingKey = 'BF' | 'CF' | 'RI' | 'RL' | 'AP' | 'RG' | 'RN' | 'MF' | 'NS' | 'NP' | 'TS' | 'NF' | 'TL' | 'FN' | 'FC' | 'FP' | 'DL' | 'BB' | 'QQ' | 'BS' | 'IN' | 'RS' | 'PD' | 'HC' | 'SC' | 'MQ' | 'BA' | 'QS' | 'TC' | 'TN';
|
|
4
|
+
export declare type DataSeriesEncodingMap = Record<DataSeriesEncodingKey, CramEncoding>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dataSeriesTypes.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/dataSeriesTypes.ts"],"names":[],"mappings":""}
|
|
@@ -1,7 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import CramCodec, { Cursor, Cursors } from './_base';
|
|
2
|
+
import CramSlice from '../slice';
|
|
3
|
+
import { CramFileBlock } from '../file';
|
|
4
|
+
import { ExternalCramEncoding } from '../encoding';
|
|
5
|
+
export default class ExternalCodec extends CramCodec<'int' | 'byte', ExternalCramEncoding['parameters']> {
|
|
6
|
+
private readonly _decodeData;
|
|
7
|
+
constructor(parameters: ExternalCramEncoding['parameters'], dataType: 'int' | 'byte');
|
|
8
|
+
decode(slice: CramSlice, coreDataBlock: CramFileBlock, blocksByContentId: Record<number, CramFileBlock>, cursors: Cursors): number;
|
|
9
|
+
_decodeInt(contentBlock: CramFileBlock, cursor: Cursor): number;
|
|
10
|
+
_decodeByte(contentBlock: CramFileBlock, cursor: Cursor): number;
|
|
6
11
|
}
|
|
7
|
-
import CramCodec from "./_base";
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { CramMalformedError, CramUnimplementedError } from '../../errors';
|
|
2
2
|
import CramCodec from './_base';
|
|
3
3
|
import { parseItf8 } from '../util';
|
|
4
|
+
import { CramBufferOverrunError } from './getBits';
|
|
4
5
|
export default class ExternalCodec extends CramCodec {
|
|
5
|
-
constructor(parameters
|
|
6
|
+
constructor(parameters, dataType) {
|
|
6
7
|
super(parameters, dataType);
|
|
7
8
|
if (this.dataType === 'int') {
|
|
8
9
|
this._decodeData = this._decodeInt;
|
|
@@ -25,7 +26,7 @@ export default class ExternalCodec extends CramCodec {
|
|
|
25
26
|
}
|
|
26
27
|
_decodeInt(contentBlock, cursor) {
|
|
27
28
|
const [result, bytesRead] = parseItf8(contentBlock.content, cursor.bytePosition);
|
|
28
|
-
cursor.bytePosition
|
|
29
|
+
cursor.bytePosition = cursor.bytePosition + bytesRead;
|
|
29
30
|
return result;
|
|
30
31
|
}
|
|
31
32
|
_decodeByte(contentBlock, cursor) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"external.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/external.
|
|
1
|
+
{"version":3,"file":"external.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/external.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAA;AACzE,OAAO,SAA8B,MAAM,SAAS,CAAA;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAA;AAGnC,OAAO,EAAE,sBAAsB,EAAE,MAAM,WAAW,CAAA;AAGlD,MAAM,CAAC,OAAO,OAAO,aAAc,SAAQ,SAG1C;IAMC,YACE,UAA8C,EAC9C,QAAwB;QAExB,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAC3B,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;YAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAA;SACnC;aAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE;YACnC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAA;SACpC;aAAM;YACL,MAAM,IAAI,sBAAsB,CAC9B,GAAG,IAAI,CAAC,QAAQ,iDAAiD,CAClE,CAAA;SACF;IACH,CAAC;IAED,MAAM,CACJ,KAAgB,EAChB,aAA4B,EAC5B,iBAAgD,EAChD,OAAgB;QAEhB,MAAM,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,UAAU,CAAA;QAC1C,MAAM,YAAY,GAAG,iBAAiB,CAAC,cAAc,CAAC,CAAA;QACtD,IAAI,CAAC,YAAY,EAAE;YACjB,MAAM,IAAI,kBAAkB,CAC1B,kCAAkC,cAAc,EAAE,CACnD,CAAA;SACF;QACD,MAAM,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,SAAS,CAAC,cAAc,CAAC,CAAA;QAC/D,OAAO,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,MAAM,CAAC,CAAA;IAC/C,CAAC;IAED,UAAU,CAAC,YAA2B,EAAE,MAAc;QACpD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,SAAS,CACnC,YAAY,CAAC,OAAO,EACpB,MAAM,CAAC,YAAY,CACpB,CAAA;QACD,MAAM,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,GAAG,SAAS,CAAA;QACrD,OAAO,MAAM,CAAA;IACf,CAAC;IAED,WAAW,CAAC,YAA2B,EAAE,MAAc;QACrD,IAAI,MAAM,CAAC,YAAY,IAAI,YAAY,CAAC,OAAO,CAAC,MAAM,EAAE;YACtD,MAAM,IAAI,sBAAsB,CAC9B,mEAAmE,CACpE,CAAA;SACF;QACD,OAAO,YAAY,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,CAAA;IACpD,CAAC;CACF"}
|
|
@@ -1,4 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import CramCodec, { Cursors } from './_base';
|
|
2
|
+
import { GammaEncoding } from '../encoding';
|
|
3
|
+
import CramSlice from '../slice';
|
|
4
|
+
import { CramFileBlock } from '../file';
|
|
5
|
+
export default class GammaCodec extends CramCodec<'int', GammaEncoding['parameters']> {
|
|
6
|
+
constructor(parameters: GammaEncoding['parameters'], dataType: 'int');
|
|
7
|
+
decode(slice: CramSlice, coreDataBlock: CramFileBlock, blocksByContentId: Record<number, CramFileBlock>, cursors: Cursors): number;
|
|
3
8
|
}
|
|
4
|
-
import CramCodec from "./_base";
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { CramUnimplementedError } from '../../errors';
|
|
2
2
|
import CramCodec from './_base';
|
|
3
|
+
import { getBits } from './getBits';
|
|
3
4
|
export default class GammaCodec extends CramCodec {
|
|
4
|
-
constructor(parameters
|
|
5
|
+
constructor(parameters, dataType) {
|
|
5
6
|
super(parameters, dataType);
|
|
6
7
|
if (this.dataType !== 'int') {
|
|
7
8
|
throw new CramUnimplementedError(`${this.dataType} decoding not yet implemented by GAMMA codec`);
|
|
@@ -9,10 +10,10 @@ export default class GammaCodec extends CramCodec {
|
|
|
9
10
|
}
|
|
10
11
|
decode(slice, coreDataBlock, blocksByContentId, cursors) {
|
|
11
12
|
let length = 1;
|
|
12
|
-
while (
|
|
13
|
-
length
|
|
13
|
+
while (getBits(coreDataBlock.content, cursors.coreBlock, 1) === 0) {
|
|
14
|
+
length = length + 1;
|
|
14
15
|
}
|
|
15
|
-
const readBits =
|
|
16
|
+
const readBits = getBits(coreDataBlock.content, cursors.coreBlock, length - 1);
|
|
16
17
|
const value = readBits | (1 << (length - 1));
|
|
17
18
|
return value - this.parameters.offset;
|
|
18
19
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gamma.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/gamma.
|
|
1
|
+
{"version":3,"file":"gamma.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/gamma.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAA;AACrD,OAAO,SAAsB,MAAM,SAAS,CAAA;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAKnC,MAAM,CAAC,OAAO,OAAO,UAAW,SAAQ,SAGvC;IACC,YAAY,UAAuC,EAAE,QAAe;QAClE,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAC3B,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;YAC3B,MAAM,IAAI,sBAAsB,CAC9B,GAAG,IAAI,CAAC,QAAQ,8CAA8C,CAC/D,CAAA;SACF;IACH,CAAC;IAED,MAAM,CACJ,KAAgB,EAChB,aAA4B,EAC5B,iBAAgD,EAChD,OAAgB;QAEhB,IAAI,MAAM,GAAG,CAAC,CAAA;QAEd,OAAO,OAAO,CAAC,aAAa,CAAC,OAAO,EAAE,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,EAAE;YACjE,MAAM,GAAG,MAAM,GAAG,CAAC,CAAA;SACpB;QAED,MAAM,QAAQ,GAAG,OAAO,CACtB,aAAa,CAAC,OAAO,EACrB,OAAO,CAAC,SAAS,EACjB,MAAM,GAAG,CAAC,CACX,CAAA;QAED,MAAM,KAAK,GAAG,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAA;QAC5C,OAAO,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAA;IACvC,CAAC;CACF"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export class CramBufferOverrunError extends Error {
|
|
2
|
+
}
|
|
3
|
+
export function getBits(data, cursor, numBits) {
|
|
4
|
+
let val = 0;
|
|
5
|
+
if (cursor.bytePosition + (7 - cursor.bitPosition + numBits) / 8 >
|
|
6
|
+
data.length) {
|
|
7
|
+
throw new CramBufferOverrunError('read error during decoding. the file seems to be truncated.');
|
|
8
|
+
}
|
|
9
|
+
for (let dlen = numBits; dlen; dlen--) {
|
|
10
|
+
// get the next `dlen` bits in the input, put them in val
|
|
11
|
+
val <<= 1;
|
|
12
|
+
val |= (data[cursor.bytePosition] >> cursor.bitPosition) & 1;
|
|
13
|
+
cursor.bitPosition -= 1;
|
|
14
|
+
if (cursor.bitPosition < 0) {
|
|
15
|
+
cursor.bytePosition += 1;
|
|
16
|
+
}
|
|
17
|
+
cursor.bitPosition &= 7;
|
|
18
|
+
}
|
|
19
|
+
return val;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=getBits.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getBits.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/getBits.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,sBAAuB,SAAQ,KAAK;CAAG;AAEpD,MAAM,UAAU,OAAO,CACrB,IAAY,EACZ,MAAqD,EACrD,OAAe;IAEf,IAAI,GAAG,GAAG,CAAC,CAAA;IACX,IACE,MAAM,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC;QAC5D,IAAI,CAAC,MAAM,EACX;QACA,MAAM,IAAI,sBAAsB,CAC9B,6DAA6D,CAC9D,CAAA;KACF;IACD,KAAK,IAAI,IAAI,GAAG,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE;QACrC,yDAAyD;QACzD,GAAG,KAAK,CAAC,CAAA;QACT,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAA;QAC5D,MAAM,CAAC,WAAW,IAAI,CAAC,CAAA;QACvB,IAAI,MAAM,CAAC,WAAW,GAAG,CAAC,EAAE;YAC1B,MAAM,CAAC,YAAY,IAAI,CAAC,CAAA;SACzB;QACD,MAAM,CAAC,WAAW,IAAI,CAAC,CAAA;KACxB;IACD,OAAO,GAAG,CAAA;AACZ,CAAC"}
|
|
@@ -1,17 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import CramCodec, { Cursor, Cursors } from './_base';
|
|
2
|
+
import { HuffmanEncoding } from '../encoding';
|
|
3
|
+
import CramSlice from '../slice';
|
|
4
|
+
import { CramFileBlock } from '../file';
|
|
5
|
+
export default class HuffmanIntCodec extends CramCodec<'byte' | 'int', HuffmanEncoding['parameters']> {
|
|
6
|
+
private codes;
|
|
7
|
+
private codeBook;
|
|
8
|
+
private sortedByValue;
|
|
9
|
+
private sortedCodes;
|
|
10
|
+
private sortedValuesByBitCode;
|
|
11
|
+
private sortedBitCodes;
|
|
12
|
+
private sortedBitLengthsByBitCode;
|
|
13
|
+
private bitCodeToValue;
|
|
14
|
+
constructor(parameters: HuffmanEncoding['parameters'], dataType: 'byte' | 'int');
|
|
3
15
|
buildCodeBook(): void;
|
|
4
|
-
codeBook: {} | undefined;
|
|
5
16
|
buildCodes(): void;
|
|
6
|
-
codes: {} | undefined;
|
|
7
17
|
buildCaches(): void;
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
sortedBitCodes: any[] | undefined;
|
|
12
|
-
sortedBitLengthsByBitCode: any[] | undefined;
|
|
13
|
-
bitCodeToValue: any[] | undefined;
|
|
14
|
-
decode(slice: any, coreDataBlock: any, blocksByContentId: any, cursors: any): any;
|
|
15
|
-
_decodeZeroLengthCode(): any;
|
|
18
|
+
decode(slice: CramSlice, coreDataBlock: CramFileBlock, blocksByContentId: Record<number, CramFileBlock>, cursors: Cursors): number;
|
|
19
|
+
_decodeZeroLengthCode(): number;
|
|
20
|
+
_decode(slice: CramSlice, coreDataBlock: CramFileBlock, coreCursor: Cursor): number;
|
|
16
21
|
}
|
|
17
|
-
import CramCodec from "./_base";
|
|
@@ -1,13 +1,22 @@
|
|
|
1
1
|
import { CramMalformedError } from '../../errors';
|
|
2
2
|
import CramCodec from './_base';
|
|
3
|
+
import { getBits } from './getBits';
|
|
3
4
|
function numberOfSetBits(ii) {
|
|
4
5
|
let i = (ii - (ii >> 1)) & 0x55555555;
|
|
5
6
|
i = (i & 0x33333333) + ((i >> 2) & 0x33333333);
|
|
6
7
|
return (((i + (i >> 4)) & 0x0f0f0f0f) * 0x01010101) >> 24;
|
|
7
8
|
}
|
|
8
9
|
export default class HuffmanIntCodec extends CramCodec {
|
|
9
|
-
constructor(parameters
|
|
10
|
+
constructor(parameters, dataType) {
|
|
10
11
|
super(parameters, dataType);
|
|
12
|
+
this.codes = {};
|
|
13
|
+
this.codeBook = {};
|
|
14
|
+
this.sortedByValue = [];
|
|
15
|
+
this.sortedCodes = [];
|
|
16
|
+
this.sortedValuesByBitCode = [];
|
|
17
|
+
this.sortedBitCodes = [];
|
|
18
|
+
this.sortedBitLengthsByBitCode = [];
|
|
19
|
+
this.bitCodeToValue = [];
|
|
11
20
|
if (!['byte', 'int'].includes(this.dataType)) {
|
|
12
21
|
throw new TypeError(`${this.dataType} decoding not yet implemented by HUFFMAN_INT codec`);
|
|
13
22
|
}
|
|
@@ -43,15 +52,19 @@ export default class HuffmanIntCodec extends CramCodec {
|
|
|
43
52
|
let codeLength = 0;
|
|
44
53
|
let codeValue = -1;
|
|
45
54
|
Object.entries(this.codeBook).forEach(([bitLength, symbols]) => {
|
|
46
|
-
|
|
55
|
+
const bitLengthInt = parseInt(bitLength, 10);
|
|
47
56
|
symbols.forEach(symbol => {
|
|
48
|
-
const code = {
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
57
|
+
const code = {
|
|
58
|
+
bitLength: bitLengthInt,
|
|
59
|
+
value: symbol,
|
|
60
|
+
bitCode: 0,
|
|
61
|
+
};
|
|
62
|
+
codeValue = codeValue + 1;
|
|
63
|
+
const delta = bitLengthInt - codeLength; // new length?
|
|
64
|
+
codeValue = codeValue << delta; // pad with 0's
|
|
52
65
|
code.bitCode = codeValue; // calculated: huffman code
|
|
53
|
-
codeLength
|
|
54
|
-
if (numberOfSetBits(codeValue) >
|
|
66
|
+
codeLength = codeLength + delta; // adjust current code length
|
|
67
|
+
if (numberOfSetBits(codeValue) > bitLengthInt) {
|
|
55
68
|
throw new CramMalformedError('Symbol out of range');
|
|
56
69
|
}
|
|
57
70
|
this.codes[symbol] = code;
|
|
@@ -88,7 +101,7 @@ export default class HuffmanIntCodec extends CramCodec {
|
|
|
88
101
|
for (let i = 0; i < this.sortedCodes.length; i += 1) {
|
|
89
102
|
const length = this.sortedCodes[i].bitLength;
|
|
90
103
|
bits <<= length - prevLen;
|
|
91
|
-
bits |=
|
|
104
|
+
bits |= getBits(input, coreCursor, length - prevLen);
|
|
92
105
|
prevLen = length;
|
|
93
106
|
{
|
|
94
107
|
const index = this.bitCodeToValue[bits];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"huffman.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/huffman.
|
|
1
|
+
{"version":3,"file":"huffman.js","sourceRoot":"","sources":["../../../src/cramFile/codecs/huffman.ts"],"names":[],"mappings":"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"}
|