New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@gmod/bam

Package Overview
Dependencies
Maintainers
5
Versions
78
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@gmod/bam - npm Package Compare versions

Comparing version 1.0.22 to 1.0.24

dist/bai.d.ts

5

CHANGELOG.md

@@ -0,1 +1,6 @@

<a name="1.0.24"></a>
## [1.0.24](https://github.com/GMOD/bam-js/compare/v1.0.22...v1.0.24) (2019-09-27)
<a name="1.0.22"></a>

@@ -2,0 +7,0 @@ ## [1.0.22](https://github.com/GMOD/bam-js/compare/v1.0.20...v1.0.22) (2019-09-03)

513

dist/bai.js

@@ -1,9 +0,56 @@

"use strict";var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");Object.defineProperty(exports, "__esModule", { value: true });exports.default = void 0;var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));var Long = _interopRequireWildcard(require("long"));
"use strict";
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
var _Object$defineProperty2 = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty2(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/define-property"));
var _defineProperties = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/define-properties"));
var _getOwnPropertyDescriptors = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptors"));
var _getOwnPropertyDescriptor = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/get-own-property-descriptor"));
var _getOwnPropertySymbols = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/get-own-property-symbols"));
var _keys = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/keys"));
var _defineProperty3 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs2/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inherits"));
var _long = _interopRequireDefault(require("long"));
var _virtualOffset = require("./virtualOffset");
var _chunk = _interopRequireDefault(require("./chunk"));
var _indexFile = _interopRequireDefault(require("./indexFile"));function ownKeys(object, enumerableOnly) {var keys = Object.keys(object);if (Object.getOwnPropertySymbols) {var symbols = Object.getOwnPropertySymbols(object);if (enumerableOnly) symbols = symbols.filter(function (sym) {return Object.getOwnPropertyDescriptor(object, sym).enumerable;});keys.push.apply(keys, symbols);}return keys;}function _objectSpread(target) {for (var i = 1; i < arguments.length; i++) {var source = arguments[i] != null ? arguments[i] : {};if (i % 2) {ownKeys(source, true).forEach(function (key) {(0, _defineProperty2.default)(target, key, source[key]);});} else if (Object.getOwnPropertyDescriptors) {Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));} else {ownKeys(source).forEach(function (key) {Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));});}}return target;}
var _indexFile = _interopRequireDefault(require("./indexFile"));
var _util = require("./util");
function ownKeys(object, enumerableOnly) { var keys = (0, _keys.default)(object); if (_getOwnPropertySymbols.default) { var symbols = (0, _getOwnPropertySymbols.default)(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return (0, _getOwnPropertyDescriptor.default)(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { (0, _defineProperty3.default)(target, key, source[key]); }); } else if (_getOwnPropertyDescriptors.default) { (0, _defineProperties.default)(target, (0, _getOwnPropertyDescriptors.default)(source)); } else { ownKeys(source).forEach(function (key) { (0, _defineProperty2.default)(target, key, (0, _getOwnPropertyDescriptor.default)(source, key)); }); } } return target; }
var BAI_MAGIC = 21578050; // BAI\1
var _require = require('./util'),longToNumber = _require.longToNumber,abortBreakPoint = _require.abortBreakPoint,canMergeBlocks = _require.canMergeBlocks;

@@ -13,62 +60,159 @@ function roundDown(n, multiple) {

}
function roundUp(n, multiple) {
return n - n % multiple + multiple;
}var
}
BAI = /*#__PURE__*/function (_IndexFile) {(0, _inherits2.default)(BAI, _IndexFile);function BAI() {(0, _classCallCheck2.default)(this, BAI);return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BAI).apply(this, arguments));}(0, _createClass2.default)(BAI, [{ key: "parsePseudoBin", value: function parsePseudoBin(
bytes, offset) {
var lineCount = longToNumber(
Long.fromBytesLE(bytes.slice(offset + 16, offset + 24), true));
var BAI =
/*#__PURE__*/
function (_IndexFile) {
(0, _inherits2.default)(BAI, _IndexFile);
return { lineCount: lineCount };
} }, { key: "lineCount", value: function () {var _lineCount = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(
function BAI() {
(0, _classCallCheck2.default)(this, BAI);
return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BAI).apply(this, arguments));
}
refId) {var index, ret;return _regenerator.default.wrap(function _callee$(_context) {while (1) {switch (_context.prev = _context.next) {case 0:_context.next = 2;return (
this.parse());case 2:_context.t0 = refId;index = _context.sent.indices[_context.t0];if (
index) {_context.next = 6;break;}return _context.abrupt("return",
-1);case 6:
(0, _createClass2.default)(BAI, [{
key: "parsePseudoBin",
value: function parsePseudoBin(bytes, offset) {
var lineCount = (0, _util.longToNumber)(_long.default.fromBytesLE(Array.prototype.slice.call(bytes, offset + 16, offset + 24), true));
return {
lineCount: lineCount
};
}
}, {
key: "lineCount",
value: function () {
var _lineCount = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee(refId) {
var index, ret;
return _regenerator.default.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
_context.next = 2;
return this.parse();
ret = index.stats || {};return _context.abrupt("return",
ret.lineCount === undefined ? -1 : ret.lineCount);case 8:case "end":return _context.stop();}}}, _callee, this);}));function lineCount(_x) {return _lineCount.apply(this, arguments);}return lineCount;}()
case 2:
_context.t0 = refId;
index = _context.sent.indices[_context.t0];
if (index) {
_context.next = 6;
break;
}
// fetch and parse the index
}, { key: "_parse", value: function () {var _parse2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(abortSignal) {var data, bytes, depth, binLimit, currOffset, i, binCount, stats, binIndex, j, bin, chunkCount, chunks, k, u, v, linearCount, linearIndex, _k;return _regenerator.default.wrap(function _callee2$(_context2) {while (1) {switch (_context2.prev = _context2.next) {case 0:
data = { bai: true, maxBlockSize: 1 << 16 };_context2.next = 3;return (
this.filehandle.readFile({ signal: abortSignal }));case 3:bytes = _context2.sent;if (!(
return _context.abrupt("return", -1);
case 6:
ret = index.stats || {};
return _context.abrupt("return", ret.lineCount === undefined ? -1 : ret.lineCount);
bytes.readUInt32LE(0) !== BAI_MAGIC)) {_context2.next = 6;break;}throw (
new Error('Not a BAI file'));case 6:
case 8:
case "end":
return _context.stop();
}
}
}, _callee, this);
}));
function lineCount(_x) {
return _lineCount.apply(this, arguments);
}
return lineCount;
}() // fetch and parse the index
}, {
key: "_parse",
value: function () {
var _parse2 = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee2(abortSignal) {
var data, bytes, depth, binLimit, currOffset, i, binCount, stats, binIndex, j, bin, chunkCount, chunks, k, u, v, linearCount, linearIndex, _k;
return _regenerator.default.wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
data = {
bai: true,
maxBlockSize: 1 << 16
};
_context2.next = 3;
return this.filehandle.readFile({
signal: abortSignal
});
case 3:
bytes = _context2.sent;
if (!(bytes.readUInt32LE(0) !== BAI_MAGIC)) {
_context2.next = 6;
break;
}
throw new Error('Not a BAI file');
case 6:
data.refCount = bytes.readInt32LE(4);
depth = 5;
binLimit = ((1 << (depth + 1) * 3) - 1) / 7;
binLimit = ((1 << (depth + 1) * 3) - 1) / 7; // read the indexes for each reference sequence
// read the indexes for each reference sequence
data.indices = new Array(data.refCount);
currOffset = 8;
i = 0;case 12:if (!(i < data.refCount)) {_context2.next = 49;break;}_context2.next = 15;return (
abortBreakPoint(abortSignal));case 15:
i = 0;
case 12:
if (!(i < data.refCount)) {
_context2.next = 49;
break;
}
_context2.next = 15;
return (0, _util.abortBreakPoint)(abortSignal);
case 15:
// the binning index
binCount = bytes.readInt32LE(currOffset);
stats = void 0;
currOffset += 4;
binIndex = {};
j = 0;case 20:if (!(j < binCount)) {_context2.next = 41;break;}
j = 0;
case 20:
if (!(j < binCount)) {
_context2.next = 41;
break;
}
bin = bytes.readUInt32LE(currOffset);
currOffset += 4;if (!(
bin === binLimit + 1)) {_context2.next = 29;break;}
currOffset += 4;
if (!(bin === binLimit + 1)) {
_context2.next = 29;
break;
}
currOffset += 4;
stats = this.parsePseudoBin(bytes, currOffset);
currOffset += 32;_context2.next = 38;break;case 29:if (!(
bin > binLimit + 1)) {_context2.next = 33;break;}throw (
new Error('bai index contains too many bins, please use CSI'));case 33:
currOffset += 32;
_context2.next = 38;
break;
case 29:
if (!(bin > binLimit + 1)) {
_context2.next = 33;
break;
}
throw new Error('bai index contains too many bins, please use CSI');
case 33:
chunkCount = bytes.readInt32LE(currOffset);
currOffset += 4;
chunks = new Array(chunkCount);
for (k = 0; k < chunkCount; k += 1) {

@@ -78,98 +222,188 @@ u = (0, _virtualOffset.fromBytes)(bytes, currOffset);

currOffset += 16;
this._findFirstData(data, u);
chunks[k] = new _chunk.default(u, v, bin);
}
binIndex[bin] = chunks;case 38:j += 1;_context2.next = 20;break;case 41:
binIndex[bin] = chunks;
case 38:
j += 1;
_context2.next = 20;
break;
case 41:
linearCount = bytes.readInt32LE(currOffset);
currOffset += 4;
// as we're going through the linear index, figure out
currOffset += 4; // as we're going through the linear index, figure out
// the smallest virtual offset in the indexes, which
// tells us where the BAM header ends
linearIndex = new Array(linearCount);
for (_k = 0; _k < linearCount; _k += 1) {
linearIndex[_k] = (0, _virtualOffset.fromBytes)(bytes, currOffset);
currOffset += 8;
this._findFirstData(data, linearIndex[_k]);
}
data.indices[i] = { binIndex: binIndex, linearIndex: linearIndex, stats: stats };case 46:i += 1;_context2.next = 12;break;case 49:return _context2.abrupt("return",
data.indices[i] = {
binIndex: binIndex,
linearIndex: linearIndex,
stats: stats
};
case 46:
i += 1;
_context2.next = 12;
break;
data);case 50:case "end":return _context2.stop();}}}, _callee2, this);}));function _parse(_x2) {return _parse2.apply(this, arguments);}return _parse;}() }, { key: "indexCov", value: function () {var _indexCov = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(
case 49:
return _context2.abrupt("return", data);
case 50:
case "end":
return _context2.stop();
}
}
}, _callee2, this);
}));
seqId, start, end) {var v, range, indexData, seqIdx, _seqIdx$linearIndex, linearIndex, stats, e, s, depths, totalSize, currentPos, i, j;return _regenerator.default.wrap(function _callee3$(_context3) {while (1) {switch (_context3.prev = _context3.next) {case 0:
function _parse(_x2) {
return _parse2.apply(this, arguments);
}
return _parse;
}()
}, {
key: "indexCov",
value: function () {
var _indexCov = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee3(seqId, start, end) {
var v, range, indexData, seqIdx, _seqIdx$linearIndex, linearIndex, stats, e, s, depths, totalSize, currentPos, i, j;
return _regenerator.default.wrap(function _callee3$(_context3) {
while (1) {
switch (_context3.prev = _context3.next) {
case 0:
v = 16384;
range = start !== undefined;_context3.next = 4;return (
this.parse());case 4:indexData = _context3.sent;
seqIdx = indexData.indices[seqId];if (
seqIdx) {_context3.next = 8;break;}return _context3.abrupt("return", []);case 8:_seqIdx$linearIndex =
seqIdx.linearIndex, linearIndex = _seqIdx$linearIndex === void 0 ? [] : _seqIdx$linearIndex, stats = seqIdx.stats;if (
linearIndex.length) {_context3.next = 11;break;}return _context3.abrupt("return", []);case 11:
e = range ? roundUp(end, v) : (linearIndex.length - 1) * v;
s = range ? roundDown(start, v) : 0;
range = start !== undefined;
_context3.next = 4;
return this.parse();
case 4:
indexData = _context3.sent;
seqIdx = indexData.indices[seqId];
if (seqIdx) {
_context3.next = 8;
break;
}
return _context3.abrupt("return", []);
case 8:
_seqIdx$linearIndex = seqIdx.linearIndex, linearIndex = _seqIdx$linearIndex === void 0 ? [] : _seqIdx$linearIndex, stats = seqIdx.stats;
if (linearIndex.length) {
_context3.next = 11;
break;
}
return _context3.abrupt("return", []);
case 11:
e = end !== undefined ? roundUp(end, v) : (linearIndex.length - 1) * v;
s = start !== undefined ? roundDown(start, v) : 0;
if (range) {
depths = new Array(Math.floor((e - s) / v));
depths = new Array((e - s) / v);
} else {
depths = new Array(linearIndex.length - 1);
}
totalSize = linearIndex[linearIndex.length - 1].blockPosition;if (!(
e > (linearIndex.length - 1) * v)) {_context3.next = 17;break;}throw (
new Error('query outside of range of linear index'));case 17:
totalSize = linearIndex[linearIndex.length - 1].blockPosition;
if (!(e > (linearIndex.length - 1) * v)) {
_context3.next = 17;
break;
}
throw new Error('query outside of range of linear index');
case 17:
currentPos = linearIndex[s / v].blockPosition;
for (i = s / v, j = 0; i + 1 < e / v; i++, j++) {
for (i = s / v, j = 0; i < e / v; i++, j++) {
depths[j] = {
score: linearIndex[i + 1].blockPosition - currentPos,
start: i * v,
end: i * v + v };
end: i * v + v
};
currentPos = linearIndex[i + 1].blockPosition;
}return _context3.abrupt("return",
depths.map(function (d) {
return _objectSpread({}, d, { score: d.score * stats.lineCount / totalSize });
}));case 20:case "end":return _context3.stop();}}}, _callee3, this);}));function indexCov(_x3, _x4, _x5) {return _indexCov.apply(this, arguments);}return indexCov;}() }, { key: "indexCovTotal", value: function () {var _indexCovTotal = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(
}
return _context3.abrupt("return", depths.map(function (d) {
return _objectSpread({}, d, {
score: d.score * stats.lineCount / totalSize
});
}));
seqId) {var v, indexData, seqIdx, _seqIdx$linearIndex2, linearIndex, stats, currentPos, depths, totalSize, i, j;return _regenerator.default.wrap(function _callee4$(_context4) {while (1) {switch (_context4.prev = _context4.next) {case 0:
v = 16384;_context4.next = 3;return (
this.parse());case 3:indexData = _context4.sent;
seqIdx = indexData.indices[seqId];if (
seqIdx) {_context4.next = 7;break;}return _context4.abrupt("return", []);case 7:_seqIdx$linearIndex2 =
seqIdx.linearIndex, linearIndex = _seqIdx$linearIndex2 === void 0 ? [] : _seqIdx$linearIndex2, stats = seqIdx.stats;if (
linearIndex.length) {_context4.next = 10;break;}return _context4.abrupt("return", []);case 10:
currentPos = linearIndex[0].blockPosition;
depths = new Array(linearIndex.length - 1);
totalSize = linearIndex.slice(-1)[0].blockPosition;
for (i = 1, j = 0; i < linearIndex.length; i++, j++) {
depths[j] = linearIndex[i].blockPosition - currentPos;
currentPos = linearIndex[i].blockPosition;
}return _context4.abrupt("return",
depths.map(function (d, i) {
return {
score: d * stats.lineCount / totalSize,
start: i * v,
end: i * v + v };
case 20:
case "end":
return _context3.stop();
}
}
}, _callee3, this);
}));
}));case 15:case "end":return _context4.stop();}}}, _callee4, this);}));function indexCovTotal(_x6) {return _indexCovTotal.apply(this, arguments);}return indexCovTotal;}() }, { key: "blocksForRange", value: function () {var _blocksForRange = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(
function indexCov(_x3, _x4, _x5) {
return _indexCov.apply(this, arguments);
}
return indexCov;
}()
}, {
key: "blocksForRange",
value: function () {
var _blocksForRange = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee4(refId, beg, end) {
var indexData, indexes, binIndex, bins, l, numOffsets, i, off, _i, chunks, j, _i2, _i3;
refId, beg, end) {var indexData, indexes, binIndex, bins, l, numOffsets, i, off, _i, chunks, j, _i2, _i3;return _regenerator.default.wrap(function _callee5$(_context5) {while (1) {switch (_context5.prev = _context5.next) {case 0:
if (beg < 0) beg = 0;_context5.next = 3;return (
return _regenerator.default.wrap(function _callee4$(_context4) {
while (1) {
switch (_context4.prev = _context4.next) {
case 0:
if (beg < 0) beg = 0;
_context4.next = 3;
return this.parse();
this.parse());case 3:indexData = _context5.sent;if (
indexData) {_context5.next = 6;break;}return _context5.abrupt("return", []);case 6:
indexes = indexData.indices[refId];if (
indexes) {_context5.next = 9;break;}return _context5.abrupt("return", []);case 9:
case 3:
indexData = _context4.sent;
binIndex = indexes.binIndex;
if (indexData) {
_context4.next = 6;
break;
}
bins = this.reg2bins(beg, end);
return _context4.abrupt("return", []);
case 6:
indexes = indexData.indices[refId];
if (indexes) {
_context4.next = 9;
break;
}
return _context4.abrupt("return", []);
case 9:
binIndex = indexes.binIndex;
bins = this.reg2bins(beg, end);
numOffsets = 0;
for (i = 0; i < bins.length; i += 1) {

@@ -179,34 +413,44 @@ if (binIndex[bins[i]]) {

}
}if (!(
}
numOffsets === 0)) {_context5.next = 15;break;}return _context5.abrupt("return", []);case 15:
if (!(numOffsets === 0)) {
_context4.next = 15;
break;
}
return _context4.abrupt("return", []);
case 15:
off = [];
numOffsets = 0;
for (_i = 0; _i < bins.length; _i += 1) {
chunks = binIndex[bins[_i]];
if (chunks)
for (j = 0; j < chunks.length; j += 1) {
off[numOffsets] = new _chunk.default(
chunks[j].minv,
chunks[j].maxv,
chunks[j].bin);
if (chunks) for (j = 0; j < chunks.length; j += 1) {
off[numOffsets] = new _chunk.default(chunks[j].minv, chunks[j].maxv, chunks[j].bin);
numOffsets += 1;
}
}if (
}
off.length) {_context5.next = 20;break;}return _context5.abrupt("return", []);case 20:
if (off.length) {
_context4.next = 20;
break;
}
off = off.sort(function (a, b) {return a.compareTo(b);});
// resolve overlaps between adjacent blocks; this may happen due to the merge in indexing
return _context4.abrupt("return", []);
case 20:
off = off.sort(function (a, b) {
return a.compareTo(b);
}); // resolve overlaps between adjacent blocks; this may happen due to the merge in indexing
for (_i2 = 1; _i2 < numOffsets; _i2 += 1) {
if (off[_i2 - 1].maxv.compareTo(off[_i2].minv) >= 0)
off[_i2 - 1].maxv = off[_i2].minv;}
if (off[_i2 - 1].maxv.compareTo(off[_i2].minv) >= 0) off[_i2 - 1].maxv = off[_i2].minv;
} // merge adjacent blocks
// merge adjacent blocks
l = 0;
for (_i3 = 1; _i3 < numOffsets; _i3 += 1) {
if (canMergeBlocks(off[l], off[_i3])) off[l].maxv = off[_i3].maxv;else
{
if ((0, _util.canMergeBlocks)(off[l], off[_i3])) off[l].maxv = off[_i3].maxv;else {
l += 1;

@@ -217,21 +461,58 @@ off[l].minv = off[_i3].minv;

}
numOffsets = l + 1;return _context5.abrupt("return",
off.slice(0, numOffsets));case 26:case "end":return _context5.stop();}}}, _callee5, this);}));function blocksForRange(_x7, _x8, _x9) {return _blocksForRange.apply(this, arguments);}return blocksForRange;}()
numOffsets = l + 1;
return _context4.abrupt("return", off.slice(0, numOffsets));
case 26:
case "end":
return _context4.stop();
}
}
}, _callee4, this);
}));
function blocksForRange(_x6, _x7, _x8) {
return _blocksForRange.apply(this, arguments);
}
return blocksForRange;
}()
/**
* calculate the list of bins that may overlap with region [beg,end) (zero-based half-open)
* @returns {Array[number]}
*/ }, { key: "reg2bins", value: function reg2bins(
beg, end) {
* calculate the list of bins that may overlap with region [beg,end) (zero-based half-open)
* @returns {Array[number]}
*/
}, {
key: "reg2bins",
value: function reg2bins(beg, end) {
var list = [0];
end -= 1;
for (var k = 1 + (beg >> 26); k <= 1 + (end >> 26); k += 1) {list.push(k);}
for (var _k2 = 9 + (beg >> 23); _k2 <= 9 + (end >> 23); _k2 += 1) {list.push(_k2);}
for (var _k3 = 73 + (beg >> 20); _k3 <= 73 + (end >> 20); _k3 += 1) {list.push(_k3);}
for (var _k4 = 585 + (beg >> 17); _k4 <= 585 + (end >> 17); _k4 += 1) {list.push(_k4);}
for (var k = 1 + (beg >> 26); k <= 1 + (end >> 26); k += 1) {
list.push(k);
}
for (var _k2 = 9 + (beg >> 23); _k2 <= 9 + (end >> 23); _k2 += 1) {
list.push(_k2);
}
for (var _k3 = 73 + (beg >> 20); _k3 <= 73 + (end >> 20); _k3 += 1) {
list.push(_k3);
}
for (var _k4 = 585 + (beg >> 17); _k4 <= 585 + (end >> 17); _k4 += 1) {
list.push(_k4);
}
for (var _k5 = 4681 + (beg >> 14); _k5 <= 4681 + (end >> 14); _k5 += 1) {
list.push(_k5);}
list.push(_k5);
}
return list;
} }]);return BAI;}(_indexFile.default);exports.default = BAI;
}
}]);
return BAI;
}(_indexFile.default);
exports.default = BAI;
//# 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","slice","call","refId","parse","index","indices","ret","stats","undefined","abortSignal","data","bai","maxBlockSize","filehandle","readFile","signal","readUInt32LE","Error","refCount","readInt32LE","depth","binLimit","currOffset","i","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","map","d","beg","indexes","bins","reg2bins","numOffsets","off","minv","maxv","sort","a","b","compareTo","l","list","push","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, canMergeBlocks } 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(Long.fromBytesLE(Array.prototype.slice.call(bytes, offset + 16, offset + 24), true))\n    return { lineCount }\n  }\n\n  async lineCount(refId: number) {\n    const index = (await this.parse()).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(abortSignal?: AbortSignal) {\n    const data: { [key: string]: any } = { bai: true, maxBlockSize: 1 << 16 }\n    const bytes = (await this.filehandle.readFile({\n      signal: abortSignal,\n    })) 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(abortSignal)\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  ): Promise<{ start: number; end: number; score: number }[]> {\n    const v = 16384\n    const range = start !== undefined\n    const indexData = await this.parse()\n    const seqIdx = indexData.indices[seqId]\n    if (!seqIdx) return []\n    const { linearIndex = [], stats } = seqIdx\n    if (!linearIndex.length) return []\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  async blocksForRange(refId: number, beg: number, end: number): Promise<Chunk[]> {\n    if (beg < 0) beg = 0\n\n    const indexData = await this.parse()\n    if (!indexData) return []\n    const indexes = indexData.indices[refId]\n    if (!indexes) return []\n\n    const binIndex: { [key: number]: any } = indexes.binIndex\n\n    const bins = this.reg2bins(beg, end)\n\n    let l\n    let numOffsets = 0\n    for (let i = 0; i < bins.length; i += 1) {\n      if (binIndex[bins[i]]) {\n        numOffsets += binIndex[bins[i]].length\n      }\n    }\n\n    if (numOffsets === 0) return []\n\n    let off = []\n    numOffsets = 0\n    for (let i = 0; i < bins.length; i += 1) {\n      const chunks = binIndex[bins[i]]\n      if (chunks)\n        for (let j = 0; j < chunks.length; j += 1) {\n          off[numOffsets] = new Chunk(chunks[j].minv, chunks[j].maxv, chunks[j].bin)\n          numOffsets += 1\n        }\n    }\n\n    if (!off.length) return []\n\n    off = off.sort((a, b) => a.compareTo(b))\n    // resolve overlaps between adjacent blocks; this may happen due to the merge in indexing\n    for (let i = 1; i < numOffsets; i += 1)\n      if (off[i - 1].maxv.compareTo(off[i].minv) >= 0) off[i - 1].maxv = off[i].minv\n\n    // merge adjacent blocks\n    l = 0\n    for (let i = 1; i < numOffsets; i += 1) {\n      if (canMergeBlocks(off[l], off[i])) off[l].maxv = off[i].maxv\n      else {\n        l += 1\n        off[l].minv = off[i].minv\n        off[l].maxv = off[i].maxv\n      }\n    }\n    numOffsets = l + 1\n\n    return off.slice(0, numOffsets)\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    const list = [0]\n    end -= 1\n    for (let k = 1 + (beg >> 26); k <= 1 + (end >> 26); k += 1) list.push(k)\n    for (let k = 9 + (beg >> 23); k <= 9 + (end >> 23); k += 1) list.push(k)\n    for (let k = 73 + (beg >> 20); k <= 73 + (end >> 20); k += 1) list.push(k)\n    for (let k = 585 + (beg >> 17); k <= 585 + (end >> 17); k += 1) list.push(k)\n    for (let k = 4681 + (beg >> 14); k <= 4681 + (end >> 14); k += 1) list.push(k)\n    return list\n  }\n}\n"]}

