@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/bai.js
CHANGED
|
@@ -1,565 +1,317 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
var
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
var
|
|
18
|
-
|
|
19
|
-
var
|
|
20
|
-
|
|
21
|
-
var
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
var
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
var
|
|
70
|
-
|
|
71
|
-
var
|
|
72
|
-
|
|
73
|
-
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; } } }; }
|
|
74
|
-
|
|
75
|
-
function _unsupportedIterableToArray(o, minLen) { var _context7; if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = (0, _slice.default)(_context7 = Object.prototype.toString.call(o)).call(_context7, 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); }
|
|
76
|
-
|
|
77
|
-
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; }
|
|
78
|
-
|
|
79
|
-
function ownKeys(object, enumerableOnly) { var keys = (0, _keys.default)(object); if (_getOwnPropertySymbols.default) { var symbols = (0, _getOwnPropertySymbols.default)(object); if (enumerableOnly) symbols = (0, _filter.default)(symbols).call(symbols, function (sym) { return (0, _getOwnPropertyDescriptor.default)(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
|
80
|
-
|
|
81
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context5; (0, _forEach.default)(_context5 = ownKeys(Object(source), true)).call(_context5, function (key) { (0, _defineProperty3.default)(target, key, source[key]); }); } else if (_getOwnPropertyDescriptors.default) { (0, _defineProperties.default)(target, (0, _getOwnPropertyDescriptors.default)(source)); } else { var _context6; (0, _forEach.default)(_context6 = ownKeys(Object(source))).call(_context6, function (key) { (0, _defineProperty2.default)(target, key, (0, _getOwnPropertyDescriptor.default)(source, key)); }); } } return target; }
|
|
82
|
-
|
|
83
|
-
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); }; }
|
|
84
|
-
|
|
85
|
-
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; } }
|
|
86
|
-
|
|
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 __assign = (this && this.__assign) || function () {
|
|
18
|
+
__assign = Object.assign || function(t) {
|
|
19
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
20
|
+
s = arguments[i];
|
|
21
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
22
|
+
t[p] = s[p];
|
|
23
|
+
}
|
|
24
|
+
return t;
|
|
25
|
+
};
|
|
26
|
+
return __assign.apply(this, arguments);
|
|
27
|
+
};
|
|
28
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
29
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
30
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
31
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
32
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
33
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
34
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
35
|
+
});
|
|
36
|
+
};
|
|
37
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
38
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
39
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
40
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
41
|
+
function step(op) {
|
|
42
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
43
|
+
while (_) try {
|
|
44
|
+
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;
|
|
45
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
46
|
+
switch (op[0]) {
|
|
47
|
+
case 0: case 1: t = op; break;
|
|
48
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
49
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
50
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
51
|
+
default:
|
|
52
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
53
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
54
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
55
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
56
|
+
if (t[2]) _.ops.pop();
|
|
57
|
+
_.trys.pop(); continue;
|
|
58
|
+
}
|
|
59
|
+
op = body.call(thisArg, _);
|
|
60
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
61
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
65
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
66
|
+
};
|
|
67
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
68
|
+
var long_1 = __importDefault(require("long"));
|
|
69
|
+
var virtualOffset_1 = require("./virtualOffset");
|
|
70
|
+
var chunk_1 = __importDefault(require("./chunk"));
|
|
71
|
+
var indexFile_1 = __importDefault(require("./indexFile"));
|
|
72
|
+
var util_1 = require("./util");
|
|
87
73
|
var BAI_MAGIC = 21578050; // BAI\1
|
|
88
|
-
|
|
89
74
|
function roundDown(n, multiple) {
|
|
90
|
-
|
|
75
|
+
return n - (n % multiple);
|
|
91
76
|
}
|
|
92
|
-
|
|
93
77
|
function roundUp(n, multiple) {
|
|
94
|
-
|
|
78
|
+
return n - (n % multiple) + multiple;
|
|
95
79
|
}
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
var _super = _createSuper(BAI);
|
|
101
|
-
|
|
102
|
-
function BAI() {
|
|
103
|
-
(0, _classCallCheck2.default)(this, BAI);
|
|
104
|
-
return _super.apply(this, arguments);
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
(0, _createClass2.default)(BAI, [{
|
|
108
|
-
key: "parsePseudoBin",
|
|
109
|
-
value: function parsePseudoBin(bytes, offset) {
|
|
110
|
-
var lineCount = (0, _util.longToNumber)(_long.default.fromBytesLE((0, _slice.default)(Array.prototype).call(bytes, offset + 16, offset + 24), true));
|
|
111
|
-
return {
|
|
112
|
-
lineCount: lineCount
|
|
113
|
-
};
|
|
80
|
+
var BAI = /** @class */ (function (_super) {
|
|
81
|
+
__extends(BAI, _super);
|
|
82
|
+
function BAI() {
|
|
83
|
+
return _super !== null && _super.apply(this, arguments) || this;
|
|
114
84
|
}
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
ret
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
index = prom.indices[refId];
|
|
135
|
-
|
|
136
|
-
if (index) {
|
|
137
|
-
_context.next = 7;
|
|
138
|
-
break;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
return _context.abrupt("return", -1);
|
|
142
|
-
|
|
143
|
-
case 7:
|
|
144
|
-
ret = index.stats || {};
|
|
145
|
-
return _context.abrupt("return", ret.lineCount === undefined ? -1 : ret.lineCount);
|
|
146
|
-
|
|
147
|
-
case 9:
|
|
148
|
-
case "end":
|
|
149
|
-
return _context.stop();
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
}, _callee, this);
|
|
153
|
-
}));
|
|
154
|
-
|
|
155
|
-
function lineCount(_x) {
|
|
156
|
-
return _lineCount.apply(this, arguments);
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
return lineCount;
|
|
160
|
-
}() // fetch and parse the index
|
|
161
|
-
|
|
162
|
-
}, {
|
|
163
|
-
key: "_parse",
|
|
164
|
-
value: function () {
|
|
165
|
-
var _parse2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
|
|
166
|
-
var opts,
|
|
167
|
-
data,
|
|
168
|
-
bytes,
|
|
169
|
-
depth,
|
|
170
|
-
binLimit,
|
|
171
|
-
currOffset,
|
|
172
|
-
i,
|
|
173
|
-
binCount,
|
|
174
|
-
stats,
|
|
175
|
-
binIndex,
|
|
176
|
-
j,
|
|
177
|
-
bin,
|
|
178
|
-
chunkCount,
|
|
179
|
-
chunks,
|
|
180
|
-
k,
|
|
181
|
-
u,
|
|
182
|
-
v,
|
|
183
|
-
linearCount,
|
|
184
|
-
linearIndex,
|
|
185
|
-
_k,
|
|
186
|
-
_args2 = arguments;
|
|
187
|
-
|
|
188
|
-
return _regenerator.default.wrap(function _callee2$(_context2) {
|
|
189
|
-
while (1) {
|
|
190
|
-
switch (_context2.prev = _context2.next) {
|
|
191
|
-
case 0:
|
|
192
|
-
opts = _args2.length > 0 && _args2[0] !== undefined ? _args2[0] : {};
|
|
193
|
-
data = {
|
|
194
|
-
bai: true,
|
|
195
|
-
maxBlockSize: 1 << 16
|
|
196
|
-
};
|
|
197
|
-
_context2.next = 4;
|
|
198
|
-
return this.filehandle.readFile(opts);
|
|
199
|
-
|
|
200
|
-
case 4:
|
|
201
|
-
bytes = _context2.sent;
|
|
202
|
-
|
|
203
|
-
if (!(bytes.readUInt32LE(0) !== BAI_MAGIC)) {
|
|
204
|
-
_context2.next = 7;
|
|
205
|
-
break;
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
throw new Error('Not a BAI file');
|
|
209
|
-
|
|
210
|
-
case 7:
|
|
211
|
-
data.refCount = bytes.readInt32LE(4);
|
|
212
|
-
depth = 5;
|
|
213
|
-
binLimit = ((1 << (depth + 1) * 3) - 1) / 7; // read the indexes for each reference sequence
|
|
214
|
-
|
|
215
|
-
data.indices = new Array(data.refCount);
|
|
216
|
-
currOffset = 8;
|
|
217
|
-
i = 0;
|
|
218
|
-
|
|
219
|
-
case 13:
|
|
220
|
-
if (!(i < data.refCount)) {
|
|
221
|
-
_context2.next = 50;
|
|
222
|
-
break;
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
_context2.next = 16;
|
|
226
|
-
return (0, _util.abortBreakPoint)(opts.signal);
|
|
227
|
-
|
|
228
|
-
case 16:
|
|
229
|
-
// the binning index
|
|
230
|
-
binCount = bytes.readInt32LE(currOffset);
|
|
231
|
-
stats = void 0;
|
|
232
|
-
currOffset += 4;
|
|
233
|
-
binIndex = {};
|
|
234
|
-
j = 0;
|
|
235
|
-
|
|
236
|
-
case 21:
|
|
237
|
-
if (!(j < binCount)) {
|
|
238
|
-
_context2.next = 42;
|
|
239
|
-
break;
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
bin = bytes.readUInt32LE(currOffset);
|
|
243
|
-
currOffset += 4;
|
|
244
|
-
|
|
245
|
-
if (!(bin === binLimit + 1)) {
|
|
246
|
-
_context2.next = 30;
|
|
247
|
-
break;
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
currOffset += 4;
|
|
251
|
-
stats = this.parsePseudoBin(bytes, currOffset);
|
|
252
|
-
currOffset += 32;
|
|
253
|
-
_context2.next = 39;
|
|
254
|
-
break;
|
|
255
|
-
|
|
256
|
-
case 30:
|
|
257
|
-
if (!(bin > binLimit + 1)) {
|
|
258
|
-
_context2.next = 34;
|
|
259
|
-
break;
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
throw new Error('bai index contains too many bins, please use CSI');
|
|
263
|
-
|
|
264
|
-
case 34:
|
|
265
|
-
chunkCount = bytes.readInt32LE(currOffset);
|
|
266
|
-
currOffset += 4;
|
|
267
|
-
chunks = new Array(chunkCount);
|
|
268
|
-
|
|
269
|
-
for (k = 0; k < chunkCount; k += 1) {
|
|
270
|
-
u = (0, _virtualOffset.fromBytes)(bytes, currOffset);
|
|
271
|
-
v = (0, _virtualOffset.fromBytes)(bytes, currOffset + 8);
|
|
272
|
-
currOffset += 16;
|
|
273
|
-
|
|
274
|
-
this._findFirstData(data, u);
|
|
275
|
-
|
|
276
|
-
chunks[k] = new _chunk.default(u, v, bin);
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
binIndex[bin] = chunks;
|
|
280
|
-
|
|
281
|
-
case 39:
|
|
282
|
-
j += 1;
|
|
283
|
-
_context2.next = 21;
|
|
284
|
-
break;
|
|
285
|
-
|
|
286
|
-
case 42:
|
|
287
|
-
linearCount = bytes.readInt32LE(currOffset);
|
|
288
|
-
currOffset += 4; // as we're going through the linear index, figure out
|
|
289
|
-
// the smallest virtual offset in the indexes, which
|
|
290
|
-
// tells us where the BAM header ends
|
|
291
|
-
|
|
292
|
-
linearIndex = new Array(linearCount);
|
|
293
|
-
|
|
294
|
-
for (_k = 0; _k < linearCount; _k += 1) {
|
|
295
|
-
linearIndex[_k] = (0, _virtualOffset.fromBytes)(bytes, currOffset);
|
|
296
|
-
currOffset += 8;
|
|
297
|
-
|
|
298
|
-
this._findFirstData(data, linearIndex[_k]);
|
|
299
|
-
}
|
|
300
|
-
|
|
301
|
-
data.indices[i] = {
|
|
302
|
-
binIndex: binIndex,
|
|
303
|
-
linearIndex: linearIndex,
|
|
304
|
-
stats: stats
|
|
305
|
-
};
|
|
306
|
-
|
|
307
|
-
case 47:
|
|
308
|
-
i += 1;
|
|
309
|
-
_context2.next = 13;
|
|
310
|
-
break;
|
|
311
|
-
|
|
312
|
-
case 50:
|
|
313
|
-
return _context2.abrupt("return", data);
|
|
314
|
-
|
|
315
|
-
case 51:
|
|
316
|
-
case "end":
|
|
317
|
-
return _context2.stop();
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
|
-
}, _callee2, this);
|
|
321
|
-
}));
|
|
322
|
-
|
|
323
|
-
function _parse() {
|
|
324
|
-
return _parse2.apply(this, arguments);
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
return _parse;
|
|
328
|
-
}()
|
|
329
|
-
}, {
|
|
330
|
-
key: "indexCov",
|
|
331
|
-
value: function () {
|
|
332
|
-
var _indexCov = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(seqId, start, end) {
|
|
333
|
-
var opts,
|
|
334
|
-
v,
|
|
335
|
-
range,
|
|
336
|
-
indexData,
|
|
337
|
-
seqIdx,
|
|
338
|
-
_seqIdx$linearIndex,
|
|
339
|
-
linearIndex,
|
|
340
|
-
stats,
|
|
341
|
-
e,
|
|
342
|
-
s,
|
|
343
|
-
depths,
|
|
344
|
-
totalSize,
|
|
345
|
-
currentPos,
|
|
346
|
-
i,
|
|
347
|
-
j,
|
|
348
|
-
_args3 = arguments;
|
|
349
|
-
|
|
350
|
-
return _regenerator.default.wrap(function _callee3$(_context3) {
|
|
351
|
-
while (1) {
|
|
352
|
-
switch (_context3.prev = _context3.next) {
|
|
353
|
-
case 0:
|
|
354
|
-
opts = _args3.length > 3 && _args3[3] !== undefined ? _args3[3] : {};
|
|
355
|
-
v = 16384;
|
|
356
|
-
range = start !== undefined;
|
|
357
|
-
_context3.next = 5;
|
|
358
|
-
return this.parse(opts);
|
|
359
|
-
|
|
360
|
-
case 5:
|
|
361
|
-
indexData = _context3.sent;
|
|
362
|
-
seqIdx = indexData.indices[seqId];
|
|
363
|
-
|
|
364
|
-
if (seqIdx) {
|
|
365
|
-
_context3.next = 9;
|
|
366
|
-
break;
|
|
367
|
-
}
|
|
368
|
-
|
|
369
|
-
return _context3.abrupt("return", []);
|
|
370
|
-
|
|
371
|
-
case 9:
|
|
372
|
-
_seqIdx$linearIndex = seqIdx.linearIndex, linearIndex = _seqIdx$linearIndex === void 0 ? [] : _seqIdx$linearIndex, stats = seqIdx.stats;
|
|
373
|
-
|
|
374
|
-
if (linearIndex.length) {
|
|
375
|
-
_context3.next = 12;
|
|
376
|
-
break;
|
|
377
|
-
}
|
|
378
|
-
|
|
379
|
-
return _context3.abrupt("return", []);
|
|
380
|
-
|
|
381
|
-
case 12:
|
|
382
|
-
e = end !== undefined ? roundUp(end, v) : (linearIndex.length - 1) * v;
|
|
383
|
-
s = start !== undefined ? roundDown(start, v) : 0;
|
|
384
|
-
|
|
385
|
-
if (range) {
|
|
386
|
-
depths = new Array((e - s) / v);
|
|
387
|
-
} else {
|
|
388
|
-
depths = new Array(linearIndex.length - 1);
|
|
85
|
+
BAI.prototype.parsePseudoBin = function (bytes, offset) {
|
|
86
|
+
var lineCount = (0, util_1.longToNumber)(long_1.default.fromBytesLE(Array.prototype.slice.call(bytes, offset + 16, offset + 24), true));
|
|
87
|
+
return { lineCount: lineCount };
|
|
88
|
+
};
|
|
89
|
+
BAI.prototype.lineCount = function (refId, opts) {
|
|
90
|
+
if (opts === void 0) { opts = {}; }
|
|
91
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
92
|
+
var prom, index, ret;
|
|
93
|
+
return __generator(this, function (_a) {
|
|
94
|
+
switch (_a.label) {
|
|
95
|
+
case 0: return [4 /*yield*/, this.parse(opts)];
|
|
96
|
+
case 1:
|
|
97
|
+
prom = _a.sent();
|
|
98
|
+
index = prom.indices[refId];
|
|
99
|
+
if (!index) {
|
|
100
|
+
return [2 /*return*/, -1];
|
|
101
|
+
}
|
|
102
|
+
ret = index.stats || {};
|
|
103
|
+
return [2 /*return*/, ret.lineCount === undefined ? -1 : ret.lineCount];
|
|
389
104
|
}
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
};
|
|
108
|
+
BAI.prototype.fetchBai = function (opts) {
|
|
109
|
+
var _this = this;
|
|
110
|
+
if (opts === void 0) { opts = {}; }
|
|
111
|
+
if (!this.baiP) {
|
|
112
|
+
this.baiP = this.filehandle.readFile(opts).catch(function (e) {
|
|
113
|
+
_this.baiP = undefined;
|
|
114
|
+
throw e;
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
return this.baiP;
|
|
118
|
+
};
|
|
119
|
+
// fetch and parse the index
|
|
120
|
+
BAI.prototype._parse = function (opts) {
|
|
121
|
+
if (opts === void 0) { opts = {}; }
|
|
122
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
123
|
+
var data, bytes, depth, binLimit, currOffset, i, binCount, stats, binIndex, j, bin, chunkCount, chunks, k, u, v, linearCount, linearIndex, k;
|
|
124
|
+
return __generator(this, function (_a) {
|
|
125
|
+
switch (_a.label) {
|
|
126
|
+
case 0:
|
|
127
|
+
data = { bai: true, maxBlockSize: 1 << 16 };
|
|
128
|
+
return [4 /*yield*/, this.fetchBai()
|
|
129
|
+
// check BAI magic numbers
|
|
130
|
+
];
|
|
131
|
+
case 1:
|
|
132
|
+
bytes = _a.sent();
|
|
133
|
+
// check BAI magic numbers
|
|
134
|
+
if (bytes.readUInt32LE(0) !== BAI_MAGIC) {
|
|
135
|
+
throw new Error('Not a BAI file');
|
|
136
|
+
}
|
|
137
|
+
data.refCount = bytes.readInt32LE(4);
|
|
138
|
+
depth = 5;
|
|
139
|
+
binLimit = ((1 << ((depth + 1) * 3)) - 1) / 7;
|
|
140
|
+
// read the indexes for each reference sequence
|
|
141
|
+
data.indices = new Array(data.refCount);
|
|
142
|
+
currOffset = 8;
|
|
143
|
+
i = 0;
|
|
144
|
+
_a.label = 2;
|
|
145
|
+
case 2:
|
|
146
|
+
if (!(i < data.refCount)) return [3 /*break*/, 5];
|
|
147
|
+
return [4 /*yield*/, (0, util_1.abortBreakPoint)(opts.signal)
|
|
148
|
+
// the binning index
|
|
149
|
+
];
|
|
150
|
+
case 3:
|
|
151
|
+
_a.sent();
|
|
152
|
+
binCount = bytes.readInt32LE(currOffset);
|
|
153
|
+
stats = void 0;
|
|
154
|
+
currOffset += 4;
|
|
155
|
+
binIndex = {};
|
|
156
|
+
for (j = 0; j < binCount; j += 1) {
|
|
157
|
+
bin = bytes.readUInt32LE(currOffset);
|
|
158
|
+
currOffset += 4;
|
|
159
|
+
if (bin === binLimit + 1) {
|
|
160
|
+
currOffset += 4;
|
|
161
|
+
stats = this.parsePseudoBin(bytes, currOffset);
|
|
162
|
+
currOffset += 32;
|
|
163
|
+
}
|
|
164
|
+
else if (bin > binLimit + 1) {
|
|
165
|
+
throw new Error('bai index contains too many bins, please use CSI');
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
168
|
+
chunkCount = bytes.readInt32LE(currOffset);
|
|
169
|
+
currOffset += 4;
|
|
170
|
+
chunks = new Array(chunkCount);
|
|
171
|
+
for (k = 0; k < chunkCount; k += 1) {
|
|
172
|
+
u = (0, virtualOffset_1.fromBytes)(bytes, currOffset);
|
|
173
|
+
v = (0, virtualOffset_1.fromBytes)(bytes, currOffset + 8);
|
|
174
|
+
currOffset += 16;
|
|
175
|
+
this._findFirstData(data, u);
|
|
176
|
+
chunks[k] = new chunk_1.default(u, v, bin);
|
|
177
|
+
}
|
|
178
|
+
binIndex[bin] = chunks;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
linearCount = bytes.readInt32LE(currOffset);
|
|
182
|
+
currOffset += 4;
|
|
183
|
+
linearIndex = new Array(linearCount);
|
|
184
|
+
for (k = 0; k < linearCount; k += 1) {
|
|
185
|
+
linearIndex[k] = (0, virtualOffset_1.fromBytes)(bytes, currOffset);
|
|
186
|
+
currOffset += 8;
|
|
187
|
+
this._findFirstData(data, linearIndex[k]);
|
|
188
|
+
}
|
|
189
|
+
data.indices[i] = { binIndex: binIndex, linearIndex: linearIndex, stats: stats };
|
|
190
|
+
_a.label = 4;
|
|
191
|
+
case 4:
|
|
192
|
+
i += 1;
|
|
193
|
+
return [3 /*break*/, 2];
|
|
194
|
+
case 5: return [2 /*return*/, data];
|
|
396
195
|
}
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
196
|
+
});
|
|
197
|
+
});
|
|
198
|
+
};
|
|
199
|
+
BAI.prototype.indexCov = function (seqId, start, end, opts) {
|
|
200
|
+
if (opts === void 0) { opts = {}; }
|
|
201
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
202
|
+
var v, range, indexData, seqIdx, _a, linearIndex, stats, e, s, depths, totalSize, currentPos, i, j;
|
|
203
|
+
return __generator(this, function (_b) {
|
|
204
|
+
switch (_b.label) {
|
|
205
|
+
case 0:
|
|
206
|
+
v = 16384;
|
|
207
|
+
range = start !== undefined;
|
|
208
|
+
return [4 /*yield*/, this.parse(opts)];
|
|
209
|
+
case 1:
|
|
210
|
+
indexData = _b.sent();
|
|
211
|
+
seqIdx = indexData.indices[seqId];
|
|
212
|
+
if (!seqIdx) {
|
|
213
|
+
return [2 /*return*/, []];
|
|
214
|
+
}
|
|
215
|
+
_a = seqIdx.linearIndex, linearIndex = _a === void 0 ? [] : _a, stats = seqIdx.stats;
|
|
216
|
+
if (!linearIndex.length) {
|
|
217
|
+
return [2 /*return*/, []];
|
|
218
|
+
}
|
|
219
|
+
e = end !== undefined ? roundUp(end, v) : (linearIndex.length - 1) * v;
|
|
220
|
+
s = start !== undefined ? roundDown(start, v) : 0;
|
|
221
|
+
if (range) {
|
|
222
|
+
depths = new Array((e - s) / v);
|
|
223
|
+
}
|
|
224
|
+
else {
|
|
225
|
+
depths = new Array(linearIndex.length - 1);
|
|
226
|
+
}
|
|
227
|
+
totalSize = linearIndex[linearIndex.length - 1].blockPosition;
|
|
228
|
+
if (e > (linearIndex.length - 1) * v) {
|
|
229
|
+
throw new Error('query outside of range of linear index');
|
|
230
|
+
}
|
|
231
|
+
currentPos = linearIndex[s / v].blockPosition;
|
|
232
|
+
for (i = s / v, j = 0; i < e / v; i++, j++) {
|
|
233
|
+
depths[j] = {
|
|
234
|
+
score: linearIndex[i + 1].blockPosition - currentPos,
|
|
235
|
+
start: i * v,
|
|
236
|
+
end: i * v + v,
|
|
237
|
+
};
|
|
238
|
+
currentPos = linearIndex[i + 1].blockPosition;
|
|
239
|
+
}
|
|
240
|
+
return [2 /*return*/, depths.map(function (d) {
|
|
241
|
+
return __assign(__assign({}, d), { score: (d.score * stats.lineCount) / totalSize });
|
|
242
|
+
})];
|
|
410
243
|
}
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
score: d.score * stats.lineCount / totalSize
|
|
415
|
-
});
|
|
416
|
-
}));
|
|
417
|
-
|
|
418
|
-
case 21:
|
|
419
|
-
case "end":
|
|
420
|
-
return _context3.stop();
|
|
421
|
-
}
|
|
422
|
-
}
|
|
423
|
-
}, _callee3, this);
|
|
424
|
-
}));
|
|
425
|
-
|
|
426
|
-
function indexCov(_x2, _x3, _x4) {
|
|
427
|
-
return _indexCov.apply(this, arguments);
|
|
428
|
-
}
|
|
429
|
-
|
|
430
|
-
return indexCov;
|
|
431
|
-
}()
|
|
244
|
+
});
|
|
245
|
+
});
|
|
246
|
+
};
|
|
432
247
|
/**
|
|
433
248
|
* calculate the list of bins that may overlap with region [beg,end) (zero-based half-open)
|
|
434
249
|
* @returns {Array[number]}
|
|
435
250
|
*/
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
overlappingBins,
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
end,
|
|
457
|
-
bin,
|
|
458
|
-
binChunks,
|
|
459
|
-
c,
|
|
460
|
-
nintv,
|
|
461
|
-
lowest,
|
|
462
|
-
minLin,
|
|
463
|
-
maxLin,
|
|
464
|
-
i,
|
|
465
|
-
vp,
|
|
466
|
-
_args4 = arguments;
|
|
467
|
-
|
|
468
|
-
return _regenerator.default.wrap(function _callee4$(_context4) {
|
|
469
|
-
while (1) {
|
|
470
|
-
switch (_context4.prev = _context4.next) {
|
|
471
|
-
case 0:
|
|
472
|
-
opts = _args4.length > 3 && _args4[3] !== undefined ? _args4[3] : {};
|
|
473
|
-
|
|
474
|
-
if (min < 0) {
|
|
475
|
-
min = 0;
|
|
476
|
-
}
|
|
477
|
-
|
|
478
|
-
_context4.next = 4;
|
|
479
|
-
return this.parse(opts);
|
|
480
|
-
|
|
481
|
-
case 4:
|
|
482
|
-
indexData = _context4.sent;
|
|
483
|
-
|
|
484
|
-
if (indexData) {
|
|
485
|
-
_context4.next = 7;
|
|
486
|
-
break;
|
|
487
|
-
}
|
|
488
|
-
|
|
489
|
-
return _context4.abrupt("return", []);
|
|
490
|
-
|
|
491
|
-
case 7:
|
|
492
|
-
ba = indexData.indices[refId];
|
|
493
|
-
|
|
494
|
-
if (ba) {
|
|
495
|
-
_context4.next = 10;
|
|
496
|
-
break;
|
|
497
|
-
}
|
|
498
|
-
|
|
499
|
-
return _context4.abrupt("return", []);
|
|
500
|
-
|
|
501
|
-
case 10:
|
|
502
|
-
overlappingBins = this.reg2bins(min, max); // List of bin #s that overlap min, max
|
|
503
|
-
|
|
504
|
-
chunks = []; // Find chunks in overlapping bins. Leaf bins (< 4681) are not pruned
|
|
505
|
-
|
|
506
|
-
_iterator = _createForOfIteratorHelper(overlappingBins);
|
|
507
|
-
|
|
508
|
-
try {
|
|
509
|
-
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
510
|
-
_step$value = (0, _slicedToArray2.default)(_step.value, 2), start = _step$value[0], end = _step$value[1];
|
|
511
|
-
|
|
512
|
-
for (bin = start; bin <= end; bin++) {
|
|
513
|
-
if (ba.binIndex[bin]) {
|
|
514
|
-
binChunks = ba.binIndex[bin];
|
|
515
|
-
|
|
516
|
-
for (c = 0; c < binChunks.length; ++c) {
|
|
517
|
-
chunks.push(new _chunk.default(binChunks[c].minv, binChunks[c].maxv, bin));
|
|
251
|
+
BAI.prototype.reg2bins = function (beg, end) {
|
|
252
|
+
end -= 1;
|
|
253
|
+
return [
|
|
254
|
+
[0, 0],
|
|
255
|
+
[1 + (beg >> 26), 1 + (end >> 26)],
|
|
256
|
+
[9 + (beg >> 23), 9 + (end >> 23)],
|
|
257
|
+
[73 + (beg >> 20), 73 + (end >> 20)],
|
|
258
|
+
[585 + (beg >> 17), 585 + (end >> 17)],
|
|
259
|
+
[4681 + (beg >> 14), 4681 + (end >> 14)],
|
|
260
|
+
];
|
|
261
|
+
};
|
|
262
|
+
BAI.prototype.blocksForRange = function (refId, min, max, opts) {
|
|
263
|
+
if (opts === void 0) { opts = {}; }
|
|
264
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
265
|
+
var indexData, ba, overlappingBins, chunks, _i, overlappingBins_1, _a, start, end, bin, binChunks, c, nintv, lowest, minLin, maxLin, i, vp;
|
|
266
|
+
return __generator(this, function (_b) {
|
|
267
|
+
switch (_b.label) {
|
|
268
|
+
case 0:
|
|
269
|
+
if (min < 0) {
|
|
270
|
+
min = 0;
|
|
518
271
|
}
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
272
|
+
return [4 /*yield*/, this.parse(opts)];
|
|
273
|
+
case 1:
|
|
274
|
+
indexData = _b.sent();
|
|
275
|
+
if (!indexData) {
|
|
276
|
+
return [2 /*return*/, []];
|
|
277
|
+
}
|
|
278
|
+
ba = indexData.indices[refId];
|
|
279
|
+
if (!ba) {
|
|
280
|
+
return [2 /*return*/, []];
|
|
281
|
+
}
|
|
282
|
+
overlappingBins = this.reg2bins(min, max) // List of bin #s that overlap min, max
|
|
283
|
+
;
|
|
284
|
+
chunks = [];
|
|
285
|
+
// Find chunks in overlapping bins. Leaf bins (< 4681) are not pruned
|
|
286
|
+
for (_i = 0, overlappingBins_1 = overlappingBins; _i < overlappingBins_1.length; _i++) {
|
|
287
|
+
_a = overlappingBins_1[_i], start = _a[0], end = _a[1];
|
|
288
|
+
for (bin = start; bin <= end; bin++) {
|
|
289
|
+
if (ba.binIndex[bin]) {
|
|
290
|
+
binChunks = ba.binIndex[bin];
|
|
291
|
+
for (c = 0; c < binChunks.length; ++c) {
|
|
292
|
+
chunks.push(new chunk_1.default(binChunks[c].minv, binChunks[c].maxv, bin));
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
nintv = ba.linearIndex.length;
|
|
298
|
+
lowest = null;
|
|
299
|
+
minLin = Math.min(min >> 14, nintv - 1);
|
|
300
|
+
maxLin = Math.min(max >> 14, nintv - 1);
|
|
301
|
+
for (i = minLin; i <= maxLin; ++i) {
|
|
302
|
+
vp = ba.linearIndex[i];
|
|
303
|
+
if (vp) {
|
|
304
|
+
if (!lowest || vp.compareTo(lowest) < 0) {
|
|
305
|
+
lowest = vp;
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
return [2 /*return*/, (0, util_1.optimizeChunks)(chunks, lowest)];
|
|
542
310
|
}
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
return _context4.stop();
|
|
549
|
-
}
|
|
550
|
-
}
|
|
551
|
-
}, _callee4, this);
|
|
552
|
-
}));
|
|
553
|
-
|
|
554
|
-
function blocksForRange(_x5, _x6, _x7) {
|
|
555
|
-
return _blocksForRange.apply(this, arguments);
|
|
556
|
-
}
|
|
557
|
-
|
|
558
|
-
return blocksForRange;
|
|
559
|
-
}()
|
|
560
|
-
}]);
|
|
561
|
-
return BAI;
|
|
562
|
-
}(_indexFile.default);
|
|
563
|
-
|
|
311
|
+
});
|
|
312
|
+
});
|
|
313
|
+
};
|
|
314
|
+
return BAI;
|
|
315
|
+
}(indexFile_1.default));
|
|
564
316
|
exports.default = BAI;
|
|
565
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/bai.ts"],"names":["BAI_MAGIC","roundDown","n","multiple","roundUp","BAI","bytes","offset","lineCount","Long","fromBytesLE","Array","prototype","call","refId","opts","parse","prom","index","indices","ret","stats","undefined","data","bai","maxBlockSize","filehandle","readFile","readUInt32LE","Error","refCount","readInt32LE","depth","binLimit","currOffset","i","signal","binCount","binIndex","j","bin","parsePseudoBin","chunkCount","chunks","k","u","v","_findFirstData","Chunk","linearCount","linearIndex","seqId","start","end","range","indexData","seqIdx","length","e","s","depths","totalSize","blockPosition","currentPos","score","d","beg","min","max","ba","overlappingBins","reg2bins","binChunks","c","push","minv","maxv","nintv","lowest","minLin","Math","maxLin","vp","compareTo","IndexFile"],"mappings":"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","sourcesContent":["import Long from 'long'\nimport { fromBytes } from './virtualOffset'\nimport Chunk from './chunk'\n\nimport IndexFile from './indexFile'\nimport { longToNumber, abortBreakPoint, optimizeChunks, BaseOpts } from './util'\n\nconst BAI_MAGIC = 21578050 // BAI\\1\n\nfunction roundDown(n: number, multiple: number) {\n  return n - (n % multiple)\n}\nfunction roundUp(n: number, multiple: number) {\n  return n - (n % multiple) + multiple\n}\n\nexport default class BAI extends IndexFile {\n  parsePseudoBin(bytes: Buffer, offset: number) {\n    const lineCount = longToNumber(\n      Long.fromBytesLE(Array.prototype.slice.call(bytes, offset + 16, offset + 24), true),\n    )\n    return { lineCount }\n  }\n\n  async lineCount(refId: number, opts: BaseOpts = {}) {\n    const prom = await this.parse(opts)\n    const index = prom.indices[refId]\n    if (!index) {\n      return -1\n    }\n    const ret = index.stats || {}\n    return ret.lineCount === undefined ? -1 : ret.lineCount\n  }\n\n  // fetch and parse the index\n  async _parse(opts: BaseOpts = {}) {\n    const data: { [key: string]: any } = { bai: true, maxBlockSize: 1 << 16 }\n    const bytes = (await this.filehandle.readFile(opts)) as Buffer\n\n    // check BAI magic numbers\n    if (bytes.readUInt32LE(0) !== BAI_MAGIC) {\n      throw new Error('Not a BAI file')\n    }\n\n    data.refCount = bytes.readInt32LE(4)\n    const depth = 5\n    const binLimit = ((1 << ((depth + 1) * 3)) - 1) / 7\n\n    // read the indexes for each reference sequence\n    data.indices = new Array(data.refCount)\n    let currOffset = 8\n    for (let i = 0; i < data.refCount; i += 1) {\n      await abortBreakPoint(opts.signal)\n\n      // the binning index\n      const binCount = bytes.readInt32LE(currOffset)\n      let stats\n\n      currOffset += 4\n      const binIndex: { [key: number]: Chunk[] } = {}\n      for (let j = 0; j < binCount; j += 1) {\n        const bin = bytes.readUInt32LE(currOffset)\n        currOffset += 4\n        if (bin === binLimit + 1) {\n          currOffset += 4\n          stats = this.parsePseudoBin(bytes, currOffset)\n          currOffset += 32\n        } else if (bin > binLimit + 1) {\n          throw new Error('bai index contains too many bins, please use CSI')\n        } else {\n          const chunkCount = bytes.readInt32LE(currOffset)\n          currOffset += 4\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      const linearCount = bytes.readInt32LE(currOffset)\n      currOffset += 4\n      // as we're going through the linear index, figure out\n      // the smallest virtual offset in the indexes, which\n      // tells us where the BAM header ends\n      const linearIndex = new Array(linearCount)\n      for (let k = 0; k < linearCount; k += 1) {\n        linearIndex[k] = fromBytes(bytes, currOffset)\n        currOffset += 8\n        this._findFirstData(data, linearIndex[k])\n      }\n\n      data.indices[i] = { binIndex, linearIndex, stats }\n    }\n\n    return data\n  }\n\n  async indexCov(\n    seqId: number,\n    start?: number,\n    end?: number,\n    opts: BaseOpts = {},\n  ): Promise<{ start: number; end: number; score: number }[]> {\n    const v = 16384\n    const range = start !== undefined\n    const indexData = await this.parse(opts)\n    const seqIdx = indexData.indices[seqId]\n    if (!seqIdx) {\n      return []\n    }\n    const { linearIndex = [], stats } = seqIdx\n    if (!linearIndex.length) {\n      return []\n    }\n    const e = end !== undefined ? roundUp(end, v) : (linearIndex.length - 1) * v\n    const s = start !== undefined ? roundDown(start, v) : 0\n    let depths\n    if (range) {\n      depths = new Array((e - s) / v)\n    } else {\n      depths = new Array(linearIndex.length - 1)\n    }\n    const totalSize = linearIndex[linearIndex.length - 1].blockPosition\n    if (e > (linearIndex.length - 1) * v) {\n      throw new Error('query outside of range of linear index')\n    }\n    let currentPos = linearIndex[s / v].blockPosition\n    for (let i = s / v, j = 0; i < e / v; i++, j++) {\n      depths[j] = {\n        score: linearIndex[i + 1].blockPosition - currentPos,\n        start: i * v,\n        end: i * v + v,\n      }\n      currentPos = linearIndex[i + 1].blockPosition\n    }\n    return depths.map(d => {\n      return { ...d, score: (d.score * stats.lineCount) / totalSize }\n    })\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    end -= 1\n    return [\n      [0, 0],\n      [1 + (beg >> 26), 1 + (end >> 26)],\n      [9 + (beg >> 23), 9 + (end >> 23)],\n      [73 + (beg >> 20), 73 + (end >> 20)],\n      [585 + (beg >> 17), 585 + (end >> 17)],\n      [4681 + (beg >> 14), 4681 + (end >> 14)],\n    ]\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    // Use the linear index to find minimum file position of chunks that could contain alignments in the region\n    const nintv = ba.linearIndex.length\n    let lowest = null\n    const minLin = Math.min(min >> 14, nintv - 1)\n    const maxLin = Math.min(max >> 14, nintv - 1)\n    for (let i = minLin; i <= maxLin; ++i) {\n      const vp = ba.linearIndex[i]\n      if (vp) {\n        if (!lowest || vp.compareTo(lowest) < 0) {\n          lowest = vp\n        }\n      }\n    }\n\n    return optimizeChunks(chunks, lowest)\n  }\n}\n"]}
|
|
317
|
+
//# sourceMappingURL=bai.js.map
|