@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.
Files changed (73) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/README.md +2 -3
  3. package/dist/bai.d.ts +2 -0
  4. package/dist/bai.js +300 -548
  5. package/dist/bai.js.map +1 -0
  6. package/dist/bamFile.d.ts +4 -6
  7. package/dist/bamFile.js +675 -1203
  8. package/dist/bamFile.js.map +1 -0
  9. package/dist/chunk.js +34 -69
  10. package/dist/chunk.js.map +1 -0
  11. package/dist/constants.js +27 -35
  12. package/dist/constants.js.map +1 -0
  13. package/dist/csi.js +317 -515
  14. package/dist/csi.js.map +1 -0
  15. package/dist/errors.js +64 -120
  16. package/dist/errors.js.map +1 -0
  17. package/dist/htsget.js +275 -396
  18. package/dist/htsget.js.map +1 -0
  19. package/dist/index.js +16 -54
  20. package/dist/index.js.map +1 -0
  21. package/dist/indexFile.d.ts +1 -2
  22. package/dist/indexFile.js +77 -163
  23. package/dist/indexFile.js.map +1 -0
  24. package/dist/record.js +496 -707
  25. package/dist/record.js.map +1 -0
  26. package/dist/sam.js +16 -49
  27. package/dist/sam.js.map +1 -0
  28. package/dist/util.d.ts +0 -1
  29. package/dist/util.js +115 -126
  30. package/dist/util.js.map +1 -0
  31. package/dist/virtualOffset.js +44 -77
  32. package/dist/virtualOffset.js.map +1 -0
  33. package/esm/bai.d.ts +26 -0
  34. package/esm/bai.js +191 -0
  35. package/esm/bai.js.map +1 -0
  36. package/esm/bamFile.d.ts +77 -0
  37. package/esm/bamFile.js +388 -0
  38. package/esm/bamFile.js.map +1 -0
  39. package/esm/chunk.d.ts +18 -0
  40. package/esm/chunk.js +33 -0
  41. package/esm/chunk.js.map +1 -0
  42. package/esm/constants.d.ts +15 -0
  43. package/esm/constants.js +27 -0
  44. package/esm/constants.js.map +1 -0
  45. package/esm/csi.d.ts +35 -0
  46. package/esm/csi.js +209 -0
  47. package/esm/csi.js.map +1 -0
  48. package/esm/errors.d.ts +23 -0
  49. package/esm/errors.js +24 -0
  50. package/esm/errors.js.map +1 -0
  51. package/esm/htsget.d.ts +33 -0
  52. package/esm/htsget.js +100 -0
  53. package/esm/htsget.js.map +1 -0
  54. package/esm/index.d.ts +6 -0
  55. package/esm/index.js +7 -0
  56. package/esm/index.js.map +1 -0
  57. package/esm/indexFile.d.ts +27 -0
  58. package/esm/indexFile.js +27 -0
  59. package/esm/indexFile.js.map +1 -0
  60. package/esm/record.d.ts +88 -0
  61. package/esm/record.js +534 -0
  62. package/esm/record.js.map +1 -0
  63. package/esm/sam.d.ts +7 -0
  64. package/esm/sam.js +16 -0
  65. package/esm/sam.js.map +1 -0
  66. package/esm/util.d.ts +35 -0
  67. package/esm/util.js +92 -0
  68. package/esm/util.js.map +1 -0
  69. package/esm/virtualOffset.d.ts +10 -0
  70. package/esm/virtualOffset.js +37 -0
  71. package/esm/virtualOffset.js.map +1 -0
  72. package/package.json +21 -29
  73. package/dist/declare.d.js +0 -2
package/dist/csi.js CHANGED
@@ -1,536 +1,338 @@
1
1
  "use strict";