@@ -1,10 +0,36 @@

"use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); // little class representing a chunk in the index
var Chunk = /*#__PURE__*/function () {
"use strict";
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
// little class representing a chunk in the index
var Chunk =
/*#__PURE__*/
function () {
/**
* @param {VirtualOffset} minv
* @param {VirtualOffset} maxv
* @param {number} bin
* @param {number} [fetchedSize]
*/
function Chunk(minv, maxv, bin, fetchedSize) {(0, _classCallCheck2.default)(this, Chunk);
* @param {VirtualOffset} minv
* @param {VirtualOffset} maxv
* @param {number} bin
* @param {number} [fetchedSize]
*/
function Chunk(minv, maxv, bin) {
var fetchedSize = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : undefined;
(0, _classCallCheck2.default)(this, Chunk);
(0, _defineProperty2.default)(this, "minv", void 0);
(0, _defineProperty2.default)(this, "maxv", void 0);
(0, _defineProperty2.default)(this, "bin", void 0);
(0, _defineProperty2.default)(this, "_fetchedSize", void 0);
this.minv = minv;

@@ -14,28 +40,30 @@ this.maxv = maxv;

this._fetchedSize = fetchedSize;
}(0, _createClass2.default)(Chunk, [{ key: "toUniqueString", value: function toUniqueString()
}
{
return "".concat(this.minv, "..").concat(this.maxv, " (bin ").concat(
this.bin, ", fetchedSize ").concat(
this.fetchedSize(), ")");
} }, { key: "toString", value: function toString()
{
(0, _createClass2.default)(Chunk, [{
key: "toUniqueString",
value: function toUniqueString() {
return "".concat(this.minv, "..").concat(this.maxv, " (bin ").concat(this.bin, ", fetchedSize ").concat(this.fetchedSize(), ")");
}
}, {
key: "toString",
value: function toString() {
return this.toUniqueString();
} }, { key: "compareTo", value: function compareTo(
b) {
return (
this.minv.compareTo(b.minv) ||
this.maxv.compareTo(b.maxv) ||
this.bin - b.bin);
} }, { key: "fetchedSize", value: function fetchedSize()
{
}
}, {
key: "compareTo",
value: function compareTo(b) {
return this.minv.compareTo(b.minv) || this.maxv.compareTo(b.maxv) || this.bin - b.bin;
}
}, {
key: "fetchedSize",
value: function fetchedSize() {
if (this._fetchedSize !== undefined) return this._fetchedSize;
return this.maxv.blockPosition + (1 << 16) - this.minv.blockPosition;
} }]);return Chunk;}();
}
}]);
return Chunk;
}();
module.exports = Chunk;
exports.default = Chunk;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jaHVuay50cyJdLCJuYW1lcyI6WyJDaHVuayIsIm1pbnYiLCJtYXh2IiwiYmluIiwiZmV0Y2hlZFNpemUiLCJ1bmRlZmluZWQiLCJfZmV0Y2hlZFNpemUiLCJ0b1VuaXF1ZVN0cmluZyIsImIiLCJjb21wYXJlVG8iLCJibG9ja1Bvc2l0aW9uIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQTtJQUNxQkEsSzs7O0FBTW5COzs7Ozs7QUFNQSxpQkFBWUMsSUFBWixFQUFpQ0MsSUFBakMsRUFBc0RDLEdBQXRELEVBQTRGO0FBQUEsUUFBekJDLFdBQXlCLHVFQUFYQyxTQUFXO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUMxRixTQUFLSixJQUFMLEdBQVlBLElBQVo7QUFDQSxTQUFLQyxJQUFMLEdBQVlBLElBQVo7QUFDQSxTQUFLQyxHQUFMLEdBQVdBLEdBQVg7QUFDQSxTQUFLRyxZQUFMLEdBQW9CRixXQUFwQjtBQUNEOzs7O3FDQUVnQjtBQUNmLHVCQUFVLEtBQUtILElBQWYsZUFBd0IsS0FBS0MsSUFBN0IsbUJBQTBDLEtBQUtDLEdBQS9DLDJCQUFtRSxLQUFLQyxXQUFMLEVBQW5FO0FBQ0Q7OzsrQkFFVTtBQUNULGFBQU8sS0FBS0csY0FBTCxFQUFQO0FBQ0Q7Ozs4QkFFU0MsQyxFQUFVO0FBQ2xCLGFBQU8sS0FBS1AsSUFBTCxDQUFVUSxTQUFWLENBQW9CRCxDQUFDLENBQUNQLElBQXRCLEtBQStCLEtBQUtDLElBQUwsQ0FBVU8sU0FBVixDQUFvQkQsQ0FBQyxDQUFDTixJQUF0QixDQUEvQixJQUE4RCxLQUFLQyxHQUFMLEdBQVdLLENBQUMsQ0FBQ0wsR0FBbEY7QUFDRDs7O2tDQUVhO0FBQ1osVUFBSSxLQUFLRyxZQUFMLEtBQXNCRCxTQUExQixFQUFxQyxPQUFPLEtBQUtDLFlBQVo7QUFDckMsYUFBTyxLQUFLSixJQUFMLENBQVVRLGFBQVYsSUFBMkIsS0FBSyxFQUFoQyxJQUFzQyxLQUFLVCxJQUFMLENBQVVTLGFBQXZEO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgVmlydHVhbE9mZnNldCBmcm9tICcuL3ZpcnR1YWxPZmZzZXQnXG5cbi8vIGxpdHRsZSBjbGFzcyByZXByZXNlbnRpbmcgYSBjaHVuayBpbiB0aGUgaW5kZXhcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENodW5rIHtcbiAgcHVibGljIG1pbnY6IFZpcnR1YWxPZmZzZXRcbiAgcHVibGljIG1heHY6IFZpcnR1YWxPZmZzZXRcbiAgcHVibGljIGJpbjogbnVtYmVyXG4gIHB1YmxpYyBfZmV0Y2hlZFNpemU/OiBudW1iZXJcblxuICAvKipcbiAgICogQHBhcmFtIHtWaXJ0dWFsT2Zmc2V0fSBtaW52XG4gICAqIEBwYXJhbSB7VmlydHVhbE9mZnNldH0gbWF4dlxuICAgKiBAcGFyYW0ge251bWJlcn0gYmluXG4gICAqIEBwYXJhbSB7bnVtYmVyfSBbZmV0Y2hlZFNpemVdXG4gICAqL1xuICBjb25zdHJ1Y3RvcihtaW52OiBWaXJ0dWFsT2Zmc2V0LCBtYXh2OiBWaXJ0dWFsT2Zmc2V0LCBiaW46IG51bWJlciwgZmV0Y2hlZFNpemUgPSB1bmRlZmluZWQpIHtcbiAgICB0aGlzLm1pbnYgPSBtaW52XG4gICAgdGhpcy5tYXh2ID0gbWF4dlxuICAgIHRoaXMuYmluID0gYmluXG4gICAgdGhpcy5fZmV0Y2hlZFNpemUgPSBmZXRjaGVkU2l6ZVxuICB9XG5cbiAgdG9VbmlxdWVTdHJpbmcoKSB7XG4gICAgcmV0dXJuIGAke3RoaXMubWludn0uLiR7dGhpcy5tYXh2fSAoYmluICR7dGhpcy5iaW59LCBmZXRjaGVkU2l6ZSAke3RoaXMuZmV0Y2hlZFNpemUoKX0pYFxuICB9XG5cbiAgdG9TdHJpbmcoKSB7XG4gICAgcmV0dXJuIHRoaXMudG9VbmlxdWVTdHJpbmcoKVxuICB9XG5cbiAgY29tcGFyZVRvKGI6IENodW5rKSB7XG4gICAgcmV0dXJuIHRoaXMubWludi5jb21wYXJlVG8oYi5taW52KSB8fCB0aGlzLm1heHYuY29tcGFyZVRvKGIubWF4dikgfHwgdGhpcy5iaW4gLSBiLmJpblxuICB9XG5cbiAgZmV0Y2hlZFNpemUoKSB7XG4gICAgaWYgKHRoaXMuX2ZldGNoZWRTaXplICE9PSB1bmRlZmluZWQpIHJldHVybiB0aGlzLl9mZXRjaGVkU2l6ZVxuICAgIHJldHVybiB0aGlzLm1heHYuYmxvY2tQb3NpdGlvbiArICgxIDw8IDE2KSAtIHRoaXMubWludi5ibG9ja1Bvc2l0aW9uXG4gIH1cbn1cbiJdfQ==

@@ -1,2 +0,11 @@

"use strict";module.exports = {
"use strict";
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _default = {
// the read is paired in sequencing, no matter whether it is mapped in a pair

@@ -25,2 +34,5 @@ BAM_FPAIRED: 1,

// supplementary alignment
BAM_FSUPPLEMENTARY: 2048 };
BAM_FSUPPLEMENTARY: 2048
};
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb25zdGFudHMudHMiXSwibmFtZXMiOlsiQkFNX0ZQQUlSRUQiLCJCQU1fRlBST1BFUl9QQUlSIiwiQkFNX0ZVTk1BUCIsIkJBTV9GTVVOTUFQIiwiQkFNX0ZSRVZFUlNFIiwiQkFNX0ZNUkVWRVJTRSIsIkJBTV9GUkVBRDEiLCJCQU1fRlJFQUQyIiwiQkFNX0ZTRUNPTkRBUlkiLCJCQU1fRlFDRkFJTCIsIkJBTV9GRFVQIiwiQkFNX0ZTVVBQTEVNRU5UQVJZIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7ZUFBZTtBQUNiO0FBQ0FBLEVBQUFBLFdBQVcsRUFBRSxDQUZBO0FBR2I7QUFDQUMsRUFBQUEsZ0JBQWdCLEVBQUUsQ0FKTDtBQUtiO0FBQ0FDLEVBQUFBLFVBQVUsRUFBRSxDQU5DO0FBT2I7QUFDQUMsRUFBQUEsV0FBVyxFQUFFLENBUkE7QUFTYjtBQUNBQyxFQUFBQSxZQUFZLEVBQUUsRUFWRDtBQVdiO0FBQ0FDLEVBQUFBLGFBQWEsRUFBRSxFQVpGO0FBYWI7QUFDQUMsRUFBQUEsVUFBVSxFQUFFLEVBZEM7QUFlYjtBQUNBQyxFQUFBQSxVQUFVLEVBQUUsR0FoQkM7QUFpQmI7QUFDQUMsRUFBQUEsY0FBYyxFQUFFLEdBbEJIO0FBbUJiO0FBQ0FDLEVBQUFBLFdBQVcsRUFBRSxHQXBCQTtBQXFCYjtBQUNBQyxFQUFBQSxRQUFRLEVBQUUsSUF0Qkc7QUF1QmI7QUFDQUMsRUFBQUEsa0JBQWtCLEVBQUU7QUF4QlAsQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IHtcbiAgLy8gIHRoZSByZWFkIGlzIHBhaXJlZCBpbiBzZXF1ZW5jaW5nLCBubyBtYXR0ZXIgd2hldGhlciBpdCBpcyBtYXBwZWQgaW4gYSBwYWlyXG4gIEJBTV9GUEFJUkVEOiAxLFxuICAvLyAgdGhlIHJlYWQgaXMgbWFwcGVkIGluIGEgcHJvcGVyIHBhaXJcbiAgQkFNX0ZQUk9QRVJfUEFJUjogMixcbiAgLy8gIHRoZSByZWFkIGl0c2VsZiBpcyB1bm1hcHBlZDsgY29uZmxpY3RpdmUgd2l0aCBCQU1fRlBST1BFUl9QQUlSXG4gIEJBTV9GVU5NQVA6IDQsXG4gIC8vICB0aGUgbWF0ZSBpcyB1bm1hcHBlZFxuICBCQU1fRk1VTk1BUDogOCxcbiAgLy8gIHRoZSByZWFkIGlzIG1hcHBlZCB0byB0aGUgcmV2ZXJzZSBzdHJhbmRcbiAgQkFNX0ZSRVZFUlNFOiAxNixcbiAgLy8gIHRoZSBtYXRlIGlzIG1hcHBlZCB0byB0aGUgcmV2ZXJzZSBzdHJhbmRcbiAgQkFNX0ZNUkVWRVJTRTogMzIsXG4gIC8vICB0aGlzIGlzIHJlYWQxXG4gIEJBTV9GUkVBRDE6IDY0LFxuICAvLyAgdGhpcyBpcyByZWFkMlxuICBCQU1fRlJFQUQyOiAxMjgsXG4gIC8vICBub3QgcHJpbWFyeSBhbGlnbm1lbnRcbiAgQkFNX0ZTRUNPTkRBUlk6IDI1NixcbiAgLy8gIFFDIGZhaWx1cmVcbiAgQkFNX0ZRQ0ZBSUw6IDUxMixcbiAgLy8gIG9wdGljYWwgb3IgUENSIGR1cGxpY2F0ZVxuICBCQU1fRkRVUDogMTAyNCxcbiAgLy8gIHN1cHBsZW1lbnRhcnkgYWxpZ25tZW50XG4gIEJBTV9GU1VQUExFTUVOVEFSWTogMjA0OCxcbn1cbiJdfQ==

@@ -1,11 +0,47 @@

"use strict";var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");Object.defineProperty(exports, "__esModule", { value: true });exports.default = void 0;var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));var Long = _interopRequireWildcard(require("long"));
"use strict";
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _assign = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/assign"));
var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs2/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/getPrototypeOf"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
var _long = _interopRequireDefault(require("long"));
var _unzip = require("./unzip");
var _virtualOffset = require("./virtualOffset");
var _chunk = _interopRequireDefault(require("./chunk"));
var _util = require("./util");
var IndexFile = require('./indexFile');
var _indexFile = _interopRequireDefault(require("./indexFile"));
var CSI1_MAGIC = 21582659; // CSI\1
var CSI2_MAGIC = 38359875; // CSI\2

