Comparing version 1.0.22 to 1.0.24
@@ -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== |
481
dist/csi.js
@@ -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":";;;;;;;;;;;;;;;;;;;;;;AAGA;;AAHA;;AACA;;AACA;AAGA,IAAMA,cAAc,GAAG,mBAAmBC,KAAnB,CAAyB,EAAzB,CAAvB;AACA,IAAMC,aAAa,GAAG,mBAAmBD,KAAnB,CAAyB,EAAzB,CAAtB;AAEA;;;;IAGqBE,S;;;AASnB,qBAAYC,IAAZ,EAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sDAHkBC,SAGlB;AAAA,oDAFM,EAEN;AAAA,0DADE,KACF;AACrB,SAAKC,IAAL,GAAY,EAAZ;AACA,SAAKC,KAAL,GAAa;AACXC,MAAAA,KAAK,EAAEJ,IAAI,CAACG,KAAL,CAAWC,KADP;AAEXC,MAAAA,GAAG,EAAEL,IAAI,CAACG,KAAL,CAAWE,GAFL;AAGXC,MAAAA,SAAS,EAAEN,IAAI,CAACG,KAAL,CAAWG;AAHX,KAAb;AAKA,SAAKC,GAAL,GAAWP,IAAI,CAACQ,UAAhB;AAPqB,sBAQQ,KAAKL,KARb;AAAA,QAQbC,KARa,eAQbA,KARa;AAAA,QAQNE,SARM,eAQNA,SARM;AASrB,SAAKG,MAAL,GAAcH,SAAS,CAACI,WAAV,CAAsBN,KAAK,GAAG,CAA9B,CAAd;AACA,SAAKF,IAAL,CAAUE,KAAV,GAAkBE,SAAS,CAACI,WAAV,CAAsBN,KAAK,GAAG,CAA9B,CAAlB;AACA,SAAKO,KAAL,GAAa,CAACL,SAAS,CAACI,WAAV,CAAsBN,KAAK,GAAG,EAA9B,IAAoC,UAArC,KAAoD,EAAjE;AACD;;;;wBAEGQ,K,EAAe;AACjB,aAAO,KAAKC,IAAL,CAAUD,KAAK,CAACE,WAAN,EAAV,CAAP;AACD;;;0BAEK;AACJ,aAAO,KAAKD,IAAL,CAAU,OAAV,KAAsB,KAAKA,IAAL,CAAU,eAAV,KAA8B,KAAKA,IAAL,CAAU,YAAV,CAA9B,IAAyDZ,SAA/E,CAAP;AACD;;;6BAEQ;AACP,aAAO,KAAKQ,MAAZ;AACD,K,CAED;AACA;;;;yBACKG,K,EAAe;AAClB,UAAIA,KAAK,IAAI,KAAKV,IAAlB,EAAwB;AACtB,eAAO,KAAKA,IAAL,CAAUU,KAAV,CAAP;AACD,OAHiB,CAIlB;;;AACA,UAAI,KAAKA,KAAL,CAAJ,EAAiB;AACf;AACA,aAAKV,IAAL,CAAUU,KAAV,IAAmB,KAAKA,KAAL,GAAnB;AACD,OAHD,MAGO;AACL,aAAKV,IAAL,CAAUU,KAAV,IAAmB,KAAKG,SAAL,CAAeH,KAAf,CAAnB;AACD;;AACD,aAAO,KAAKV,IAAL,CAAUU,KAAV,CAAP;AACD;;;4BAEO;AAAA;;AACN,WAAKI,aAAL;;AAEA,UAAIC,IAAI,GAAG,CACT,KADS,EAET,0BAFS,EAGT,UAHS,EAIT,WAJS,EAKT,WALS,EAMT,qBANS,EAOT,yBAPS,CAAX;AAUA,UAAI,CAAC,KAAKC,iBAAL,EAAL,EACED,IAAI,CAACE,IAAL,CAAU,OAAV,EAAmB,KAAnB,EAA0B,QAA1B,EAAoC,OAApC,EAA6C,MAA7C,EAAqD,IAArD,EAA2D,OAA3D,EAAoE,eAApE,EAAqF,iBAArF;;AACF,UAAI,KAAKC,QAAL,EAAJ,EAAqB;AACnBH,QAAAA,IAAI,CAACE,IAAL,CACE,qCADF,EAEE,qCAFF,EAGE,qCAHF,EAIE,qBAJF,EAKE,oBALF,EAME,uBANF,EAOE,kBAPF;AASD;;AACDF,MAAAA,IAAI,GAAGA,IAAI,CAACI,MAAL,CAAY,KAAKC,QAAL,IAAiB,EAA7B,CAAP;AAEA,yBAAY,KAAKpB,IAAjB,EAAuBqB,OAAvB,CAA+B,UAAAC,CAAC,EAAI;AAClC,YAAIA,CAAC,CAAC,CAAD,CAAD,KAAS,GAAT,IAAgBA,CAAC,KAAK,2BAAtB,IAAqDA,CAAC,KAAK,aAA/D,EAA8EP,IAAI,CAACE,IAAL,CAAUK,CAAV;AAC/E,OAFD;AAIA,UAAMC,IAAgC,GAAG,EAAzC;AACAR,MAAAA,IAAI,GAAGA,IAAI,CAACS,MAAL,CAAY,UAAAC,CAAC,EAAI;AACtB,YAAIA,CAAC,IAAI,KAAI,CAACzB,IAAV,IAAkB,KAAI,CAACA,IAAL,CAAUyB,CAAV,MAAiB1B,SAAvC,EAAkD,OAAO,KAAP;AAElD,YAAM2B,EAAE,GAAGD,CAAC,CAACb,WAAF,EAAX;AACA,YAAMe,CAAC,GAAGJ,IAAI,CAACG,EAAD,CAAd;AACAH,QAAAA,IAAI,CAACG,EAAD,CAAJ,GAAW,IAAX;AACA,eAAO,CAACC,CAAR;AACD,OAPM,CAAP;AASA,aAAOZ,IAAP;AACD;;;6BAEQ;AACP,aAAOhB,SAAP;AACD;;;+BAEU;AACT,aAAO,KAAKY,IAAL,CAAU,aAAV,CAAP;AACD;;;yBAEI;AACH,aAAO,KAAKN,GAAZ;AACD;;;gDAE2B;AAC1B,aAAO,KAAKM,IAAL,CAAU,qCAAV,CAAP;AACD,K,CAED;;AACA;;;;;;yBAGK;AACH,UAAMiB,EAAE,GAAG,CAAC,KAAKjB,IAAL,CAAU,YAAV,IAA0B,MAA3B,KAAsC,CAAjD;AACA,aAAOiB,EAAE,KAAK,GAAP,GAAa7B,SAAb,GAAyB6B,EAAhC;AACD;;;4BAEO;AACN,aAAO,KAAKjB,IAAL,CAAU,IAAV,CAAP;AACD;;;2BAEM;AACL,UAAI,KAAKK,iBAAL,EAAJ,EAA8B,OAAOjB,SAAP;AAE9B,UAAM8B,IAAI,GAAG,EAAb;AAHK,UAIGzB,SAJH,GAIiB,KAAKH,KAJtB,CAIGG,SAJH;;AAKL,UAAM0B,CAAC,GAAG,KAAK7B,KAAL,CAAWC,KAAX,GAAmB,EAAnB,GAAwB,KAAKS,IAAL,CAAU,cAAV,CAAxB,GAAoD,KAAKA,IAAL,CAAU,aAAV,IAA2B,CAA/E,GAAmF,KAAKA,IAAL,CAAU,YAAV,CAA7F;;AACA,UAAMoB,IAAI,GAAG,KAAKpB,IAAL,CAAU,YAAV,CAAb;;AACA,WAAK,IAAIqB,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGD,IAApB,EAA0B,EAAEC,CAA5B,EAA+B;AAC7BH,QAAAA,IAAI,CAACZ,IAAL,CAAUb,SAAS,CAAC0B,CAAC,GAAGE,CAAL,CAAnB;AACD;;AACD,aAAOH,IAAI,CAACI,IAAL,CAAU,GAAV,CAAP;AACD;;;6BAEQ;AACP,aAAO,KAAKC,qBAAL,KAA+B,CAAC,CAAhC,GAAoC,CAA3C;AACD;;;wDAEmC;AAClC,UAAI,KAAKC,cAAL,EAAJ,EAA2B,OAAOpC,SAAP;AAC3B,aAAO,KAAKqC,yBAAL,KAAmC,CAAC,CAApC,GAAwC,CAA/C;AACD;;;2BAEM;AACL,aAAO,KAAKzB,IAAL,CAAU,YAAV,CAAP;AACD;;;iCAEY;AACX,UAAM0B,EAAE,GAAG,KAAK1B,IAAL,CAAU,cAAV,CAAX;;AACA,aAAO,KAAKV,KAAL,CAAWG,SAAX,CAAqBkC,QAArB,CAA8B,OAA9B,EAAuC,KAAKrC,KAAL,CAAWC,KAAX,GAAmB,EAA1D,EAA8D,KAAKD,KAAL,CAAWC,KAAX,GAAmB,EAAnB,GAAwBmC,EAAxB,GAA6B,CAA3F,CAAP;AACD;AAED;;;;;;;8BAIUE,O,EAAkB;AAC1B;AACA;AACA;AACA,UAAI,KAAKC,cAAT,EAAyB,OAAOzC,SAAP;AAJC,UAMlBK,SANkB,GAMJ,KAAKH,KAND,CAMlBG,SANkB;;AAO1B,UAAI0B,CAAC,GACH,KAAKW,UAAL,IACA,KAAKxC,KAAL,CAAWC,KAAX,GACE,EADF,GAEE,KAAKS,IAAL,CAAU,cAAV,CAFF,GAGE,KAAKA,IAAL,CAAU,aAAV,IAA2B,CAH7B,GAIE,KAAKA,IAAL,CAAU,YAAV,CAJF,GAKE,KAAKA,IAAL,CAAU,YAAV,CAPJ;;AASA,UAAM+B,QAAQ,GAAG,KAAKzC,KAAL,CAAWE,GAA5B;AACA,UAAIwC,KAAJ;;AACA,aAAOb,CAAC,GAAGY,QAAJ,IAAgBC,KAAK,KAAKJ,OAAjC,EAA0C;AACxC,YAAMK,GAAG,GAAGC,MAAM,CAACC,YAAP,CAAoB1C,SAAS,CAAC0B,CAAD,CAA7B,EAAkC1B,SAAS,CAAC0B,CAAC,GAAG,CAAL,CAA3C,CAAZ;AACAa,QAAAA,KAAK,GAAGC,GAAG,CAAChC,WAAJ,EAAR;AACA,YAAMmC,IAAI,GAAGF,MAAM,CAACC,YAAP,CAAoB1C,SAAS,CAAC0B,CAAC,GAAG,CAAL,CAA7B,CAAb;AACAA,QAAAA,CAAC,IAAI,CAAL;AAEA,YAAIkB,KAAK,SAAT;;AACA,gBAAQD,IAAI,CAACnC,WAAL,EAAR;AACE,eAAK,GAAL;AACEoC,YAAAA,KAAK,GAAGH,MAAM,CAACC,YAAP,CAAoB1C,SAAS,CAAC0B,CAAD,CAA7B,CAAR;AACAA,YAAAA,CAAC,IAAI,CAAL;AACA;;AACF,eAAK,GAAL;AACEkB,YAAAA,KAAK,GAAG5C,SAAS,CAACI,WAAV,CAAsBsB,CAAtB,CAAR;AACAA,YAAAA,CAAC,IAAI,CAAL;AACA;;AACF,eAAK,GAAL;AACEkB,YAAAA,KAAK,GAAG5C,SAAS,CAAC6C,QAAV,CAAmBnB,CAAnB,CAAR;AACAA,YAAAA,CAAC,IAAI,CAAL;AACA;;AACF,eAAK,GAAL;AACEkB,YAAAA,KAAK,GAAG5C,SAAS,CAAC8C,WAAV,CAAsBpB,CAAtB,CAAR;AACAA,YAAAA,CAAC,IAAI,CAAL;AACA;;AACF,eAAK,GAAL;AACEkB,YAAAA,KAAK,GAAG5C,SAAS,CAAC+C,WAAV,CAAsBrB,CAAtB,CAAR;AACAA,YAAAA,CAAC,IAAI,CAAL;AACA;;AACF,eAAK,GAAL;AACA,eAAK,GAAL;AACEkB,YAAAA,KAAK,GAAG,EAAR;;AACA,mBAAOlB,CAAC,IAAIY,QAAZ,EAAsB;AACpB,kBAAMU,EAAE,GAAGhD,SAAS,CAAC0B,CAAC,EAAF,CAApB;;AACA,kBAAIsB,EAAE,KAAK,CAAX,EAAc;AACZ;AACD,eAFD,MAEO;AACLJ,gBAAAA,KAAK,IAAIH,MAAM,CAACC,YAAP,CAAoBM,EAApB,CAAT;AACD;AACF;;AACD;;AACF,eAAK,GAAL;AAAU;AACRJ,cAAAA,KAAK,GAAG,EAAR;AACA,kBAAMI,GAAE,GAAGhD,SAAS,CAAC0B,CAAC,EAAF,CAApB;AACA,kBAAMuB,KAAK,GAAGR,MAAM,CAACC,YAAP,CAAoBM,GAApB,CAAd;;AACA,kBAAIC,KAAK,KAAK,GAAV,IAAiBA,KAAK,KAAK,GAA/B,EAAoC;AAClC,oBAAMC,KAAK,GAAGlD,SAAS,CAACI,WAAV,CAAsBsB,CAAtB,CAAd;AACAA,gBAAAA,CAAC,IAAI,CAAL;;AACA,qBAAK,IAAIR,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGgC,KAApB,EAA2BhC,CAAC,EAA5B,EAAgC;AAC9B0B,kBAAAA,KAAK,IAAI5C,SAAS,CAACI,WAAV,CAAsBsB,CAAtB,CAAT;AACA,sBAAIR,CAAC,GAAG,CAAJ,GAAQgC,KAAZ,EAAmBN,KAAK,IAAI,GAAT;AACnBlB,kBAAAA,CAAC,IAAI,CAAL;AACD;AACF;;AACD,kBAAIuB,KAAK,KAAK,GAAV,IAAiBA,KAAK,KAAK,GAA/B,EAAoC;AAClC,oBAAMC,MAAK,GAAGlD,SAAS,CAACI,WAAV,CAAsBsB,CAAtB,CAAd;;AACAA,gBAAAA,CAAC,IAAI,CAAL;;AACA,qBAAK,IAAIR,EAAC,GAAG,CAAb,EAAgBA,EAAC,GAAGgC,MAApB,EAA2BhC,EAAC,EAA5B,EAAgC;AAC9B0B,kBAAAA,KAAK,IAAI5C,SAAS,CAAC8C,WAAV,CAAsBpB,CAAtB,CAAT;AACA,sBAAIR,EAAC,GAAG,CAAJ,GAAQgC,MAAZ,EAAmBN,KAAK,IAAI,GAAT;AACnBlB,kBAAAA,CAAC,IAAI,CAAL;AACD;AACF;;AACD,kBAAIuB,KAAK,KAAK,GAAV,IAAiBA,KAAK,KAAK,GAA/B,EAAoC;AAClC,oBAAMC,OAAK,GAAGlD,SAAS,CAACI,WAAV,CAAsBsB,CAAtB,CAAd;;AACAA,gBAAAA,CAAC,IAAI,CAAL;;AACA,qBAAK,IAAIR,GAAC,GAAG,CAAb,EAAgBA,GAAC,GAAGgC,OAApB,EAA2BhC,GAAC,EAA5B,EAAgC;AAC9B0B,kBAAAA,KAAK,IAAI5C,SAAS,CAAC6C,QAAV,CAAmBnB,CAAnB,CAAT;AACA,sBAAIR,GAAC,GAAG,CAAJ,GAAQgC,OAAZ,EAAmBN,KAAK,IAAI,GAAT;AACnBlB,kBAAAA,CAAC,IAAI,CAAL;AACD;AACF;;AACD,kBAAIuB,KAAK,KAAK,GAAd,EAAmB;AACjB,oBAAMC,OAAK,GAAGlD,SAAS,CAACI,WAAV,CAAsBsB,CAAtB,CAAd;;AACAA,gBAAAA,CAAC,IAAI,CAAL;;AACA,qBAAK,IAAIR,GAAC,GAAG,CAAb,EAAgBA,GAAC,GAAGgC,OAApB,EAA2BhC,GAAC,EAA5B,EAAgC;AAC9B0B,kBAAAA,KAAK,IAAI5C,SAAS,CAAC+C,WAAV,CAAsBrB,CAAtB,CAAT;AACA,sBAAIR,GAAC,GAAG,CAAJ,GAAQgC,OAAZ,EAAmBN,KAAK,IAAI,GAAT;AACnBlB,kBAAAA,CAAC,IAAI,CAAL;AACD;AACF;;AACD;AACD;;AACD;AACEyB,YAAAA,OAAO,CAACC,IAAR,iCAAsCT,IAAtC;AACAC,YAAAA,KAAK,GAAGjD,SAAR;AACA+B,YAAAA,CAAC,GAAGY,QAAJ;AAAa;AA9EjB;;AAiFA,aAAKD,UAAL,GAAkBX,CAAlB;;AAEA,aAAKV,QAAL,CAAcH,IAAd,CAAmB2B,GAAnB;;AACA,YAAID,KAAK,KAAKJ,OAAd,EAAuB,OAAOS,KAAP;AAEvB,aAAKhD,IAAL,CAAU2C,KAAV,IAAmBK,KAAnB;AACD;;AACD,WAAKR,cAAL,GAAsB,IAAtB;AACA,aAAOzC,SAAP;AACD;;;oCAEe;AACd,WAAKc,SAAL;AACD;;;gCAEW4C,K,EAAe;AACzB;AACA,aAAOA,KAAK,CAACC,KAAN,CAAY,QAAZ,EAAsBC,GAAtB,CAA0B,UAACC,EAAD;AAAA,eAAgB,CAACA,EAAE,CAACF,KAAH,CAAS,IAAT,EAAe,CAAf,EAAkBG,WAAlB,EAAD,EAAkC,wBAASD,EAAT,EAAa,EAAb,CAAlC,CAAhB;AAAA,OAA1B,CAAP;AACD;AAED;;;;;;+BAGW;AACT,aAAO,CAAC,EAAE,KAAKnD,KAAL,GAAaqD,mBAAUC,WAAzB,CAAR;AACD;AAED;;;;uCACmB;AACjB,aAAO,CAAC,EAAE,KAAKtD,KAAL,GAAaqD,mBAAUE,gBAAzB,CAAR;AACD;AAED;;;;wCACoB;AAClB,aAAO,CAAC,EAAE,KAAKvD,KAAL,GAAaqD,mBAAUG,UAAzB,CAAR;AACD;AAED;;;;qCACiB;AACf,aAAO,CAAC,EAAE,KAAKxD,KAAL,GAAaqD,mBAAUI,WAAzB,CAAR;AACD;AAED;;;;4CACwB;AACtB,aAAO,CAAC,EAAE,KAAKzD,KAAL,GAAaqD,mBAAUK,YAAzB,CAAR;AACD;AAED;;;;gDAC4B;AAC1B,aAAO,CAAC,EAAE,KAAK1D,KAAL,GAAaqD,mBAAUM,aAAzB,CAAR;AACD;AAED;;;;8BACU;AACR,aAAO,CAAC,EAAE,KAAK3D,KAAL,GAAaqD,mBAAUO,UAAzB,CAAR;AACD;AAED;;;;8BACU;AACR,aAAO,CAAC,EAAE,KAAK5D,KAAL,GAAaqD,mBAAUQ,UAAzB,CAAR;AACD;AAED;;;;kCACc;AACZ,aAAO,CAAC,EAAE,KAAK7D,KAAL,GAAaqD,mBAAUS,cAAzB,CAAR;AACD;AAED;;;;iCACa;AACX,aAAO,CAAC,EAAE,KAAK9D,KAAL,GAAaqD,mBAAUU,WAAzB,CAAR;AACD;AAED;;;;kCACc;AACZ,aAAO,CAAC,EAAE,KAAK/D,KAAL,GAAaqD,mBAAUW,QAAzB,CAAR;AACD;AAED;;;;sCACkB;AAChB,aAAO,CAAC,EAAE,KAAKhE,KAAL,GAAaqD,mBAAUY,kBAAzB,CAAR;AACD;;;4BAEO;AACN,UAAI,KAAK1D,iBAAL,EAAJ,EAA8B,OAAOjB,SAAP;AADxB,yBAGuB,KAAKE,KAH5B;AAAA,UAGEG,SAHF,gBAGEA,SAHF;AAAA,UAGaF,KAHb,gBAGaA,KAHb;;AAIN,UAAMyE,WAAW,GAAG,KAAKhE,IAAL,CAAU,aAAV,CAApB;;AACA,UAAImB,CAAC,GAAG5B,KAAK,GAAG,EAAR,GAAa,KAAKS,IAAL,CAAU,cAAV,CAArB;;AACA,UAAI8C,KAAK,GAAG,EAAZ;AACA,UAAImB,IAAI,GAAG,CAAX;;AACA,WAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGF,WAApB,EAAiC,EAAEE,CAAnC,EAAsC;AACpC,YAAMC,KAAK,GAAG1E,SAAS,CAACI,WAAV,CAAsBsB,CAAtB,CAAd;AACA,YAAMiD,GAAG,GAAGD,KAAK,IAAI,CAArB;AACA,YAAMlB,EAAE,GAAGhE,aAAa,CAACkF,KAAK,GAAG,GAAT,CAAxB;AACArB,QAAAA,KAAK,IAAIsB,GAAG,GAAGnB,EAAf,CAJoC,CAMpC;AACA;;AACA,YAAIA,EAAE,KAAK,GAAP,IAAcA,EAAE,KAAK,GAArB,IAA4BA,EAAE,KAAK,GAAvC,EAA4CgB,IAAI,IAAIG,GAAR;AAE5CjD,QAAAA,CAAC,IAAI,CAAL;AACD;;AAED,WAAK9B,IAAL,CAAUgF,aAAV,GAA0BJ,IAA1B;AACA,aAAOnB,KAAP;AACD;;;6BAEQ,CAAE;;;oCAEK;AACd,WAAK9C,IAAL,CAAU,OAAV,EADc,CACK;AACnB;;;AACA,aAAO,KAAKX,IAAL,CAAUgF,aAAjB;AACD;;;kCAEa;AACZ,aAAO,KAAKrE,IAAL,CAAU,UAAV,IAAwB,MAA/B;AACD;;;mCAEc;AACb,aAAO,KAAKA,IAAL,CAAU,YAAV,IAA0B,IAAjC;AACD;AAED;;;;;;iCAGa;AACX,aAAQ,KAAKA,IAAL,CAAU,YAAV,IAA0B,CAA3B,IAAiC,CAAxC;AACD;;;mCAEc;AACb,UAAIsE,GAAG,GAAG,EAAV;AADa,UAEL7E,SAFK,GAES,KAAKH,KAFd,CAELG,SAFK;AAGb,UAAM0B,CAAC,GAAG,KAAK7B,KAAL,CAAWC,KAAX,GAAmB,EAAnB,GAAwB,KAAKS,IAAL,CAAU,cAAV,CAAxB,GAAoD,KAAKA,IAAL,CAAU,aAAV,IAA2B,CAAzF;;AACA,UAAMuE,QAAQ,GAAG,KAAKvE,IAAL,CAAU,YAAV,CAAjB;;AACA,WAAK,IAAIqB,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGkD,QAApB,EAA8B,EAAElD,CAAhC,EAAmC;AACjC,YAAMmD,EAAE,GAAG/E,SAAS,CAAC0B,CAAC,GAAGE,CAAL,CAApB;AACAiD,QAAAA,GAAG,IAAIvF,cAAc,CAAC,CAACyF,EAAE,GAAG,IAAN,KAAe,CAAhB,CAArB;AACA,YAAIF,GAAG,CAACG,MAAJ,GAAa,KAAKC,GAAL,CAAS,YAAT,CAAjB,EAAyCJ,GAAG,IAAIvF,cAAc,CAACyF,EAAE,GAAG,IAAN,CAArB;AAC1C;;AACD,aAAOF,GAAP;AACD,K,CAED;;;;yCACqB;AACnB,UAAI,CAAC,KAAKjE,iBAAL,EAAD,IAA6B,CAAC,KAAKmB,cAAL,EAA9B,IAAuD,KAAK5B,MAAL,KAAgB,KAAK+E,WAAL,EAA3E,EAA+F;AAC7F,YAAMC,EAAE,GAAG,KAAKrD,qBAAL,KAA+B,GAA/B,GAAqC,GAAhD;AACA,YAAMsD,EAAE,GAAG,KAAKpD,yBAAL,KAAmC,GAAnC,GAAyC,GAApD;AACA,YAAIqD,EAAE,GAAG,GAAT;AACA,YAAIC,EAAE,GAAG,GAAT;;AACA,YAAI,KAAKC,OAAL,EAAJ,EAAoB;AAClBF,UAAAA,EAAE,GAAG,GAAL;AACAC,UAAAA,EAAE,GAAG,GAAL;AACD,SAHD,MAGO,IAAI,KAAKE,OAAL,EAAJ,EAAoB;AACzBH,UAAAA,EAAE,GAAG,GAAL;AACAC,UAAAA,EAAE,GAAG,GAAL;AACD;;AAED,YAAMG,GAAG,GAAG,EAAZ;AACA,YAAMC,KAAK,GAAG,KAAKC,eAAL,EAAd;;AACA,YAAID,KAAK,GAAG,CAAZ,EAAe;AACbD,UAAAA,GAAG,CAAC,CAAD,CAAH,GAASN,EAAT;AACAM,UAAAA,GAAG,CAAC,CAAD,CAAH,GAASJ,EAAT;AACAI,UAAAA,GAAG,CAAC,CAAD,CAAH,GAASL,EAAT;AACAK,UAAAA,GAAG,CAAC,CAAD,CAAH,GAASH,EAAT;AACD,SALD,MAKO;AACLG,UAAAA,GAAG,CAAC,CAAD,CAAH,GAASN,EAAT;AACAM,UAAAA,GAAG,CAAC,CAAD,CAAH,GAASJ,EAAT;AACAI,UAAAA,GAAG,CAAC,CAAD,CAAH,GAASL,EAAT;AACAK,UAAAA,GAAG,CAAC,CAAD,CAAH,GAASH,EAAT;AACD;;AACD,eAAOG,GAAG,CAAC5D,IAAJ,CAAS,EAAT,CAAP;AACD;;AACD,aAAO,IAAP;AACD;;;iCAEY;AACX,aAAO,KAAKhC,KAAL,CAAWG,SAAX,CAAqBI,WAArB,CAAiC,KAAKP,KAAL,CAAWC,KAAX,GAAmB,EAApD,CAAP;AACD;;;+BAEU;AACT,aAAO,KAAKD,KAAL,CAAWG,SAAX,CAAqBI,WAArB,CAAiC,KAAKP,KAAL,CAAWC,KAAX,GAAmB,EAApD,CAAP;AACD;;;iCAEY;AACX,aAAO,KAAKD,KAAL,CAAWG,SAAX,CAAqBI,WAArB,CAAiC,KAAKP,KAAL,CAAWC,KAAX,GAAmB,EAApD,CAAP;AACD;;;kCAEa;AACZ,aAAO,KAAKD,KAAL,CAAWG,SAAX,CAAqBI,WAArB,CAAiC,KAAKP,KAAL,CAAWC,KAAX,GAAmB,EAApD,CAAP;AACD;;;gCAEW;AACV,aAAO,KAAKD,KAAL,CAAWG,SAAX,CAAqBI,WAArB,CAAiC,KAAKP,KAAL,CAAWC,KAAX,GAAmB,EAApD,CAAP;AACD;;;sCAEiB;AAChB,aAAO,KAAKD,KAAL,CAAWG,SAAX,CAAqBI,WAArB,CAAiC,KAAKP,KAAL,CAAWC,KAAX,GAAmB,EAApD,CAAP;AACD;;;6BAEQ;AAAA;;AACP,UAAMF,IAA4B,GAAG,EAArC;AACA,yBAAY,IAAZ,EAAkBqB,OAAlB,CAA0B,UAAAC,CAAC,EAAI;AAC7B,YAAIA,CAAC,CAAC0E,MAAF,CAAS,CAAT,MAAgB,GAAhB,IAAuB1E,CAAC,KAAK,OAAjC,EAA0C,OADb,CAE7B;;AACAtB,QAAAA,IAAI,CAACsB,CAAD,CAAJ,GAAU,MAAI,CAACA,CAAD,CAAd;AACD,OAJD;AAMA,aAAOtB,IAAP;AACD","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= |
119
dist/util.js
@@ -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 @@ [](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
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
Minified code
QualityThis package contains minified code. This may be harmless in some cases where minified code is included in packaged libraries, however packages on npm should not minify code.
Found 1 instance in 1 package
282028
31
3103
1
135
12
20
1
+ Added@types/long@^4.0.0
+ Added@types/node@^12.7.8
+ Added@types/pako@^1.0.1
+ Added@babel/runtime-corejs2@7.26.9(transitive)
+ Added@types/long@4.0.2(transitive)
+ Added@types/node@12.20.55(transitive)
+ Added@types/pako@1.0.7(transitive)
+ Addedcore-js@2.6.12(transitive)
- Removed@babel/runtime@^7.4.3
- Removed@babel/runtime@7.26.9(transitive)
Updatedquick-lru@2