2
-
3
- var _interopRequireWildcard = require("@babel/runtime-corejs3/helpers/interopRequireWildcard");
4
-
5
- var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
6
-
7
- var _Object$defineProperty = require("@babel/runtime-corejs3/core-js-stable/object/define-property");
8
-
9
- _Object$defineProperty(exports, "__esModule", {
10
- value: true
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
- exports.default = void 0;
14
-
15
- var _getIterator2 = _interopRequireDefault(require("@babel/runtime-corejs3/core-js/get-iterator"));
16
-
17
- var _isArray = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/array/is-array"));
18
-
19
- var _getIteratorMethod2 = _interopRequireDefault(require("@babel/runtime-corejs3/core-js/get-iterator-method"));
20
-
21
- var _symbol = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/symbol"));
22
-
23
- var _from = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/array/from"));
24
-
25
- var _construct = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/reflect/construct"));
26
-
27
- var _concat = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat"));
28
-
29
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
30
-
31
- var _slice = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/slice"));
32
-
33
- var _assign = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/assign"));
34
-
35
- var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs3/regenerator"));
36
-
37
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/asyncToGenerator"));
38
-
39
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/classCallCheck"));
40
-
41
- var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/createClass"));
42
-
43
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/assertThisInitialized"));
44
-
45
- var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/inherits"));
46
-
47
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/possibleConstructorReturn"));
48
-
49
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/getPrototypeOf"));
50
-
51
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
52
-
53
- var _long = _interopRequireDefault(require("long"));
54
-
55
- var _bgzfFilehandle = require("@gmod/bgzf-filehandle");
56
-
57
- var _virtualOffset = _interopRequireWildcard(require("./virtualOffset"));
58
-
59
- var _chunk = _interopRequireDefault(require("./chunk"));
60
-
61
- var _util = require("./util");
62
-
63
- var _indexFile = _interopRequireDefault(require("./indexFile"));
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
- return num * Math.pow(2, bits);
85
+ return num * Math.pow(2, bits);
81
86
  }
82
-
83
87
  function rshift(num, bits) {
84
- return Math.floor(num / Math.pow(2, bits));
88
+ return Math.floor(num / Math.pow(2, bits));
85
89
  }
86
-
87
- var CSI = /*#__PURE__*/function (_IndexFile) {
88
- (0, _inherits2.default)(CSI, _IndexFile);
89
-
90
- var _super = _createSuper(CSI);
91
-
92
- function CSI(args) {
93
- var _this;
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
- key: "_parseNameBytes",
223
- value: function _parseNameBytes(namesBytes) {
224
- var currRefId = 0;
225
- var currNameStart = 0;
226
- var refIdToName = [];
227
- var refNameToId = {};
228
-
229
- for (var i = 0; i < namesBytes.length; i += 1) {
230
- if (!namesBytes[i]) {
231
- if (currNameStart < i) {
232
- var refName = namesBytes.toString('utf8', currNameStart, i);
233
- refName = this.renameRefSeq(refName);
234
- refIdToName[currRefId] = refName;
235
- refNameToId[refName] = currRefId;
236
- }
237
-
238
- currNameStart = i + 1;
239
- currRefId += 1;
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
- _context3.next = 28;
318
- return (0, _util.abortBreakPoint)(opts.signal);
319
-
320
- case 28:
321
- // the binning index
322
- binCount = bytes.readInt32LE(currOffset);
323
- currOffset += 4;
324
- binIndex = {};
325
- stats = void 0; // < provided by parsing a pseudo-bin, if present
326
-
327
- for (j = 0; j < binCount; j += 1) {
328
- bin = bytes.readUInt32LE(currOffset);
329
-
330
- if (bin > this.maxBinNumber) {
331
- // this is a fake bin that actually has stats information
332
- // about the reference sequence in it
333
- stats = this.parsePseudoBin(bytes, currOffset + 4);
334
- currOffset += 4 + 8 + 4 + 16 + 16;
335
- } else {
336
- loffset = (0, _virtualOffset.fromBytes)(bytes, currOffset + 4);
337
-
338
- this._findFirstData(data, loffset);
339
-
340
- chunkCount = bytes.readInt32LE(currOffset + 12);
341
- currOffset += 16;
342
- chunks = new Array(chunkCount);
343
-
344
- for (k = 0; k < chunkCount; k += 1) {
345
- u = (0, _virtualOffset.fromBytes)(bytes, currOffset);
346
- v = (0, _virtualOffset.fromBytes)(bytes, currOffset + 8);
347
- currOffset += 16; // this._findFirstData(data, u)
348
-
349
- chunks[k] = new _chunk.default(u, v, bin);
350
- }
351
-
352
- binIndex[bin] = chunks;
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
- data.indices[i] = {
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
- }, _callee3, this);
375
- }));
376
-
377
- function _parse(_x2) {
378
- return _parse2.apply(this, arguments);
379
- }
380
-
381
- return _parse;
382
- }()
383
- }, {
384
- key: "parsePseudoBin",
385
- value: function parsePseudoBin(bytes, offset) {
386
- // const one = Long.fromBytesLE(bytes.slice(offset + 4, offset + 12), true)
387
- // const two = Long.fromBytesLE(bytes.slice(offset + 12, offset + 20), true)
388
- // const three = longToNumber(
389
- // Long.fromBytesLE(bytes.slice(offset + 20, offset + 28), true),
390
- // )
391
- var lineCount = (0, _util.longToNumber)(_long.default.fromBytesLE((0, _slice.default)(Array.prototype).call(bytes, offset + 28, offset + 36), true));
392
- return {
393
- lineCount: lineCount
394
- };
395
- }
396
- }, {
397
- key: "blocksForRange",
398
- value: function () {
399
- var _blocksForRange = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(refId, min, max) {
400
- var opts,
401
- indexData,
402
- ba,
403
- overlappingBins,
404
- chunks,
405
- _iterator,
406
- _step,
407
- _step$value,
408
- start,
409
- end,
410
- bin,
411
- binChunks,
412
- c,
413
- _args4 = arguments;
414
-
415
- return _regenerator.default.wrap(function _callee4$(_context4) {
416
- while (1) {
417
- switch (_context4.prev = _context4.next) {
418
- case 0:
419
- opts = _args4.length > 3 && _args4[3] !== undefined ? _args4[3] : {};
420
-
421
- if (min < 0) {
422
- min = 0;
423
- }
424
-
425
- _context4.next = 4;
426
- return this.parse(opts);
427
-
428
- case 4:
429
- indexData = _context4.sent;
430
-
431
- if (indexData) {
432
- _context4.next = 7;
433
- break;
434
- }
435
-
436
- return _context4.abrupt("return", []);
437
-
438
- case 7:
439
- ba = indexData.indices[refId];
440
-
441
- if (ba) {
442
- _context4.next = 10;
443
- break;
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
- return _context4.abrupt("return", []);
447
-
448
- case 10:
449
- overlappingBins = this.reg2bins(min, max); // List of bin #s that overlap min, max
450
-
451
- chunks = []; // Find chunks in overlapping bins. Leaf bins (< 4681) are not pruned
452
-
453
- _iterator = _createForOfIteratorHelper(overlappingBins);
454
-
455
- try {
456
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
457
- _step$value = (0, _slicedToArray2.default)(_step.value, 2), start = _step$value[0], end = _step$value[1];
458
-
459
- for (bin = start; bin <= end; bin++) {
460
- if (ba.binIndex[bin]) {
461
- binChunks = ba.binIndex[bin];
462
-
463
- for (c = 0; c < binChunks.length; ++c) {
464
- chunks.push(new _chunk.default(binChunks[c].minv, binChunks[c].maxv, bin));
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
- return _context4.abrupt("return", (0, _util.optimizeChunks)(chunks, new _virtualOffset.default(0, 0)));
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
- key: "reg2bins",
498
- value: function reg2bins(beg, end) {
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
- bins.push([b, e]);
527
- }
528
-
529
- return bins;
530
- }
531
- }]);
532
- return CSI;
533
- }(_indexFile.default);
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