@@ -16,32 +52,131 @@

}
function rshift(num, bits) {
return Math.floor(num / Math.pow(2, bits));
}var
}
CSI = /*#__PURE__*/function (_IndexFile) {(0, _inherits2.default)(CSI, _IndexFile);function CSI() {(0, _classCallCheck2.default)(this, CSI);return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(CSI).apply(this, arguments));}(0, _createClass2.default)(CSI, [{ key: "lineCount", value: function () {var _lineCount = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(
refId) {var indexData, idx, stats;return _regenerator.default.wrap(function _callee$(_context) {while (1) {switch (_context.prev = _context.next) {case 0:_context.next = 2;return (
this.parse());case 2:indexData = _context.sent;if (
indexData) {_context.next = 5;break;}return _context.abrupt("return", -1);case 5:
idx = indexData.indices[refId];if (
idx) {_context.next = 8;break;}return _context.abrupt("return", -1);case 8:
stats = indexData.indices[refId].stats;if (!
stats) {_context.next = 11;break;}return _context.abrupt("return", stats.lineCount);case 11:return _context.abrupt("return",
-1);case 12:case "end":return _context.stop();}}}, _callee, this);}));function lineCount(_x) {return _lineCount.apply(this, arguments);}return lineCount;}() }, { key: "parseAuxData", value: function parseAuxData(
var CSI =
/*#__PURE__*/
function (_IndexFile) {
(0, _inherits2.default)(CSI, _IndexFile);
function CSI(args) {
var _this;
bytes, offset, auxLength) {
(0, _classCallCheck2.default)(this, CSI);
_this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(CSI).call(this, args));
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "maxBinNumber", void 0);
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "depth", void 0);
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "minShift", void 0);
_this.maxBinNumber = 0;
_this.depth = 0;
_this.minShift = 0;
return _this;
}
(0, _createClass2.default)(CSI, [{
key: "lineCount",
value: function () {
var _lineCount = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee(refId) {
var indexData, idx, stats;
return _regenerator.default.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
_context.next = 2;
return this.parse();
case 2:
indexData = _context.sent;
if (indexData) {
_context.next = 5;
break;
}
return _context.abrupt("return", -1);
case 5:
idx = indexData.indices[refId];
if (idx) {
_context.next = 8;
break;
}
return _context.abrupt("return", -1);
case 8:
stats = indexData.indices[refId].stats;
if (!stats) {
_context.next = 11;
break;
}
return _context.abrupt("return", stats.lineCount);
case 11:
return _context.abrupt("return", -1);
case 12:
case "end":
return _context.stop();
}
}
}, _callee, this);
}));
function lineCount(_x) {
return _lineCount.apply(this, arguments);
}
return lineCount;
}()
}, {
key: "indexCov",
value: function () {
var _indexCov = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee2() {
return _regenerator.default.wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
throw new Error('CSI indexes do not support indexcov');
case 2:
case "end":
return _context2.stop();
}
}
}, _callee2);
}));
function indexCov() {
return _indexCov.apply(this, arguments);
}
return indexCov;
}()
}, {
key: "parseAuxData",
value: function parseAuxData(bytes, offset, auxLength) {
if (auxLength < 30) return {};
var data = {};
data.formatFlags = bytes.readInt32LE(offset);
data.coordinateType =
data.formatFlags & 0x10000 ? 'zero-based-half-open' : '1-based-closed';
data.format = { 0: 'generic', 1: 'SAM', 2: 'VCF' }[data.formatFlags & 0xf];
if (!data.format)
throw new Error("invalid Tabix preset format flags ".concat(data.formatFlags));
data.coordinateType = data.formatFlags & 0x10000 ? 'zero-based-half-open' : '1-based-closed';
data.format = {
0: 'generic',
1: 'SAM',
2: 'VCF'
}[data.formatFlags & 0xf];
if (!data.format) throw new Error("invalid Tabix preset format flags ".concat(data.formatFlags));
data.columnNumbers = {
ref: bytes.readInt32LE(offset + 4),
start: bytes.readInt32LE(offset + 8),
end: bytes.readInt32LE(offset + 12) };
end: bytes.readInt32LE(offset + 12)
};
data.metaValue = bytes.readInt32LE(offset + 16);

@@ -51,13 +186,8 @@ data.metaChar = data.metaValue ? String.fromCharCode(data.metaValue) : '';

var nameSectionLength = bytes.readInt32LE(offset + 24);
Object.assign(
data,
this._parseNameBytes(
bytes.slice(offset + 28, offset + 28 + nameSectionLength)));
(0, _assign.default)(data, this._parseNameBytes(bytes.slice(offset + 28, offset + 28 + nameSectionLength)));
return data;
} }, { key: "_parseNameBytes", value: function _parseNameBytes(
namesBytes) {
}
}, {
key: "_parseNameBytes",
value: function _parseNameBytes(namesBytes) {
var currRefId = 0;

@@ -67,2 +197,3 @@ var currNameStart = 0;

var refNameToId = {};
for (var i = 0; i < namesBytes.length; i += 1) {

@@ -76,2 +207,3 @@ if (!namesBytes[i]) {

}
currNameStart = i + 1;

@@ -81,22 +213,61 @@ currRefId += 1;

}
return { refNameToId: refNameToId, refIdToName: refIdToName };
}
// fetch and parse the index
}, { key: "_parse", value: function () {var _parse2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(abortSignal) {var data, bytes, auxLength, currOffset, i, binCount, binIndex, stats, j, bin, loffset, chunkCount, chunks, k, u, v;return _regenerator.default.wrap(function _callee2$(_context2) {while (1) {switch (_context2.prev = _context2.next) {case 0:
data = { csi: true, maxBlockSize: 1 << 16 };_context2.t0 =
_unzip.unzip;_context2.next = 4;return (
this.filehandle.readFile({ signal: abortSignal }));case 4:_context2.t1 = _context2.sent;_context2.next = 7;return (0, _context2.t0)(_context2.t1);case 7:bytes = _context2.sent;if (!(
return {
refNameToId: refNameToId,
refIdToName: refIdToName
};
} // fetch and parse the index
}, {
key: "_parse",
value: function () {
var _parse2 = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee3(abortSignal) {
var data, bytes, auxLength, currOffset, i, binCount, binIndex, stats, j, bin, loffset, chunkCount, chunks, k, u, v;
return _regenerator.default.wrap(function _callee3$(_context3) {
while (1) {
switch (_context3.prev = _context3.next) {
case 0:
data = {
csi: true,
maxBlockSize: 1 << 16
};
_context3.t0 = _unzip.unzip;
_context3.next = 4;
return this.filehandle.readFile({
signal: abortSignal
});
case 4:
_context3.t1 = _context3.sent;
_context3.next = 7;
return (0, _context3.t0)(_context3.t1);
bytes.readUInt32LE(0) === CSI1_MAGIC)) {_context2.next = 12;break;}
data.csiVersion = 1;_context2.next = 17;break;case 12:if (!(
bytes.readUInt32LE(0) === CSI2_MAGIC)) {_context2.next = 16;break;}
data.csiVersion = 2;_context2.next = 17;break;case 16:throw (
case 7:
bytes = _context3.sent;
new Error('Not a CSI file'));case 17:
if (!(bytes.readUInt32LE(0) === CSI1_MAGIC)) {
_context3.next = 12;
break;
}
data.csiVersion = 1;
_context3.next = 17;
break;
case 12:
if (!(bytes.readUInt32LE(0) === CSI2_MAGIC)) {
_context3.next = 16;
break;
}
data.csiVersion = 2;
_context3.next = 17;
break;
case 16:
throw new Error('Not a CSI file');
case 17:
this.minShift = bytes.readInt32LE(4);

@@ -106,12 +277,23 @@ this.depth = bytes.readInt32LE(8);

auxLength = bytes.readInt32LE(12);
if (auxLength) {
Object.assign(data, this.parseAuxData(bytes, 16, auxLength));
(0, _assign.default)(data, this.parseAuxData(bytes, 16, auxLength));
}
data.refCount = bytes.readInt32LE(16 + auxLength);
// read the indexes for each reference sequence
data.refCount = bytes.readInt32LE(16 + auxLength); // read the indexes for each reference sequence
data.indices = new Array(data.refCount);
currOffset = 16 + auxLength + 4;
i = 0;case 26:if (!(i < data.refCount)) {_context2.next = 38;break;}_context2.next = 29;return (
(0, _util.abortBreakPoint)(abortSignal));case 29:
i = 0;
case 26:
if (!(i < data.refCount)) {
_context3.next = 38;
break;
}
_context3.next = 29;
return (0, _util.abortBreakPoint)(abortSignal);
case 29:
// the binning index

@@ -122,4 +304,6 @@ binCount = bytes.readInt32LE(currOffset);

stats = void 0; // < provided by parsing a pseudo-bin, if present
for (j = 0; j < binCount; j += 1) {
bin = bytes.readUInt32LE(currOffset);
if (bin > this.maxBinNumber) {

@@ -132,13 +316,17 @@ // this is a fake bin that actually has stats information

loffset = (0, _virtualOffset.fromBytes)(bytes, currOffset + 4);
this._findFirstData(data, loffset);
chunkCount = bytes.readInt32LE(currOffset + 12);
currOffset += 16;
chunks = new Array(chunkCount);
for (k = 0; k < chunkCount; k += 1) {
u = (0, _virtualOffset.fromBytes)(bytes, currOffset);
v = (0, _virtualOffset.fromBytes)(bytes, currOffset + 8);
currOffset += 16;
// this._findFirstData(data, u)
currOffset += 16; // this._findFirstData(data, u)
chunks[k] = new _chunk.default(u, v, bin);
}
binIndex[bin] = chunks;

@@ -148,9 +336,32 @@ }

data.indices[i] = { binIndex: binIndex, stats: stats };case 35:i += 1;_context2.next = 26;break;case 38:return _context2.abrupt("return",
data.indices[i] = {
binIndex: binIndex,
stats: stats
};
case 35:
i += 1;
_context3.next = 26;
break;
data);case 39:case "end":return _context2.stop();}}}, _callee2, this);}));function _parse(_x2) {return _parse2.apply(this, arguments);}return _parse;}() }, { key: "parsePseudoBin", value: function parsePseudoBin(
case 38:
return _context3.abrupt("return", data);
case 39:
case "end":
return _context3.stop();
}
}
}, _callee3, this);
}));
bytes, offset) {
function _parse(_x2) {
return _parse2.apply(this, arguments);
}
return _parse;
}()
}, {
key: "parsePseudoBin",
value: function parsePseudoBin(bytes, offset) {
// const one = Long.fromBytesLE(bytes.slice(offset + 4, offset + 12), true)

@@ -161,49 +372,101 @@ // const two = Long.fromBytesLE(bytes.slice(offset + 12, offset + 20), true)

// )
var lineCount = (0, _util.longToNumber)(
Long.fromBytesLE(bytes.slice(offset + 28, offset + 36), true));
var lineCount = (0, _util.longToNumber)(_long.default.fromBytesLE(Array.prototype.slice.call(bytes, offset + 28, offset + 36), true));
return {
lineCount: lineCount
};
}
}, {
key: "blocksForRange",
value: function () {
var _blocksForRange = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee4(refId, beg, end) {
var opts,
indexData,
indexes,
binIndex,
bins,
l,
numOffsets,
i,
off,
_i,
chunks,
j,
_i2,
_i3,
_i4,
_args4 = arguments;
return { lineCount: lineCount };
} }, { key: "blocksForRange", value: function () {var _blocksForRange = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(
return _regenerator.default.wrap(function _callee4$(_context4) {
while (1) {
switch (_context4.prev = _context4.next) {
case 0:
opts = _args4.length > 3 && _args4[3] !== undefined ? _args4[3] : {};
if (beg < 0) beg = 0;
_context4.next = 4;
return this.parse(opts.signal);
refId, beg, end, opts) {var indexData, indexes, binIndex, bins, l, numOffsets, i, off, _i, chunks, j, _i2, _i3, _i4;return _regenerator.default.wrap(function _callee3$(_context3) {while (1) {switch (_context3.prev = _context3.next) {case 0:
if (beg < 0) beg = 0;_context3.next = 3;return (
case 4:
indexData = _context4.sent;
this.parse(opts.signal));case 3:indexData = _context3.sent;if (
indexData) {_context3.next = 6;break;}return _context3.abrupt("return", []);case 6:
indexes = indexData.indices[refId];if (
indexes) {_context3.next = 9;break;}return _context3.abrupt("return", []);case 9:
if (indexData) {
_context4.next = 7;
break;
}
binIndex = indexes.binIndex;
return _context4.abrupt("return", []);
bins = this.reg2bins(beg, end);
case 7:
indexes = indexData.indices[refId];
if (indexes) {
_context4.next = 10;
break;
}
return _context4.abrupt("return", []);
case 10:
binIndex = indexes.binIndex;
bins = this.reg2bins(beg, end);
numOffsets = 0;
for (i = 0; i < bins.length; i += 1) {
if (binIndex[bins[i]]) numOffsets += binIndex[bins[i]].length;
}if (!(
}
numOffsets === 0)) {_context3.next = 15;break;}return _context3.abrupt("return", []);case 15:
if (!(numOffsets === 0)) {
_context4.next = 16;
break;
}
return _context4.abrupt("return", []);
case 16:
off = [];
numOffsets = 0;
for (_i = 0; _i < bins.length; _i += 1) {
chunks = binIndex[bins[_i]];
if (chunks)
for (j = 0; j < chunks.length; j += 1) {
off[numOffsets] = new _chunk.default(
chunks[j].minv,
chunks[j].maxv,
chunks[j].bin);
if (chunks) for (j = 0; j < chunks.length; j += 1) {
off[numOffsets] = new _chunk.default(chunks[j].minv, chunks[j].maxv, chunks[j].bin);
numOffsets += 1;
}
}if (
}
off.length) {_context3.next = 20;break;}return _context3.abrupt("return", []);case 20:
if (off.length) {
_context4.next = 21;
break;
}
off = off.sort(function (a, b) {return a.compareTo(b);});
return _context4.abrupt("return", []);
// resolve completely contained adjacent blocks
case 21:
off = off.sort(function (a, b) {
return a.compareTo(b);
}); // resolve completely contained adjacent blocks
l = 0;
for (_i2 = 1; _i2 < numOffsets; _i2 += 1) {

@@ -216,14 +479,14 @@ if (off[l].maxv.compareTo(off[_i2].maxv) < 0) {

}
numOffsets = l + 1;
// resolve overlaps between adjacent blocks; this may happen due to the merge in indexing
numOffsets = l + 1; // resolve overlaps between adjacent blocks; this may happen due to the merge in indexing
for (_i3 = 1; _i3 < numOffsets; _i3 += 1) {
if (off[_i3 - 1].maxv.compareTo(off[_i3].minv) >= 0)
off[_i3 - 1].maxv = off[_i3].minv;}
if (off[_i3 - 1].maxv.compareTo(off[_i3].minv) >= 0) off[_i3 - 1].maxv = off[_i3].minv;
} // merge adjacent blocks
// merge adjacent blocks
l = 0;
for (_i4 = 1; _i4 < numOffsets; _i4 += 1) {
if ((0, _util.canMergeBlocks)(off[l], off[_i4])) off[l].maxv = off[_i4].maxv;else
{
if ((0, _util.canMergeBlocks)(off[l], off[_i4])) off[l].maxv = off[_i4].maxv;else {
l += 1;

@@ -234,15 +497,33 @@ off[l].minv = off[_i4].minv;

}
numOffsets = l + 1;return _context3.abrupt("return",
off.slice(0, numOffsets));case 29:case "end":return _context3.stop();}}}, _callee3, this);}));function blocksForRange(_x3, _x4, _x5, _x6) {return _blocksForRange.apply(this, arguments);}return blocksForRange;}()
numOffsets = l + 1;
return _context4.abrupt("return", off.slice(0, numOffsets));
case 30:
case "end":
return _context4.stop();
}
}
}, _callee4, this);
}));
function blocksForRange(_x3, _x4, _x5) {
return _blocksForRange.apply(this, arguments);
}
return blocksForRange;
}()
/**
* calculate the list of bins that may overlap with region [beg,end) (zero-based half-open)
* @returns {Array[number]}
*/ }, { key: "reg2bins", value: function reg2bins(
beg, end) {
* calculate the list of bins that may overlap with region [beg,end) (zero-based half-open)
* @returns {Array[number]}
*/
}, {
key: "reg2bins",
value: function reg2bins(beg, end) {
beg -= 1; // < convert to 1-based closed
if (beg < 1) beg = 1;
if (end > Math.pow(2, 50)) end = Math.pow(2, 34); // 17 GiB ought to be enough for anybody
end -= 1;

@@ -253,12 +534,20 @@ var l = 0;

var bins = [];
for (; l <= this.depth; s -= 3, t += lshift(1, l * 3), l += 1) {
var b = t + rshift(beg, s);
var e = t + rshift(end, s);
if (e - b + bins.length > this.maxBinNumber)
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"));
if (e - b + bins.length > this.maxBinNumber) 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"));
for (var i = b; i <= e; i += 1) {bins.push(i);}
for (var i = b; i <= e; i += 1) {
bins.push(i);
}
}
return bins;
} }]);return CSI;}(IndexFile);exports.default = CSI;
}
}]);
return CSI;
}(_indexFile.default);
exports.default = CSI;
//# 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","Error","bytes","offset","auxLength","data","formatFlags","readInt32LE","coordinateType","format","columnNumbers","ref","start","end","metaValue","metaChar","String","fromCharCode","skipLines","nameSectionLength","_parseNameBytes","slice","namesBytes","currRefId","currNameStart","refIdToName","refNameToId","i","length","refName","toString","renameRefSeq","abortSignal","csi","maxBlockSize","unzip","filehandle","readFile","signal","readUInt32LE","csiVersion","parseAuxData","refCount","Array","currOffset","binCount","binIndex","j","bin","parsePseudoBin","loffset","_findFirstData","chunkCount","chunks","k","u","v","Chunk","Long","fromBytesLE","prototype","call","beg","opts","indexes","bins","reg2bins","numOffsets","off","minv","maxv","sort","a","b","compareTo","l","t","s","e","push","IndexFile"],"mappings":"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","sourcesContent":["import Long from 'long'\nimport { unzip } from './unzip'\n\nimport { fromBytes } from './virtualOffset'\nimport Chunk from './chunk'\nimport { longToNumber, abortBreakPoint, canMergeBlocks } 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) return -1\n    const idx = indexData.indices[refId]\n    if (!idx) return -1\n    const { stats } = indexData.indices[refId]\n    if (stats) return stats.lineCount\n    return -1\n  }\n  async indexCov() {\n    throw new Error('CSI indexes do not support indexcov')\n    return []\n  }\n\n  parseAuxData(bytes: Buffer, offset: number, auxLength: number) {\n    if (auxLength < 30) return {}\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 })[data.formatFlags & 0xf]\n    if (!data.format) throw new Error(`invalid Tabix preset format flags ${data.formatFlags}`)\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(data, this._parseNameBytes(bytes.slice(offset + 28, offset + 28 + nameSectionLength)))\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(abortSignal?: AbortSignal) {\n    const data: { [key: string]: any } = { csi: true, maxBlockSize: 1 << 16 }\n    const bytes = await unzip((await this.filehandle.readFile({ signal: abortSignal })) as 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(abortSignal)\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(Long.fromBytesLE(Array.prototype.slice.call(bytes, offset + 28, offset + 36), true))\n    return { lineCount }\n  }\n\n  async blocksForRange(refId: number, beg: number, end: number, opts: Record<string, any> = {}): Promise<Chunk[]> {\n    if (beg < 0) beg = 0\n\n    const indexData = await this.parse(opts.signal)\n    if (!indexData) return []\n    const indexes = indexData.indices[refId]\n    if (!indexes) return []\n\n    const { binIndex } = indexes\n\n    const bins = this.reg2bins(beg, end)\n\n    let l\n    let numOffsets = 0\n    for (let i = 0; i < bins.length; i += 1) {\n      if (binIndex[bins[i]]) numOffsets += binIndex[bins[i]].length\n    }\n\n    if (numOffsets === 0) return []\n\n    let off = []\n    numOffsets = 0\n    for (let i = 0; i < bins.length; i += 1) {\n      const chunks = binIndex[bins[i]]\n      if (chunks)\n        for (let j = 0; j < chunks.length; j += 1) {\n          off[numOffsets] = new Chunk(chunks[j].minv, chunks[j].maxv, chunks[j].bin)\n          numOffsets += 1\n        }\n    }\n\n    if (!off.length) return []\n\n    off = off.sort((a, b) => a.compareTo(b))\n\n    // resolve completely contained adjacent blocks\n    l = 0\n    for (let i = 1; i < numOffsets; i += 1) {\n      if (off[l].maxv.compareTo(off[i].maxv) < 0) {\n        l += 1\n        off[l].minv = off[i].minv\n        off[l].maxv = off[i].maxv\n      }\n    }\n    numOffsets = l + 1\n\n    // resolve overlaps between adjacent blocks; this may happen due to the merge in indexing\n    for (let i = 1; i < numOffsets; i += 1)\n      if (off[i - 1].maxv.compareTo(off[i].minv) >= 0) off[i - 1].maxv = off[i].minv\n\n    // merge adjacent blocks\n    l = 0\n    for (let i = 1; i < numOffsets; i += 1) {\n      if (canMergeBlocks(off[l], off[i])) off[l].maxv = off[i].maxv\n      else {\n        l += 1\n        off[l].minv = off[i].minv\n        off[l].maxv = off[i].maxv\n      }\n    }\n    numOffsets = l + 1\n\n    return off.slice(0, numOffsets)\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) beg = 1\n    if (end > 2 ** 50) end = 2 ** 34 // 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      for (let i = b; i <= e; i += 1) bins.push(i)\n    }\n    return bins\n  }\n}\n"]}

@@ -1,29 +0,128 @@

"use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));var _wrapNativeSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapNativeSuper"));var BamError = /*#__PURE__*/function (_Error) {(0, _inherits2.default)(BamError, _Error);function BamError() {(0, _classCallCheck2.default)(this, BamError);return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamError).apply(this, arguments));}return BamError;}((0, _wrapNativeSuper2.default)(Error));
"use strict";
/** Error caused by encountering a part of the BAM spec that has not yet been implemented */var
BamUnimplementedError = /*#__PURE__*/function (_Error2) {(0, _inherits2.default)(BamUnimplementedError, _Error2);function BamUnimplementedError() {(0, _classCallCheck2.default)(this, BamUnimplementedError);return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamUnimplementedError).apply(this, arguments));}return BamUnimplementedError;}((0, _wrapNativeSuper2.default)(Error));
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
/** An error caused by malformed data. */var
BamMalformedError = /*#__PURE__*/function (_BamError) {(0, _inherits2.default)(BamMalformedError, _BamError);function BamMalformedError() {(0, _classCallCheck2.default)(this, BamMalformedError);return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamMalformedError).apply(this, arguments));}return BamMalformedError;}(BamError);
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.BamArgumentError = exports.BamSizeLimitError = exports.BamBufferOverrunError = exports.BamMalformedError = exports.BamUnimplementedError = exports.BamError = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inherits"));
var _wrapNativeSuper2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/wrapNativeSuper"));
var BamError =
/*#__PURE__*/
function (_Error) {
(0, _inherits2.default)(BamError, _Error);
function BamError() {
(0, _classCallCheck2.default)(this, BamError);
return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamError).apply(this, arguments));
}
return BamError;
}((0, _wrapNativeSuper2.default)(Error));
/** Error caused by encountering a part of the BAM spec that has not yet been implemented */
exports.BamError = BamError;
var BamUnimplementedError =
/*#__PURE__*/
function (_Error2) {
(0, _inherits2.default)(BamUnimplementedError, _Error2);
function BamUnimplementedError() {
(0, _classCallCheck2.default)(this, BamUnimplementedError);
return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamUnimplementedError).apply(this, arguments));
}
return BamUnimplementedError;
}((0, _wrapNativeSuper2.default)(Error));
/** An error caused by malformed data. */
exports.BamUnimplementedError = BamUnimplementedError;
var BamMalformedError =
/*#__PURE__*/
function (_BamError) {
(0, _inherits2.default)(BamMalformedError, _BamError);
function BamMalformedError() {
(0, _classCallCheck2.default)(this, BamMalformedError);
return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamMalformedError).apply(this, arguments));
}
return BamMalformedError;
}(BamError);
/**
* An error caused by attempting to read beyond the end of the defined data.
*/var
BamBufferOverrunError = /*#__PURE__*/function (_BamMalformedError) {(0, _inherits2.default)(BamBufferOverrunError, _BamMalformedError);function BamBufferOverrunError() {(0, _classCallCheck2.default)(this, BamBufferOverrunError);return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamBufferOverrunError).apply(this, arguments));}return BamBufferOverrunError;}(BamMalformedError);
* An error caused by attempting to read beyond the end of the defined data.
*/
exports.BamMalformedError = BamMalformedError;
var BamBufferOverrunError =
/*#__PURE__*/
function (_BamMalformedError) {
(0, _inherits2.default)(BamBufferOverrunError, _BamMalformedError);
function BamBufferOverrunError() {
(0, _classCallCheck2.default)(this, BamBufferOverrunError);
return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamBufferOverrunError).apply(this, arguments));
}
return BamBufferOverrunError;
}(BamMalformedError);
/**
* An error caused by data being too big, exceeding a size limit.
*/var
BamSizeLimitError = /*#__PURE__*/function (_BamError2) {(0, _inherits2.default)(BamSizeLimitError, _BamError2);function BamSizeLimitError() {(0, _classCallCheck2.default)(this, BamSizeLimitError);return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamSizeLimitError).apply(this, arguments));}return BamSizeLimitError;}(BamError);
* An error caused by data being too big, exceeding a size limit.
*/
exports.BamBufferOverrunError = BamBufferOverrunError;
var BamSizeLimitError =
/*#__PURE__*/
function (_BamError2) {
(0, _inherits2.default)(BamSizeLimitError, _BamError2);
function BamSizeLimitError() {
(0, _classCallCheck2.default)(this, BamSizeLimitError);
return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamSizeLimitError).apply(this, arguments));
}
return BamSizeLimitError;
}(BamError);
/**
* An invalid argument was supplied to a bam-js method or object.
*/var
BamArgumentError = /*#__PURE__*/function (_BamError3) {(0, _inherits2.default)(BamArgumentError, _BamError3);function BamArgumentError() {(0, _classCallCheck2.default)(this, BamArgumentError);return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamArgumentError).apply(this, arguments));}return BamArgumentError;}(BamError);
* An invalid argument was supplied to a bam-js method or object.
*/
module.exports = {
BamBufferOverrunError: BamBufferOverrunError,
BamMalformedError: BamMalformedError,
BamUnimplementedError: BamUnimplementedError,
BamSizeLimitError: BamSizeLimitError,
BamArgumentError: BamArgumentError };
exports.BamSizeLimitError = BamSizeLimitError;
var BamArgumentError =
/*#__PURE__*/
function (_BamError3) {
(0, _inherits2.default)(BamArgumentError, _BamError3);
function BamArgumentError() {
(0, _classCallCheck2.default)(this, BamArgumentError);
return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(BamArgumentError).apply(this, arguments));
}
return BamArgumentError;
}(BamError);
exports.BamArgumentError = BamArgumentError;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9lcnJvcnMudHMiXSwibmFtZXMiOlsiQmFtRXJyb3IiLCJFcnJvciIsIkJhbVVuaW1wbGVtZW50ZWRFcnJvciIsIkJhbU1hbGZvcm1lZEVycm9yIiwiQmFtQnVmZmVyT3ZlcnJ1bkVycm9yIiwiQmFtU2l6ZUxpbWl0RXJyb3IiLCJCYW1Bcmd1bWVudEVycm9yIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBQWFBLFE7Ozs7Ozs7Ozs7O2lDQUFpQkMsSztBQUU5Qjs7Ozs7SUFDYUMscUI7Ozs7Ozs7Ozs7O2lDQUE4QkQsSztBQUUzQzs7Ozs7SUFDYUUsaUI7Ozs7Ozs7Ozs7O0VBQTBCSCxRO0FBRXZDOzs7Ozs7O0lBR2FJLHFCOzs7Ozs7Ozs7OztFQUE4QkQsaUI7QUFFM0M7Ozs7Ozs7SUFHYUUsaUI7Ozs7Ozs7Ozs7O0VBQTBCTCxRO0FBRXZDOzs7Ozs7O0lBR2FNLGdCOzs7Ozs7Ozs7OztFQUF5Qk4sUSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBCYW1FcnJvciBleHRlbmRzIEVycm9yIHt9XG5cbi8qKiBFcnJvciBjYXVzZWQgYnkgZW5jb3VudGVyaW5nIGEgcGFydCBvZiB0aGUgQkFNIHNwZWMgdGhhdCBoYXMgbm90IHlldCBiZWVuIGltcGxlbWVudGVkICovXG5leHBvcnQgY2xhc3MgQmFtVW5pbXBsZW1lbnRlZEVycm9yIGV4dGVuZHMgRXJyb3Ige31cblxuLyoqIEFuIGVycm9yIGNhdXNlZCBieSBtYWxmb3JtZWQgZGF0YS4gICovXG5leHBvcnQgY2xhc3MgQmFtTWFsZm9ybWVkRXJyb3IgZXh0ZW5kcyBCYW1FcnJvciB7fVxuXG4vKipcbiAqIEFuIGVycm9yIGNhdXNlZCBieSBhdHRlbXB0aW5nIHRvIHJlYWQgYmV5b25kIHRoZSBlbmQgb2YgdGhlIGRlZmluZWQgZGF0YS5cbiAqL1xuZXhwb3J0IGNsYXNzIEJhbUJ1ZmZlck92ZXJydW5FcnJvciBleHRlbmRzIEJhbU1hbGZvcm1lZEVycm9yIHt9XG5cbi8qKlxuICogQW4gZXJyb3IgY2F1c2VkIGJ5IGRhdGEgYmVpbmcgdG9vIGJpZywgZXhjZWVkaW5nIGEgc2l6ZSBsaW1pdC5cbiAqL1xuZXhwb3J0IGNsYXNzIEJhbVNpemVMaW1pdEVycm9yIGV4dGVuZHMgQmFtRXJyb3Ige31cblxuLyoqXG4gKiBBbiBpbnZhbGlkIGFyZ3VtZW50IHdhcyBzdXBwbGllZCB0byBhIGJhbS1qcyBtZXRob2Qgb3Igb2JqZWN0LlxuICovXG5leHBvcnQgY2xhc3MgQmFtQXJndW1lbnRFcnJvciBleHRlbmRzIEJhbUVycm9yIHt9XG4iXX0=

