@gmod/bbi 1.0.30 → 1.0.33
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 +17 -57
- package/README.md +17 -27
- package/dist/bbi.js +354 -552
- package/dist/bigbed.d.ts +1 -1
- package/dist/bigbed.js +278 -470
- package/dist/bigwig.js +88 -112
- package/dist/blockView.js +403 -494
- package/dist/index.js +6 -41
- package/dist/range.js +115 -176
- package/dist/unzip-pako.d.ts +2 -0
- package/dist/unzip-pako.js +8 -0
- package/dist/unzip.d.ts +2 -0
- package/dist/unzip.js +5 -0
- package/dist/util.js +110 -116
- package/esm/bbi.d.ts +84 -0
- package/esm/bbi.js +259 -0
- package/esm/bigbed.d.ts +12 -0
- package/esm/bigbed.js +182 -0
- package/esm/bigwig.d.ts +13 -0
- package/esm/bigwig.js +35 -0
- package/esm/blockView.d.ts +42 -0
- package/esm/blockView.js +321 -0
- package/esm/index.d.ts +3 -0
- package/esm/index.js +7 -0
- package/esm/range.d.ts +18 -0
- package/esm/range.js +126 -0
- package/esm/unzip-pako.d.ts +2 -0
- package/esm/unzip-pako.js +8 -0
- package/esm/unzip.d.ts +2 -0
- package/esm/unzip.js +5 -0
- package/esm/util.d.ts +24 -0
- package/esm/util.js +74 -0
- package/package.json +29 -31
- package/dist/declares.d.js +0 -2
package/dist/bigbed.js
CHANGED
|
@@ -1,213 +1,162 @@
|
|
|
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
|
-
|
|
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
|
+
exports.BigBed = exports.filterUndef = void 0;
|
|
69
|
+
var binary_parser_1 = require("@gmod/binary-parser");
|
|
70
|
+
var rxjs_1 = require("rxjs");
|
|
71
|
+
var operators_1 = require("rxjs/operators");
|
|
72
|
+
var abortable_promise_cache_1 = __importDefault(require("abortable-promise-cache"));
|
|
73
|
+
var quick_lru_1 = __importDefault(require("quick-lru"));
|
|
74
|
+
var bbi_1 = require("./bbi");
|
|
51
75
|
function filterUndef(ts) {
|
|
52
|
-
|
|
53
|
-
return !!t;
|
|
54
|
-
});
|
|
76
|
+
return ts.filter(function (t) { return !!t; });
|
|
55
77
|
}
|
|
56
|
-
|
|
57
|
-
var BigBed =
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
}),
|
|
71
|
-
fill: function () {
|
|
72
|
-
var _fill = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(args, signal) {
|
|
73
|
-
return _regenerator.default.wrap(function _callee$(_context) {
|
|
74
|
-
while (1) {
|
|
75
|
-
switch (_context.prev = _context.next) {
|
|
76
|
-
case 0:
|
|
77
|
-
return _context.abrupt("return", _this._readIndices(_objectSpread(_objectSpread({}, args), {}, {
|
|
78
|
-
signal: signal
|
|
79
|
-
})));
|
|
80
|
-
|
|
81
|
-
case 1:
|
|
82
|
-
case "end":
|
|
83
|
-
return _context.stop();
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
}, _callee);
|
|
87
|
-
}));
|
|
88
|
-
|
|
89
|
-
function fill(_x, _x2) {
|
|
90
|
-
return _fill.apply(this, arguments);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
return fill;
|
|
94
|
-
}()
|
|
95
|
-
}));
|
|
96
|
-
return _this;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
(0, _createClass2.default)(BigBed, [{
|
|
100
|
-
key: "readIndices",
|
|
101
|
-
value: function readIndices() {
|
|
102
|
-
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
103
|
-
var options = 'aborted' in opts ? {
|
|
104
|
-
signal: opts
|
|
105
|
-
} : opts;
|
|
106
|
-
return this.readIndicesCache.get(JSON.stringify(options), options, options.signal);
|
|
78
|
+
exports.filterUndef = filterUndef;
|
|
79
|
+
var BigBed = /** @class */ (function (_super) {
|
|
80
|
+
__extends(BigBed, _super);
|
|
81
|
+
function BigBed(opts) {
|
|
82
|
+
var _this = _super.call(this, opts) || this;
|
|
83
|
+
_this.readIndicesCache = new abortable_promise_cache_1.default({
|
|
84
|
+
cache: new quick_lru_1.default({ maxSize: 1 }),
|
|
85
|
+
fill: function (args, signal) { return __awaiter(_this, void 0, void 0, function () {
|
|
86
|
+
return __generator(this, function (_a) {
|
|
87
|
+
return [2 /*return*/, this._readIndices(__assign(__assign({}, args), { signal: signal }))];
|
|
88
|
+
});
|
|
89
|
+
}); },
|
|
90
|
+
});
|
|
91
|
+
return _this;
|
|
107
92
|
}
|
|
93
|
+
BigBed.prototype.readIndices = function (opts) {
|
|
94
|
+
if (opts === void 0) { opts = {}; }
|
|
95
|
+
var options = 'aborted' in opts ? { signal: opts } : opts;
|
|
96
|
+
return this.readIndicesCache.get(JSON.stringify(options), options, options.signal);
|
|
97
|
+
};
|
|
108
98
|
/*
|
|
109
99
|
* retrieve unzoomed view for any scale
|
|
110
100
|
* @param scale - unused
|
|
111
101
|
* @param abortSignal - an optional AbortSignal to kill operation
|
|
112
102
|
* @return promise for a BlockView
|
|
113
103
|
*/
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
switch (_context2.prev = _context2.next) {
|
|
122
|
-
case 0:
|
|
123
|
-
return _context2.abrupt("return", this.getUnzoomedView(opts));
|
|
124
|
-
|
|
125
|
-
case 1:
|
|
126
|
-
case "end":
|
|
127
|
-
return _context2.stop();
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
}, _callee2, this);
|
|
131
|
-
}));
|
|
132
|
-
|
|
133
|
-
function getView(_x3, _x4) {
|
|
134
|
-
return _getView.apply(this, arguments);
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
return getView;
|
|
138
|
-
}()
|
|
104
|
+
BigBed.prototype.getView = function (scale, opts) {
|
|
105
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
106
|
+
return __generator(this, function (_a) {
|
|
107
|
+
return [2 /*return*/, this.getUnzoomedView(opts)];
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
};
|
|
139
111
|
/*
|
|
140
112
|
* parse the bigbed extraIndex fields
|
|
141
113
|
* @param abortSignal to abort operation
|
|
142
114
|
* @return a Promise for an array of Index data structure since there can be multiple extraIndexes in a bigbed, see bedToBigBed documentation
|
|
143
115
|
*/
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
case 18:
|
|
186
|
-
_yield$this$bbi$read2 = _context3.sent;
|
|
187
|
-
buffer = _yield$this$bbi$read2.buffer;
|
|
188
|
-
extParser = new _binaryParser.Parser().endianess(le).int16('type').int16('fieldcount').uint64('offset').skip(4).int16('field');
|
|
189
|
-
indices = [];
|
|
190
|
-
|
|
191
|
-
for (i = 0; i < count; i += 1) {
|
|
192
|
-
indices.push(extParser.parse(buffer.slice(i * blocklen)).result);
|
|
116
|
+
BigBed.prototype._readIndices = function (opts) {
|
|
117
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
118
|
+
var _a, extHeaderOffset, isBigEndian, data, le, ret, count, offset, blocklen, len, buffer, extParser, indices, i;
|
|
119
|
+
return __generator(this, function (_b) {
|
|
120
|
+
switch (_b.label) {
|
|
121
|
+
case 0: return [4 /*yield*/, this.getHeader(opts)];
|
|
122
|
+
case 1:
|
|
123
|
+
_a = _b.sent(), extHeaderOffset = _a.extHeaderOffset, isBigEndian = _a.isBigEndian;
|
|
124
|
+
return [4 /*yield*/, this.bbi.read(Buffer.alloc(64), 0, 64, extHeaderOffset)];
|
|
125
|
+
case 2:
|
|
126
|
+
data = (_b.sent()).buffer;
|
|
127
|
+
le = isBigEndian ? 'big' : 'little';
|
|
128
|
+
ret = new binary_parser_1.Parser()
|
|
129
|
+
.endianess(le)
|
|
130
|
+
.uint16('size')
|
|
131
|
+
.uint16('count')
|
|
132
|
+
.uint64('offset')
|
|
133
|
+
.parse(data).result;
|
|
134
|
+
count = ret.count, offset = ret.offset;
|
|
135
|
+
// no extra index is defined if count==0
|
|
136
|
+
if (count === 0) {
|
|
137
|
+
return [2 /*return*/, []];
|
|
138
|
+
}
|
|
139
|
+
blocklen = 20;
|
|
140
|
+
len = blocklen * count;
|
|
141
|
+
return [4 /*yield*/, this.bbi.read(Buffer.alloc(len), 0, len, offset)];
|
|
142
|
+
case 3:
|
|
143
|
+
buffer = (_b.sent()).buffer;
|
|
144
|
+
extParser = new binary_parser_1.Parser()
|
|
145
|
+
.endianess(le)
|
|
146
|
+
.int16('type')
|
|
147
|
+
.int16('fieldcount')
|
|
148
|
+
.uint64('offset')
|
|
149
|
+
.skip(4)
|
|
150
|
+
.int16('field');
|
|
151
|
+
indices = [];
|
|
152
|
+
for (i = 0; i < count; i += 1) {
|
|
153
|
+
indices.push(extParser.parse(buffer.subarray(i * blocklen)).result);
|
|
154
|
+
}
|
|
155
|
+
return [2 /*return*/, indices];
|
|
193
156
|
}
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
case 24:
|
|
198
|
-
case "end":
|
|
199
|
-
return _context3.stop();
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
}, _callee3, this);
|
|
203
|
-
}));
|
|
204
|
-
|
|
205
|
-
function _readIndices(_x5) {
|
|
206
|
-
return _readIndices2.apply(this, arguments);
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
return _readIndices;
|
|
210
|
-
}()
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
};
|
|
211
160
|
/*
|
|
212
161
|
* perform a search in the bigbed extraIndex to find which blocks in the bigbed data to look for the
|
|
213
162
|
* actual feature data
|
|
@@ -216,208 +165,106 @@ var BigBed = /*#__PURE__*/function (_BBI) {
|
|
|
216
165
|
* @param opts - a SearchOptions argument with optional signal
|
|
217
166
|
* @return a Promise for an array of bigbed block Loc entries
|
|
218
167
|
*/
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
while (1) {
|
|
235
|
-
switch (_context6.prev = _context6.next) {
|
|
236
|
-
case 0:
|
|
237
|
-
opts = _args6.length > 1 && _args6[1] !== undefined ? _args6[1] : {};
|
|
238
|
-
_context6.next = 3;
|
|
239
|
-
return this.getHeader(opts);
|
|
240
|
-
|
|
241
|
-
case 3:
|
|
242
|
-
_yield$this$getHeader2 = _context6.sent;
|
|
243
|
-
isBigEndian = _yield$this$getHeader2.isBigEndian;
|
|
244
|
-
_context6.next = 7;
|
|
245
|
-
return this.readIndices(opts);
|
|
246
|
-
|
|
247
|
-
case 7:
|
|
248
|
-
indices = _context6.sent;
|
|
249
|
-
|
|
250
|
-
if (indices.length) {
|
|
251
|
-
_context6.next = 10;
|
|
252
|
-
break;
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
return _context6.abrupt("return", []);
|
|
256
|
-
|
|
257
|
-
case 10:
|
|
258
|
-
locs = indices.map( /*#__PURE__*/function () {
|
|
259
|
-
var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(index) {
|
|
260
|
-
var offset, field, _yield$_this2$bbi$rea, data, p, _p$parse$result, blockSize, keySize, valSize, bpt, bptReadNode, rootNodeOffset;
|
|
261
|
-
|
|
262
|
-
return _regenerator.default.wrap(function _callee5$(_context5) {
|
|
263
|
-
while (1) {
|
|
264
|
-
switch (_context5.prev = _context5.next) {
|
|
265
|
-
case 0:
|
|
266
|
-
offset = index.offset, field = index.field;
|
|
267
|
-
_context5.next = 3;
|
|
268
|
-
return _this2.bbi.read(Buffer.alloc(32), 0, 32, offset, opts);
|
|
269
|
-
|
|
270
|
-
case 3:
|
|
271
|
-
_yield$_this2$bbi$rea = _context5.sent;
|
|
272
|
-
data = _yield$_this2$bbi$rea.buffer;
|
|
273
|
-
p = new _binaryParser.Parser().endianess(isBigEndian ? 'big' : 'little').int32('magic').int32('blockSize').int32('keySize').int32('valSize').uint64('itemCount');
|
|
274
|
-
_p$parse$result = p.parse(data).result, blockSize = _p$parse$result.blockSize, keySize = _p$parse$result.keySize, valSize = _p$parse$result.valSize;
|
|
275
|
-
bpt = new _binaryParser.Parser().endianess(isBigEndian ? 'big' : 'little').int8('nodeType').skip(1).int16('cnt').choice({
|
|
276
|
-
tag: 'nodeType',
|
|
277
|
-
choices: {
|
|
278
|
-
0: new _binaryParser.Parser().array('leafkeys', {
|
|
279
|
-
length: 'cnt',
|
|
280
|
-
type: new _binaryParser.Parser().string('key', {
|
|
281
|
-
length: keySize,
|
|
282
|
-
stripNull: true
|
|
283
|
-
}).uint64('offset')
|
|
284
|
-
}),
|
|
285
|
-
1: new _binaryParser.Parser().array('keys', {
|
|
286
|
-
length: 'cnt',
|
|
287
|
-
type: new _binaryParser.Parser().string('key', {
|
|
288
|
-
length: keySize,
|
|
289
|
-
stripNull: true
|
|
290
|
-
}).uint64('offset').uint32('length').uint32('reserved')
|
|
291
|
-
})
|
|
292
|
-
}
|
|
293
|
-
});
|
|
294
|
-
|
|
295
|
-
bptReadNode = /*#__PURE__*/function () {
|
|
296
|
-
var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(nodeOffset) {
|
|
297
|
-
var len, _yield$_this2$bbi$rea2, buffer, node, lastOffset, i, key, _i;
|
|
298
|
-
|
|
299
|
-
return _regenerator.default.wrap(function _callee4$(_context4) {
|
|
300
|
-
while (1) {
|
|
301
|
-
switch (_context4.prev = _context4.next) {
|
|
302
|
-
case 0:
|
|
303
|
-
len = 4 + blockSize * (keySize + valSize);
|
|
304
|
-
_context4.next = 3;
|
|
305
|
-
return _this2.bbi.read(Buffer.alloc(len), 0, len, nodeOffset, opts);
|
|
306
|
-
|
|
307
|
-
case 3:
|
|
308
|
-
_yield$_this2$bbi$rea2 = _context4.sent;
|
|
309
|
-
buffer = _yield$_this2$bbi$rea2.buffer;
|
|
310
|
-
node = bpt.parse(buffer).result;
|
|
311
|
-
|
|
312
|
-
if (!node.leafkeys) {
|
|
313
|
-
_context4.next = 17;
|
|
314
|
-
break;
|
|
315
|
-
}
|
|
316
|
-
|
|
317
|
-
i = 0;
|
|
318
|
-
|
|
319
|
-
case 8:
|
|
320
|
-
if (!(i < node.leafkeys.length)) {
|
|
321
|
-
_context4.next = 16;
|
|
322
|
-
break;
|
|
323
|
-
}
|
|
324
|
-
|
|
325
|
-
key = node.leafkeys[i].key;
|
|
326
|
-
|
|
327
|
-
if (!(name.localeCompare(key) < 0 && lastOffset)) {
|
|
328
|
-
_context4.next = 12;
|
|
329
|
-
break;
|
|
330
|
-
}
|
|
331
|
-
|
|
332
|
-
return _context4.abrupt("return", bptReadNode(lastOffset));
|
|
333
|
-
|
|
334
|
-
case 12:
|
|
335
|
-
lastOffset = node.leafkeys[i].offset;
|
|
336
|
-
|
|
337
|
-
case 13:
|
|
338
|
-
i += 1;
|
|
339
|
-
_context4.next = 8;
|
|
340
|
-
break;
|
|
341
|
-
|
|
342
|
-
case 16:
|
|
343
|
-
return _context4.abrupt("return", bptReadNode(lastOffset));
|
|
344
|
-
|
|
345
|
-
case 17:
|
|
346
|
-
_i = 0;
|
|
347
|
-
|
|
348
|
-
case 18:
|
|
349
|
-
if (!(_i < node.keys.length)) {
|
|
350
|
-
_context4.next = 24;
|
|
351
|
-
break;
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
if (!(node.keys[_i].key === name)) {
|
|
355
|
-
_context4.next = 21;
|
|
356
|
-
break;
|
|
357
|
-
}
|
|
358
|
-
|
|
359
|
-
return _context4.abrupt("return", _objectSpread(_objectSpread({}, node.keys[_i]), {}, {
|
|
360
|
-
field: field
|
|
361
|
-
}));
|
|
362
|
-
|
|
363
|
-
case 21:
|
|
364
|
-
_i += 1;
|
|
365
|
-
_context4.next = 18;
|
|
366
|
-
break;
|
|
367
|
-
|
|
368
|
-
case 24:
|
|
369
|
-
return _context4.abrupt("return", undefined);
|
|
370
|
-
|
|
371
|
-
case 25:
|
|
372
|
-
case "end":
|
|
373
|
-
return _context4.stop();
|
|
374
|
-
}
|
|
375
|
-
}
|
|
376
|
-
}, _callee4);
|
|
377
|
-
}));
|
|
378
|
-
|
|
379
|
-
return function bptReadNode(_x8) {
|
|
380
|
-
return _ref2.apply(this, arguments);
|
|
381
|
-
};
|
|
382
|
-
}();
|
|
383
|
-
|
|
384
|
-
rootNodeOffset = 32;
|
|
385
|
-
return _context5.abrupt("return", bptReadNode(offset + rootNodeOffset));
|
|
386
|
-
|
|
387
|
-
case 11:
|
|
388
|
-
case "end":
|
|
389
|
-
return _context5.stop();
|
|
168
|
+
BigBed.prototype.searchExtraIndexBlocks = function (name, opts) {
|
|
169
|
+
if (opts === void 0) { opts = {}; }
|
|
170
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
171
|
+
var isBigEndian, indices, locs, _a;
|
|
172
|
+
var _this = this;
|
|
173
|
+
return __generator(this, function (_b) {
|
|
174
|
+
switch (_b.label) {
|
|
175
|
+
case 0: return [4 /*yield*/, this.getHeader(opts)];
|
|
176
|
+
case 1:
|
|
177
|
+
isBigEndian = (_b.sent()).isBigEndian;
|
|
178
|
+
return [4 /*yield*/, this.readIndices(opts)];
|
|
179
|
+
case 2:
|
|
180
|
+
indices = _b.sent();
|
|
181
|
+
if (!indices.length) {
|
|
182
|
+
return [2 /*return*/, []];
|
|
390
183
|
}
|
|
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
|
-
|
|
184
|
+
locs = indices.map(function (index) { return __awaiter(_this, void 0, void 0, function () {
|
|
185
|
+
var offset, field, data, p, _a, blockSize, keySize, valSize, bpt, bptReadNode, rootNodeOffset;
|
|
186
|
+
var _this = this;
|
|
187
|
+
return __generator(this, function (_b) {
|
|
188
|
+
switch (_b.label) {
|
|
189
|
+
case 0:
|
|
190
|
+
offset = index.offset, field = index.field;
|
|
191
|
+
return [4 /*yield*/, this.bbi.read(Buffer.alloc(32), 0, 32, offset, opts)];
|
|
192
|
+
case 1:
|
|
193
|
+
data = (_b.sent()).buffer;
|
|
194
|
+
p = new binary_parser_1.Parser()
|
|
195
|
+
.endianess(isBigEndian ? 'big' : 'little')
|
|
196
|
+
.int32('magic')
|
|
197
|
+
.int32('blockSize')
|
|
198
|
+
.int32('keySize')
|
|
199
|
+
.int32('valSize')
|
|
200
|
+
.uint64('itemCount');
|
|
201
|
+
_a = p.parse(data).result, blockSize = _a.blockSize, keySize = _a.keySize, valSize = _a.valSize;
|
|
202
|
+
bpt = new binary_parser_1.Parser()
|
|
203
|
+
.endianess(isBigEndian ? 'big' : 'little')
|
|
204
|
+
.int8('nodeType')
|
|
205
|
+
.skip(1)
|
|
206
|
+
.int16('cnt')
|
|
207
|
+
.choice({
|
|
208
|
+
tag: 'nodeType',
|
|
209
|
+
choices: {
|
|
210
|
+
0: new binary_parser_1.Parser().array('leafkeys', {
|
|
211
|
+
length: 'cnt',
|
|
212
|
+
type: new binary_parser_1.Parser()
|
|
213
|
+
.string('key', { length: keySize, stripNull: true })
|
|
214
|
+
.uint64('offset'),
|
|
215
|
+
}),
|
|
216
|
+
1: new binary_parser_1.Parser().array('keys', {
|
|
217
|
+
length: 'cnt',
|
|
218
|
+
type: new binary_parser_1.Parser()
|
|
219
|
+
.string('key', { length: keySize, stripNull: true })
|
|
220
|
+
.uint64('offset')
|
|
221
|
+
.uint32('length')
|
|
222
|
+
.uint32('reserved'),
|
|
223
|
+
}),
|
|
224
|
+
},
|
|
225
|
+
});
|
|
226
|
+
bptReadNode = function (nodeOffset) { return __awaiter(_this, void 0, void 0, function () {
|
|
227
|
+
var len, buffer, node, lastOffset, i, key, i;
|
|
228
|
+
return __generator(this, function (_a) {
|
|
229
|
+
switch (_a.label) {
|
|
230
|
+
case 0:
|
|
231
|
+
len = 4 + blockSize * (keySize + valSize);
|
|
232
|
+
return [4 /*yield*/, this.bbi.read(Buffer.alloc(len), 0, len, nodeOffset, opts)];
|
|
233
|
+
case 1:
|
|
234
|
+
buffer = (_a.sent()).buffer;
|
|
235
|
+
node = bpt.parse(buffer).result;
|
|
236
|
+
if (node.leafkeys) {
|
|
237
|
+
lastOffset = void 0;
|
|
238
|
+
for (i = 0; i < node.leafkeys.length; i += 1) {
|
|
239
|
+
key = node.leafkeys[i].key;
|
|
240
|
+
if (name.localeCompare(key) < 0 && lastOffset) {
|
|
241
|
+
return [2 /*return*/, bptReadNode(lastOffset)];
|
|
242
|
+
}
|
|
243
|
+
lastOffset = node.leafkeys[i].offset;
|
|
244
|
+
}
|
|
245
|
+
return [2 /*return*/, bptReadNode(lastOffset)];
|
|
246
|
+
}
|
|
247
|
+
for (i = 0; i < node.keys.length; i += 1) {
|
|
248
|
+
if (node.keys[i].key === name) {
|
|
249
|
+
return [2 /*return*/, __assign(__assign({}, node.keys[i]), { field: field })];
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
return [2 /*return*/, undefined];
|
|
253
|
+
}
|
|
254
|
+
});
|
|
255
|
+
}); };
|
|
256
|
+
rootNodeOffset = 32;
|
|
257
|
+
return [2 /*return*/, bptReadNode(offset + rootNodeOffset)];
|
|
258
|
+
}
|
|
259
|
+
});
|
|
260
|
+
}); });
|
|
261
|
+
_a = filterUndef;
|
|
262
|
+
return [4 /*yield*/, Promise.all(locs)];
|
|
263
|
+
case 3: return [2 /*return*/, _a.apply(void 0, [_b.sent()])];
|
|
264
|
+
}
|
|
265
|
+
});
|
|
266
|
+
});
|
|
267
|
+
};
|
|
421
268
|
/*
|
|
422
269
|
* retrieve the features from the bigbed data that were found through the lookup of the extraIndex
|
|
423
270
|
* note that there can be multiple extraIndex, see the BigBed specification and the -extraIndex argument to bedToBigBed
|
|
@@ -426,80 +273,41 @@ var BigBed = /*#__PURE__*/function (_BBI) {
|
|
|
426
273
|
* @param opts - a SearchOptions argument with optional signal
|
|
427
274
|
* @return a Promise for an array of Feature
|
|
428
275
|
*/
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
276
|
+
BigBed.prototype.searchExtraIndex = function (name, opts) {
|
|
277
|
+
if (opts === void 0) { opts = {}; }
|
|
278
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
279
|
+
var blocks, view, res, ret;
|
|
280
|
+
return __generator(this, function (_a) {
|
|
281
|
+
switch (_a.label) {
|
|
282
|
+
case 0: return [4 /*yield*/, this.searchExtraIndexBlocks(name, opts)];
|
|
283
|
+
case 1:
|
|
284
|
+
blocks = _a.sent();
|
|
285
|
+
if (!blocks.length) {
|
|
286
|
+
return [2 /*return*/, []];
|
|
287
|
+
}
|
|
288
|
+
return [4 /*yield*/, this.getUnzoomedView(opts)];
|
|
289
|
+
case 2:
|
|
290
|
+
view = _a.sent();
|
|
291
|
+
res = blocks.map(function (block) {
|
|
292
|
+
return new rxjs_1.Observable(function (observer) {
|
|
293
|
+
view.readFeatures(observer, [block], opts);
|
|
294
|
+
}).pipe((0, operators_1.reduce)(function (acc, curr) { return acc.concat(curr); }), (0, operators_1.map)(function (x) {
|
|
295
|
+
for (var i = 0; i < x.length; i += 1) {
|
|
296
|
+
x[i].field = block.field;
|
|
297
|
+
}
|
|
298
|
+
return x;
|
|
299
|
+
}));
|
|
300
|
+
});
|
|
301
|
+
return [4 /*yield*/, rxjs_1.merge.apply(void 0, res).toPromise()];
|
|
302
|
+
case 3:
|
|
303
|
+
ret = _a.sent();
|
|
304
|
+
return [2 /*return*/, ret.filter(function (f) {
|
|
305
|
+
return f.rest.split('\t')[f.field - 3] === name;
|
|
306
|
+
})];
|
|
454
307
|
}
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
return this.getUnzoomedView(opts);
|
|
461
|
-
|
|
462
|
-
case 8:
|
|
463
|
-
view = _context7.sent;
|
|
464
|
-
res = blocks.map(function (block) {
|
|
465
|
-
return new _rxjs.Observable(function (observer) {
|
|
466
|
-
view.readFeatures(observer, [block], opts);
|
|
467
|
-
}).pipe((0, _operators.reduce)(function (acc, curr) {
|
|
468
|
-
return acc.concat(curr);
|
|
469
|
-
}), (0, _operators.map)(function (x) {
|
|
470
|
-
for (var i = 0; i < x.length; i += 1) {
|
|
471
|
-
x[i].field = block.field; // eslint-disable-line
|
|
472
|
-
}
|
|
473
|
-
|
|
474
|
-
return x;
|
|
475
|
-
}));
|
|
476
|
-
});
|
|
477
|
-
_context7.next = 12;
|
|
478
|
-
return _rxjs.merge.apply(void 0, (0, _toConsumableArray2.default)(res)).toPromise();
|
|
479
|
-
|
|
480
|
-
case 12:
|
|
481
|
-
ret = _context7.sent;
|
|
482
|
-
return _context7.abrupt("return", ret.filter(function (f) {
|
|
483
|
-
return f.rest.split('\t')[f.field - 3] === name;
|
|
484
|
-
}));
|
|
485
|
-
|
|
486
|
-
case 14:
|
|
487
|
-
case "end":
|
|
488
|
-
return _context7.stop();
|
|
489
|
-
}
|
|
490
|
-
}
|
|
491
|
-
}, _callee7, this);
|
|
492
|
-
}));
|
|
493
|
-
|
|
494
|
-
function searchExtraIndex(_x9) {
|
|
495
|
-
return _searchExtraIndex.apply(this, arguments);
|
|
496
|
-
}
|
|
497
|
-
|
|
498
|
-
return searchExtraIndex;
|
|
499
|
-
}()
|
|
500
|
-
}]);
|
|
501
|
-
return BigBed;
|
|
502
|
-
}(_bbi.BBI);
|
|
503
|
-
|
|
308
|
+
});
|
|
309
|
+
});
|
|
310
|
+
};
|
|
311
|
+
return BigBed;
|
|
312
|
+
}(bbi_1.BBI));
|
|
504
313
|
exports.BigBed = BigBed;
|
|
505
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/bigbed.ts"],"names":["filterUndef","ts","filter","t","BigBed","opts","AbortablePromiseCache","cache","QuickLRU","maxSize","fill","args","signal","_readIndices","options","readIndicesCache","get","JSON","stringify","scale","getUnzoomedView","getHeader","extHeaderOffset","isBigEndian","bbi","read","Buffer","alloc","data","buffer","le","ret","Parser","endianess","uint16","uint64","parse","result","count","offset","blocklen","len","extParser","int16","skip","indices","i","push","slice","name","readIndices","length","locs","map","index","field","p","int32","blockSize","keySize","valSize","bpt","int8","choice","tag","choices","array","type","string","stripNull","uint32","bptReadNode","nodeOffset","node","leafkeys","key","localeCompare","lastOffset","keys","undefined","rootNodeOffset","Promise","all","searchExtraIndexBlocks","blocks","view","res","block","Observable","observer","readFeatures","pipe","acc","curr","concat","x","merge","toPromise","f","rest","split","BBI"],"mappings":"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","sourcesContent":["import { Parser } from '@gmod/binary-parser'\nimport { Observable, Observer, merge } from 'rxjs'\nimport { map, reduce } from 'rxjs/operators'\nimport AbortablePromiseCache from 'abortable-promise-cache'\nimport QuickLRU from 'quick-lru'\n\nimport { BBI, Feature, RequestOptions } from './bbi'\nimport { BlockView } from './blockView'\n\ninterface Loc {\n  key: string\n  offset: number\n  length: number\n  field?: number\n}\n\ninterface Index {\n  type: number\n  fieldcount: number\n  offset: number\n  field: number\n}\n\nexport function filterUndef<T>(ts: (T | undefined)[]): T[] {\n  return ts.filter((t: T | undefined): t is T => !!t)\n}\n\nexport class BigBed extends BBI {\n  public readIndicesCache = new AbortablePromiseCache({\n    cache: new QuickLRU({ maxSize: 1 }),\n    fill: async (args: any, signal?: AbortSignal) => {\n      return this._readIndices({ ...args, signal })\n    },\n  })\n\n  public constructor(opts: any) {\n    super(opts)\n  }\n\n  public readIndices(opts: AbortSignal | RequestOptions = {}) {\n    const options = 'aborted' in opts ? { signal: opts } : opts\n    return this.readIndicesCache.get(JSON.stringify(options), options, options.signal)\n  }\n\n  /*\n   * retrieve unzoomed view for any scale\n   * @param scale - unused\n   * @param abortSignal - an optional AbortSignal to kill operation\n   * @return promise for a BlockView\n   */\n  protected async getView(scale: number, opts: RequestOptions): Promise<BlockView> {\n    return this.getUnzoomedView(opts)\n  }\n\n  /*\n   * parse the bigbed extraIndex fields\n   * @param abortSignal to abort operation\n   * @return a Promise for an array of Index data structure since there can be multiple extraIndexes in a bigbed, see bedToBigBed documentation\n   */\n  private async _readIndices(opts: RequestOptions): Promise<Index[]> {\n    const { extHeaderOffset, isBigEndian } = await this.getHeader(opts)\n    const { buffer: data } = await this.bbi.read(Buffer.alloc(64), 0, 64, extHeaderOffset)\n    const le = isBigEndian ? 'big' : 'little'\n    const ret = new Parser()\n      .endianess(le)\n      .uint16('size')\n      .uint16('count')\n      .uint64('offset')\n      .parse(data).result\n    const { count, offset } = ret\n\n    // no extra index is defined if count==0\n    if (count === 0) {\n      return []\n    }\n\n    const blocklen = 20\n    const len = blocklen * count\n    const { buffer } = await this.bbi.read(Buffer.alloc(len), 0, len, offset)\n    const extParser = new Parser()\n      .endianess(le)\n      .int16('type')\n      .int16('fieldcount')\n      .uint64('offset')\n      .skip(4)\n      .int16('field')\n    const indices = []\n\n    for (let i = 0; i < count; i += 1) {\n      indices.push(extParser.parse(buffer.slice(i * blocklen)).result)\n    }\n    return indices\n  }\n\n  /*\n   * perform a search in the bigbed extraIndex to find which blocks in the bigbed data to look for the\n   * actual feature data\n   *\n   * @param name - the name to search for\n   * @param opts - a SearchOptions argument with optional signal\n   * @return a Promise for an array of bigbed block Loc entries\n   */\n  private async searchExtraIndexBlocks(name: string, opts: RequestOptions = {}): Promise<Loc[]> {\n    const { isBigEndian } = await this.getHeader(opts)\n    const indices = await this.readIndices(opts)\n    if (!indices.length) {\n      return []\n    }\n    const locs = indices.map(\n      async (index: any): Promise<Loc | undefined> => {\n        const { offset, field } = index\n        const { buffer: data } = await this.bbi.read(Buffer.alloc(32), 0, 32, offset, opts)\n        const p = new Parser()\n          .endianess(isBigEndian ? 'big' : 'little')\n          .int32('magic')\n          .int32('blockSize')\n          .int32('keySize')\n          .int32('valSize')\n          .uint64('itemCount')\n\n        const { blockSize, keySize, valSize } = p.parse(data).result\n        const bpt = new Parser()\n          .endianess(isBigEndian ? 'big' : 'little')\n          .int8('nodeType')\n          .skip(1)\n          .int16('cnt')\n          .choice({\n            tag: 'nodeType',\n            choices: {\n              0: new Parser().array('leafkeys', {\n                length: 'cnt',\n                type: new Parser()\n                  .string('key', { length: keySize, stripNull: true })\n                  .uint64('offset'),\n              }),\n              1: new Parser().array('keys', {\n                length: 'cnt',\n                type: new Parser()\n                  .string('key', { length: keySize, stripNull: true })\n                  .uint64('offset')\n                  .uint32('length')\n                  .uint32('reserved'),\n              }),\n            },\n          })\n\n        const bptReadNode = async (nodeOffset: number): Promise<Loc | undefined> => {\n          const len = 4 + blockSize * (keySize + valSize)\n          const { buffer } = await this.bbi.read(Buffer.alloc(len), 0, len, nodeOffset, opts)\n          const node = bpt.parse(buffer).result\n          if (node.leafkeys) {\n            let lastOffset\n            for (let i = 0; i < node.leafkeys.length; i += 1) {\n              const { key } = node.leafkeys[i]\n              if (name.localeCompare(key) < 0 && lastOffset) {\n                return bptReadNode(lastOffset)\n              }\n              lastOffset = node.leafkeys[i].offset\n            }\n            return bptReadNode(lastOffset)\n          }\n          for (let i = 0; i < node.keys.length; i += 1) {\n            if (node.keys[i].key === name) {\n              return { ...node.keys[i], field }\n            }\n          }\n\n          return undefined\n        }\n        const rootNodeOffset = 32\n        return bptReadNode(offset + rootNodeOffset)\n      },\n    )\n    return filterUndef(await Promise.all(locs))\n  }\n\n  /*\n   * retrieve the features from the bigbed data that were found through the lookup of the extraIndex\n   * note that there can be multiple extraIndex, see the BigBed specification and the -extraIndex argument to bedToBigBed\n   *\n   * @param name - the name to search for\n   * @param opts - a SearchOptions argument with optional signal\n   * @return a Promise for an array of Feature\n   */\n  public async searchExtraIndex(name: string, opts: RequestOptions = {}): Promise<Feature[]> {\n    const blocks = await this.searchExtraIndexBlocks(name, opts)\n    if (!blocks.length) return []\n    const view = await this.getUnzoomedView(opts)\n    const res = blocks.map(block => {\n      return new Observable((observer: Observer<Feature[]>) => {\n        view.readFeatures(observer, [block], opts)\n      }).pipe(\n        reduce((acc, curr) => acc.concat(curr)),\n        map(x => {\n          for (let i = 0; i < x.length; i += 1) {\n             x[i].field = block.field // eslint-disable-line\n          }\n          return x\n        }),\n      )\n    })\n    const ret = await merge(...res).toPromise()\n    return ret.filter((f: any) => {\n      return f.rest.split('\\t')[f.field - 3] === name\n    })\n  }\n}\n"]}
|