@gmod/bam 1.1.8 → 1.1.9
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 +8 -0
- package/README.md +2 -3
- package/dist/bai.d.ts +2 -0
- package/dist/bai.js +300 -548
- package/dist/bai.js.map +1 -0
- package/dist/bamFile.d.ts +4 -6
- package/dist/bamFile.js +675 -1203
- package/dist/bamFile.js.map +1 -0
- package/dist/chunk.js +34 -69
- package/dist/chunk.js.map +1 -0
- package/dist/constants.js +27 -35
- package/dist/constants.js.map +1 -0
- package/dist/csi.js +317 -515
- package/dist/csi.js.map +1 -0
- package/dist/errors.js +64 -120
- package/dist/errors.js.map +1 -0
- package/dist/htsget.js +275 -396
- package/dist/htsget.js.map +1 -0
- package/dist/index.js +16 -54
- package/dist/index.js.map +1 -0
- package/dist/indexFile.d.ts +1 -2
- package/dist/indexFile.js +77 -163
- package/dist/indexFile.js.map +1 -0
- package/dist/record.js +496 -707
- package/dist/record.js.map +1 -0
- package/dist/sam.js +16 -49
- package/dist/sam.js.map +1 -0
- package/dist/util.d.ts +0 -1
- package/dist/util.js +115 -126
- package/dist/util.js.map +1 -0
- package/dist/virtualOffset.js +44 -77
- package/dist/virtualOffset.js.map +1 -0
- package/esm/bai.d.ts +26 -0
- package/esm/bai.js +191 -0
- package/esm/bai.js.map +1 -0
- package/esm/bamFile.d.ts +77 -0
- package/esm/bamFile.js +388 -0
- package/esm/bamFile.js.map +1 -0
- package/esm/chunk.d.ts +18 -0
- package/esm/chunk.js +33 -0
- package/esm/chunk.js.map +1 -0
- package/esm/constants.d.ts +15 -0
- package/esm/constants.js +27 -0
- package/esm/constants.js.map +1 -0
- package/esm/csi.d.ts +35 -0
- package/esm/csi.js +209 -0
- package/esm/csi.js.map +1 -0
- package/esm/errors.d.ts +23 -0
- package/esm/errors.js +24 -0
- package/esm/errors.js.map +1 -0
- package/esm/htsget.d.ts +33 -0
- package/esm/htsget.js +100 -0
- package/esm/htsget.js.map +1 -0
- package/esm/index.d.ts +6 -0
- package/esm/index.js +7 -0
- package/esm/index.js.map +1 -0
- package/esm/indexFile.d.ts +27 -0
- package/esm/indexFile.js +27 -0
- package/esm/indexFile.js.map +1 -0
- package/esm/record.d.ts +88 -0
- package/esm/record.js +534 -0
- package/esm/record.js.map +1 -0
- package/esm/sam.d.ts +7 -0
- package/esm/sam.js +16 -0
- package/esm/sam.js.map +1 -0
- package/esm/util.d.ts +35 -0
- package/esm/util.js +92 -0
- package/esm/util.js.map +1 -0
- package/esm/virtualOffset.d.ts +10 -0
- package/esm/virtualOffset.js +37 -0
- package/esm/virtualOffset.js.map +1 -0
- package/package.json +21 -29
- package/dist/declare.d.js +0 -2
package/dist/csi.js
CHANGED
|
@@ -1,536 +1,338 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
var
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
2
|
+
var __extends = (this && this.__extends) || (function () {
|
|
3
|
+
var extendStatics = function (d, b) {
|
|
4
|
+
extendStatics = Object.setPrototypeOf ||
|
|
5
|
+
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
6
|
+
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
7
|
+
return extendStatics(d, b);
|
|
8
|
+
};
|
|
9
|
+
return function (d, b) {
|
|
10
|
+
if (typeof b !== "function" && b !== null)
|
|
11
|
+
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
12
|
+
extendStatics(d, b);
|
|
13
|
+
function __() { this.constructor = d; }
|
|
14
|
+
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
15
|
+
};
|
|
16
|
+
})();
|
|
17
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
18
|
+
if (k2 === undefined) k2 = k;
|
|
19
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
20
|
+
}) : (function(o, m, k, k2) {
|
|
21
|
+
if (k2 === undefined) k2 = k;
|
|
22
|
+
o[k2] = m[k];
|
|
23
|
+
}));
|
|
24
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
25
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
26
|
+
}) : function(o, v) {
|
|
27
|
+
o["default"] = v;
|
|
11
28
|
});
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
var
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
var
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
var
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
var
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
var
|
|
60
|
-
|
|
61
|
-
var
|
|
62
|
-
|
|
63
|
-
var
|
|
64
|
-
|
|
65
|
-
function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof _symbol.default === "undefined" || (0, _getIteratorMethod2.default)(o) == null) { if ((0, _isArray.default)(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = (0, _getIterator2.default)(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
|
|
66
|
-
|
|
67
|
-
function _unsupportedIterableToArray(o, minLen) { var _context8; if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = (0, _slice.default)(_context8 = Object.prototype.toString.call(o)).call(_context8, 8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return (0, _from.default)(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
68
|
-
|
|
69
|
-
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
70
|
-
|
|
71
|
-
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = (0, _construct.default)(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
|
|
72
|
-
|
|
73
|
-
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_construct.default) return false; if (_construct.default.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call((0, _construct.default)(Date, [], function () {})); return true; } catch (e) { return false; } }
|
|
74
|
-
|
|
29
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
30
|
+
if (mod && mod.__esModule) return mod;
|
|
31
|
+
var result = {};
|
|
32
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
33
|
+
__setModuleDefault(result, mod);
|
|
34
|
+
return result;
|
|
35
|
+
};
|
|
36
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
37
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
38
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
39
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
40
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
41
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
42
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
46
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
47
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
48
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
49
|
+
function step(op) {
|
|
50
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
51
|
+
while (_) try {
|
|
52
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
53
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
54
|
+
switch (op[0]) {
|
|
55
|
+
case 0: case 1: t = op; break;
|
|
56
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
57
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
58
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
59
|
+
default:
|
|
60
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
61
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
62
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
63
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
64
|
+
if (t[2]) _.ops.pop();
|
|
65
|
+
_.trys.pop(); continue;
|
|
66
|
+
}
|
|
67
|
+
op = body.call(thisArg, _);
|
|
68
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
69
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
73
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
74
|
+
};
|
|
75
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
76
|
+
var long_1 = __importDefault(require("long"));
|
|
77
|
+
var bgzf_filehandle_1 = require("@gmod/bgzf-filehandle");
|
|
78
|
+
var virtualOffset_1 = __importStar(require("./virtualOffset"));
|
|
79
|
+
var chunk_1 = __importDefault(require("./chunk"));
|
|
80
|
+
var util_1 = require("./util");
|
|
81
|
+
var indexFile_1 = __importDefault(require("./indexFile"));
|
|
75
82
|
var CSI1_MAGIC = 21582659; // CSI\1
|
|
76
|
-
|
|
77
83
|
var CSI2_MAGIC = 38359875; // CSI\2
|
|
78
|
-
|
|
79
84
|
function lshift(num, bits) {
|
|
80
|
-
|
|
85
|
+
return num * Math.pow(2, bits);
|
|
81
86
|
}
|
|
82
|
-
|
|
83
87
|
function rshift(num, bits) {
|
|
84
|
-
|
|
88
|
+
return Math.floor(num / Math.pow(2, bits));
|
|
85
89
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
(0, _classCallCheck2.default)(this, CSI);
|
|
96
|
-
_this = _super.call(this, args);
|
|
97
|
-
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "maxBinNumber", void 0);
|
|
98
|
-
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "depth", void 0);
|
|
99
|
-
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "minShift", void 0);
|
|
100
|
-
_this.maxBinNumber = 0;
|
|
101
|
-
_this.depth = 0;
|
|
102
|
-
_this.minShift = 0;
|
|
103
|
-
return _this;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
(0, _createClass2.default)(CSI, [{
|
|
107
|
-
key: "lineCount",
|
|
108
|
-
value: function () {
|
|
109
|
-
var _lineCount = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(refId) {
|
|
110
|
-
var indexData, idx, stats;
|
|
111
|
-
return _regenerator.default.wrap(function _callee$(_context) {
|
|
112
|
-
while (1) {
|
|
113
|
-
switch (_context.prev = _context.next) {
|
|
114
|
-
case 0:
|
|
115
|
-
_context.next = 2;
|
|
116
|
-
return this.parse();
|
|
117
|
-
|
|
118
|
-
case 2:
|
|
119
|
-
indexData = _context.sent;
|
|
120
|
-
|
|
121
|
-
if (indexData) {
|
|
122
|
-
_context.next = 5;
|
|
123
|
-
break;
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
return _context.abrupt("return", -1);
|
|
127
|
-
|
|
128
|
-
case 5:
|
|
129
|
-
idx = indexData.indices[refId];
|
|
130
|
-
|
|
131
|
-
if (idx) {
|
|
132
|
-
_context.next = 8;
|
|
133
|
-
break;
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
return _context.abrupt("return", -1);
|
|
137
|
-
|
|
138
|
-
case 8:
|
|
139
|
-
stats = indexData.indices[refId].stats;
|
|
140
|
-
|
|
141
|
-
if (!stats) {
|
|
142
|
-
_context.next = 11;
|
|
143
|
-
break;
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
return _context.abrupt("return", stats.lineCount);
|
|
147
|
-
|
|
148
|
-
case 11:
|
|
149
|
-
return _context.abrupt("return", -1);
|
|
150
|
-
|
|
151
|
-
case 12:
|
|
152
|
-
case "end":
|
|
153
|
-
return _context.stop();
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
}, _callee, this);
|
|
157
|
-
}));
|
|
158
|
-
|
|
159
|
-
function lineCount(_x) {
|
|
160
|
-
return _lineCount.apply(this, arguments);
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
return lineCount;
|
|
164
|
-
}()
|
|
165
|
-
}, {
|
|
166
|
-
key: "indexCov",
|
|
167
|
-
value: function () {
|
|
168
|
-
var _indexCov = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
|
|
169
|
-
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
170
|
-
while (1) {
|
|
171
|
-
switch (_context2.prev = _context2.next) {
|
|
172
|
-
case 0:
|
|
173
|
-
return _context2.abrupt("return", []);
|
|
174
|
-
|
|
175
|
-
case 1:
|
|
176
|
-
case "end":
|
|
177
|
-
return _context2.stop();
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
}, _callee2);
|
|
181
|
-
}));
|
|
182
|
-
|
|
183
|
-
function indexCov() {
|
|
184
|
-
return _indexCov.apply(this, arguments);
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
return indexCov;
|
|
188
|
-
}()
|
|
189
|
-
}, {
|
|
190
|
-
key: "parseAuxData",
|
|
191
|
-
value: function parseAuxData(bytes, offset, auxLength) {
|
|
192
|
-
if (auxLength < 30) {
|
|
193
|
-
return {};
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
var data = {};
|
|
197
|
-
data.formatFlags = bytes.readInt32LE(offset);
|
|
198
|
-
data.coordinateType = data.formatFlags & 0x10000 ? 'zero-based-half-open' : '1-based-closed';
|
|
199
|
-
data.format = {
|
|
200
|
-
0: 'generic',
|
|
201
|
-
1: 'SAM',
|
|
202
|
-
2: 'VCF'
|
|
203
|
-
}[data.formatFlags & 0xf];
|
|
204
|
-
|
|
205
|
-
if (!data.format) {
|
|
206
|
-
throw new Error("invalid Tabix preset format flags ".concat(data.formatFlags));
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
data.columnNumbers = {
|
|
210
|
-
ref: bytes.readInt32LE(offset + 4),
|
|
211
|
-
start: bytes.readInt32LE(offset + 8),
|
|
212
|
-
end: bytes.readInt32LE(offset + 12)
|
|
213
|
-
};
|
|
214
|
-
data.metaValue = bytes.readInt32LE(offset + 16);
|
|
215
|
-
data.metaChar = data.metaValue ? String.fromCharCode(data.metaValue) : '';
|
|
216
|
-
data.skipLines = bytes.readInt32LE(offset + 20);
|
|
217
|
-
var nameSectionLength = bytes.readInt32LE(offset + 24);
|
|
218
|
-
(0, _assign.default)(data, this._parseNameBytes((0, _slice.default)(bytes).call(bytes, offset + 28, offset + 28 + nameSectionLength)));
|
|
219
|
-
return data;
|
|
90
|
+
var CSI = /** @class */ (function (_super) {
|
|
91
|
+
__extends(CSI, _super);
|
|
92
|
+
function CSI(args) {
|
|
93
|
+
var _this = _super.call(this, args) || this;
|
|
94
|
+
_this.maxBinNumber = 0;
|
|
95
|
+
_this.depth = 0;
|
|
96
|
+
_this.minShift = 0;
|
|
97
|
+
return _this;
|
|
220
98
|
}
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
}
|
|
242
|
-
|
|
243
|
-
return {
|
|
244
|
-
refNameToId: refNameToId,
|
|
245
|
-
refIdToName: refIdToName
|
|
246
|
-
};
|
|
247
|
-
} // fetch and parse the index
|
|
248
|
-
|
|
249
|
-
}, {
|
|
250
|
-
key: "_parse",
|
|
251
|
-
value: function () {
|
|
252
|
-
var _parse2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(opts) {
|
|
253
|
-
var data, buffer, bytes, auxLength, currOffset, i, binCount, binIndex, stats, j, bin, loffset, chunkCount, chunks, k, u, v;
|
|
254
|
-
return _regenerator.default.wrap(function _callee3$(_context3) {
|
|
255
|
-
while (1) {
|
|
256
|
-
switch (_context3.prev = _context3.next) {
|
|
257
|
-
case 0:
|
|
258
|
-
data = {
|
|
259
|
-
csi: true,
|
|
260
|
-
maxBlockSize: 1 << 16
|
|
261
|
-
};
|
|
262
|
-
_context3.next = 3;
|
|
263
|
-
return this.filehandle.readFile(opts);
|
|
264
|
-
|
|
265
|
-
case 3:
|
|
266
|
-
buffer = _context3.sent;
|
|
267
|
-
_context3.next = 6;
|
|
268
|
-
return (0, _bgzfFilehandle.unzip)(buffer);
|
|
269
|
-
|
|
270
|
-
case 6:
|
|
271
|
-
bytes = _context3.sent;
|
|
272
|
-
|
|
273
|
-
if (!(bytes.readUInt32LE(0) === CSI1_MAGIC)) {
|
|
274
|
-
_context3.next = 11;
|
|
275
|
-
break;
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
data.csiVersion = 1;
|
|
279
|
-
_context3.next = 16;
|
|
280
|
-
break;
|
|
281
|
-
|
|
282
|
-
case 11:
|
|
283
|
-
if (!(bytes.readUInt32LE(0) === CSI2_MAGIC)) {
|
|
284
|
-
_context3.next = 15;
|
|
285
|
-
break;
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
data.csiVersion = 2;
|
|
289
|
-
_context3.next = 16;
|
|
290
|
-
break;
|
|
291
|
-
|
|
292
|
-
case 15:
|
|
293
|
-
throw new Error('Not a CSI file');
|
|
294
|
-
|
|
295
|
-
case 16:
|
|
296
|
-
this.minShift = bytes.readInt32LE(4);
|
|
297
|
-
this.depth = bytes.readInt32LE(8);
|
|
298
|
-
this.maxBinNumber = ((1 << (this.depth + 1) * 3) - 1) / 7;
|
|
299
|
-
auxLength = bytes.readInt32LE(12);
|
|
300
|
-
|
|
301
|
-
if (auxLength) {
|
|
302
|
-
(0, _assign.default)(data, this.parseAuxData(bytes, 16, auxLength));
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
data.refCount = bytes.readInt32LE(16 + auxLength); // read the indexes for each reference sequence
|
|
306
|
-
|
|
307
|
-
data.indices = new Array(data.refCount);
|
|
308
|
-
currOffset = 16 + auxLength + 4;
|
|
309
|
-
i = 0;
|
|
310
|
-
|
|
311
|
-
case 25:
|
|
312
|
-
if (!(i < data.refCount)) {
|
|
313
|
-
_context3.next = 37;
|
|
314
|
-
break;
|
|
99
|
+
CSI.prototype.lineCount = function (refId) {
|
|
100
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
101
|
+
var indexData, idx, stats;
|
|
102
|
+
return __generator(this, function (_a) {
|
|
103
|
+
switch (_a.label) {
|
|
104
|
+
case 0: return [4 /*yield*/, this.parse()];
|
|
105
|
+
case 1:
|
|
106
|
+
indexData = _a.sent();
|
|
107
|
+
if (!indexData) {
|
|
108
|
+
return [2 /*return*/, -1];
|
|
109
|
+
}
|
|
110
|
+
idx = indexData.indices[refId];
|
|
111
|
+
if (!idx) {
|
|
112
|
+
return [2 /*return*/, -1];
|
|
113
|
+
}
|
|
114
|
+
stats = indexData.indices[refId].stats;
|
|
115
|
+
if (stats) {
|
|
116
|
+
return [2 /*return*/, stats.lineCount];
|
|
117
|
+
}
|
|
118
|
+
return [2 /*return*/, -1];
|
|
315
119
|
}
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
120
|
+
});
|
|
121
|
+
});
|
|
122
|
+
};
|
|
123
|
+
CSI.prototype.indexCov = function () {
|
|
124
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
125
|
+
return __generator(this, function (_a) {
|
|
126
|
+
return [2 /*return*/, []];
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
};
|
|
130
|
+
CSI.prototype.parseAuxData = function (bytes, offset, auxLength) {
|
|
131
|
+
if (auxLength < 30) {
|
|
132
|
+
return {};
|
|
133
|
+
}
|
|
134
|
+
var data = {};
|
|
135
|
+
data.formatFlags = bytes.readInt32LE(offset);
|
|
136
|
+
data.coordinateType =
|
|
137
|
+
data.formatFlags & 0x10000 ? 'zero-based-half-open' : '1-based-closed';
|
|
138
|
+
data.format = { 0: 'generic', 1: 'SAM', 2: 'VCF' }[data.formatFlags & 0xf];
|
|
139
|
+
if (!data.format) {
|
|
140
|
+
throw new Error("invalid Tabix preset format flags ".concat(data.formatFlags));
|
|
141
|
+
}
|
|
142
|
+
data.columnNumbers = {
|
|
143
|
+
ref: bytes.readInt32LE(offset + 4),
|
|
144
|
+
start: bytes.readInt32LE(offset + 8),
|
|
145
|
+
end: bytes.readInt32LE(offset + 12),
|
|
146
|
+
};
|
|
147
|
+
data.metaValue = bytes.readInt32LE(offset + 16);
|
|
148
|
+
data.metaChar = data.metaValue ? String.fromCharCode(data.metaValue) : '';
|
|
149
|
+
data.skipLines = bytes.readInt32LE(offset + 20);
|
|
150
|
+
var nameSectionLength = bytes.readInt32LE(offset + 24);
|
|
151
|
+
Object.assign(data, this._parseNameBytes(bytes.slice(offset + 28, offset + 28 + nameSectionLength)));
|
|
152
|
+
return data;
|
|
153
|
+
};
|
|
154
|
+
CSI.prototype._parseNameBytes = function (namesBytes) {
|
|
155
|
+
var currRefId = 0;
|
|
156
|
+
var currNameStart = 0;
|
|
157
|
+
var refIdToName = [];
|
|
158
|
+
var refNameToId = {};
|
|
159
|
+
for (var i = 0; i < namesBytes.length; i += 1) {
|
|
160
|
+
if (!namesBytes[i]) {
|
|
161
|
+
if (currNameStart < i) {
|
|
162
|
+
var refName = namesBytes.toString('utf8', currNameStart, i);
|
|
163
|
+
refName = this.renameRefSeq(refName);
|
|
164
|
+
refIdToName[currRefId] = refName;
|
|
165
|
+
refNameToId[refName] = currRefId;
|
|
354
166
|
}
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
binIndex: binIndex,
|
|
358
|
-
stats: stats
|
|
359
|
-
};
|
|
360
|
-
|
|
361
|
-
case 34:
|
|
362
|
-
i += 1;
|
|
363
|
-
_context3.next = 25;
|
|
364
|
-
break;
|
|
365
|
-
|
|
366
|
-
case 37:
|
|
367
|
-
return _context3.abrupt("return", data);
|
|
368
|
-
|
|
369
|
-
case 38:
|
|
370
|
-
case "end":
|
|
371
|
-
return _context3.stop();
|
|
167
|
+
currNameStart = i + 1;
|
|
168
|
+
currRefId += 1;
|
|
372
169
|
}
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
return
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
170
|
+
}
|
|
171
|
+
return { refNameToId: refNameToId, refIdToName: refIdToName };
|
|
172
|
+
};
|
|
173
|
+
// fetch and parse the index
|
|
174
|
+
CSI.prototype._parse = function (opts) {
|
|
175
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
176
|
+
var data, buffer, bytes, auxLength, currOffset, i, binCount, binIndex, stats // < provided by parsing a pseudo-bin, if present
|
|
177
|
+
, j, bin, loffset, chunkCount, chunks, k, u, v;
|
|
178
|
+
return __generator(this, function (_a) {
|
|
179
|
+
switch (_a.label) {
|
|
180
|
+
case 0:
|
|
181
|
+
data = { csi: true, maxBlockSize: 1 << 16 };
|
|
182
|
+
return [4 /*yield*/, this.filehandle.readFile(opts)];
|
|
183
|
+
case 1:
|
|
184
|
+
buffer = (_a.sent());
|
|
185
|
+
return [4 /*yield*/, (0, bgzf_filehandle_1.unzip)(buffer)
|
|
186
|
+
// check TBI magic numbers
|
|
187
|
+
];
|
|
188
|
+
case 2:
|
|
189
|
+
bytes = _a.sent();
|
|
190
|
+
// check TBI magic numbers
|
|
191
|
+
if (bytes.readUInt32LE(0) === CSI1_MAGIC) {
|
|
192
|
+
data.csiVersion = 1;
|
|
193
|
+
}
|
|
194
|
+
else if (bytes.readUInt32LE(0) === CSI2_MAGIC) {
|
|
195
|
+
data.csiVersion = 2;
|
|
196
|
+
}
|
|
197
|
+
else {
|
|
198
|
+
throw new Error('Not a CSI file');
|
|
199
|
+
// TODO: do we need to support big-endian CSI files?
|
|
200
|
+
}
|
|
201
|
+
this.minShift = bytes.readInt32LE(4);
|
|
202
|
+
this.depth = bytes.readInt32LE(8);
|
|
203
|
+
this.maxBinNumber = ((1 << ((this.depth + 1) * 3)) - 1) / 7;
|
|
204
|
+
auxLength = bytes.readInt32LE(12);
|
|
205
|
+
if (auxLength) {
|
|
206
|
+
Object.assign(data, this.parseAuxData(bytes, 16, auxLength));
|
|
207
|
+
}
|
|
208
|
+
data.refCount = bytes.readInt32LE(16 + auxLength);
|
|
209
|
+
// read the indexes for each reference sequence
|
|
210
|
+
data.indices = new Array(data.refCount);
|
|
211
|
+
currOffset = 16 + auxLength + 4;
|
|
212
|
+
i = 0;
|
|
213
|
+
_a.label = 3;
|
|
214
|
+
case 3:
|
|
215
|
+
if (!(i < data.refCount)) return [3 /*break*/, 6];
|
|
216
|
+
return [4 /*yield*/, (0, util_1.abortBreakPoint)(opts.signal)
|
|
217
|
+
// the binning index
|
|
218
|
+
];
|
|
219
|
+
case 4:
|
|
220
|
+
_a.sent();
|
|
221
|
+
binCount = bytes.readInt32LE(currOffset);
|
|
222
|
+
currOffset += 4;
|
|
223
|
+
binIndex = {};
|
|
224
|
+
stats = void 0;
|
|
225
|
+
for (j = 0; j < binCount; j += 1) {
|
|
226
|
+
bin = bytes.readUInt32LE(currOffset);
|
|
227
|
+
if (bin > this.maxBinNumber) {
|
|
228
|
+
// this is a fake bin that actually has stats information
|
|
229
|
+
// about the reference sequence in it
|
|
230
|
+
stats = this.parsePseudoBin(bytes, currOffset + 4);
|
|
231
|
+
currOffset += 4 + 8 + 4 + 16 + 16;
|
|
232
|
+
}
|
|
233
|
+
else {
|
|
234
|
+
loffset = (0, virtualOffset_1.fromBytes)(bytes, currOffset + 4);
|
|
235
|
+
this._findFirstData(data, loffset);
|
|
236
|
+
chunkCount = bytes.readInt32LE(currOffset + 12);
|
|
237
|
+
currOffset += 16;
|
|
238
|
+
chunks = new Array(chunkCount);
|
|
239
|
+
for (k = 0; k < chunkCount; k += 1) {
|
|
240
|
+
u = (0, virtualOffset_1.fromBytes)(bytes, currOffset);
|
|
241
|
+
v = (0, virtualOffset_1.fromBytes)(bytes, currOffset + 8);
|
|
242
|
+
currOffset += 16;
|
|
243
|
+
// this._findFirstData(data, u)
|
|
244
|
+
chunks[k] = new chunk_1.default(u, v, bin);
|
|
245
|
+
}
|
|
246
|
+
binIndex[bin] = chunks;
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
data.indices[i] = { binIndex: binIndex, stats: stats };
|
|
250
|
+
_a.label = 5;
|
|
251
|
+
case 5:
|
|
252
|
+
i += 1;
|
|
253
|
+
return [3 /*break*/, 3];
|
|
254
|
+
case 6: return [2 /*return*/, data];
|
|
444
255
|
}
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
256
|
+
});
|
|
257
|
+
});
|
|
258
|
+
};
|
|
259
|
+
CSI.prototype.parsePseudoBin = function (bytes, offset) {
|
|
260
|
+
// const one = Long.fromBytesLE(bytes.slice(offset + 4, offset + 12), true)
|
|
261
|
+
// const two = Long.fromBytesLE(bytes.slice(offset + 12, offset + 20), true)
|
|
262
|
+
// const three = longToNumber(
|
|
263
|
+
// Long.fromBytesLE(bytes.slice(offset + 20, offset + 28), true),
|
|
264
|
+
// )
|
|
265
|
+
var lineCount = (0, util_1.longToNumber)(long_1.default.fromBytesLE(Array.prototype.slice.call(bytes, offset + 28, offset + 36), true));
|
|
266
|
+
return { lineCount: lineCount };
|
|
267
|
+
};
|
|
268
|
+
CSI.prototype.blocksForRange = function (refId, min, max, opts) {
|
|
269
|
+
if (opts === void 0) { opts = {}; }
|
|
270
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
271
|
+
var indexData, ba, overlappingBins, chunks, _i, overlappingBins_1, _a, start, end, bin, binChunks, c;
|
|
272
|
+
return __generator(this, function (_b) {
|
|
273
|
+
switch (_b.label) {
|
|
274
|
+
case 0:
|
|
275
|
+
if (min < 0) {
|
|
276
|
+
min = 0;
|
|
277
|
+
}
|
|
278
|
+
return [4 /*yield*/, this.parse(opts)];
|
|
279
|
+
case 1:
|
|
280
|
+
indexData = _b.sent();
|
|
281
|
+
if (!indexData) {
|
|
282
|
+
return [2 /*return*/, []];
|
|
283
|
+
}
|
|
284
|
+
ba = indexData.indices[refId];
|
|
285
|
+
if (!ba) {
|
|
286
|
+
return [2 /*return*/, []];
|
|
287
|
+
}
|
|
288
|
+
overlappingBins = this.reg2bins(min, max) // List of bin #s that overlap min, max
|
|
289
|
+
;
|
|
290
|
+
chunks = [];
|
|
291
|
+
// Find chunks in overlapping bins. Leaf bins (< 4681) are not pruned
|
|
292
|
+
for (_i = 0, overlappingBins_1 = overlappingBins; _i < overlappingBins_1.length; _i++) {
|
|
293
|
+
_a = overlappingBins_1[_i], start = _a[0], end = _a[1];
|
|
294
|
+
for (bin = start; bin <= end; bin++) {
|
|
295
|
+
if (ba.binIndex[bin]) {
|
|
296
|
+
binChunks = ba.binIndex[bin];
|
|
297
|
+
for (c = 0; c < binChunks.length; ++c) {
|
|
298
|
+
chunks.push(new chunk_1.default(binChunks[c].minv, binChunks[c].maxv, bin));
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
}
|
|
465
302
|
}
|
|
466
|
-
|
|
467
|
-
}
|
|
468
|
-
}
|
|
469
|
-
} catch (err) {
|
|
470
|
-
_iterator.e(err);
|
|
471
|
-
} finally {
|
|
472
|
-
_iterator.f();
|
|
303
|
+
return [2 /*return*/, (0, util_1.optimizeChunks)(chunks, new virtualOffset_1.default(0, 0))];
|
|
473
304
|
}
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
case 15:
|
|
478
|
-
case "end":
|
|
479
|
-
return _context4.stop();
|
|
480
|
-
}
|
|
481
|
-
}
|
|
482
|
-
}, _callee4, this);
|
|
483
|
-
}));
|
|
484
|
-
|
|
485
|
-
function blocksForRange(_x3, _x4, _x5) {
|
|
486
|
-
return _blocksForRange.apply(this, arguments);
|
|
487
|
-
}
|
|
488
|
-
|
|
489
|
-
return blocksForRange;
|
|
490
|
-
}()
|
|
305
|
+
});
|
|
306
|
+
});
|
|
307
|
+
};
|
|
491
308
|
/**
|
|
492
309
|
* calculate the list of bins that may overlap with region [beg,end) (zero-based half-open)
|
|
493
310
|
* @returns {Array[number]}
|
|
494
311
|
*/
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
beg -= 1; // < convert to 1-based closed
|
|
500
|
-
|
|
501
|
-
if (beg < 1) {
|
|
502
|
-
beg = 1;
|
|
503
|
-
}
|
|
504
|
-
|
|
505
|
-
if (end > Math.pow(2, 50)) {
|
|
506
|
-
end = Math.pow(2, 34);
|
|
507
|
-
} // 17 GiB ought to be enough for anybody
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
end -= 1;
|
|
511
|
-
var l = 0;
|
|
512
|
-
var t = 0;
|
|
513
|
-
var s = this.minShift + this.depth * 3;
|
|
514
|
-
var bins = [];
|
|
515
|
-
|
|
516
|
-
for (; l <= this.depth; s -= 3, t += lshift(1, l * 3), l += 1) {
|
|
517
|
-
var b = t + rshift(beg, s);
|
|
518
|
-
var e = t + rshift(end, s);
|
|
519
|
-
|
|
520
|
-
if (e - b + bins.length > this.maxBinNumber) {
|
|
521
|
-
var _context5, _context6, _context7;
|
|
522
|
-
|
|
523
|
-
throw new Error((0, _concat.default)(_context5 = (0, _concat.default)(_context6 = (0, _concat.default)(_context7 = "query ".concat(beg, "-")).call(_context7, end, " is too large for current binning scheme (shift ")).call(_context6, this.minShift, ", depth ")).call(_context5, this.depth, "), try a smaller query or a coarser index binning scheme"));
|
|
312
|
+
CSI.prototype.reg2bins = function (beg, end) {
|
|
313
|
+
beg -= 1; // < convert to 1-based closed
|
|
314
|
+
if (beg < 1) {
|
|
315
|
+
beg = 1;
|
|
524
316
|
}
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
317
|
+
if (end > Math.pow(2, 50)) {
|
|
318
|
+
end = Math.pow(2, 34);
|
|
319
|
+
} // 17 GiB ought to be enough for anybody
|
|
320
|
+
end -= 1;
|
|
321
|
+
var l = 0;
|
|
322
|
+
var t = 0;
|
|
323
|
+
var s = this.minShift + this.depth * 3;
|
|
324
|
+
var bins = [];
|
|
325
|
+
for (; l <= this.depth; s -= 3, t += lshift(1, l * 3), l += 1) {
|
|
326
|
+
var b = t + rshift(beg, s);
|
|
327
|
+
var e = t + rshift(end, s);
|
|
328
|
+
if (e - b + bins.length > this.maxBinNumber) {
|
|
329
|
+
throw new Error("query ".concat(beg, "-").concat(end, " is too large for current binning scheme (shift ").concat(this.minShift, ", depth ").concat(this.depth, "), try a smaller query or a coarser index binning scheme"));
|
|
330
|
+
}
|
|
331
|
+
bins.push([b, e]);
|
|
332
|
+
}
|
|
333
|
+
return bins;
|
|
334
|
+
};
|
|
335
|
+
return CSI;
|
|
336
|
+
}(indexFile_1.default));
|
|
535
337
|
exports.default = CSI;
|
|
536
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/csi.ts"],"names":["CSI1_MAGIC","CSI2_MAGIC","lshift","num","bits","rshift","Math","floor","CSI","args","maxBinNumber","depth","minShift","refId","parse","indexData","idx","indices","stats","lineCount","bytes","offset","auxLength","data","formatFlags","readInt32LE","coordinateType","format","Error","columnNumbers","ref","start","end","metaValue","metaChar","String","fromCharCode","skipLines","nameSectionLength","_parseNameBytes","namesBytes","currRefId","currNameStart","refIdToName","refNameToId","i","length","refName","toString","renameRefSeq","opts","csi","maxBlockSize","filehandle","readFile","buffer","readUInt32LE","csiVersion","parseAuxData","refCount","Array","currOffset","signal","binCount","binIndex","j","bin","parsePseudoBin","loffset","_findFirstData","chunkCount","chunks","k","u","v","Chunk","Long","fromBytesLE","prototype","call","min","max","ba","overlappingBins","reg2bins","binChunks","c","push","minv","maxv","VirtualOffset","beg","l","t","s","bins","b","e","IndexFile"],"mappings":"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","sourcesContent":["import Long from 'long'\nimport { unzip } from '@gmod/bgzf-filehandle'\nimport VirtualOffset, { fromBytes } from './virtualOffset'\nimport Chunk from './chunk'\nimport { longToNumber, abortBreakPoint, optimizeChunks, BaseOpts } from './util'\n\nimport IndexFile from './indexFile'\n\nconst CSI1_MAGIC = 21582659 // CSI\\1\nconst CSI2_MAGIC = 38359875 // CSI\\2\n\nfunction lshift(num: number, bits: number) {\n  return num * 2 ** bits\n}\nfunction rshift(num: number, bits: number) {\n  return Math.floor(num / 2 ** bits)\n}\n\nexport default class CSI extends IndexFile {\n  private maxBinNumber: number\n  private depth: number\n  private minShift: number\n  constructor(args: any) {\n    super(args)\n    this.maxBinNumber = 0\n    this.depth = 0\n    this.minShift = 0\n  }\n  async lineCount(refId: number): Promise<number> {\n    const indexData = await this.parse()\n    if (!indexData) {\n      return -1\n    }\n    const idx = indexData.indices[refId]\n    if (!idx) {\n      return -1\n    }\n    const { stats } = indexData.indices[refId]\n    if (stats) {\n      return stats.lineCount\n    }\n    return -1\n  }\n\n  async indexCov() {\n    return []\n  }\n\n  parseAuxData(bytes: Buffer, offset: number, auxLength: number) {\n    if (auxLength < 30) {\n      return {}\n    }\n\n    const data: { [key: string]: any } = {}\n    data.formatFlags = bytes.readInt32LE(offset)\n    data.coordinateType = data.formatFlags & 0x10000 ? 'zero-based-half-open' : '1-based-closed'\n    data.format = ({ 0: 'generic', 1: 'SAM', 2: 'VCF' } as { [key: number]: string })[\n      data.formatFlags & 0xf\n    ]\n    if (!data.format) {\n      throw new Error(`invalid Tabix preset format flags ${data.formatFlags}`)\n    }\n    data.columnNumbers = {\n      ref: bytes.readInt32LE(offset + 4),\n      start: bytes.readInt32LE(offset + 8),\n      end: bytes.readInt32LE(offset + 12),\n    }\n    data.metaValue = bytes.readInt32LE(offset + 16)\n    data.metaChar = data.metaValue ? String.fromCharCode(data.metaValue) : ''\n    data.skipLines = bytes.readInt32LE(offset + 20)\n    const nameSectionLength = bytes.readInt32LE(offset + 24)\n\n    Object.assign(\n      data,\n      this._parseNameBytes(bytes.slice(offset + 28, offset + 28 + nameSectionLength)),\n    )\n    return data\n  }\n\n  _parseNameBytes(namesBytes: Buffer) {\n    let currRefId = 0\n    let currNameStart = 0\n    const refIdToName = []\n    const refNameToId: { [key: string]: number } = {}\n    for (let i = 0; i < namesBytes.length; i += 1) {\n      if (!namesBytes[i]) {\n        if (currNameStart < i) {\n          let refName = namesBytes.toString('utf8', currNameStart, i)\n          refName = this.renameRefSeq(refName)\n          refIdToName[currRefId] = refName\n          refNameToId[refName] = currRefId\n        }\n        currNameStart = i + 1\n        currRefId += 1\n      }\n    }\n    return { refNameToId, refIdToName }\n  }\n\n  // fetch and parse the index\n  async _parse(opts: { signal?: AbortSignal }) {\n    const data: { [key: string]: any } = { csi: true, maxBlockSize: 1 << 16 }\n    const buffer = (await this.filehandle.readFile(opts)) as Buffer\n    const bytes = await unzip(buffer)\n\n    // check TBI magic numbers\n    if (bytes.readUInt32LE(0) === CSI1_MAGIC) {\n      data.csiVersion = 1\n    } else if (bytes.readUInt32LE(0) === CSI2_MAGIC) {\n      data.csiVersion = 2\n    } else {\n      throw new Error('Not a CSI file')\n      // TODO: do we need to support big-endian CSI files?\n    }\n\n    this.minShift = bytes.readInt32LE(4)\n    this.depth = bytes.readInt32LE(8)\n    this.maxBinNumber = ((1 << ((this.depth + 1) * 3)) - 1) / 7\n    const auxLength = bytes.readInt32LE(12)\n    if (auxLength) {\n      Object.assign(data, this.parseAuxData(bytes, 16, auxLength))\n    }\n    data.refCount = bytes.readInt32LE(16 + auxLength)\n\n    // read the indexes for each reference sequence\n    data.indices = new Array(data.refCount)\n    let currOffset = 16 + auxLength + 4\n    for (let i = 0; i < data.refCount; i += 1) {\n      await abortBreakPoint(opts.signal)\n      // the binning index\n      const binCount = bytes.readInt32LE(currOffset)\n      currOffset += 4\n      const binIndex: { [key: string]: Chunk[] } = {}\n      let stats // < provided by parsing a pseudo-bin, if present\n      for (let j = 0; j < binCount; j += 1) {\n        const bin = bytes.readUInt32LE(currOffset)\n        if (bin > this.maxBinNumber) {\n          // this is a fake bin that actually has stats information\n          // about the reference sequence in it\n          stats = this.parsePseudoBin(bytes, currOffset + 4)\n          currOffset += 4 + 8 + 4 + 16 + 16\n        } else {\n          const loffset = fromBytes(bytes, currOffset + 4)\n          this._findFirstData(data, loffset)\n          const chunkCount = bytes.readInt32LE(currOffset + 12)\n          currOffset += 16\n          const chunks = new Array(chunkCount)\n          for (let k = 0; k < chunkCount; k += 1) {\n            const u = fromBytes(bytes, currOffset)\n            const v = fromBytes(bytes, currOffset + 8)\n            currOffset += 16\n            // this._findFirstData(data, u)\n            chunks[k] = new Chunk(u, v, bin)\n          }\n          binIndex[bin] = chunks\n        }\n      }\n\n      data.indices[i] = { binIndex, stats }\n    }\n\n    return data\n  }\n\n  parsePseudoBin(bytes: Buffer, offset: number) {\n    // const one = Long.fromBytesLE(bytes.slice(offset + 4, offset + 12), true)\n    // const two = Long.fromBytesLE(bytes.slice(offset + 12, offset + 20), true)\n    // const three = longToNumber(\n    //   Long.fromBytesLE(bytes.slice(offset + 20, offset + 28), true),\n    // )\n    const lineCount = longToNumber(\n      Long.fromBytesLE(Array.prototype.slice.call(bytes, offset + 28, offset + 36), true),\n    )\n    return { lineCount }\n  }\n\n  async blocksForRange(refId: number, min: number, max: number, opts: BaseOpts = {}) {\n    if (min < 0) {\n      min = 0\n    }\n\n    const indexData = await this.parse(opts)\n    if (!indexData) {\n      return []\n    }\n    const ba = indexData.indices[refId]\n    if (!ba) {\n      return []\n    }\n\n    const overlappingBins = this.reg2bins(min, max) // List of bin #s that overlap min, max\n    const chunks: Chunk[] = []\n\n    // Find chunks in overlapping bins.  Leaf bins (< 4681) are not pruned\n    for (const [start, end] of overlappingBins) {\n      for (let bin = start; bin <= end; bin++) {\n        if (ba.binIndex[bin]) {\n          const binChunks = ba.binIndex[bin]\n          for (let c = 0; c < binChunks.length; ++c) {\n            chunks.push(new Chunk(binChunks[c].minv, binChunks[c].maxv, bin))\n          }\n        }\n      }\n    }\n\n    return optimizeChunks(chunks, new VirtualOffset(0, 0))\n  }\n\n  /**\n   * calculate the list of bins that may overlap with region [beg,end) (zero-based half-open)\n   * @returns {Array[number]}\n   */\n  reg2bins(beg: number, end: number) {\n    beg -= 1 // < convert to 1-based closed\n    if (beg < 1) {\n      beg = 1\n    }\n    if (end > 2 ** 50) {\n      end = 2 ** 34\n    } // 17 GiB ought to be enough for anybody\n    end -= 1\n    let l = 0\n    let t = 0\n    let s = this.minShift + this.depth * 3\n    const bins = []\n    for (; l <= this.depth; s -= 3, t += lshift(1, l * 3), l += 1) {\n      const b = t + rshift(beg, s)\n      const e = t + rshift(end, s)\n      if (e - b + bins.length > this.maxBinNumber) {\n        throw new Error(\n          `query ${beg}-${end} is too large for current binning scheme (shift ${this.minShift}, depth ${this.depth}), try a smaller query or a coarser index binning scheme`,\n        )\n      }\n      bins.push([b, e])\n    }\n    return bins\n  }\n}\n"]}
|
|
338
|
+
//# sourceMappingURL=csi.js.map
|