@@ -1,2 +0,28 @@

"use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");Object.defineProperty(exports, "__esModule", { value: true });Object.defineProperty(exports, "BAI", { enumerable: true, get: function get() {return _bai.default;} });Object.defineProperty(exports, "BamFile", { enumerable: true, get: function get() {return _bamFile.default;} });var _bai = _interopRequireDefault(require("./bai"));
var _bamFile = _interopRequireDefault(require("./bamFile"));
"use strict";
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
_Object$defineProperty(exports, "BAI", {
enumerable: true,
get: function get() {
return _bai.default;
}
});
_Object$defineProperty(exports, "BamFile", {
enumerable: true,
get: function get() {
return _bamFile.default;
}
});
var _bai = _interopRequireDefault(require("./bai"));
var _bamFile = _interopRequireDefault(require("./bamFile"));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBCQUkgZnJvbSAnLi9iYWknXG5pbXBvcnQgQmFtRmlsZSBmcm9tICcuL2JhbUZpbGUnXG5cbmV4cG9ydCB7IEJBSSwgQmFtRmlsZSB9XG4iXX0=

@@ -1,44 +0,148 @@

"use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));var _abortablePromiseCache = _interopRequireDefault(require("abortable-promise-cache"));
var _quickLru = _interopRequireDefault(require("quick-lru"));var
"use strict";
IndexFile = /*#__PURE__*/function () {
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs2/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
var _abortablePromiseCache = _interopRequireDefault(require("abortable-promise-cache"));
var _quickLru = _interopRequireDefault(require("quick-lru"));
var IndexFile =
/*#__PURE__*/
function () {
/**
* @param {filehandle} filehandle
* @param {function} [renameRefSeqs]
*/
function IndexFile(_ref) {var filehandle = _ref.filehandle,_ref$renameRefSeqs = _ref.renameRefSeqs,renameRefSeqs = _ref$renameRefSeqs === void 0 ? function (n) {return n;} : _ref$renameRefSeqs;(0, _classCallCheck2.default)(this, IndexFile);
* @param {filehandle} filehandle
* @param {function} [renameRefSeqs]
*/
function IndexFile(_ref) {
var filehandle = _ref.filehandle,
_ref$renameRefSeq = _ref.renameRefSeq,
renameRefSeq = _ref$renameRefSeq === void 0 ? function (n) {
return n;
} : _ref$renameRefSeq;
(0, _classCallCheck2.default)(this, IndexFile);
(0, _defineProperty2.default)(this, "filehandle", void 0);
(0, _defineProperty2.default)(this, "renameRefSeq", void 0);
(0, _defineProperty2.default)(this, "_parseCache", void 0);
this.filehandle = filehandle;
this.renameRefSeq = renameRefSeqs;
}(0, _createClass2.default)(IndexFile, [{ key: "_findFirstData", value: function _findFirstData(
this.renameRefSeq = renameRefSeq;
}
data, virtualOffset) {
(0, _createClass2.default)(IndexFile, [{
key: "_findFirstData",
value: function _findFirstData(data, virtualOffset) {
var currentFdl = data.firstDataLine;
if (currentFdl) {
data.firstDataLine =
currentFdl.compareTo(virtualOffset) > 0 ? virtualOffset : currentFdl;
data.firstDataLine = currentFdl.compareTo(virtualOffset) > 0 ? virtualOffset : currentFdl;
} else {
data.firstDataLine = virtualOffset;
}
} }, { key: "parse", value: function () {var _parse = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(
}
}, {
key: "parse",
value: function () {
var _parse2 = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee(abortSignal) {
var _this = this;
abortSignal) {var _this = this;return _regenerator.default.wrap(function _callee$(_context) {while (1) {switch (_context.prev = _context.next) {case 0:
if (!this._parseCache)
this._parseCache = new _abortablePromiseCache.default({
cache: new _quickLru.default({ maxSize: 1 }),
fill: function fill(data, signal) {return _this._parse(signal);} });return _context.abrupt("return",
return _regenerator.default.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
if (!this._parseCache) this._parseCache = new _abortablePromiseCache.default({
cache: new _quickLru.default({
maxSize: 1
}),
fill: function fill(data, signal) {
return _this._parse(signal);
}
});
return _context.abrupt("return", this._parseCache.get('index', null, abortSignal));
this._parseCache.get('index', null, abortSignal));case 2:case "end":return _context.stop();}}}, _callee, this);}));function parse(_x) {return _parse.apply(this, arguments);}return parse;}()
case 2:
case "end":
return _context.stop();
}
}
}, _callee, this);
}));
function parse(_x) {
return _parse2.apply(this, arguments);
}
return parse;
}()
/**
* @param {number} seqId
* @param {AbortSignal} [abortSignal]
* @returns {Promise} true if the index contains entries for
* the given reference sequence ID, false otherwise
*/ }, { key: "hasRefSeq", value: function () {var _hasRefSeq = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(
seqId, abortSignal) {return _regenerator.default.wrap(function _callee2$(_context2) {while (1) {switch (_context2.prev = _context2.next) {case 0:_context2.next = 2;return (
this.parse(abortSignal));case 2:_context2.t1 = seqId;_context2.t0 = _context2.sent.indices[_context2.t1];if (_context2.t0) {_context2.next = 6;break;}_context2.t0 = {};case 6:return _context2.abrupt("return", !!_context2.t0.binIndex);case 7:case "end":return _context2.stop();}}}, _callee2, this);}));function hasRefSeq(_x2, _x3) {return _hasRefSeq.apply(this, arguments);}return hasRefSeq;}() }]);return IndexFile;}();
* @param {number} seqId
* @param {AbortSignal} [abortSignal]
* @returns {Promise} true if the index contains entries for
* the given reference sequence ID, false otherwise
*/
}, {
key: "hasRefSeq",
value: function () {
var _hasRefSeq = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee2(seqId, abortSignal) {
return _regenerator.default.wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
_context2.next = 2;
return this.parse(abortSignal);
case 2:
_context2.t1 = seqId;
_context2.t0 = _context2.sent.indices[_context2.t1];
module.exports = IndexFile;
if (_context2.t0) {
_context2.next = 6;
break;
}
_context2.t0 = {};
case 6:
return _context2.abrupt("return", !!_context2.t0.binIndex);
case 7:
case "end":
return _context2.stop();
}
}
}, _callee2, this);
}));
function hasRefSeq(_x2, _x3) {
return _hasRefSeq.apply(this, arguments);
}
return hasRefSeq;
}()
}]);
return IndexFile;
}();
exports.default = IndexFile;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleEZpbGUudHMiXSwibmFtZXMiOlsiSW5kZXhGaWxlIiwiZmlsZWhhbmRsZSIsInJlbmFtZVJlZlNlcSIsIm4iLCJkYXRhIiwidmlydHVhbE9mZnNldCIsImN1cnJlbnRGZGwiLCJmaXJzdERhdGFMaW5lIiwiY29tcGFyZVRvIiwiYWJvcnRTaWduYWwiLCJfcGFyc2VDYWNoZSIsIkFib3J0YWJsZVByb21pc2VDYWNoZSIsImNhY2hlIiwiUXVpY2tMUlUiLCJtYXhTaXplIiwiZmlsbCIsInNpZ25hbCIsIl9wYXJzZSIsImdldCIsInNlcUlkIiwicGFyc2UiLCJpbmRpY2VzIiwiYmluSW5kZXgiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7SUFLOEJBLFM7OztBQUs1Qjs7OztBQUlBLDJCQU1HO0FBQUEsUUFMREMsVUFLQyxRQUxEQSxVQUtDO0FBQUEsaUNBSkRDLFlBSUM7QUFBQSxRQUpEQSxZQUlDLGtDQUpjLFVBQUNDLENBQUQ7QUFBQSxhQUFlQSxDQUFmO0FBQUEsS0FJZDtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0QsU0FBS0YsVUFBTCxHQUFrQkEsVUFBbEI7QUFDQSxTQUFLQyxZQUFMLEdBQW9CQSxZQUFwQjtBQUNEOzs7O21DQWVjRSxJLEVBQVdDLGEsRUFBOEI7QUFDdEQsVUFBTUMsVUFBVSxHQUFHRixJQUFJLENBQUNHLGFBQXhCOztBQUNBLFVBQUlELFVBQUosRUFBZ0I7QUFDZEYsUUFBQUEsSUFBSSxDQUFDRyxhQUFMLEdBQXFCRCxVQUFVLENBQUNFLFNBQVgsQ0FBcUJILGFBQXJCLElBQXNDLENBQXRDLEdBQTBDQSxhQUExQyxHQUEwREMsVUFBL0U7QUFDRCxPQUZELE1BRU87QUFDTEYsUUFBQUEsSUFBSSxDQUFDRyxhQUFMLEdBQXFCRixhQUFyQjtBQUNEO0FBQ0Y7Ozs7OztpREFFV0ksVzs7Ozs7OztBQUNWLG9CQUFJLENBQUMsS0FBS0MsV0FBVixFQUNFLEtBQUtBLFdBQUwsR0FBbUIsSUFBSUMsOEJBQUosQ0FBMEI7QUFDM0NDLGtCQUFBQSxLQUFLLEVBQUUsSUFBSUMsaUJBQUosQ0FBYTtBQUFFQyxvQkFBQUEsT0FBTyxFQUFFO0FBQVgsbUJBQWIsQ0FEb0M7QUFFM0NDLGtCQUFBQSxJQUFJLEVBQUUsY0FBQ1gsSUFBRCxFQUFZWSxNQUFaO0FBQUEsMkJBQW9DLEtBQUksQ0FBQ0MsTUFBTCxDQUFZRCxNQUFaLENBQXBDO0FBQUE7QUFGcUMsaUJBQTFCLENBQW5CO2lEQUlLLEtBQUtOLFdBQUwsQ0FBaUJRLEdBQWpCLENBQXFCLE9BQXJCLEVBQThCLElBQTlCLEVBQW9DVCxXQUFwQyxDOzs7Ozs7Ozs7Ozs7Ozs7O0FBR1Q7Ozs7Ozs7Ozs7OztrREFNZ0JVLEssRUFBZVYsVzs7Ozs7O3VCQUNaLEtBQUtXLEtBQUwsQ0FBV1gsV0FBWCxDOzs7K0JBQWlDVSxLOzhDQUFSRSxPOzs7Ozs7OytCQUFrQixFOzs7aUVBQUlDLFEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQWJvcnRhYmxlUHJvbWlzZUNhY2hlIGZyb20gJ2Fib3J0YWJsZS1wcm9taXNlLWNhY2hlJ1xuaW1wb3J0IFF1aWNrTFJVIGZyb20gJ3F1aWNrLWxydSdcbmltcG9ydCB7IEdlbmVyaWNGaWxlaGFuZGxlIH0gZnJvbSAnZ2VuZXJpYy1maWxlaGFuZGxlJ1xuaW1wb3J0IFZpcnR1YWxPZmZzZXQgZnJvbSAnLi92aXJ0dWFsT2Zmc2V0J1xuaW1wb3J0IENodW5rIGZyb20gJy4vY2h1bmsnXG5cbmV4cG9ydCBkZWZhdWx0IGFic3RyYWN0IGNsYXNzIEluZGV4RmlsZSB7XG4gIHB1YmxpYyBmaWxlaGFuZGxlOiBHZW5lcmljRmlsZWhhbmRsZVxuICBwdWJsaWMgcmVuYW1lUmVmU2VxOiBGdW5jdGlvblxuICBwcml2YXRlIF9wYXJzZUNhY2hlOiBhbnlcblxuICAvKipcbiAgICogQHBhcmFtIHtmaWxlaGFuZGxlfSBmaWxlaGFuZGxlXG4gICAqIEBwYXJhbSB7ZnVuY3Rpb259IFtyZW5hbWVSZWZTZXFzXVxuICAgKi9cbiAgY29uc3RydWN0b3Ioe1xuICAgIGZpbGVoYW5kbGUsXG4gICAgcmVuYW1lUmVmU2VxID0gKG46IHN0cmluZykgPT4gbixcbiAgfToge1xuICAgIGZpbGVoYW5kbGU6IEdlbmVyaWNGaWxlaGFuZGxlXG4gICAgcmVuYW1lUmVmU2VxPzogKGE6IHN0cmluZykgPT4gc3RyaW5nXG4gIH0pIHtcbiAgICB0aGlzLmZpbGVoYW5kbGUgPSBmaWxlaGFuZGxlXG4gICAgdGhpcy5yZW5hbWVSZWZTZXEgPSByZW5hbWVSZWZTZXFcbiAgfVxuICBwdWJsaWMgYWJzdHJhY3QgYXN5bmMgbGluZUNvdW50KHJlZklkOiBudW1iZXIpOiBQcm9taXNlPG51bWJlcj5cbiAgcHJvdGVjdGVkIGFic3RyYWN0IGFzeW5jIF9wYXJzZShzaWduYWw/OiBBYm9ydFNpZ25hbCk6IFByb21pc2U8YW55PlxuICBwdWJsaWMgYWJzdHJhY3QgYXN5bmMgaW5kZXhDb3YoXG4gICAgcmVmSWQ6IG51bWJlcixcbiAgICBzdGFydD86IG51bWJlcixcbiAgICBlbmQ/OiBudW1iZXIsXG4gICk6IFByb21pc2U8eyBzdGFydDogbnVtYmVyOyBlbmQ6IG51bWJlcjsgc2NvcmU6IG51bWJlciB9W10+XG4gIHB1YmxpYyBhYnN0cmFjdCBhc3luYyBibG9ja3NGb3JSYW5nZShcbiAgICBjaHJJZDogbnVtYmVyLFxuICAgIHN0YXJ0OiBudW1iZXIsXG4gICAgZW5kOiBudW1iZXIsXG4gICAgb3B0czogUmVjb3JkPHN0cmluZywgYW55PixcbiAgKTogUHJvbWlzZTxDaHVua1tdPlxuXG4gIF9maW5kRmlyc3REYXRhKGRhdGE6IGFueSwgdmlydHVhbE9mZnNldDogVmlydHVhbE9mZnNldCkge1xuICAgIGNvbnN0IGN1cnJlbnRGZGwgPSBkYXRhLmZpcnN0RGF0YUxpbmVcbiAgICBpZiAoY3VycmVudEZkbCkge1xuICAgICAgZGF0YS5maXJzdERhdGFMaW5lID0gY3VycmVudEZkbC5jb21wYXJlVG8odmlydHVhbE9mZnNldCkgPiAwID8gdmlydHVhbE9mZnNldCA6IGN1cnJlbnRGZGxcbiAgICB9IGVsc2Uge1xuICAgICAgZGF0YS5maXJzdERhdGFMaW5lID0gdmlydHVhbE9mZnNldFxuICAgIH1cbiAgfVxuXG4gIGFzeW5jIHBhcnNlKGFib3J0U2lnbmFsPzogQWJvcnRTaWduYWwpIHtcbiAgICBpZiAoIXRoaXMuX3BhcnNlQ2FjaGUpXG4gICAgICB0aGlzLl9wYXJzZUNhY2hlID0gbmV3IEFib3J0YWJsZVByb21pc2VDYWNoZSh7XG4gICAgICAgIGNhY2hlOiBuZXcgUXVpY2tMUlUoeyBtYXhTaXplOiAxIH0pLFxuICAgICAgICBmaWxsOiAoZGF0YTogYW55LCBzaWduYWw6IEFib3J0U2lnbmFsKSA9PiB0aGlzLl9wYXJzZShzaWduYWwpLFxuICAgICAgfSlcbiAgICByZXR1cm4gdGhpcy5fcGFyc2VDYWNoZS5nZXQoJ2luZGV4JywgbnVsbCwgYWJvcnRTaWduYWwpXG4gIH1cblxuICAvKipcbiAgICogQHBhcmFtIHtudW1iZXJ9IHNlcUlkXG4gICAqIEBwYXJhbSB7QWJvcnRTaWduYWx9IFthYm9ydFNpZ25hbF1cbiAgICogQHJldHVybnMge1Byb21pc2V9IHRydWUgaWYgdGhlIGluZGV4IGNvbnRhaW5zIGVudHJpZXMgZm9yXG4gICAqIHRoZSBnaXZlbiByZWZlcmVuY2Ugc2VxdWVuY2UgSUQsIGZhbHNlIG90aGVyd2lzZVxuICAgKi9cbiAgYXN5bmMgaGFzUmVmU2VxKHNlcUlkOiBudW1iZXIsIGFib3J0U2lnbmFsPzogQWJvcnRTaWduYWwpIHtcbiAgICByZXR1cm4gISEoKGF3YWl0IHRoaXMucGFyc2UoYWJvcnRTaWduYWwpKS5pbmRpY2VzW3NlcUlkXSB8fCB7fSkuYmluSW5kZXhcbiAgfVxufVxuIl19

@@ -1,11 +0,49 @@

"use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));var Constants = require('./constants');
"use strict";
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _parseInt2 = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/parse-int"));
var _keys = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/object/keys"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
var _constants = _interopRequireDefault(require("./constants"));
/* eslint-disable @typescript-eslint/camelcase */
/* eslint-disable @typescript-eslint/no-empty-function */
/* eslint-disable @typescript-eslint/ban-ts-ignore */
var SEQRET_DECODER = '=ACMGRSVTWYHKDBN'.split('');
var CIGAR_DECODER = 'MIDNSHP=X???????'.split('');
/**
* Class of each BAM record returned by this API.
*/
/**
* Class of each BAM record returned by this API.
*/var
BamRecord = /*#__PURE__*/function () {
function BamRecord(args) {(0, _classCallCheck2.default)(this, BamRecord);
var BamRecord =
/*#__PURE__*/
function () {
function BamRecord(args) {
(0, _classCallCheck2.default)(this, BamRecord);
(0, _defineProperty2.default)(this, "data", void 0);
(0, _defineProperty2.default)(this, "bytes", void 0);
(0, _defineProperty2.default)(this, "flags", void 0);
(0, _defineProperty2.default)(this, "_id", void 0);
(0, _defineProperty2.default)(this, "_refID", void 0);
(0, _defineProperty2.default)(this, "_tagOffset", undefined);
(0, _defineProperty2.default)(this, "_tagList", []);
(0, _defineProperty2.default)(this, "_allTagsParsed", false);
this.data = {};

@@ -15,41 +53,40 @@ this.bytes = {

end: args.bytes.end,
byteArray: args.bytes.byteArray };
byteArray: args.bytes.byteArray
};
this._id = args.fileOffset;
this._coreParse();
var _this$bytes = this.bytes,
start = _this$bytes.start,
byteArray = _this$bytes.byteArray;
this._refID = byteArray.readInt32LE(start + 4);
this.data.start = byteArray.readInt32LE(start + 8);
this.flags = (byteArray.readInt32LE(start + 16) & 0xffff0000) >> 16;
}
/**
* parse the core data: ref ID and start
*/(0, _createClass2.default)(BamRecord, [{ key: "_coreParse", value: function _coreParse()
{var _this$bytes =
this.bytes,start = _this$bytes.start,byteArray = _this$bytes.byteArray;
this._refID = byteArray.readInt32LE(start + 4);
this.data.start = byteArray.readInt32LE(start + 8);
this.flags = (byteArray.readInt32LE(start + 16) & 0xffff0000) >> 16;
} }, { key: "get", value: function get(
field) {
(0, _createClass2.default)(BamRecord, [{
key: "get",
value: function get(field) {
return this._get(field.toLowerCase());
} }, { key: "end", value: function end()
{
return (
this._get('start') + (
this._get('length_on_ref') || this._get('seq_length') || undefined));
} }, { key: "seq_id", value: function seq_id()
{
}
}, {
key: "end",
value: function end() {
return this._get('start') + (this._get('length_on_ref') || this._get('seq_length') || undefined);
}
}, {
key: "seq_id",
value: function seq_id() {
return this._refID;
}
} // same as get(), except requires lower-case arguments. used
// internally to save lots of calls to field.toLowerCase()
// same as get(), except requires lower-case arguments. used
// internally to save lots of calls to field.toLowerCase()
}, { key: "_get", value: function _get(field) {
}, {
key: "_get",
value: function _get(field) {
if (field in this.data) {
return this.data[field];
}
} //@ts-ignore
if (this[field]) {
//@ts-ignore
this.data[field] = this[field]();

@@ -59,56 +96,26 @@ } else {

}
return this.data[field];
} }, { key: "_tags", value: function _tags()
}
}, {
key: "_tags",
value: function _tags() {
var _this = this;
{var _this = this;
this._parseAllTags();
var tags = [
'seq',
'seq_reverse_complemented',
'unmapped',
'qc_failed',
'duplicate',
'secondary_alignment',
'supplementary_alignment'];
var tags = ['seq', 'seq_reverse_complemented', 'unmapped', 'qc_failed', 'duplicate', 'secondary_alignment', 'supplementary_alignment'];
if (!this.isSegmentUnmapped()) tags.push('start', 'end', 'strand', 'score', 'qual', 'MQ', 'CIGAR', 'length_on_ref', 'template_length');
if (!this.isSegmentUnmapped())
tags.push(
'start',
'end',
'strand',
'score',
'qual',
'MQ',
'CIGAR',
'length_on_ref',
'template_length');
if (this.isPaired()) {
tags.push(
'multi_segment_all_correctly_aligned',
'multi_segment_next_segment_unmapped',
'multi_segment_next_segment_reversed',
'multi_segment_first',
'multi_segment_last',
'next_segment_position',
'pair_orientation');
tags.push('multi_segment_all_correctly_aligned', 'multi_segment_next_segment_unmapped', 'multi_segment_next_segment_reversed', 'multi_segment_first', 'multi_segment_last', 'next_segment_position', 'pair_orientation');
}
}
tags = tags.concat(this._tagList || []);
Object.keys(this.data).forEach(function (k) {
if (
k[0] !== '_' &&
k !== 'multi_segment_all_aligned' &&
k !== 'next_seq_id')
tags.push(k);
(0, _keys.default)(this.data).forEach(function (k) {
if (k[0] !== '_' && k !== 'multi_segment_all_aligned' && k !== 'next_seq_id') tags.push(k);
});
var seen = {};
tags = tags.filter(function (t) {
if (t in _this.data && _this.data[t] === undefined) return false;
var lt = t.toLowerCase();

@@ -119,80 +126,88 @@ var s = seen[lt];

});
return tags;
} }, { key: "parent", value: function parent()
{
}
}, {
key: "parent",
value: function parent() {
return undefined;
} }, { key: "children", value: function children()
{
}
}, {
key: "children",
value: function children() {
return this._get('subfeatures');
} }, { key: "id", value: function id()
{
}
}, {
key: "id",
value: function id() {
return this._id;
} }, { key: "multi_segment_all_aligned", value: function multi_segment_all_aligned()
{
}
}, {
key: "multi_segment_all_aligned",
value: function multi_segment_all_aligned() {
return this._get('multi_segment_all_correctly_aligned');
}
} // special parsers
// special parsers
/**
* Mapping quality score.
*/ }, { key: "mq", value: function mq()
{
*/
}, {
key: "mq",
value: function mq() {
var mq = (this._get('_bin_mq_nl') & 0xff00) >> 8;
return mq === 255 ? undefined : mq;
} }, { key: "score", value: function score()
{
}
}, {
key: "score",
value: function score() {
return this._get('mq');
} }, { key: "qual", value: function qual()
{
}
}, {
key: "qual",
value: function qual() {
if (this.isSegmentUnmapped()) return undefined;
var qseq = [];
var byteArray = this.bytes.byteArray;
var qseq = [];var
byteArray = this.bytes.byteArray;
var p =
this.bytes.start +
36 +
this._get('_l_read_name') +
this._get('_n_cigar_op') * 4 +
this._get('_seq_bytes');
var p = this.bytes.start + 36 + this._get('_l_read_name') + this._get('_n_cigar_op') * 4 + this._get('_seq_bytes');
var lseq = this._get('seq_length');
for (var j = 0; j < lseq; ++j) {
qseq.push(byteArray[p + j]);
}
return qseq.join(' ');
} }, { key: "strand", value: function strand()
{
}
}, {
key: "strand",
value: function strand() {
return this.isReverseComplemented() ? -1 : 1;
} }, { key: "multi_segment_next_segment_strand", value: function multi_segment_next_segment_strand()
{
}
}, {
key: "multi_segment_next_segment_strand",
value: function multi_segment_next_segment_strand() {
if (this.isMateUnmapped()) return undefined;
return this.isMateReverseComplemented() ? -1 : 1;
} }, { key: "name", value: function name()
{
}
}, {
key: "name",
value: function name() {
return this._get('_read_name');
} }, { key: "_read_name", value: function _read_name()
{
}
}, {
key: "_read_name",
value: function _read_name() {
var nl = this._get('_l_read_name');
return this.bytes.byteArray.toString(
'ascii',
this.bytes.start + 36,
this.bytes.start + 36 + nl - 1);
return this.bytes.byteArray.toString('ascii', this.bytes.start + 36, this.bytes.start + 36 + nl - 1);
}
/**
* Get the value of a tag, parsing the tags as far as necessary.
* Only called if we have not already parsed that field.
*/
/**
* Get the value of a tag, parsing the tags as far as necessary.
* Only called if we have not already parsed that field.
*/ }, { key: "_parseTag", value: function _parseTag(
tagName) {
}, {
key: "_parseTag",
value: function _parseTag(tagName) {
// if all of the tags have been parsed and we're still being

@@ -202,16 +217,9 @@ // called, we already know that we have no such tag, because

if (this._allTagsParsed) return undefined;
var byteArray = this.bytes.byteArray;
this._tagList = this._tagList || [];var
byteArray = this.bytes.byteArray;
var p =
this._tagOffset ||
this.bytes.start +
36 +
this._get('_l_read_name') +
this._get('_n_cigar_op') * 4 +
this._get('_seq_bytes') +
this._get('seq_length');
var p = this._tagOffset || this.bytes.start + 36 + this._get('_l_read_name') + this._get('_n_cigar_op') * 4 + this._get('_seq_bytes') + this._get('seq_length');
var blockEnd = this.bytes.end;
var lcTag;
while (p < blockEnd && lcTag !== tagName) {

@@ -222,4 +230,4 @@ var tag = String.fromCharCode(byteArray[p], byteArray[p + 1]);

p += 3;
var value = void 0;
var value = void 0;
switch (type.toLowerCase()) {

@@ -230,2 +238,3 @@ case 'a':

break;
case 'i':

@@ -235,2 +244,3 @@ value = byteArray.readInt32LE(p);

break;
case 'c':

@@ -240,2 +250,3 @@ value = byteArray.readInt8(p);

break;
case 's':

@@ -245,2 +256,3 @@ value = byteArray.readInt16LE(p);

break;
case 'f':

@@ -250,7 +262,10 @@ value = byteArray.readFloatLE(p);

break;
case 'z':
case 'h':
value = '';
while (p <= blockEnd) {
var cc = byteArray[p++];
if (cc === 0) {

@@ -262,10 +277,15 @@ break;

}
break;
case 'b':{
case 'b':
{
value = '';
var _cc = byteArray[p++];
var Btype = String.fromCharCode(_cc);
if (Btype === 'i' || Btype === 'I') {
var limit = byteArray.readInt32LE(p);
p += 4;
for (var k = 0; k < limit; k++) {

@@ -277,5 +297,8 @@ value += byteArray.readInt32LE(p);

}
if (Btype === 's' || Btype === 'S') {
var _limit = byteArray.readInt32LE(p);
p += 4;
for (var _k = 0; _k < _limit; _k++) {

@@ -287,5 +310,8 @@ value += byteArray.readInt16LE(p);

}
if (Btype === 'c' || Btype === 'C') {
var _limit2 = byteArray.readInt32LE(p);
p += 4;
for (var _k2 = 0; _k2 < _limit2; _k2++) {

@@ -297,5 +323,8 @@ value += byteArray.readInt8(p);

}
if (Btype === 'f') {
var _limit3 = byteArray.readInt32LE(p);
p += 4;
for (var _k3 = 0; _k3 < _limit3; _k3++) {

@@ -307,8 +336,11 @@ value += byteArray.readFloatLE(p);

}
break;
}
default:
console.warn("Unknown BAM tag type '".concat(type, "', tags may be incomplete"));
value = undefined;
p = blockEnd; // stop parsing tags
p = blockEnd;
// stop parsing tags
}

@@ -319,90 +351,124 @@

this._tagList.push(tag);
if (lcTag === tagName) return value;
this.data[lcTag] = value;
}
this._allTagsParsed = true;
return undefined;
} }, { key: "_parseAllTags", value: function _parseAllTags()
{
}
}, {
key: "_parseAllTags",
value: function _parseAllTags() {
this._parseTag();
} }, { key: "_parseCigar", value: function _parseCigar(
}
}, {
key: "_parseCigar",
value: function _parseCigar(cigar) {
//@ts-ignore
return cigar.match(/\d+\D/g).map(function (op) {
return [op.match(/\D/)[0].toUpperCase(), (0, _parseInt2.default)(op, 10)];
});
}
/**
* @returns {boolean} true if the read is paired, regardless of whether both segments are mapped
*/
cigar) {
return cigar.
match(/\d+\D/g).
map(function (op) {return [op.match(/\D/)[0].toUpperCase(), parseInt(op, 10)];});
}, {
key: "isPaired",
value: function isPaired() {
return !!(this.flags & _constants.default.BAM_FPAIRED);
}
/** @returns {boolean} true if the read is paired, and both segments are mapped */
/**
* @returns {boolean} true if the read is paired, regardless of whether both segments are mapped
*/ }, { key: "isPaired", value: function isPaired()
{
return !!(this.flags & Constants.BAM_FPAIRED);
}, {
key: "isProperlyPaired",
value: function isProperlyPaired() {
return !!(this.flags & _constants.default.BAM_FPROPER_PAIR);
}
/** @returns {boolean} true if the read itself is unmapped; conflictive with isProperlyPaired */
/** @returns {boolean} true if the read is paired, and both segments are mapped */ }, { key: "isProperlyPaired", value: function isProperlyPaired()
{
return !!(this.flags & Constants.BAM_FPROPER_PAIR);
}, {
key: "isSegmentUnmapped",
value: function isSegmentUnmapped() {
return !!(this.flags & _constants.default.BAM_FUNMAP);
}
/** @returns {boolean} true if the read itself is unmapped; conflictive with isProperlyPaired */
/** @returns {boolean} true if the read itself is unmapped; conflictive with isProperlyPaired */ }, { key: "isSegmentUnmapped", value: function isSegmentUnmapped()
{
return !!(this.flags & Constants.BAM_FUNMAP);
}, {
key: "isMateUnmapped",
value: function isMateUnmapped() {
return !!(this.flags & _constants.default.BAM_FMUNMAP);
}
/** @returns {boolean} true if the read is mapped to the reverse strand */
/** @returns {boolean} true if the read itself is unmapped; conflictive with isProperlyPaired */ }, { key: "isMateUnmapped", value: function isMateUnmapped()
{
return !!(this.flags & Constants.BAM_FMUNMAP);
}, {
key: "isReverseComplemented",
value: function isReverseComplemented() {
return !!(this.flags & _constants.default.BAM_FREVERSE);
}
/** @returns {boolean} true if the mate is mapped to the reverse strand */
/** @returns {boolean} true if the read is mapped to the reverse strand */ }, { key: "isReverseComplemented", value: function isReverseComplemented()
{
return !!(this.flags & Constants.BAM_FREVERSE);
}, {
key: "isMateReverseComplemented",
value: function isMateReverseComplemented() {
return !!(this.flags & _constants.default.BAM_FMREVERSE);
}
/** @returns {boolean} true if this is read number 1 in a pair */
/** @returns {boolean} true if the mate is mapped to the reverse strand */ }, { key: "isMateReverseComplemented", value: function isMateReverseComplemented()
{
return !!(this.flags & Constants.BAM_FMREVERSE);
}, {
key: "isRead1",
value: function isRead1() {
return !!(this.flags & _constants.default.BAM_FREAD1);
}
/** @returns {boolean} true if this is read number 2 in a pair */
/** @returns {boolean} true if this is read number 1 in a pair */ }, { key: "isRead1", value: function isRead1()
{
return !!(this.flags & Constants.BAM_FREAD1);
}, {
key: "isRead2",
value: function isRead2() {
return !!(this.flags & _constants.default.BAM_FREAD2);
}
/** @returns {boolean} true if this is a secondary alignment */
/** @returns {boolean} true if this is read number 2 in a pair */ }, { key: "isRead2", value: function isRead2()
{
return !!(this.flags & Constants.BAM_FREAD2);
}, {
key: "isSecondary",
value: function isSecondary() {
return !!(this.flags & _constants.default.BAM_FSECONDARY);
}
/** @returns {boolean} true if this read has failed QC checks */
/** @returns {boolean} true if this is a secondary alignment */ }, { key: "isSecondary", value: function isSecondary()
{
return !!(this.flags & Constants.BAM_FSECONDARY);
}, {
key: "isFailedQc",
value: function isFailedQc() {
return !!(this.flags & _constants.default.BAM_FQCFAIL);
}
/** @returns {boolean} true if the read is an optical or PCR duplicate */
/** @returns {boolean} true if this read has failed QC checks */ }, { key: "isFailedQc", value: function isFailedQc()
{
return !!(this.flags & Constants.BAM_FQCFAIL);
}, {
key: "isDuplicate",
value: function isDuplicate() {
return !!(this.flags & _constants.default.BAM_FDUP);
}
/** @returns {boolean} true if this is a supplementary alignment */
/** @returns {boolean} true if the read is an optical or PCR duplicate */ }, { key: "isDuplicate", value: function isDuplicate()
{
return !!(this.flags & Constants.BAM_FDUP);
}, {
key: "isSupplementary",
value: function isSupplementary() {
return !!(this.flags & _constants.default.BAM_FSUPPLEMENTARY);
}
}, {
key: "cigar",
value: function cigar() {
if (this.isSegmentUnmapped()) return undefined;
var _this$bytes2 = this.bytes,
byteArray = _this$bytes2.byteArray,
start = _this$bytes2.start;
/** @returns {boolean} true if this is a supplementary alignment */ }, { key: "isSupplementary", value: function isSupplementary()
{
return !!(this.flags & Constants.BAM_FSUPPLEMENTARY);
} }, { key: "cigar", value: function cigar()
var numCigarOps = this._get('_n_cigar_op');
{
if (this.isSegmentUnmapped()) return undefined;var _this$bytes2 =
var p = start + 36 + this._get('_l_read_name');
this.bytes,byteArray = _this$bytes2.byteArray,start = _this$bytes2.start;
var numCigarOps = this._get('_n_cigar_op');
var p = start + 36 + this._get('_l_read_name');
var cigar = '';
var lref = 0;
for (var c = 0; c < numCigarOps; ++c) {

@@ -412,8 +478,6 @@ var cigop = byteArray.readInt32LE(p);

var op = CIGAR_DECODER[cigop & 0xf];
cigar += lop + op;
cigar += lop + op; // soft clip, hard clip, and insertion don't count toward
// the length on the reference
// soft clip, hard clip, and insertion don't count toward
// the length on the reference
if (op !== 'H' && op !== 'S' && op !== 'I') lref += lop;
p += 4;

@@ -424,36 +488,43 @@ }

return cigar;
} }, { key: "_flags", value: function _flags()
}
}, {
key: "_flags",
value: function _flags() {}
}, {
key: "length_on_ref",
value: function length_on_ref() {
this._get('cigar'); // the length_on_ref is set as a
// side effect of the CIGAR parsing
{} }, { key: "length_on_ref", value: function length_on_ref()
{
this._get('cigar'); // the length_on_ref is set as a
// side effect of the CIGAR parsing
return this.data.length_on_ref;
} }, { key: "_n_cigar_op", value: function _n_cigar_op()
{
}
}, {
key: "_n_cigar_op",
value: function _n_cigar_op() {
return this._get('_flag_nc') & 0xffff;
} }, { key: "_l_read_name", value: function _l_read_name()
{
}
}, {
key: "_l_read_name",
value: function _l_read_name() {
return this._get('_bin_mq_nl') & 0xff;
}
/**
* number of bytes in the sequence field
*/
/**
* number of bytes in the sequence field
*/ }, { key: "_seq_bytes", value: function _seq_bytes()
{
}, {
key: "_seq_bytes",
value: function _seq_bytes() {
return this._get('seq_length') + 1 >> 1;
} }, { key: "getReadBases", value: function getReadBases()
}
}, {
key: "getReadBases",
value: function getReadBases() {
var seq = '';
var byteArray = this.bytes.byteArray;
var p = this.bytes.start + 36 + this._get('_l_read_name') + this._get('_n_cigar_op') * 4;
{
var seq = '';var
byteArray = this.bytes.byteArray;
var p =
this.bytes.start +
36 +
this._get('_l_read_name') +
this._get('_n_cigar_op') * 4;
var seqBytes = this._get('_seq_bytes');
for (var j = 0; j < seqBytes; ++j) {

@@ -464,12 +535,10 @@ var sb = byteArray[p + j];

}
return seq;
}
} // adapted from igv.js
// adapted from igv.js
}, { key: "getPairOrientation", value: function getPairOrientation() {
if (
!this.isSegmentUnmapped() &&
!this.isMateUnmapped() &&
this._refID === this._next_refid())
{
}, {
key: "getPairOrientation",
value: function getPairOrientation() {
if (!this.isSegmentUnmapped() && !this.isMateUnmapped() && this._refID === this._next_refid()) {
var s1 = this.isReverseComplemented() ? 'R' : 'F';

@@ -479,2 +548,3 @@ var s2 = this.isMateReverseComplemented() ? 'R' : 'F';

var o2 = ' ';
if (this.isRead1()) {

@@ -490,2 +560,3 @@ o1 = '1';

var isize = this.template_length();
if (isize > 0) {

@@ -502,42 +573,56 @@ tmp[0] = s1;

}
return tmp.join('');
}
return null;
} }, { key: "_bin_mq_nl", value: function _bin_mq_nl()
{
}
}, {
key: "_bin_mq_nl",
value: function _bin_mq_nl() {
return this.bytes.byteArray.readInt32LE(this.bytes.start + 12);
} }, { key: "_flag_nc", value: function _flag_nc()
{
}
}, {
key: "_flag_nc",
value: function _flag_nc() {
return this.bytes.byteArray.readInt32LE(this.bytes.start + 16);
} }, { key: "seq_length", value: function seq_length()
{
}
}, {
key: "seq_length",
value: function seq_length() {
return this.bytes.byteArray.readInt32LE(this.bytes.start + 20);
} }, { key: "_next_refid", value: function _next_refid()
{
}
}, {
key: "_next_refid",
value: function _next_refid() {
return this.bytes.byteArray.readInt32LE(this.bytes.start + 24);
} }, { key: "_next_pos", value: function _next_pos()
{
}
}, {
key: "_next_pos",
value: function _next_pos() {
return this.bytes.byteArray.readInt32LE(this.bytes.start + 28);
} }, { key: "template_length", value: function template_length()
{
}
}, {
key: "template_length",
value: function template_length() {
return this.bytes.byteArray.readInt32LE(this.bytes.start + 32);
} }, { key: "toJSON", value: function toJSON()
}
}, {
key: "toJSON",
value: function toJSON() {
var _this2 = this;
{var _this2 = this;
var data = {};
Object.keys(this).forEach(function (k) {
if (k.charAt(0) === '_' || k === 'bytes') return;
(0, _keys.default)(this).forEach(function (k) {
if (k.charAt(0) === '_' || k === 'bytes') return; //@ts-ignore
data[k] = _this2[k];
});
return data;
} }]);return BamRecord;}();
}
}]);
return BamRecord;
}();
module.exports = BamRecord;
exports.default = BamRecord;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/record.ts"],"names":["SEQRET_DECODER","split","CIGAR_DECODER","BamRecord","args","undefined","data","bytes","start","end","byteArray","_id","fileOffset","_refID","readInt32LE","flags","field","_get","toLowerCase","_parseTag","_parseAllTags","tags","isSegmentUnmapped","push","isPaired","concat","_tagList","forEach","k","seen","filter","t","lt","s","mq","qseq","p","lseq","j","join","isReverseComplemented","isMateUnmapped","isMateReverseComplemented","nl","toString","tagName","_allTagsParsed","_tagOffset","blockEnd","lcTag","tag","String","fromCharCode","type","value","readInt8","readInt16LE","readFloatLE","cc","Btype","limit","console","warn","cigar","match","map","op","toUpperCase","Constants","BAM_FPAIRED","BAM_FPROPER_PAIR","BAM_FUNMAP","BAM_FMUNMAP","BAM_FREVERSE","BAM_FMREVERSE","BAM_FREAD1","BAM_FREAD2","BAM_FSECONDARY","BAM_FQCFAIL","BAM_FDUP","BAM_FSUPPLEMENTARY","numCigarOps","lref","c","cigop","lop","length_on_ref","seq","seqBytes","sb","length","get","_next_refid","s1","s2","o1","o2","isRead1","isRead2","tmp","isize","template_length","charAt"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/camelcase */\n/* eslint-disable @typescript-eslint/no-empty-function */\n/* eslint-disable @typescript-eslint/ban-ts-ignore */\nimport Constants from './constants'\n\nconst SEQRET_DECODER = '=ACMGRSVTWYHKDBN'.split('')\nconst CIGAR_DECODER = 'MIDNSHP=X???????'.split('')\n\n/**\n * Class of each BAM record returned by this API.\n */\nexport default class BamRecord {\n  private data: any\n  private bytes: any\n  private flags: any\n  private _id: number\n  private _refID: number\n  private _tagOffset: number | undefined = undefined\n  private _tagList: string[] = []\n  private _allTagsParsed = false\n  constructor(args: any) {\n    this.data = {}\n    this.bytes = {\n      start: args.bytes.start,\n      end: args.bytes.end,\n      byteArray: args.bytes.byteArray,\n    }\n    this._id = args.fileOffset\n    const { start, byteArray } = this.bytes\n    this._refID = byteArray.readInt32LE(start + 4)\n    this.data.start = byteArray.readInt32LE(start + 8)\n    this.flags = (byteArray.readInt32LE(start + 16) & 0xffff0000) >> 16\n  }\n\n  get(field: string) {\n    return this._get(field.toLowerCase())\n  }\n\n  end() {\n    return this._get('start') + (this._get('length_on_ref') || this._get('seq_length') || undefined)\n  }\n\n  seq_id() {\n    return this._refID\n  }\n\n  // same as get(), except requires lower-case arguments.  used\n  // internally to save lots of calls to field.toLowerCase()\n  _get(field: string) {\n    if (field in this.data) {\n      return this.data[field]\n    }\n    //@ts-ignore\n    if (this[field]) {\n      //@ts-ignore\n      this.data[field] = this[field]()\n    } else {\n      this.data[field] = this._parseTag(field)\n    }\n    return this.data[field]\n  }\n\n  _tags() {\n    this._parseAllTags()\n\n    let tags = [\n      'seq',\n      'seq_reverse_complemented',\n      'unmapped',\n      'qc_failed',\n      'duplicate',\n      'secondary_alignment',\n      'supplementary_alignment',\n    ]\n\n    if (!this.isSegmentUnmapped())\n      tags.push('start', 'end', 'strand', 'score', 'qual', 'MQ', 'CIGAR', 'length_on_ref', 'template_length')\n    if (this.isPaired()) {\n      tags.push(\n        'multi_segment_all_correctly_aligned',\n        'multi_segment_next_segment_unmapped',\n        'multi_segment_next_segment_reversed',\n        'multi_segment_first',\n        'multi_segment_last',\n        'next_segment_position',\n        'pair_orientation',\n      )\n    }\n    tags = tags.concat(this._tagList || [])\n\n    Object.keys(this.data).forEach(k => {\n      if (k[0] !== '_' && k !== 'multi_segment_all_aligned' && k !== 'next_seq_id') tags.push(k)\n    })\n\n    const seen: { [key: string]: boolean } = {}\n    tags = tags.filter(t => {\n      if (t in this.data && this.data[t] === undefined) return false\n\n      const lt = t.toLowerCase()\n      const s = seen[lt]\n      seen[lt] = true\n      return !s\n    })\n\n    return tags\n  }\n\n  parent() {\n    return undefined\n  }\n\n  children() {\n    return this._get('subfeatures')\n  }\n\n  id() {\n    return this._id\n  }\n\n  multi_segment_all_aligned() {\n    return this._get('multi_segment_all_correctly_aligned')\n  }\n\n  // special parsers\n  /**\n   * Mapping quality score.\n   */\n  mq() {\n    const mq = (this._get('_bin_mq_nl') & 0xff00) >> 8\n    return mq === 255 ? undefined : mq\n  }\n\n  score() {\n    return this._get('mq')\n  }\n\n  qual() {\n    if (this.isSegmentUnmapped()) return undefined\n\n    const qseq = []\n    const { byteArray } = this.bytes\n    const p = this.bytes.start + 36 + this._get('_l_read_name') + this._get('_n_cigar_op') * 4 + this._get('_seq_bytes')\n    const lseq = this._get('seq_length')\n    for (let j = 0; j < lseq; ++j) {\n      qseq.push(byteArray[p + j])\n    }\n    return qseq.join(' ')\n  }\n\n  strand() {\n    return this.isReverseComplemented() ? -1 : 1\n  }\n\n  multi_segment_next_segment_strand() {\n    if (this.isMateUnmapped()) return undefined\n    return this.isMateReverseComplemented() ? -1 : 1\n  }\n\n  name() {\n    return this._get('_read_name')\n  }\n\n  _read_name() {\n    const nl = this._get('_l_read_name')\n    return this.bytes.byteArray.toString('ascii', this.bytes.start + 36, this.bytes.start + 36 + nl - 1)\n  }\n\n  /**\n   * Get the value of a tag, parsing the tags as far as necessary.\n   * Only called if we have not already parsed that field.\n   */\n  _parseTag(tagName?: string) {\n    // if all of the tags have been parsed and we're still being\n    // called, we already know that we have no such tag, because\n    // it would already have been cached.\n    if (this._allTagsParsed) return undefined\n\n    const { byteArray } = this.bytes\n    let p =\n      this._tagOffset ||\n      this.bytes.start +\n        36 +\n        this._get('_l_read_name') +\n        this._get('_n_cigar_op') * 4 +\n        this._get('_seq_bytes') +\n        this._get('seq_length')\n\n    const blockEnd = this.bytes.end\n    let lcTag\n    while (p < blockEnd && lcTag !== tagName) {\n      const tag = String.fromCharCode(byteArray[p], byteArray[p + 1])\n      lcTag = tag.toLowerCase()\n      const type = String.fromCharCode(byteArray[p + 2])\n      p += 3\n\n      let value\n      switch (type.toLowerCase()) {\n        case 'a':\n          value = String.fromCharCode(byteArray[p])\n          p += 1\n          break\n        case 'i':\n          value = byteArray.readInt32LE(p)\n          p += 4\n          break\n        case 'c':\n          value = byteArray.readInt8(p)\n          p += 1\n          break\n        case 's':\n          value = byteArray.readInt16LE(p)\n          p += 2\n          break\n        case 'f':\n          value = byteArray.readFloatLE(p)\n          p += 4\n          break\n        case 'z':\n        case 'h':\n          value = ''\n          while (p <= blockEnd) {\n            const cc = byteArray[p++]\n            if (cc === 0) {\n              break\n            } else {\n              value += String.fromCharCode(cc)\n            }\n          }\n          break\n        case 'b': {\n          value = ''\n          const cc = byteArray[p++]\n          const Btype = String.fromCharCode(cc)\n          if (Btype === 'i' || Btype === 'I') {\n            const limit = byteArray.readInt32LE(p)\n            p += 4\n            for (let k = 0; k < limit; k++) {\n              value += byteArray.readInt32LE(p)\n              if (k + 1 < limit) value += ','\n              p += 4\n            }\n          }\n          if (Btype === 's' || Btype === 'S') {\n            const limit = byteArray.readInt32LE(p)\n            p += 4\n            for (let k = 0; k < limit; k++) {\n              value += byteArray.readInt16LE(p)\n              if (k + 1 < limit) value += ','\n              p += 2\n            }\n          }\n          if (Btype === 'c' || Btype === 'C') {\n            const limit = byteArray.readInt32LE(p)\n            p += 4\n            for (let k = 0; k < limit; k++) {\n              value += byteArray.readInt8(p)\n              if (k + 1 < limit) value += ','\n              p += 1\n            }\n          }\n          if (Btype === 'f') {\n            const limit = byteArray.readInt32LE(p)\n            p += 4\n            for (let k = 0; k < limit; k++) {\n              value += byteArray.readFloatLE(p)\n              if (k + 1 < limit) value += ','\n              p += 4\n            }\n          }\n          break\n        }\n        default:\n          console.warn(`Unknown BAM tag type '${type}', tags may be incomplete`)\n          value = undefined\n          p = blockEnd // stop parsing tags\n      }\n\n      this._tagOffset = p\n\n      this._tagList.push(tag)\n      if (lcTag === tagName) return value\n\n      this.data[lcTag] = value\n    }\n    this._allTagsParsed = true\n    return undefined\n  }\n\n  _parseAllTags() {\n    this._parseTag()\n  }\n\n  _parseCigar(cigar: string) {\n    //@ts-ignore\n    return cigar.match(/\\d+\\D/g).map((op: string) => [op.match(/\\D/)[0].toUpperCase(), parseInt(op, 10)])\n  }\n\n  /**\n   * @returns {boolean} true if the read is paired, regardless of whether both segments are mapped\n   */\n  isPaired() {\n    return !!(this.flags & Constants.BAM_FPAIRED)\n  }\n\n  /** @returns {boolean} true if the read is paired, and both segments are mapped */\n  isProperlyPaired() {\n    return !!(this.flags & Constants.BAM_FPROPER_PAIR)\n  }\n\n  /** @returns {boolean} true if the read itself is unmapped; conflictive with isProperlyPaired */\n  isSegmentUnmapped() {\n    return !!(this.flags & Constants.BAM_FUNMAP)\n  }\n\n  /** @returns {boolean} true if the read itself is unmapped; conflictive with isProperlyPaired */\n  isMateUnmapped() {\n    return !!(this.flags & Constants.BAM_FMUNMAP)\n  }\n\n  /** @returns {boolean} true if the read is mapped to the reverse strand */\n  isReverseComplemented() {\n    return !!(this.flags & Constants.BAM_FREVERSE)\n  }\n\n  /** @returns {boolean} true if the mate is mapped to the reverse strand */\n  isMateReverseComplemented() {\n    return !!(this.flags & Constants.BAM_FMREVERSE)\n  }\n\n  /** @returns {boolean} true if this is read number 1 in a pair */\n  isRead1() {\n    return !!(this.flags & Constants.BAM_FREAD1)\n  }\n\n  /** @returns {boolean} true if this is read number 2 in a pair */\n  isRead2() {\n    return !!(this.flags & Constants.BAM_FREAD2)\n  }\n\n  /** @returns {boolean} true if this is a secondary alignment */\n  isSecondary() {\n    return !!(this.flags & Constants.BAM_FSECONDARY)\n  }\n\n  /** @returns {boolean} true if this read has failed QC checks */\n  isFailedQc() {\n    return !!(this.flags & Constants.BAM_FQCFAIL)\n  }\n\n  /** @returns {boolean} true if the read is an optical or PCR duplicate */\n  isDuplicate() {\n    return !!(this.flags & Constants.BAM_FDUP)\n  }\n\n  /** @returns {boolean} true if this is a supplementary alignment */\n  isSupplementary() {\n    return !!(this.flags & Constants.BAM_FSUPPLEMENTARY)\n  }\n\n  cigar() {\n    if (this.isSegmentUnmapped()) return undefined\n\n    const { byteArray, start } = this.bytes\n    const numCigarOps = this._get('_n_cigar_op')\n    let p = start + 36 + this._get('_l_read_name')\n    let cigar = ''\n    let lref = 0\n    for (let c = 0; c < numCigarOps; ++c) {\n      const cigop = byteArray.readInt32LE(p)\n      const lop = cigop >> 4\n      const op = CIGAR_DECODER[cigop & 0xf]\n      cigar += lop + op\n\n      // soft clip, hard clip, and insertion don't count toward\n      // the length on the reference\n      if (op !== 'H' && op !== 'S' && op !== 'I') lref += lop\n\n      p += 4\n    }\n\n    this.data.length_on_ref = lref\n    return cigar\n  }\n\n  _flags() {}\n\n  length_on_ref() {\n    this._get('cigar') // the length_on_ref is set as a\n    // side effect of the CIGAR parsing\n    return this.data.length_on_ref\n  }\n\n  _n_cigar_op() {\n    return this._get('_flag_nc') & 0xffff\n  }\n\n  _l_read_name() {\n    return this._get('_bin_mq_nl') & 0xff\n  }\n\n  /**\n   * number of bytes in the sequence field\n   */\n  _seq_bytes() {\n    return (this._get('seq_length') + 1) >> 1\n  }\n\n  getReadBases() {\n    let seq = ''\n    const { byteArray } = this.bytes\n    const p = this.bytes.start + 36 + this._get('_l_read_name') + this._get('_n_cigar_op') * 4\n    const seqBytes = this._get('_seq_bytes')\n    for (let j = 0; j < seqBytes; ++j) {\n      const sb = byteArray[p + j]\n      seq += SEQRET_DECODER[(sb & 0xf0) >> 4]\n      if (seq.length < this.get('seq_length')) seq += SEQRET_DECODER[sb & 0x0f]\n    }\n    return seq\n  }\n\n  // adapted from igv.js\n  getPairOrientation() {\n    if (!this.isSegmentUnmapped() && !this.isMateUnmapped() && this._refID === this._next_refid()) {\n      const s1 = this.isReverseComplemented() ? 'R' : 'F'\n      const s2 = this.isMateReverseComplemented() ? 'R' : 'F'\n      let o1 = ' '\n      let o2 = ' '\n      if (this.isRead1()) {\n        o1 = '1'\n        o2 = '2'\n      } else if (this.isRead2()) {\n        o1 = '2'\n        o2 = '1'\n      }\n\n      const tmp = []\n      const isize = this.template_length()\n      if (isize > 0) {\n        tmp[0] = s1\n        tmp[1] = o1\n        tmp[2] = s2\n        tmp[3] = o2\n      } else {\n        tmp[2] = s1\n        tmp[3] = o1\n        tmp[0] = s2\n        tmp[1] = o2\n      }\n      return tmp.join('')\n    }\n    return null\n  }\n\n  _bin_mq_nl() {\n    return this.bytes.byteArray.readInt32LE(this.bytes.start + 12)\n  }\n\n  _flag_nc() {\n    return this.bytes.byteArray.readInt32LE(this.bytes.start + 16)\n  }\n\n  seq_length() {\n    return this.bytes.byteArray.readInt32LE(this.bytes.start + 20)\n  }\n\n  _next_refid() {\n    return this.bytes.byteArray.readInt32LE(this.bytes.start + 24)\n  }\n\n  _next_pos() {\n    return this.bytes.byteArray.readInt32LE(this.bytes.start + 28)\n  }\n\n  template_length() {\n    return this.bytes.byteArray.readInt32LE(this.bytes.start + 32)\n  }\n\n  toJSON() {\n    const data: { [key: string]: any } = {}\n    Object.keys(this).forEach(k => {\n      if (k.charAt(0) === '_' || k === 'bytes') return\n      //@ts-ignore\n      data[k] = this[k]\n    })\n\n    return data\n  }\n}\n"]}

@@ -1,13 +0,44 @@

"use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");Object.defineProperty(exports, "__esModule", { value: true });exports.parseHeaderText = parseHeaderText;var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));var _toArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toArray"));function parseHeaderText(text) {
"use strict";
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.parseHeaderText = parseHeaderText;
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/slicedToArray"));
var _toArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/toArray"));
function parseHeaderText(text) {
var lines = text.split(/\r?\n/);
var data = [];
lines.forEach(function (line) {var _line$split =
line.split(/\t/),_line$split2 = (0, _toArray2.default)(_line$split),tag = _line$split2[0],fields = _line$split2.slice(1);
var parsedFields = fields.map(function (f) {var _f$split =
f.split(':', 2),_f$split2 = (0, _slicedToArray2.default)(_f$split, 2),fieldTag = _f$split2[0],value = _f$split2[1];
return { tag: fieldTag, value: value };
lines.forEach(function (line) {
var _line$split = line.split(/\t/),
_line$split2 = (0, _toArray2.default)(_line$split),
tag = _line$split2[0],
fields = _line$split2.slice(1);
var parsedFields = fields.map(function (f) {
var _f$split = f.split(':', 2),
_f$split2 = (0, _slicedToArray2.default)(_f$split, 2),
fieldTag = _f$split2[0],
value = _f$split2[1];
return {
tag: fieldTag,
value: value
};
});
if (tag) data.push({ tag: tag.substr(1), data: parsedFields });
if (tag) data.push({
tag: tag.substr(1),
data: parsedFields
});
});
return data;
}
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9zYW0udHMiXSwibmFtZXMiOlsicGFyc2VIZWFkZXJUZXh0IiwidGV4dCIsImxpbmVzIiwic3BsaXQiLCJkYXRhIiwiZm9yRWFjaCIsImxpbmUiLCJ0YWciLCJmaWVsZHMiLCJwYXJzZWRGaWVsZHMiLCJtYXAiLCJmIiwiZmllbGRUYWciLCJ2YWx1ZSIsInB1c2giLCJzdWJzdHIiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBTyxTQUFTQSxlQUFULENBQXlCQyxJQUF6QixFQUF1QztBQUM1QyxNQUFNQyxLQUFLLEdBQUdELElBQUksQ0FBQ0UsS0FBTCxDQUFXLE9BQVgsQ0FBZDtBQUNBLE1BQU1DLElBQStELEdBQUcsRUFBeEU7QUFDQUYsRUFBQUEsS0FBSyxDQUFDRyxPQUFOLENBQWMsVUFBQUMsSUFBSSxFQUFJO0FBQUEsc0JBQ0tBLElBQUksQ0FBQ0gsS0FBTCxDQUFXLElBQVgsQ0FETDtBQUFBO0FBQUEsUUFDYkksR0FEYTtBQUFBLFFBQ0xDLE1BREs7O0FBRXBCLFFBQU1DLFlBQVksR0FBR0QsTUFBTSxDQUFDRSxHQUFQLENBQVcsVUFBQUMsQ0FBQyxFQUFJO0FBQUEscUJBQ1RBLENBQUMsQ0FBQ1IsS0FBRixDQUFRLEdBQVIsRUFBYSxDQUFiLENBRFM7QUFBQTtBQUFBLFVBQzVCUyxRQUQ0QjtBQUFBLFVBQ2xCQyxLQURrQjs7QUFFbkMsYUFBTztBQUFFTixRQUFBQSxHQUFHLEVBQUVLLFFBQVA7QUFBaUJDLFFBQUFBLEtBQUssRUFBTEE7QUFBakIsT0FBUDtBQUNELEtBSG9CLENBQXJCO0FBSUEsUUFBSU4sR0FBSixFQUFTSCxJQUFJLENBQUNVLElBQUwsQ0FBVTtBQUFFUCxNQUFBQSxHQUFHLEVBQUVBLEdBQUcsQ0FBQ1EsTUFBSixDQUFXLENBQVgsQ0FBUDtBQUFzQlgsTUFBQUEsSUFBSSxFQUFFSztBQUE1QixLQUFWO0FBQ1YsR0FQRDtBQVFBLFNBQU9MLElBQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiBwYXJzZUhlYWRlclRleHQodGV4dDogc3RyaW5nKSB7XG4gIGNvbnN0IGxpbmVzID0gdGV4dC5zcGxpdCgvXFxyP1xcbi8pXG4gIGNvbnN0IGRhdGE6IHsgdGFnOiBzdHJpbmc7IGRhdGE6IHsgdGFnOiBzdHJpbmc7IHZhbHVlOiBzdHJpbmcgfVtdIH1bXSA9IFtdXG4gIGxpbmVzLmZvckVhY2gobGluZSA9PiB7XG4gICAgY29uc3QgW3RhZywgLi4uZmllbGRzXSA9IGxpbmUuc3BsaXQoL1xcdC8pXG4gICAgY29uc3QgcGFyc2VkRmllbGRzID0gZmllbGRzLm1hcChmID0+IHtcbiAgICAgIGNvbnN0IFtmaWVsZFRhZywgdmFsdWVdID0gZi5zcGxpdCgnOicsIDIpXG4gICAgICByZXR1cm4geyB0YWc6IGZpZWxkVGFnLCB2YWx1ZSB9XG4gICAgfSlcbiAgICBpZiAodGFnKSBkYXRhLnB1c2goeyB0YWc6IHRhZy5zdWJzdHIoMSksIGRhdGE6IHBhcnNlZEZpZWxkcyB9KVxuICB9KVxuICByZXR1cm4gZGF0YVxufVxuIl19

@@ -1,4 +0,17 @@

"use strict";var _require = require('pako'),Inflate = _require.Inflate,Z_SYNC_FLUSH = _require.Z_SYNC_FLUSH;
"use strict";
function pakoUnzip(inputData) {
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.unzip = unzip;
exports.unzipChunk = unzipChunk;
var _pako = require("pako");
/* eslint-disable @typescript-eslint/ban-ts-ignore */
//@ts-ignore
function unzip(inputData) {
var strm;

@@ -9,10 +22,14 @@ var pos = 0;

var inflator;
do {
var remainingInput = inputData.slice(pos);
inflator = new Inflate();var _inflator =
inflator;strm = _inflator.strm;
inflator.push(remainingInput, Z_SYNC_FLUSH);
inflator = new _pako.Inflate() //@ts-ignore
;
var _inflator = inflator;
strm = _inflator.strm;
//@ts-ignore
inflator.push(remainingInput, _pako.Z_SYNC_FLUSH);
if (inflator.err) throw new Error(inflator.msg);
pos += strm.next_in; //@ts-ignore
pos += strm.next_in;
chunks[i] = Buffer.from(inflator.result);

@@ -23,9 +40,8 @@ i += 1;

var result = Buffer.concat(chunks);
return result;
}
// similar to pakounzip, except it does extra counting and
} // similar to pakounzip, except it does extra counting and
// trimming to make sure to return only exactly the data
// range specified in the chunk
function unzipChunk(inputData, chunk) {

@@ -37,8 +53,12 @@ var strm;

var fileStartingOffset = chunk.minv.blockPosition;
do {
var remainingInput = inputData.slice(pos);
inflator = new Inflate();var _inflator2 =
inflator;strm = _inflator2.strm;
inflator.push(remainingInput, Z_SYNC_FLUSH);
if (inflator.err) throw new Error(inflator.msg);
inflator = new _pako.Inflate() //@ts-ignore
;
var _inflator2 = inflator;
strm = _inflator2.strm;
//@ts-ignore
inflator.push(remainingInput, _pako.Z_SYNC_FLUSH);
if (inflator.err) throw new Error(inflator.msg); //@ts-ignore

@@ -49,6 +69,5 @@ decompressedBlocks.push(Buffer.from(inflator.result));

// this is the first chunk, trim it
decompressedBlocks[0] = decompressedBlocks[0].slice(
chunk.minv.dataPosition);
decompressedBlocks[0] = decompressedBlocks[0].slice(chunk.minv.dataPosition);
}
}
if (fileStartingOffset + pos >= chunk.maxv.blockPosition) {

@@ -58,13 +77,6 @@ // this is the last chunk, trim it and stop decompressing

// trimmed part of the slice length
decompressedBlocks[decompressedBlocks.length - 1] = decompressedBlocks[
decompressedBlocks.length - 1].
slice(
0,
chunk.maxv.blockPosition === chunk.minv.blockPosition ?
chunk.maxv.dataPosition - chunk.minv.dataPosition + 1 :
chunk.maxv.dataPosition + 1);
decompressedBlocks[decompressedBlocks.length - 1] = decompressedBlocks[decompressedBlocks.length - 1].slice(0, chunk.maxv.blockPosition === chunk.minv.blockPosition ? chunk.maxv.dataPosition - chunk.minv.dataPosition + 1 : chunk.maxv.dataPosition + 1);
break;
}
pos += strm.next_in;

@@ -76,5 +88,2 @@ } while (strm.avail_in);

}
module.exports = {
unzip: pakoUnzip,
unzipChunk: unzipChunk };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91bnppcC50cyJdLCJuYW1lcyI6WyJ1bnppcCIsImlucHV0RGF0YSIsInN0cm0iLCJwb3MiLCJpIiwiY2h1bmtzIiwiaW5mbGF0b3IiLCJyZW1haW5pbmdJbnB1dCIsInNsaWNlIiwiSW5mbGF0ZSIsInB1c2giLCJaX1NZTkNfRkxVU0giLCJlcnIiLCJFcnJvciIsIm1zZyIsIm5leHRfaW4iLCJCdWZmZXIiLCJmcm9tIiwicmVzdWx0IiwiYXZhaWxfaW4iLCJjb25jYXQiLCJ1bnppcENodW5rIiwiY2h1bmsiLCJkZWNvbXByZXNzZWRCbG9ja3MiLCJmaWxlU3RhcnRpbmdPZmZzZXQiLCJtaW52IiwiYmxvY2tQb3NpdGlvbiIsImxlbmd0aCIsImRhdGFQb3NpdGlvbiIsIm1heHYiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBRUE7O0FBRkE7QUFDQTtBQUlPLFNBQVNBLEtBQVQsQ0FBZUMsU0FBZixFQUFrQztBQUN2QyxNQUFJQyxJQUFKO0FBQ0EsTUFBSUMsR0FBRyxHQUFHLENBQVY7QUFDQSxNQUFJQyxDQUFDLEdBQUcsQ0FBUjtBQUNBLE1BQU1DLE1BQU0sR0FBRyxFQUFmO0FBQ0EsTUFBSUMsUUFBSjs7QUFDQSxLQUFHO0FBQ0QsUUFBTUMsY0FBYyxHQUFHTixTQUFTLENBQUNPLEtBQVYsQ0FBZ0JMLEdBQWhCLENBQXZCO0FBQ0FHLElBQUFBLFFBQVEsR0FBRyxJQUFJRyxhQUFKLEVBQVgsQ0FDQTtBQURBO0FBRkMsb0JBSVlILFFBSlo7QUFJR0osSUFBQUEsSUFKSCxhQUlHQSxJQUpIO0FBS0Q7QUFDQUksSUFBQUEsUUFBUSxDQUFDSSxJQUFULENBQWNILGNBQWQsRUFBOEJJLGtCQUE5QjtBQUNBLFFBQUlMLFFBQVEsQ0FBQ00sR0FBYixFQUFrQixNQUFNLElBQUlDLEtBQUosQ0FBVVAsUUFBUSxDQUFDUSxHQUFuQixDQUFOO0FBRWxCWCxJQUFBQSxHQUFHLElBQUlELElBQUksQ0FBQ2EsT0FBWixDQVRDLENBVUQ7O0FBQ0FWLElBQUFBLE1BQU0sQ0FBQ0QsQ0FBRCxDQUFOLEdBQVlZLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZWCxRQUFRLENBQUNZLE1BQXJCLENBQVo7QUFDQWQsSUFBQUEsQ0FBQyxJQUFJLENBQUw7QUFDRCxHQWJELFFBYVNGLElBQUksQ0FBQ2lCLFFBYmQ7O0FBZUEsTUFBTUQsTUFBTSxHQUFHRixNQUFNLENBQUNJLE1BQVAsQ0FBY2YsTUFBZCxDQUFmO0FBRUEsU0FBT2EsTUFBUDtBQUNELEMsQ0FFRDtBQUNBO0FBQ0E7OztBQUNPLFNBQVNHLFVBQVQsQ0FBb0JwQixTQUFwQixFQUF1Q3FCLEtBQXZDLEVBQXFEO0FBQzFELE1BQUlwQixJQUFKO0FBQ0EsTUFBSUMsR0FBRyxHQUFHLENBQVY7QUFDQSxNQUFNb0Isa0JBQWtCLEdBQUcsRUFBM0I7QUFDQSxNQUFJakIsUUFBSjtBQUNBLE1BQU1rQixrQkFBa0IsR0FBR0YsS0FBSyxDQUFDRyxJQUFOLENBQVdDLGFBQXRDOztBQUNBLEtBQUc7QUFDRCxRQUFNbkIsY0FBYyxHQUFHTixTQUFTLENBQUNPLEtBQVYsQ0FBZ0JMLEdBQWhCLENBQXZCO0FBQ0FHLElBQUFBLFFBQVEsR0FBRyxJQUFJRyxhQUFKLEVBQVgsQ0FDQTtBQURBO0FBRkMscUJBSVlILFFBSlo7QUFJR0osSUFBQUEsSUFKSCxjQUlHQSxJQUpIO0FBS0Q7QUFDQUksSUFBQUEsUUFBUSxDQUFDSSxJQUFULENBQWNILGNBQWQsRUFBOEJJLGtCQUE5QjtBQUNBLFFBQUlMLFFBQVEsQ0FBQ00sR0FBYixFQUFrQixNQUFNLElBQUlDLEtBQUosQ0FBVVAsUUFBUSxDQUFDUSxHQUFuQixDQUFOLENBUGpCLENBU0Q7O0FBQ0FTLElBQUFBLGtCQUFrQixDQUFDYixJQUFuQixDQUF3Qk0sTUFBTSxDQUFDQyxJQUFQLENBQVlYLFFBQVEsQ0FBQ1ksTUFBckIsQ0FBeEI7O0FBRUEsUUFBSUssa0JBQWtCLENBQUNJLE1BQW5CLEtBQThCLENBQTlCLElBQW1DTCxLQUFLLENBQUNHLElBQU4sQ0FBV0csWUFBbEQsRUFBZ0U7QUFDOUQ7QUFDQUwsTUFBQUEsa0JBQWtCLENBQUMsQ0FBRCxDQUFsQixHQUF3QkEsa0JBQWtCLENBQUMsQ0FBRCxDQUFsQixDQUFzQmYsS0FBdEIsQ0FBNEJjLEtBQUssQ0FBQ0csSUFBTixDQUFXRyxZQUF2QyxDQUF4QjtBQUNEOztBQUNELFFBQUlKLGtCQUFrQixHQUFHckIsR0FBckIsSUFBNEJtQixLQUFLLENBQUNPLElBQU4sQ0FBV0gsYUFBM0MsRUFBMEQ7QUFDeEQ7QUFDQTtBQUNBO0FBRUFILE1BQUFBLGtCQUFrQixDQUFDQSxrQkFBa0IsQ0FBQ0ksTUFBbkIsR0FBNEIsQ0FBN0IsQ0FBbEIsR0FBb0RKLGtCQUFrQixDQUFDQSxrQkFBa0IsQ0FBQ0ksTUFBbkIsR0FBNEIsQ0FBN0IsQ0FBbEIsQ0FBa0RuQixLQUFsRCxDQUNsRCxDQURrRCxFQUVsRGMsS0FBSyxDQUFDTyxJQUFOLENBQVdILGFBQVgsS0FBNkJKLEtBQUssQ0FBQ0csSUFBTixDQUFXQyxhQUF4QyxHQUNJSixLQUFLLENBQUNPLElBQU4sQ0FBV0QsWUFBWCxHQUEwQk4sS0FBSyxDQUFDRyxJQUFOLENBQVdHLFlBQXJDLEdBQW9ELENBRHhELEdBRUlOLEtBQUssQ0FBQ08sSUFBTixDQUFXRCxZQUFYLEdBQTBCLENBSm9CLENBQXBEO0FBTUE7QUFDRDs7QUFDRHpCLElBQUFBLEdBQUcsSUFBSUQsSUFBSSxDQUFDYSxPQUFaO0FBQ0QsR0E5QkQsUUE4QlNiLElBQUksQ0FBQ2lCLFFBOUJkOztBQWdDQSxNQUFNRCxNQUFNLEdBQUdGLE1BQU0sQ0FBQ0ksTUFBUCxDQUFjRyxrQkFBZCxDQUFmO0FBQ0EsU0FBT0wsTUFBUDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10cy1pZ25vcmUgKi9cbi8vQHRzLWlnbm9yZVxuaW1wb3J0IHsgSW5mbGF0ZSwgWl9TWU5DX0ZMVVNIIH0gZnJvbSAncGFrbydcbmltcG9ydCBDaHVuayBmcm9tICcuL2NodW5rJ1xuXG5leHBvcnQgZnVuY3Rpb24gdW56aXAoaW5wdXREYXRhOiBCdWZmZXIpIHtcbiAgbGV0IHN0cm1cbiAgbGV0IHBvcyA9IDBcbiAgbGV0IGkgPSAwXG4gIGNvbnN0IGNodW5rcyA9IFtdXG4gIGxldCBpbmZsYXRvclxuICBkbyB7XG4gICAgY29uc3QgcmVtYWluaW5nSW5wdXQgPSBpbnB1dERhdGEuc2xpY2UocG9zKVxuICAgIGluZmxhdG9yID0gbmV3IEluZmxhdGUoKVxuICAgIC8vQHRzLWlnbm9yZVxuICAgIDsoeyBzdHJtIH0gPSBpbmZsYXRvcilcbiAgICAvL0B0cy1pZ25vcmVcbiAgICBpbmZsYXRvci5wdXNoKHJlbWFpbmluZ0lucHV0LCBaX1NZTkNfRkxVU0gpXG4gICAgaWYgKGluZmxhdG9yLmVycikgdGhyb3cgbmV3IEVycm9yKGluZmxhdG9yLm1zZylcblxuICAgIHBvcyArPSBzdHJtLm5leHRfaW5cbiAgICAvL0B0cy1pZ25vcmVcbiAgICBjaHVua3NbaV0gPSBCdWZmZXIuZnJvbShpbmZsYXRvci5yZXN1bHQpXG4gICAgaSArPSAxXG4gIH0gd2hpbGUgKHN0cm0uYXZhaWxfaW4pXG5cbiAgY29uc3QgcmVzdWx0ID0gQnVmZmVyLmNvbmNhdChjaHVua3MpXG5cbiAgcmV0dXJuIHJlc3VsdFxufVxuXG4vLyBzaW1pbGFyIHRvIHBha291bnppcCwgZXhjZXB0IGl0IGRvZXMgZXh0cmEgY291bnRpbmcgYW5kXG4vLyB0cmltbWluZyB0byBtYWtlIHN1cmUgdG8gcmV0dXJuIG9ubHkgZXhhY3RseSB0aGUgZGF0YVxuLy8gcmFuZ2Ugc3BlY2lmaWVkIGluIHRoZSBjaHVua1xuZXhwb3J0IGZ1bmN0aW9uIHVuemlwQ2h1bmsoaW5wdXREYXRhOiBCdWZmZXIsIGNodW5rOiBDaHVuaykge1xuICBsZXQgc3RybVxuICBsZXQgcG9zID0gMFxuICBjb25zdCBkZWNvbXByZXNzZWRCbG9ja3MgPSBbXVxuICBsZXQgaW5mbGF0b3JcbiAgY29uc3QgZmlsZVN0YXJ0aW5nT2Zmc2V0ID0gY2h1bmsubWludi5ibG9ja1Bvc2l0aW9uXG4gIGRvIHtcbiAgICBjb25zdCByZW1haW5pbmdJbnB1dCA9IGlucHV0RGF0YS5zbGljZShwb3MpXG4gICAgaW5mbGF0b3IgPSBuZXcgSW5mbGF0ZSgpXG4gICAgLy9AdHMtaWdub3JlXG4gICAgOyh7IHN0cm0gfSA9IGluZmxhdG9yKVxuICAgIC8vQHRzLWlnbm9yZVxuICAgIGluZmxhdG9yLnB1c2gocmVtYWluaW5nSW5wdXQsIFpfU1lOQ19GTFVTSClcbiAgICBpZiAoaW5mbGF0b3IuZXJyKSB0aHJvdyBuZXcgRXJyb3IoaW5mbGF0b3IubXNnKVxuXG4gICAgLy9AdHMtaWdub3JlXG4gICAgZGVjb21wcmVzc2VkQmxvY2tzLnB1c2goQnVmZmVyLmZyb20oaW5mbGF0b3IucmVzdWx0KSlcblxuICAgIGlmIChkZWNvbXByZXNzZWRCbG9ja3MubGVuZ3RoID09PSAxICYmIGNodW5rLm1pbnYuZGF0YVBvc2l0aW9uKSB7XG4gICAgICAvLyB0aGlzIGlzIHRoZSBmaXJzdCBjaHVuaywgdHJpbSBpdFxuICAgICAgZGVjb21wcmVzc2VkQmxvY2tzWzBdID0gZGVjb21wcmVzc2VkQmxvY2tzWzBdLnNsaWNlKGNodW5rLm1pbnYuZGF0YVBvc2l0aW9uKVxuICAgIH1cbiAgICBpZiAoZmlsZVN0YXJ0aW5nT2Zmc2V0ICsgcG9zID49IGNodW5rLm1heHYuYmxvY2tQb3NpdGlvbikge1xuICAgICAgLy8gdGhpcyBpcyB0aGUgbGFzdCBjaHVuaywgdHJpbSBpdCBhbmQgc3RvcCBkZWNvbXByZXNzaW5nXG4gICAgICAvLyBub3RlIGlmIGl0IGlzIHRoZSBzYW1lIGJsb2NrIGlzIG1pbnYgaXQgc3VidHJhY3RzIHRoYXQgYWxyZWFkeVxuICAgICAgLy8gdHJpbW1lZCBwYXJ0IG9mIHRoZSBzbGljZSBsZW5ndGhcblxuICAgICAgZGVjb21wcmVzc2VkQmxvY2tzW2RlY29tcHJlc3NlZEJsb2Nrcy5sZW5ndGggLSAxXSA9IGRlY29tcHJlc3NlZEJsb2Nrc1tkZWNvbXByZXNzZWRCbG9ja3MubGVuZ3RoIC0gMV0uc2xpY2UoXG4gICAgICAgIDAsXG4gICAgICAgIGNodW5rLm1heHYuYmxvY2tQb3NpdGlvbiA9PT0gY2h1bmsubWludi5ibG9ja1Bvc2l0aW9uXG4gICAgICAgICAgPyBjaHVuay5tYXh2LmRhdGFQb3NpdGlvbiAtIGNodW5rLm1pbnYuZGF0YVBvc2l0aW9uICsgMVxuICAgICAgICAgIDogY2h1bmsubWF4di5kYXRhUG9zaXRpb24gKyAxLFxuICAgICAgKVxuICAgICAgYnJlYWtcbiAgICB9XG4gICAgcG9zICs9IHN0cm0ubmV4dF9pblxuICB9IHdoaWxlIChzdHJtLmF2YWlsX2luKVxuXG4gIGNvbnN0IHJlc3VsdCA9IEJ1ZmZlci5jb25jYXQoZGVjb21wcmVzc2VkQmxvY2tzKVxuICByZXR1cm4gcmVzdWx0XG59XG4iXX0=

@@ -1,22 +0,46 @@

"use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));function longToNumber(long) {
if (
long.greaterThan(Number.MAX_SAFE_INTEGER) ||
long.lessThan(Number.MIN_SAFE_INTEGER))
{
"use strict";
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.longToNumber = longToNumber;
exports.checkAbortSignal = checkAbortSignal;
exports.abortBreakPoint = abortBreakPoint;
exports.canMergeBlocks = canMergeBlocks;
var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs2/regenerator"));
var _promise = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/promise"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/asyncToGenerator"));
var _minSafeInteger = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/number/min-safe-integer"));
var _maxSafeInteger = _interopRequireDefault(require("@babel/runtime-corejs2/core-js/number/max-safe-integer"));
function longToNumber(long) {
if (long.greaterThan(_maxSafeInteger.default) || long.lessThan(_minSafeInteger.default)) {
throw new Error('integer overflow');
}
return long.toNumber();
}
/**
* Properly check if the given AbortSignal is aborted.
* Per the standard, if the signal reads as aborted,
* this function throws either a DOMException AbortError, or a regular error
* with a `code` attribute set to `ERR_ABORTED`.
*
* For convenience, passing `undefined` is a no-op
*
* @param {AbortSignal} [signal] an AbortSignal, or anything with an `aborted` attribute
* @returns nothing
*/
/**
* Properly check if the given AbortSignal is aborted.
* Per the standard, if the signal reads as aborted,
* this function throws either a DOMException AbortError, or a regular error
* with a `code` attribute set to `ERR_ABORTED`.
*
* For convenience, passing `undefined` is a no-op
*
* @param {AbortSignal} [signal] an AbortSignal, or anything with an `aborted` attribute
* @returns nothing
*/
function checkAbortSignal(signal) {

@@ -27,7 +51,7 @@ if (!signal) return;

// console.log('bam aborted!')
if (typeof DOMException !== 'undefined')
// eslint-disable-next-line no-undef
throw new DOMException('aborted', 'AbortError');else
{
var e = new Error('aborted');
if (typeof DOMException !== 'undefined') // eslint-disable-next-line no-undef
throw new DOMException('aborted', 'AbortError');else {
var e = new Error('aborted'); // eslint-disable-next-line @typescript-eslint/ban-ts-ignore
//@ts-ignore
e.code = 'ERR_ABORTED';

@@ -38,26 +62,41 @@ throw e;

}
/**
* Skips to the next tick, then runs `checkAbortSignal`.
* Await this to inside an otherwise synchronous loop to
* provide a place to break when an abort signal is received.
* @param {AbortSignal} signal
*/function
abortBreakPoint(_x) {return _abortBreakPoint.apply(this, arguments);}function _abortBreakPoint() {_abortBreakPoint = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(signal) {return _regenerator.default.wrap(function _callee$(_context) {while (1) {switch (_context.prev = _context.next) {case 0:_context.next = 2;return (
Promise.resolve());case 2:
checkAbortSignal(signal);case 3:case "end":return _context.stop();}}}, _callee);}));return _abortBreakPoint.apply(this, arguments);}
* Skips to the next tick, then runs `checkAbortSignal`.
* Await this to inside an otherwise synchronous loop to
* provide a place to break when an abort signal is received.
* @param {AbortSignal} signal
*/
function canMergeBlocks(block1, block2) {
return (
block1.minv.blockPosition === block1.maxv.blockPosition &&
block1.maxv.blockPosition === block2.minv.blockPosition &&
block2.minv.blockPosition === block2.maxv.blockPosition);
function abortBreakPoint(_x) {
return _abortBreakPoint.apply(this, arguments);
}
function _abortBreakPoint() {
_abortBreakPoint = (0, _asyncToGenerator2.default)(
/*#__PURE__*/
_regenerator.default.mark(function _callee(signal) {
return _regenerator.default.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
_context.next = 2;
return _promise.default.resolve();
case 2:
checkAbortSignal(signal);
case 3:
case "end":
return _context.stop();
}
}
}, _callee);
}));
return _abortBreakPoint.apply(this, arguments);
}
module.exports = {
longToNumber: longToNumber,
checkAbortSignal: checkAbortSignal,
abortBreakPoint: abortBreakPoint,
canMergeBlocks: canMergeBlocks };
function canMergeBlocks(block1, block2) {
return block1.minv.blockPosition === block1.maxv.blockPosition && block1.maxv.blockPosition === block2.minv.blockPosition && block2.minv.blockPosition === block2.maxv.blockPosition;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbImxvbmdUb051bWJlciIsImxvbmciLCJncmVhdGVyVGhhbiIsImxlc3NUaGFuIiwiRXJyb3IiLCJ0b051bWJlciIsImNoZWNrQWJvcnRTaWduYWwiLCJzaWduYWwiLCJhYm9ydGVkIiwiRE9NRXhjZXB0aW9uIiwiZSIsImNvZGUiLCJhYm9ydEJyZWFrUG9pbnQiLCJyZXNvbHZlIiwiY2FuTWVyZ2VCbG9ja3MiLCJibG9jazEiLCJibG9jazIiLCJtaW52IiwiYmxvY2tQb3NpdGlvbiIsIm1heHYiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDTyxTQUFTQSxZQUFULENBQXNCQyxJQUF0QixFQUFrQztBQUN2QyxNQUFJQSxJQUFJLENBQUNDLFdBQUwsNkJBQTZDRCxJQUFJLENBQUNFLFFBQUwseUJBQWpELEVBQXlGO0FBQ3ZGLFVBQU0sSUFBSUMsS0FBSixDQUFVLGtCQUFWLENBQU47QUFDRDs7QUFDRCxTQUFPSCxJQUFJLENBQUNJLFFBQUwsRUFBUDtBQUNEO0FBRUQ7Ozs7Ozs7Ozs7Ozs7QUFXTyxTQUFTQyxnQkFBVCxDQUEwQkMsTUFBMUIsRUFBZ0Q7QUFDckQsTUFBSSxDQUFDQSxNQUFMLEVBQWE7O0FBRWIsTUFBSUEsTUFBTSxDQUFDQyxPQUFYLEVBQW9CO0FBQ2xCO0FBQ0EsUUFBSSxPQUFPQyxZQUFQLEtBQXdCLFdBQTVCLEVBQ0U7QUFDQSxZQUFNLElBQUlBLFlBQUosQ0FBaUIsU0FBakIsRUFBNEIsWUFBNUIsQ0FBTixDQUZGLEtBR0s7QUFDSCxVQUFNQyxDQUFDLEdBQUcsSUFBSU4sS0FBSixDQUFVLFNBQVYsQ0FBVixDQURHLENBRUg7QUFDQTs7QUFDQU0sTUFBQUEsQ0FBQyxDQUFDQyxJQUFGLEdBQVMsYUFBVDtBQUNBLFlBQU1ELENBQU47QUFDRDtBQUNGO0FBQ0Y7QUFFRDs7Ozs7Ozs7U0FNc0JFLGU7Ozs7Ozs7NEJBQWYsaUJBQStCTCxNQUEvQjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxtQkFDQyxpQkFBUU0sT0FBUixFQUREOztBQUFBO0FBRUxQLFlBQUFBLGdCQUFnQixDQUFDQyxNQUFELENBQWhCOztBQUZLO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEc7Ozs7QUFLQSxTQUFTTyxjQUFULENBQXdCQyxNQUF4QixFQUF1Q0MsTUFBdkMsRUFBc0Q7QUFDM0QsU0FDRUQsTUFBTSxDQUFDRSxJQUFQLENBQVlDLGFBQVosS0FBOEJILE1BQU0sQ0FBQ0ksSUFBUCxDQUFZRCxhQUExQyxJQUNBSCxNQUFNLENBQUNJLElBQVAsQ0FBWUQsYUFBWixLQUE4QkYsTUFBTSxDQUFDQyxJQUFQLENBQVlDLGFBRDFDLElBRUFGLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZQyxhQUFaLEtBQThCRixNQUFNLENBQUNHLElBQVAsQ0FBWUQsYUFINUM7QUFLRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBDaHVuayBmcm9tICcuL2NodW5rJ1xuZXhwb3J0IGZ1bmN0aW9uIGxvbmdUb051bWJlcihsb25nOiBMb25nKSB7XG4gIGlmIChsb25nLmdyZWF0ZXJUaGFuKE51bWJlci5NQVhfU0FGRV9JTlRFR0VSKSB8fCBsb25nLmxlc3NUaGFuKE51bWJlci5NSU5fU0FGRV9JTlRFR0VSKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignaW50ZWdlciBvdmVyZmxvdycpXG4gIH1cbiAgcmV0dXJuIGxvbmcudG9OdW1iZXIoKVxufVxuXG4vKipcbiAqIFByb3Blcmx5IGNoZWNrIGlmIHRoZSBnaXZlbiBBYm9ydFNpZ25hbCBpcyBhYm9ydGVkLlxuICogUGVyIHRoZSBzdGFuZGFyZCwgaWYgdGhlIHNpZ25hbCByZWFkcyBhcyBhYm9ydGVkLFxuICogdGhpcyBmdW5jdGlvbiB0aHJvd3MgZWl0aGVyIGEgRE9NRXhjZXB0aW9uIEFib3J0RXJyb3IsIG9yIGEgcmVndWxhciBlcnJvclxuICogd2l0aCBhIGBjb2RlYCBhdHRyaWJ1dGUgc2V0IHRvIGBFUlJfQUJPUlRFRGAuXG4gKlxuICogRm9yIGNvbnZlbmllbmNlLCBwYXNzaW5nIGB1bmRlZmluZWRgIGlzIGEgbm8tb3BcbiAqXG4gKiBAcGFyYW0ge0Fib3J0U2lnbmFsfSBbc2lnbmFsXSBhbiBBYm9ydFNpZ25hbCwgb3IgYW55dGhpbmcgd2l0aCBhbiBgYWJvcnRlZGAgYXR0cmlidXRlXG4gKiBAcmV0dXJucyBub3RoaW5nXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjaGVja0Fib3J0U2lnbmFsKHNpZ25hbD86IEFib3J0U2lnbmFsKSB7XG4gIGlmICghc2lnbmFsKSByZXR1cm5cblxuICBpZiAoc2lnbmFsLmFib3J0ZWQpIHtcbiAgICAvLyBjb25zb2xlLmxvZygnYmFtIGFib3J0ZWQhJylcbiAgICBpZiAodHlwZW9mIERPTUV4Y2VwdGlvbiAhPT0gJ3VuZGVmaW5lZCcpXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgIG5vLXVuZGVmXG4gICAgICB0aHJvdyBuZXcgRE9NRXhjZXB0aW9uKCdhYm9ydGVkJywgJ0Fib3J0RXJyb3InKVxuICAgIGVsc2Uge1xuICAgICAgY29uc3QgZSA9IG5ldyBFcnJvcignYWJvcnRlZCcpXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHMtaWdub3JlXG4gICAgICAvL0B0cy1pZ25vcmVcbiAgICAgIGUuY29kZSA9ICdFUlJfQUJPUlRFRCdcbiAgICAgIHRocm93IGVcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBTa2lwcyB0byB0aGUgbmV4dCB0aWNrLCB0aGVuIHJ1bnMgYGNoZWNrQWJvcnRTaWduYWxgLlxuICogQXdhaXQgdGhpcyB0byBpbnNpZGUgYW4gb3RoZXJ3aXNlIHN5bmNocm9ub3VzIGxvb3AgdG9cbiAqIHByb3ZpZGUgYSBwbGFjZSB0byBicmVhayB3aGVuIGFuIGFib3J0IHNpZ25hbCBpcyByZWNlaXZlZC5cbiAqIEBwYXJhbSB7QWJvcnRTaWduYWx9IHNpZ25hbFxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gYWJvcnRCcmVha1BvaW50KHNpZ25hbD86IEFib3J0U2lnbmFsKSB7XG4gIGF3YWl0IFByb21pc2UucmVzb2x2ZSgpXG4gIGNoZWNrQWJvcnRTaWduYWwoc2lnbmFsKVxufVxuXG5leHBvcnQgZnVuY3Rpb24gY2FuTWVyZ2VCbG9ja3MoYmxvY2sxOiBDaHVuaywgYmxvY2syOiBDaHVuaykge1xuICByZXR1cm4gKFxuICAgIGJsb2NrMS5taW52LmJsb2NrUG9zaXRpb24gPT09IGJsb2NrMS5tYXh2LmJsb2NrUG9zaXRpb24gJiZcbiAgICBibG9jazEubWF4di5ibG9ja1Bvc2l0aW9uID09PSBibG9jazIubWludi5ibG9ja1Bvc2l0aW9uICYmXG4gICAgYmxvY2syLm1pbnYuYmxvY2tQb3NpdGlvbiA9PT0gYmxvY2syLm1heHYuYmxvY2tQb3NpdGlvblxuICApXG59XG4iXX0=

@@ -1,40 +0,70 @@

"use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");Object.defineProperty(exports, "__esModule", { value: true });exports.fromBytes = fromBytes;exports.VirtualOffset = void 0;var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));var VirtualOffset = /*#__PURE__*/function () {
function VirtualOffset(blockPosition, dataPosition) {(0, _classCallCheck2.default)(this, VirtualOffset);
"use strict";
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
_Object$defineProperty(exports, "__esModule", {
value: true
});
exports.fromBytes = fromBytes;
exports.default = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
var VirtualOffset =
/*#__PURE__*/
function () {
function VirtualOffset(blockPosition, dataPosition) {
(0, _classCallCheck2.default)(this, VirtualOffset);
(0, _defineProperty2.default)(this, "blockPosition", void 0);
(0, _defineProperty2.default)(this, "dataPosition", void 0);
this.blockPosition = blockPosition; // < offset of the compressed data block
this.dataPosition = dataPosition; // < offset into the uncompressed data
}(0, _createClass2.default)(VirtualOffset, [{ key: "toString", value: function toString()
}
{
(0, _createClass2.default)(VirtualOffset, [{
key: "toString",
value: function toString() {
return "".concat(this.blockPosition, ":").concat(this.dataPosition);
} }, { key: "compareTo", value: function compareTo(
}
}, {
key: "compareTo",
value: function compareTo(b) {
return this.blockPosition - b.blockPosition || this.dataPosition - b.dataPosition;
}
}], [{
key: "min",
value: function min() {
var min;
var i = 0;
b) {
return (
this.blockPosition - b.blockPosition || this.dataPosition - b.dataPosition);
for (; !min; i += 1) {
min = i < 0 || arguments.length <= i ? undefined : arguments[i];
}
} }], [{ key: "min", value: function min()
{
var min;
var i = 0;
for (; !min; i += 1) {min = i < 0 || arguments.length <= i ? undefined : arguments[i];}
for (; i < arguments.length; i += 1) {
if (min.compareTo(i < 0 || arguments.length <= i ? undefined : arguments[i]) > 0) min = i < 0 || arguments.length <= i ? undefined : arguments[i];
}
return min;
} }]);return VirtualOffset;}();exports.VirtualOffset = VirtualOffset;
}
}]);
return VirtualOffset;
}();
function fromBytes(bytes) {var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;var bigendian = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
if (bigendian)
throw new Error('big-endian virtual file offsets not implemented');
exports.default = VirtualOffset;
return new VirtualOffset(
bytes[offset + 7] * 0x10000000000 +
bytes[offset + 6] * 0x100000000 +
bytes[offset + 5] * 0x1000000 +
bytes[offset + 4] * 0x10000 +
bytes[offset + 3] * 0x100 +
bytes[offset + 2],
bytes[offset + 1] << 8 | bytes[offset]);
}
function fromBytes(bytes) {
var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
var bigendian = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
if (bigendian) throw new Error('big-endian virtual file offsets not implemented');
return new VirtualOffset(bytes[offset + 7] * 0x10000000000 + bytes[offset + 6] * 0x100000000 + bytes[offset + 5] * 0x1000000 + bytes[offset + 4] * 0x10000 + bytes[offset + 3] * 0x100 + bytes[offset + 2], bytes[offset + 1] << 8 | bytes[offset]);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy92aXJ0dWFsT2Zmc2V0LnRzIl0sIm5hbWVzIjpbIlZpcnR1YWxPZmZzZXQiLCJibG9ja1Bvc2l0aW9uIiwiZGF0YVBvc2l0aW9uIiwiYiIsIm1pbiIsImkiLCJsZW5ndGgiLCJjb21wYXJlVG8iLCJmcm9tQnl0ZXMiLCJieXRlcyIsIm9mZnNldCIsImJpZ2VuZGlhbiIsIkVycm9yIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBQXFCQSxhOzs7QUFHbkIseUJBQVlDLGFBQVosRUFBbUNDLFlBQW5DLEVBQXlEO0FBQUE7QUFBQTtBQUFBO0FBQ3ZELFNBQUtELGFBQUwsR0FBcUJBLGFBQXJCLENBRHVELENBQ3BCOztBQUNuQyxTQUFLQyxZQUFMLEdBQW9CQSxZQUFwQixDQUZ1RCxDQUV0QjtBQUNsQzs7OzsrQkFFVTtBQUNULHVCQUFVLEtBQUtELGFBQWYsY0FBZ0MsS0FBS0MsWUFBckM7QUFDRDs7OzhCQUVTQyxDLEVBQWtCO0FBQzFCLGFBQU8sS0FBS0YsYUFBTCxHQUFxQkUsQ0FBQyxDQUFDRixhQUF2QixJQUF3QyxLQUFLQyxZQUFMLEdBQW9CQyxDQUFDLENBQUNELFlBQXJFO0FBQ0Q7OzswQkFFb0M7QUFDbkMsVUFBSUUsR0FBSjtBQUNBLFVBQUlDLENBQUMsR0FBRyxDQUFSOztBQUNBLGFBQU8sQ0FBQ0QsR0FBUixFQUFhQyxDQUFDLElBQUksQ0FBbEI7QUFBcUJELFFBQUFBLEdBQUcsR0FBUUMsQ0FBUiw0QkFBUUEsQ0FBUix5QkFBUUEsQ0FBUixDQUFIO0FBQXJCOztBQUNBLGFBQU9BLENBQUMsR0FBRyxVQUFLQyxNQUFoQixFQUF3QkQsQ0FBQyxJQUFJLENBQTdCLEVBQWdDO0FBQzlCLFlBQUlELEdBQUcsQ0FBQ0csU0FBSixDQUFtQkYsQ0FBbkIsNEJBQW1CQSxDQUFuQix5QkFBbUJBLENBQW5CLEtBQXlCLENBQTdCLEVBQWdDRCxHQUFHLEdBQVFDLENBQVIsNEJBQVFBLENBQVIseUJBQVFBLENBQVIsQ0FBSDtBQUNqQzs7QUFDRCxhQUFPRCxHQUFQO0FBQ0Q7Ozs7Ozs7QUFFSSxTQUFTSSxTQUFULENBQW1CQyxLQUFuQixFQUFpRTtBQUFBLE1BQS9CQyxNQUErQix1RUFBdEIsQ0FBc0I7QUFBQSxNQUFuQkMsU0FBbUIsdUVBQVAsS0FBTztBQUN0RSxNQUFJQSxTQUFKLEVBQWUsTUFBTSxJQUFJQyxLQUFKLENBQVUsaURBQVYsQ0FBTjtBQUVmLFNBQU8sSUFBSVosYUFBSixDQUNMUyxLQUFLLENBQUNDLE1BQU0sR0FBRyxDQUFWLENBQUwsR0FBb0IsYUFBcEIsR0FDRUQsS0FBSyxDQUFDQyxNQUFNLEdBQUcsQ0FBVixDQUFMLEdBQW9CLFdBRHRCLEdBRUVELEtBQUssQ0FBQ0MsTUFBTSxHQUFHLENBQVYsQ0FBTCxHQUFvQixTQUZ0QixHQUdFRCxLQUFLLENBQUNDLE1BQU0sR0FBRyxDQUFWLENBQUwsR0FBb0IsT0FIdEIsR0FJRUQsS0FBSyxDQUFDQyxNQUFNLEdBQUcsQ0FBVixDQUFMLEdBQW9CLEtBSnRCLEdBS0VELEtBQUssQ0FBQ0MsTUFBTSxHQUFHLENBQVYsQ0FORixFQU9KRCxLQUFLLENBQUNDLE1BQU0sR0FBRyxDQUFWLENBQUwsSUFBcUIsQ0FBdEIsR0FBMkJELEtBQUssQ0FBQ0MsTUFBRCxDQVAzQixDQUFQO0FBU0QiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZGVmYXVsdCBjbGFzcyBWaXJ0dWFsT2Zmc2V0IHtcbiAgcHVibGljIGJsb2NrUG9zaXRpb246IG51bWJlclxuICBwdWJsaWMgZGF0YVBvc2l0aW9uOiBudW1iZXJcbiAgY29uc3RydWN0b3IoYmxvY2tQb3NpdGlvbjogbnVtYmVyLCBkYXRhUG9zaXRpb246IG51bWJlcikge1xuICAgIHRoaXMuYmxvY2tQb3NpdGlvbiA9IGJsb2NrUG9zaXRpb24gLy8gPCBvZmZzZXQgb2YgdGhlIGNvbXByZXNzZWQgZGF0YSBibG9ja1xuICAgIHRoaXMuZGF0YVBvc2l0aW9uID0gZGF0YVBvc2l0aW9uIC8vIDwgb2Zmc2V0IGludG8gdGhlIHVuY29tcHJlc3NlZCBkYXRhXG4gIH1cblxuICB0b1N0cmluZygpIHtcbiAgICByZXR1cm4gYCR7dGhpcy5ibG9ja1Bvc2l0aW9ufToke3RoaXMuZGF0YVBvc2l0aW9ufWBcbiAgfVxuXG4gIGNvbXBhcmVUbyhiOiBWaXJ0dWFsT2Zmc2V0KSB7XG4gICAgcmV0dXJuIHRoaXMuYmxvY2tQb3NpdGlvbiAtIGIuYmxvY2tQb3NpdGlvbiB8fCB0aGlzLmRhdGFQb3NpdGlvbiAtIGIuZGF0YVBvc2l0aW9uXG4gIH1cblxuICBzdGF0aWMgbWluKC4uLmFyZ3M6IFZpcnR1YWxPZmZzZXRbXSkge1xuICAgIGxldCBtaW5cbiAgICBsZXQgaSA9IDBcbiAgICBmb3IgKDsgIW1pbjsgaSArPSAxKSBtaW4gPSBhcmdzW2ldXG4gICAgZm9yICg7IGkgPCBhcmdzLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgICBpZiAobWluLmNvbXBhcmVUbyhhcmdzW2ldKSA+IDApIG1pbiA9IGFyZ3NbaV1cbiAgICB9XG4gICAgcmV0dXJuIG1pblxuICB9XG59XG5leHBvcnQgZnVuY3Rpb24gZnJvbUJ5dGVzKGJ5dGVzOiBCdWZmZXIsIG9mZnNldCA9IDAsIGJpZ2VuZGlhbiA9IGZhbHNlKSB7XG4gIGlmIChiaWdlbmRpYW4pIHRocm93IG5ldyBFcnJvcignYmlnLWVuZGlhbiB2aXJ0dWFsIGZpbGUgb2Zmc2V0cyBub3QgaW1wbGVtZW50ZWQnKVxuXG4gIHJldHVybiBuZXcgVmlydHVhbE9mZnNldChcbiAgICBieXRlc1tvZmZzZXQgKyA3XSAqIDB4MTAwMDAwMDAwMDAgK1xuICAgICAgYnl0ZXNbb2Zmc2V0ICsgNl0gKiAweDEwMDAwMDAwMCArXG4gICAgICBieXRlc1tvZmZzZXQgKyA1XSAqIDB4MTAwMDAwMCArXG4gICAgICBieXRlc1tvZmZzZXQgKyA0XSAqIDB4MTAwMDAgK1xuICAgICAgYnl0ZXNbb2Zmc2V0ICsgM10gKiAweDEwMCArXG4gICAgICBieXRlc1tvZmZzZXQgKyAyXSxcbiAgICAoYnl0ZXNbb2Zmc2V0ICsgMV0gPDwgOCkgfCBieXRlc1tvZmZzZXRdLFxuICApXG59XG4iXX0=
{
"name": "@gmod/bam",
"version": "1.0.22",
"version": "1.0.24",
"description": "Parser for BAM and BAM index (bai) files",

@@ -22,6 +22,8 @@ "license": "MIT",

"coverage": "npm test -- --coverage",
"lint": "eslint src test",
"lint": "eslint --ext .js,.ts src test",
"clean": "rimraf dist",
"prebuild": "npm run clean && npm run lint",
"build": "babel src -d dist",
"build:types": "tsc --emitDeclarationOnly",
"build:js": "babel src --out-dir dist --extensions \".ts,.tsx\" --source-maps inline",
"build": "npm run build:types && npm run build:js",
"preversion": "npm run lint && npm test && npm run build",

@@ -41,3 +43,6 @@ "version": "standard-changelog && git add CHANGELOG.md",

"dependencies": {
"@babel/runtime": "^7.4.3",
"@babel/runtime-corejs2": "^7.5.5",
"@types/long": "^4.0.0",
"@types/node": "^12.7.8",
"@types/pako": "^1.0.1",
"abortable-promise-cache": "^1.0.1",

@@ -50,3 +55,3 @@ "cross-fetch": "^3.0.2",

"pako": "^1.0.10",
"quick-lru": "^2.0.0"
"quick-lru": "2"
},

@@ -56,4 +61,8 @@ "devDependencies": {

"@babel/core": "^7.3.3",
"@babel/plugin-proposal-class-properties": "^7.5.5",
"@babel/plugin-transform-runtime": "^7.2.0",
"@babel/preset-env": "^7.3.1",
"@babel/preset-typescript": "^7.6.0",
"@typescript-eslint/eslint-plugin": "^2.3.1",
"@typescript-eslint/parser": "^2.3.1",
"babel-jest": "^24.1.0",

@@ -64,2 +73,3 @@ "eslint": "^5.12.0",

"eslint-plugin-import": "^2.10.0",
"eslint-plugin-jest": "^22.17.0",
"eslint-plugin-prettier": "^3.0.1",

@@ -69,3 +79,4 @@ "jest": "^24.3.1",

"rimraf": "^2.6.2",
"standard-changelog": "^1.0.0"
"standard-changelog": "^1.0.0",
"typescript": "^3.6.3"
},

@@ -72,0 +83,0 @@ "publishConfig": {

@@ -56,7 +56,17 @@ [![Generated with nod](https://img.shields.io/badge/generator-nod-2196F3.svg?style=flat-square)](https://github.com/diegohaz/nod)

### async *streamRecordsForRange(refName, start, end, opts)
This is a async generator function that takes the same signature as getRecordsForRange but results can be processed using
for await(const chunk of file.streamRecordsForRange(refName, start, end, opts)) {
}
The getRecordsForRange simply wraps this process by concatenating chunks into an array
### async indexCov(refName, start, end)
* refName - a string for the chrom to fetch from
* start - a 0 based half open start coordinate (optional, will fetch whole chromosome without)
* end - a 0 based half open end coordinate (optional, will fetch whole chromosome without even if start is specified)
* start - a 0 based half open start coordinate (optional)
* end - a 0 based half open end coordinate (optional)

@@ -63,0 +73,0 @@ Returns features of the form {start, end, score} containing estimated feature density across 16kb windows in the genome

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc