@gmod/bam 1.1.8 → 1.1.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/README.md +2 -3
  3. package/dist/bai.d.ts +2 -0
  4. package/dist/bai.js +300 -548
  5. package/dist/bai.js.map +1 -0
  6. package/dist/bamFile.d.ts +4 -6
  7. package/dist/bamFile.js +675 -1203
  8. package/dist/bamFile.js.map +1 -0
  9. package/dist/chunk.js +34 -69
  10. package/dist/chunk.js.map +1 -0
  11. package/dist/constants.js +27 -35
  12. package/dist/constants.js.map +1 -0
  13. package/dist/csi.js +317 -515
  14. package/dist/csi.js.map +1 -0
  15. package/dist/errors.js +64 -120
  16. package/dist/errors.js.map +1 -0
  17. package/dist/htsget.js +275 -396
  18. package/dist/htsget.js.map +1 -0
  19. package/dist/index.js +16 -54
  20. package/dist/index.js.map +1 -0
  21. package/dist/indexFile.d.ts +1 -2
  22. package/dist/indexFile.js +77 -163
  23. package/dist/indexFile.js.map +1 -0
  24. package/dist/record.js +496 -707
  25. package/dist/record.js.map +1 -0
  26. package/dist/sam.js +16 -49
  27. package/dist/sam.js.map +1 -0
  28. package/dist/util.d.ts +0 -1
  29. package/dist/util.js +115 -126
  30. package/dist/util.js.map +1 -0
  31. package/dist/virtualOffset.js +44 -77
  32. package/dist/virtualOffset.js.map +1 -0
  33. package/esm/bai.d.ts +26 -0
  34. package/esm/bai.js +191 -0
  35. package/esm/bai.js.map +1 -0
  36. package/esm/bamFile.d.ts +77 -0
  37. package/esm/bamFile.js +388 -0
  38. package/esm/bamFile.js.map +1 -0
  39. package/esm/chunk.d.ts +18 -0
  40. package/esm/chunk.js +33 -0
  41. package/esm/chunk.js.map +1 -0
  42. package/esm/constants.d.ts +15 -0
  43. package/esm/constants.js +27 -0
  44. package/esm/constants.js.map +1 -0
  45. package/esm/csi.d.ts +35 -0
  46. package/esm/csi.js +209 -0
  47. package/esm/csi.js.map +1 -0
  48. package/esm/errors.d.ts +23 -0
  49. package/esm/errors.js +24 -0
  50. package/esm/errors.js.map +1 -0
  51. package/esm/htsget.d.ts +33 -0
  52. package/esm/htsget.js +100 -0
  53. package/esm/htsget.js.map +1 -0
  54. package/esm/index.d.ts +6 -0
  55. package/esm/index.js +7 -0
  56. package/esm/index.js.map +1 -0
  57. package/esm/indexFile.d.ts +27 -0
  58. package/esm/indexFile.js +27 -0
  59. package/esm/indexFile.js.map +1 -0
  60. package/esm/record.d.ts +88 -0
  61. package/esm/record.js +534 -0
  62. package/esm/record.js.map +1 -0
  63. package/esm/sam.d.ts +7 -0
  64. package/esm/sam.js +16 -0
  65. package/esm/sam.js.map +1 -0
  66. package/esm/util.d.ts +35 -0
  67. package/esm/util.js +92 -0
  68. package/esm/util.js.map +1 -0
  69. package/esm/virtualOffset.d.ts +10 -0
  70. package/esm/virtualOffset.js +37 -0
  71. package/esm/virtualOffset.js.map +1 -0
  72. package/package.json +21 -29
  73. package/dist/declare.d.js +0 -2
package/dist/htsget.js CHANGED
@@ -1,406 +1,285 @@
1
1
  "use strict";
2
-
3
- var _interopRequireWildcard = require("@babel/runtime-corejs3/helpers/interopRequireWildcard");
4
-
5
- var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
6
-
7
- var _Object$defineProperty2 = require("@babel/runtime-corejs3/core-js-stable/object/define-property");
8
-
9
- _Object$defineProperty2(exports, "__esModule", {
10
- value: true
2
+ var __extends = (this && this.__extends) || (function () {
3
+ var extendStatics = function (d, b) {
4
+ extendStatics = Object.setPrototypeOf ||
5
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
+ return extendStatics(d, b);
8
+ };
9
+ return function (d, b) {
10
+ if (typeof b !== "function" && b !== null)
11
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
+ extendStatics(d, b);
13
+ function __() { this.constructor = d; }
14
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
+ };
16
+ })();
17
+ var __assign = (this && this.__assign) || function () {
18
+ __assign = Object.assign || function(t) {
19
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
20
+ s = arguments[i];
21
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
22
+ t[p] = s[p];
23
+ }
24
+ return t;
25
+ };
26
+ return __assign.apply(this, arguments);
27
+ };
28
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
29
+ if (k2 === undefined) k2 = k;
30
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
31
+ }) : (function(o, m, k, k2) {
32
+ if (k2 === undefined) k2 = k;
33
+ o[k2] = m[k];
34
+ }));
35
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
36
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
37
+ }) : function(o, v) {
38
+ o["default"] = v;
11
39
  });
12
-
13
- exports.default = void 0;
14
-
15
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/objectWithoutProperties"));
16
-
17
- var _startsWith = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/starts-with"));
18
-
19
- var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
20
-
21
- var _promise = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/promise"));
22
-
23
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/define-property"));
24
-
25
- var _defineProperties = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/define-properties"));
26
-
27
- var _getOwnPropertyDescriptors = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors"));
28
-
29
- var _getOwnPropertyDescriptor = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor"));
30
-
31
- var _getOwnPropertySymbols = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols"));
32
-
33
- var _keys = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/object/keys"));
34
-
35
- var _construct = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/reflect/construct"));
36
-
37
- var _forEach = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/for-each"));
38
-
39
- var _filter = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/filter"));
40
-
41
- var _regenerator = _interopRequireDefault(require("@babel/runtime-corejs3/regenerator"));
42
-
43
- var _slice = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/slice"));
44
-
45
- var _concat2 = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat"));
46
-
47
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/classCallCheck"));
48
-
49
- var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/createClass"));
50
-
51
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/assertThisInitialized"));
52
-
53
- var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/inherits"));
54
-
55
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/possibleConstructorReturn"));
56
-
57
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/getPrototypeOf"));
58
-
59
- var _defineProperty3 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
60
-
61
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/asyncToGenerator"));
62
-
63
- var _wrapAsyncGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/wrapAsyncGenerator"));
64
-
65
- var _awaitAsyncGenerator2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/awaitAsyncGenerator"));
66
-
67
- var _asyncIterator2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/asyncIterator"));
68
-
69
- var _asyncGeneratorDelegate2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/asyncGeneratorDelegate"));
70
-
71
- var _bamFile = _interopRequireWildcard(require("./bamFile"));
72
-
40
+ var __importStar = (this && this.__importStar) || function (mod) {
41
+ if (mod && mod.__esModule) return mod;
42
+ var result = {};
43
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
44
+ __setModuleDefault(result, mod);
45
+ return result;
46
+ };
47
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
48
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
49
+ return new (P || (P = Promise))(function (resolve, reject) {
50
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
51
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
52
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
53
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
54
+ });
55
+ };
56
+ var __generator = (this && this.__generator) || function (thisArg, body) {
57
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
58
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
59
+ function verb(n) { return function (v) { return step([n, v]); }; }
60
+ function step(op) {
61
+ if (f) throw new TypeError("Generator is already executing.");
62
+ while (_) try {
63
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
64
+ if (y = 0, t) op = [op[0] & 2, t.value];
65
+ switch (op[0]) {
66
+ case 0: case 1: t = op; break;
67
+ case 4: _.label++; return { value: op[1], done: false };
68
+ case 5: _.label++; y = op[1]; op = [0]; continue;
69
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
70
+ default:
71
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
72
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
73
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
74
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
75
+ if (t[2]) _.ops.pop();
76
+ _.trys.pop(); continue;
77
+ }
78
+ op = body.call(thisArg, _);
79
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
80
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
81
+ }
82
+ };
83
+ var __rest = (this && this.__rest) || function (s, e) {
84
+ var t = {};
85
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
86
+ t[p] = s[p];
87
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
88
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
89
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
90
+ t[p[i]] = s[p[i]];
91
+ }
92
+ return t;
93
+ };
94
+ var __await = (this && this.__await) || function (v) { return this instanceof __await ? (this.v = v, this) : new __await(v); }
95
+ var __asyncValues = (this && this.__asyncValues) || function (o) {
96
+ if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
97
+ var m = o[Symbol.asyncIterator], i;
98
+ return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
99
+ function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
100
+ function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
101
+ };
102
+ var __asyncDelegator = (this && this.__asyncDelegator) || function (o) {
103
+ var i, p;
104
+ return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
105
+ function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; }
106
+ };
107
+ var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) {
108
+ if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
109
+ var g = generator.apply(thisArg, _arguments || []), i, q = [];
110
+ return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
111
+ function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
112
+ function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
113
+ function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
114
+ function fulfill(value) { resume("next", value); }
115
+ function reject(value) { resume("throw", value); }
116
+ function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
117
+ };
118
+ var __values = (this && this.__values) || function(o) {
119
+ var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
120
+ if (m) return m.call(o);
121
+ if (o && typeof o.length === "number") return {
122
+ next: function () {
123
+ if (o && i >= o.length) o = void 0;
124
+ return { value: o && o[i++], done: !o };
125
+ }
126
+ };
127
+ throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
128
+ };
129
+ Object.defineProperty(exports, "__esModule", { value: true });
130
+ var bamFile_1 = __importStar(require("./bamFile"));
73
131
  require("cross-fetch/polyfill");
74
-
75
- var _bgzfFilehandle = require("@gmod/bgzf-filehandle");
76
-
77
- var _sam = require("./sam");
78
-
79
- function ownKeys(object, enumerableOnly) { var keys = (0, _keys.default)(object); if (_getOwnPropertySymbols.default) { var symbols = (0, _getOwnPropertySymbols.default)(object); if (enumerableOnly) symbols = (0, _filter.default)(symbols).call(symbols, function (sym) { return (0, _getOwnPropertyDescriptor.default)(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
80
-
81
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context13; (0, _forEach.default)(_context13 = ownKeys(Object(source), true)).call(_context13, function (key) { (0, _defineProperty3.default)(target, key, source[key]); }); } else if (_getOwnPropertyDescriptors.default) { (0, _defineProperties.default)(target, (0, _getOwnPropertyDescriptors.default)(source)); } else { var _context14; (0, _forEach.default)(_context14 = ownKeys(Object(source))).call(_context14, function (key) { (0, _defineProperty2.default)(target, key, (0, _getOwnPropertyDescriptor.default)(source, key)); }); } } return target; }
82
-
83
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = (0, _construct.default)(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
84
-
85
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_construct.default) return false; if (_construct.default.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call((0, _construct.default)(Date, [], function () {})); return true; } catch (e) { return false; } }
86
-
87
- function concat(_x, _x2) {
88
- return _concat.apply(this, arguments);
132
+ var bgzf_filehandle_1 = require("@gmod/bgzf-filehandle");
133
+ var sam_1 = require("./sam");
134
+ function concat(arr, opts) {
135
+ return __awaiter(this, void 0, void 0, function () {
136
+ var res, _a, _b;
137
+ var _this = this;
138
+ return __generator(this, function (_c) {
139
+ switch (_c.label) {
140
+ case 0: return [4 /*yield*/, Promise.all(arr.map(function (chunk) { return __awaiter(_this, void 0, void 0, function () {
141
+ var url, headers, referer, rest, res_1, _a, _b;
142
+ return __generator(this, function (_c) {
143
+ switch (_c.label) {
144
+ case 0:
145
+ url = chunk.url, headers = chunk.headers;
146
+ if (!url.startsWith('data:')) return [3 /*break*/, 1];
147
+ return [2 /*return*/, Buffer.from(url.split(',')[1], 'base64')];
148
+ case 1:
149
+ referer = headers.referer, rest = __rest(headers, ["referer"]);
150
+ return [4 /*yield*/, fetch(url, __assign(__assign({}, opts), { headers: __assign(__assign({}, opts.headers), rest) }))];
151
+ case 2:
152
+ res_1 = _c.sent();
153
+ if (!res_1.ok) {
154
+ throw new Error("Failed to fetch ".concat(res_1.statusText));
155
+ }
156
+ _b = (_a = Buffer).from;
157
+ return [4 /*yield*/, res_1.arrayBuffer()];
158
+ case 3: return [2 /*return*/, _b.apply(_a, [_c.sent()])];
159
+ }
160
+ });
161
+ }); }))];
162
+ case 1:
163
+ res = _c.sent();
164
+ _b = (_a = Buffer).concat;
165
+ return [4 /*yield*/, Promise.all(res.map(function (elt) { return (0, bgzf_filehandle_1.unzip)(elt); }))];
166
+ case 2: return [2 /*return*/, _b.apply(_a, [_c.sent()])];
167
+ }
168
+ });
169
+ });
89
170
  }
90
-
91
- function _concat() {
92
- _concat = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(arr, opts) {
93
- var res;
94
- return _regenerator.default.wrap(function _callee5$(_context16) {
95
- while (1) {
96
- switch (_context16.prev = _context16.next) {
97
- case 0:
98
- _context16.next = 2;
99
- return _promise.default.all((0, _map.default)(arr).call(arr, /*#__PURE__*/function () {
100
- var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(chunk) {
101
- var url, headers, referer, rest, _res;
102
-
103
- return _regenerator.default.wrap(function _callee4$(_context15) {
104
- while (1) {
105
- switch (_context15.prev = _context15.next) {
106
- case 0:
107
- url = chunk.url, headers = chunk.headers;
108
-
109
- if (!(0, _startsWith.default)(url).call(url, 'data:')) {
110
- _context15.next = 5;
111
- break;
171
+ var HtsgetFile = /** @class */ (function (_super) {
172
+ __extends(HtsgetFile, _super);
173
+ function HtsgetFile(args) {
174
+ var _this =
175
+ // @ts-ignore override bam defaults
176
+ _super.call(this, { bamFilehandle: '?', baiFilehandle: '?' }) || this;
177
+ _this.baseUrl = args.baseUrl;
178
+ _this.trackId = args.trackId;
179
+ return _this;
180
+ }
181
+ HtsgetFile.prototype.streamRecordsForRange = function (chr, min, max, opts) {
182
+ if (opts === void 0) { opts = {
183
+ viewAsPairs: false,
184
+ pairAcrossChr: false,
185
+ maxInsertSize: 200000,
186
+ }; }
187
+ return __asyncGenerator(this, arguments, function streamRecordsForRange_1() {
188
+ var base, url, chrId, result, data, uncba, chunk;
189
+ return __generator(this, function (_a) {
190
+ switch (_a.label) {
191
+ case 0:
192
+ base = "".concat(this.baseUrl, "/").concat(this.trackId);
193
+ url = "".concat(base, "?referenceName=").concat(chr, "&start=").concat(min, "&end=").concat(max, "&format=BAM");
194
+ chrId = this.chrToIndex && this.chrToIndex[chr];
195
+ return [4 /*yield*/, __await(fetch(url, __assign({}, opts)))];
196
+ case 1:
197
+ result = _a.sent();
198
+ if (!result.ok) {
199
+ throw new Error(result.statusText);
112
200
  }
113
-
114
- return _context15.abrupt("return", Buffer.from(url.split(',')[1], 'base64'));
115
-
116
- case 5:
117
- //remove referer header, it is not even allowed to be specified
118
- //@ts-ignore
119
- //eslint-disable-next-line @typescript-eslint/no-unused-vars
120
- referer = headers.referer, rest = (0, _objectWithoutProperties2.default)(headers, ["referer"]);
121
- _context15.next = 8;
122
- return fetch(url, _objectSpread(_objectSpread({}, opts), {}, {
123
- headers: _objectSpread(_objectSpread({}, opts.headers), rest)
124
- }));
125
-
126
- case 8:
127
- _res = _context15.sent;
128
-
129
- if (_res.ok) {
130
- _context15.next = 11;
131
- break;
132
- }
133
-
134
- throw new Error("Failed to fetch ".concat(_res.statusText));
135
-
136
- case 11:
137
- _context15.t0 = Buffer;
138
- _context15.next = 14;
139
- return _res.arrayBuffer();
140
-
141
- case 14:
142
- _context15.t1 = _context15.sent;
143
- return _context15.abrupt("return", _context15.t0.from.call(_context15.t0, _context15.t1));
144
-
145
- case 16:
146
- case "end":
147
- return _context15.stop();
148
- }
149
- }
150
- }, _callee4);
151
- }));
152
-
153
- return function (_x4) {
154
- return _ref.apply(this, arguments);
155
- };
156
- }()));
157
-
158
- case 2:
159
- res = _context16.sent;
160
- _context16.t0 = (0, _concat2.default)(Buffer);
161
- _context16.t1 = Buffer;
162
- _context16.next = 7;
163
- return _promise.default.all((0, _map.default)(res).call(res, function (elt) {
164
- return (0, _bgzfFilehandle.unzip)(elt);
165
- }));
166
-
167
- case 7:
168
- _context16.t2 = _context16.sent;
169
- return _context16.abrupt("return", _context16.t0.call.call(_context16.t0, _context16.t1, _context16.t2));
170
-
171
- case 9:
172
- case "end":
173
- return _context16.stop();
174
- }
175
- }
176
- }, _callee5);
177
- }));
178
- return _concat.apply(this, arguments);
179
- }
180
-
181
- var HtsgetFile = /*#__PURE__*/function (_BamFile) {
182
- (0, _inherits2.default)(HtsgetFile, _BamFile);
183
-
184
- var _super = _createSuper(HtsgetFile);
185
-
186
- function HtsgetFile(args) {
187
- var _this2;
188
-
189
- (0, _classCallCheck2.default)(this, HtsgetFile);
190
- // @ts-ignore override bam defaults
191
- _this2 = _super.call(this, {
192
- bamFilehandle: '?',
193
- baiFilehandle: '?'
194
- });
195
- (0, _defineProperty3.default)((0, _assertThisInitialized2.default)(_this2), "baseUrl", void 0);
196
- (0, _defineProperty3.default)((0, _assertThisInitialized2.default)(_this2), "trackId", void 0);
197
- _this2.baseUrl = args.baseUrl;
198
- _this2.trackId = args.trackId;
199
- return _this2;
200
- }
201
-
202
- (0, _createClass2.default)(HtsgetFile, [{
203
- key: "streamRecordsForRange",
204
- value: function streamRecordsForRange(chr, min, max) {
205
- var _this = this;
206
-
207
- var opts = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {
208
- viewAsPairs: false,
209
- pairAcrossChr: false,
210
- maxInsertSize: 200000
211
- };
212
- return (0, _wrapAsyncGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
213
- var _context, _context2, _context3, _context4, _context5;
214
-
215
- var base, url, chrId, result, data, uncba, chunk;
216
- return _regenerator.default.wrap(function _callee$(_context8) {
217
- while (1) {
218
- switch (_context8.prev = _context8.next) {
219
- case 0:
220
- base = (0, _concat2.default)(_context = "".concat(_this.baseUrl, "/")).call(_context, _this.trackId);
221
- url = (0, _concat2.default)(_context2 = (0, _concat2.default)(_context3 = (0, _concat2.default)(_context4 = "".concat(base, "?referenceName=")).call(_context4, chr, "&start=")).call(_context3, min, "&end=")).call(_context2, max, "&format=BAM");
222
- chrId = _this.chrToIndex && _this.chrToIndex[chr];
223
- _context8.next = 5;
224
- return (0, _awaitAsyncGenerator2.default)(fetch(url, _objectSpread({}, opts)));
225
-
226
- case 5:
227
- result = _context8.sent;
228
-
229
- if (result.ok) {
230
- _context8.next = 8;
231
- break;
201
+ return [4 /*yield*/, __await(result.json())];
202
+ case 2:
203
+ data = _a.sent();
204
+ return [4 /*yield*/, __await(concat(data.htsget.urls.slice(1), opts))];
205
+ case 3:
206
+ uncba = _a.sent();
207
+ chunk = {
208
+ buffer: uncba,
209
+ chunk: { minv: { dataPosition: 0 } },
210
+ toString: function () {
211
+ return "".concat(chr, "_").concat(min, "_").concat(max);
212
+ },
213
+ };
214
+ return [5 /*yield**/, __values(__asyncDelegator(__asyncValues(this._fetchChunkFeatures(
215
+ // @ts-ignore
216
+ [chunk], chrId, min, max, opts))))];
217
+ case 4: return [4 /*yield*/, __await.apply(void 0, [_a.sent()])];
218
+ case 5:
219
+ _a.sent();
220
+ return [2 /*return*/];
232
221
  }
233
-
234
- throw new Error(result.statusText);
235
-
236
- case 8:
237
- _context8.next = 10;
238
- return (0, _awaitAsyncGenerator2.default)(result.json());
239
-
240
- case 10:
241
- data = _context8.sent;
242
- _context8.next = 13;
243
- return (0, _awaitAsyncGenerator2.default)(concat((0, _slice.default)(_context5 = data.htsget.urls).call(_context5, 1), opts));
244
-
245
- case 13:
246
- uncba = _context8.sent;
247
- chunk = {
248
- buffer: uncba,
249
- chunk: {
250
- minv: {
251
- dataPosition: 0
252
- }
253
- },
254
- toString: function toString() {
255
- var _context6, _context7;
256
-
257
- return (0, _concat2.default)(_context6 = (0, _concat2.default)(_context7 = "".concat(chr, "_")).call(_context7, min, "_")).call(_context6, max);
258
- }
259
- };
260
- return _context8.delegateYield((0, _asyncGeneratorDelegate2.default)((0, _asyncIterator2.default)(_this._fetchChunkFeatures( // @ts-ignore
261
- [chunk], chrId, min, max, opts)), _awaitAsyncGenerator2.default), "t0", 16);
262
-
263
- case 16:
264
- case "end":
265
- return _context8.stop();
266
- }
267
- }
268
- }, _callee);
269
- }))();
270
- } //@ts-ignore
271
-
272
- }, {
273
- key: "_readChunk",
274
- value: function () {
275
- var _readChunk2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(params) {
276
- var chunk, buffer, c2;
277
- return _regenerator.default.wrap(function _callee2$(_context9) {
278
- while (1) {
279
- switch (_context9.prev = _context9.next) {
280
- case 0:
222
+ });
223
+ });
224
+ };
225
+ //@ts-ignore
226
+ HtsgetFile.prototype._readChunk = function (params) {
227
+ return __awaiter(this, void 0, void 0, function () {
228
+ var chunk, buffer, c2;
229
+ return __generator(this, function (_a) {
281
230
  chunk = params.chunk;
282
231
  buffer = chunk.buffer, c2 = chunk.chunk;
283
- return _context9.abrupt("return", {
284
- data: buffer,
285
- cpositions: null,
286
- dpositions: null,
287
- chunk: c2
288
- });
289
-
290
- case 3:
291
- case "end":
292
- return _context9.stop();
293
- }
294
- }
295
- }, _callee2);
296
- }));
297
-
298
- function _readChunk(_x3) {
299
- return _readChunk2.apply(this, arguments);
300
- }
301
-
302
- return _readChunk;
303
- }()
304
- }, {
305
- key: "getHeader",
306
- value: function () {
307
- var _getHeader = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3() {
308
- var _context10;
309
-
310
- var opts,
311
- url,
312
- result,
313
- data,
314
- uncba,
315
- headLen,
316
- headerText,
317
- samHeader,
318
- idToName,
319
- nameToId,
320
- sqLines,
321
- _args3 = arguments;
322
- return _regenerator.default.wrap(function _callee3$(_context12) {
323
- while (1) {
324
- switch (_context12.prev = _context12.next) {
325
- case 0:
326
- opts = _args3.length > 0 && _args3[0] !== undefined ? _args3[0] : {};
327
- url = (0, _concat2.default)(_context10 = "".concat(this.baseUrl, "/")).call(_context10, this.trackId, "?referenceName=na&class=header");
328
- _context12.next = 4;
329
- return fetch(url, opts);
330
-
331
- case 4:
332
- result = _context12.sent;
333
-
334
- if (result.ok) {
335
- _context12.next = 7;
336
- break;
337
- }
338
-
339
- throw new Error("Failed to fetch ".concat(result.statusText));
340
-
341
- case 7:
342
- _context12.next = 9;
343
- return result.json();
344
-
345
- case 9:
346
- data = _context12.sent;
347
- _context12.next = 12;
348
- return concat(data.htsget.urls, opts);
349
-
350
- case 12:
351
- uncba = _context12.sent;
352
-
353
- if (!(uncba.readInt32LE(0) !== _bamFile.BAM_MAGIC)) {
354
- _context12.next = 15;
355
- break;
232
+ return [2 /*return*/, { data: buffer, cpositions: null, dpositions: null, chunk: c2 }];
233
+ });
234
+ });
235
+ };
236
+ HtsgetFile.prototype.getHeader = function (opts) {
237
+ if (opts === void 0) { opts = {}; }
238
+ return __awaiter(this, void 0, void 0, function () {
239
+ var url, result, data, uncba, headLen, headerText, samHeader, idToName, nameToId, sqLines;
240
+ return __generator(this, function (_a) {
241
+ switch (_a.label) {
242
+ case 0:
243
+ url = "".concat(this.baseUrl, "/").concat(this.trackId, "?referenceName=na&class=header");
244
+ return [4 /*yield*/, fetch(url, opts)];
245
+ case 1:
246
+ result = _a.sent();
247
+ if (!result.ok) {
248
+ throw new Error("Failed to fetch ".concat(result.statusText));
249
+ }
250
+ return [4 /*yield*/, result.json()];
251
+ case 2:
252
+ data = _a.sent();
253
+ return [4 /*yield*/, concat(data.htsget.urls, opts)];
254
+ case 3:
255
+ uncba = _a.sent();
256
+ if (uncba.readInt32LE(0) !== bamFile_1.BAM_MAGIC) {
257
+ throw new Error('Not a BAM file');
258
+ }
259
+ headLen = uncba.readInt32LE(4);
260
+ headerText = uncba.toString('utf8', 8, 8 + headLen);
261
+ samHeader = (0, sam_1.parseHeaderText)(headerText);
262
+ idToName = [];
263
+ nameToId = {};
264
+ sqLines = samHeader.filter(function (l) { return l.tag === 'SQ'; });
265
+ sqLines.forEach(function (sqLine, refId) {
266
+ sqLine.data.forEach(function (item) {
267
+ if (item.tag === 'SN') {
268
+ // this is the ref name
269
+ var refName = item.value;
270
+ nameToId[refName] = refId;
271
+ idToName[refId] = refName;
272
+ }
273
+ });
274
+ });
275
+ this.chrToIndex = nameToId;
276
+ this.indexToChr = idToName;
277
+ return [2 /*return*/, samHeader];
356
278
  }
357
-
358
- throw new Error('Not a BAM file');
359
-
360
- case 15:
361
- headLen = uncba.readInt32LE(4);
362
- headerText = uncba.toString('utf8', 8, 8 + headLen);
363
- samHeader = (0, _sam.parseHeaderText)(headerText); // use the @SQ lines in the header to figure out the
364
- // mapping between ref ref ID numbers and names
365
-
366
- idToName = [];
367
- nameToId = {};
368
- sqLines = (0, _filter.default)(samHeader).call(samHeader, function (l) {
369
- return l.tag === 'SQ';
370
- });
371
- (0, _forEach.default)(sqLines).call(sqLines, function (sqLine, refId) {
372
- var _context11;
373
-
374
- (0, _forEach.default)(_context11 = sqLine.data).call(_context11, function (item) {
375
- if (item.tag === 'SN') {
376
- // this is the ref name
377
- var refName = item.value;
378
- nameToId[refName] = refId;
379
- idToName[refId] = refName;
380
- }
381
- });
382
- });
383
- this.chrToIndex = nameToId;
384
- this.indexToChr = idToName;
385
- return _context12.abrupt("return", samHeader);
386
-
387
- case 25:
388
- case "end":
389
- return _context12.stop();
390
- }
391
- }
392
- }, _callee3, this);
393
- }));
394
-
395
- function getHeader() {
396
- return _getHeader.apply(this, arguments);
397
- }
398
-
399
- return getHeader;
400
- }()
401
- }]);
402
- return HtsgetFile;
403
- }(_bamFile.default);
404
-
279
+ });
280
+ });
281
+ };
282
+ return HtsgetFile;
283
+ }(bamFile_1.default));
405
284
  exports.default = HtsgetFile;
406
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9odHNnZXQudHMiXSwibmFtZXMiOlsiY29uY2F0IiwiYXJyIiwib3B0cyIsImFsbCIsImNodW5rIiwidXJsIiwiaGVhZGVycyIsIkJ1ZmZlciIsImZyb20iLCJzcGxpdCIsInJlZmVyZXIiLCJyZXN0IiwiZmV0Y2giLCJyZXMiLCJvayIsIkVycm9yIiwic3RhdHVzVGV4dCIsImFycmF5QnVmZmVyIiwiZWx0IiwiSHRzZ2V0RmlsZSIsImFyZ3MiLCJiYW1GaWxlaGFuZGxlIiwiYmFpRmlsZWhhbmRsZSIsImJhc2VVcmwiLCJ0cmFja0lkIiwiY2hyIiwibWluIiwibWF4Iiwidmlld0FzUGFpcnMiLCJwYWlyQWNyb3NzQ2hyIiwibWF4SW5zZXJ0U2l6ZSIsImJhc2UiLCJjaHJJZCIsImNoclRvSW5kZXgiLCJyZXN1bHQiLCJqc29uIiwiZGF0YSIsImh0c2dldCIsInVybHMiLCJ1bmNiYSIsImJ1ZmZlciIsIm1pbnYiLCJkYXRhUG9zaXRpb24iLCJ0b1N0cmluZyIsIl9mZXRjaENodW5rRmVhdHVyZXMiLCJwYXJhbXMiLCJjMiIsImNwb3NpdGlvbnMiLCJkcG9zaXRpb25zIiwicmVhZEludDMyTEUiLCJCQU1fTUFHSUMiLCJoZWFkTGVuIiwiaGVhZGVyVGV4dCIsInNhbUhlYWRlciIsImlkVG9OYW1lIiwibmFtZVRvSWQiLCJzcUxpbmVzIiwibCIsInRhZyIsInNxTGluZSIsInJlZklkIiwiaXRlbSIsInJlZk5hbWUiLCJ2YWx1ZSIsImluZGV4VG9DaHIiLCJCYW1GaWxlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQ0E7O0FBQ0E7O0FBRUE7O0FBQ0E7Ozs7Ozs7Ozs7U0FXZUEsTTs7Ozs7b0ZBQWYsa0JBQXNCQyxHQUF0QixFQUE4Q0MsSUFBOUM7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxtQkFDb0IsaUJBQVFDLEdB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LENBQUN2QixJQUFQLG1CQUFvQixVQUFDeUIsSUFBRCxFQUFzQjtBQUN4Qyx3QkFBSUEsSUFBSSxDQUFDSCxHQUFMLEtBQWEsSUFBakIsRUFBdUI7QUFDckI7QUFDQSwwQkFBTUksT0FBTyxHQUFHRCxJQUFJLENBQUNFLEtBQXJCO0FBQ0FSLHNCQUFBQSxRQUFRLENBQUNPLE9BQUQsQ0FBUixHQUFvQkYsS0FBcEI7QUFDQU4sc0JBQUFBLFFBQVEsQ0FBQ00sS0FBRCxDQUFSLEdBQWtCRSxPQUFsQjtBQUNEO0FBQ0YsbUJBUEQ7QUFRRCxpQkFUTSxDQUFQO0FBVUEscUJBQUs3QixVQUFMLEdBQWtCc0IsUUFBbEI7QUFDQSxxQkFBS1MsVUFBTCxHQUFrQlYsUUFBbEI7bURBQ09ELFM7Ozs7Ozs7Ozs7Ozs7Ozs7OztFQXRGNkJZLGdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZU9wdHMsIEJhbU9wdHMgfSBmcm9tICcuL3V0aWwnXG5pbXBvcnQgQmFtRmlsZSwgeyBCQU1fTUFHSUMgfSBmcm9tICcuL2JhbUZpbGUnXG5pbXBvcnQgJ2Nyb3NzLWZldGNoL3BvbHlmaWxsJ1xuaW1wb3J0IENodW5rIGZyb20gJy4vY2h1bmsnXG5pbXBvcnQgeyB1bnppcCB9IGZyb20gJ0BnbW9kL2JnemYtZmlsZWhhbmRsZSdcbmltcG9ydCB7IHBhcnNlSGVhZGVyVGV4dCB9IGZyb20gJy4vc2FtJ1xuXG5pbnRlcmZhY2UgSGVhZGVyTGluZSB7XG4gIHRhZzogc3RyaW5nXG4gIHZhbHVlOiBzdHJpbmdcbn1cblxuaW50ZXJmYWNlIEh0c2dldENodW5rIHtcbiAgdXJsOiBzdHJpbmdcbiAgaGVhZGVycz86IFJlY29yZDxzdHJpbmcsIHN0cmluZz5cbn1cbmFzeW5jIGZ1bmN0aW9uIGNvbmNhdChhcnI6IHsgdXJsOiBzdHJpbmcgfVtdLCBvcHRzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+KSB7XG4gIGNvbnN0IHJlcyA9IGF3YWl0IFByb21pc2UuYWxsKFxuICAgIGFyci5tYXAoYXN5bmMgKGNodW5rOiBIdHNnZXRDaHVuaykgPT4ge1xuICAgICAgY29uc3QgeyB1cmwsIGhlYWRlcnMgfSA9IGNodW5rXG4gICAgICBpZiAodXJsLnN0YXJ0c1dpdGgoJ2RhdGE6JykpIHtcbiAgICAgICAgcmV0dXJuIEJ1ZmZlci5mcm9tKHVybC5zcGxpdCgnLCcpWzFdLCAnYmFzZTY0JylcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIC8vcmVtb3ZlIHJlZmVyZXIgaGVhZGVyLCBpdCBpcyBub3QgZXZlbiBhbGxvd2VkIHRvIGJlIHNwZWNpZmllZFxuICAgICAgICAvL0B0cy1pZ25vcmVcbiAgICAgICAgLy9lc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVudXNlZC12YXJzXG4gICAgICAgIGNvbnN0IHsgcmVmZXJlciwgLi4ucmVzdCB9ID0gaGVhZGVyc1xuICAgICAgICBjb25zdCByZXMgPSBhd2FpdCBmZXRjaCh1cmwsIHsgLi4ub3B0cywgaGVhZGVyczogeyAuLi5vcHRzLmhlYWRlcnMsIC4uLnJlc3QgfSB9KVxuICAgICAgICBpZiAoIXJlcy5vaykge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgRmFpbGVkIHRvIGZldGNoICR7cmVzLnN0YXR1c1RleHR9YClcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gQnVmZmVyLmZyb20oYXdhaXQgcmVzLmFycmF5QnVmZmVyKCkpXG4gICAgICB9XG4gICAgfSksXG4gIClcblxuICByZXR1cm4gQnVmZmVyLmNvbmNhdChhd2FpdCBQcm9taXNlLmFsbChyZXMubWFwKGVsdCA9PiB1bnppcChlbHQpKSkpXG59XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEh0c2dldEZpbGUgZXh0ZW5kcyBCYW1GaWxlIHtcbiAgcHJpdmF0ZSBiYXNlVXJsOiBzdHJpbmdcblxuICBwcml2YXRlIHRyYWNrSWQ6IHN0cmluZ1xuXG4gIGNvbnN0cnVjdG9yKGFyZ3M6IHsgdHJhY2tJZDogc3RyaW5nOyBiYXNlVXJsOiBzdHJpbmcgfSkge1xuICAgIC8vIEB0cy1pZ25vcmUgb3ZlcnJpZGUgYmFtIGRlZmF1bHRzXG4gICAgc3VwZXIoeyBiYW1GaWxlaGFuZGxlOiAnPycsIGJhaUZpbGVoYW5kbGU6ICc/JyB9KVxuICAgIHRoaXMuYmFzZVVybCA9IGFyZ3MuYmFzZVVybFxuICAgIHRoaXMudHJhY2tJZCA9IGFyZ3MudHJhY2tJZFxuICB9XG5cbiAgYXN5bmMgKnN0cmVhbVJlY29yZHNGb3JSYW5nZShcbiAgICBjaHI6IHN0cmluZyxcbiAgICBtaW46IG51bWJlcixcbiAgICBtYXg6IG51bWJlcixcbiAgICBvcHRzOiBCYW1PcHRzID0geyB2aWV3QXNQYWlyczogZmFsc2UsIHBhaXJBY3Jvc3NDaHI6IGZhbHNlLCBtYXhJbnNlcnRTaXplOiAyMDAwMDAgfSxcbiAgKSB7XG4gICAgY29uc3QgYmFzZSA9IGAke3RoaXMuYmFzZVVybH0vJHt0aGlzLnRyYWNrSWR9YFxuICAgIGNvbnN0IHVybCA9IGAke2Jhc2V9P3JlZmVyZW5jZU5hbWU9JHtjaHJ9JnN0YXJ0PSR7bWlufSZlbmQ9JHttYXh9JmZvcm1hdD1CQU1gXG4gICAgY29uc3QgY2hySWQgPSB0aGlzLmNoclRvSW5kZXggJiYgdGhpcy5jaHJUb0luZGV4W2Nocl1cbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBmZXRjaCh1cmwsIHsgLi4ub3B0cyB9KVxuICAgIGlmICghcmVzdWx0Lm9rKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IocmVzdWx0LnN0YXR1c1RleHQpXG4gICAgfVxuICAgIGNvbnN0IGRhdGEgPSBhd2FpdCByZXN1bHQuanNvbigpXG4gICAgY29uc3QgdW5jYmEgPSBhd2FpdCBjb25jYXQoZGF0YS5odHNnZXQudXJscy5zbGljZSgxKSwgb3B0cylcbiAgICBjb25zdCBjaHVuayA9IHtcbiAgICAgIGJ1ZmZlcjogdW5jYmEsXG4gICAgICBjaHVuazogeyBtaW52OiB7IGRhdGFQb3NpdGlvbjogMCB9IH0sXG4gICAgICB0b1N0cmluZygpIHtcbiAgICAgICAgcmV0dXJuIGAke2Nocn1fJHttaW59XyR7bWF4fWBcbiAgICAgIH0sXG4gICAgfVxuXG4gICAgeWllbGQqIHRoaXMuX2ZldGNoQ2h1bmtGZWF0dXJlcyhcbiAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgIFtjaHVua10sXG4gICAgICBjaHJJZCxcbiAgICAgIG1pbixcbiAgICAgIG1heCxcbiAgICAgIG9wdHMsXG4gICAgKVxuICB9XG5cbiAgLy9AdHMtaWdub3JlXG4gIGFzeW5jIF9yZWFkQ2h1bmsocGFyYW1zOiB7IGNodW5rOiB7IGJ1ZmZlcjogQnVmZmVyOyBjaHVuazogQ2h1bmsgfTsgb3B0czogQmFzZU9wdHMgfSkge1xuICAgIGNvbnN0IHsgY2h1bmsgfSA9IHBhcmFtc1xuICAgIGNvbnN0IHsgYnVmZmVyLCBjaHVuazogYzIgfSA9IGNodW5rXG4gICAgcmV0dXJuIHsgZGF0YTogYnVmZmVyLCBjcG9zaXRpb25zOiBudWxsLCBkcG9zaXRpb25zOiBudWxsLCBjaHVuazogYzIgfVxuICB9XG5cbiAgYXN5bmMgZ2V0SGVhZGVyKG9wdHM6IEJhc2VPcHRzID0ge30pIHtcbiAgICBjb25zdCB1cmwgPSBgJHt0aGlzLmJhc2VVcmx9LyR7dGhpcy50cmFja0lkfT9yZWZlcmVuY2VOYW1lPW5hJmNsYXNzPWhlYWRlcmBcbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBmZXRjaCh1cmwsIG9wdHMpXG4gICAgaWYgKCFyZXN1bHQub2spIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgRmFpbGVkIHRvIGZldGNoICR7cmVzdWx0LnN0YXR1c1RleHR9YClcbiAgICB9XG4gICAgY29uc3QgZGF0YSA9IGF3YWl0IHJlc3VsdC5qc29uKClcbiAgICBjb25zdCB1bmNiYSA9IGF3YWl0IGNvbmNhdChkYXRhLmh0c2dldC51cmxzLCBvcHRzKVxuXG4gICAgaWYgKHVuY2JhLnJlYWRJbnQzMkxFKDApICE9PSBCQU1fTUFHSUMpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignTm90IGEgQkFNIGZpbGUnKVxuICAgIH1cbiAgICBjb25zdCBoZWFkTGVuID0gdW5jYmEucmVhZEludDMyTEUoNClcblxuICAgIGNvbnN0IGhlYWRlclRleHQgPSB1bmNiYS50b1N0cmluZygndXRmOCcsIDgsIDggKyBoZWFkTGVuKVxuICAgIGNvbnN0IHNhbUhlYWRlciA9IHBhcnNlSGVhZGVyVGV4dChoZWFkZXJUZXh0KVxuXG4gICAgLy8gdXNlIHRoZSBAU1EgbGluZXMgaW4gdGhlIGhlYWRlciB0byBmaWd1cmUgb3V0IHRoZVxuICAgIC8vIG1hcHBpbmcgYmV0d2VlbiByZWYgcmVmIElEIG51bWJlcnMgYW5kIG5hbWVzXG4gICAgY29uc3QgaWRUb05hbWU6IHN0cmluZ1tdID0gW11cbiAgICBjb25zdCBuYW1lVG9JZDogUmVjb3JkPHN0cmluZywgbnVtYmVyPiA9IHt9XG4gICAgY29uc3Qgc3FMaW5lcyA9IHNhbUhlYWRlci5maWx0ZXIoKGw6IHsgdGFnOiBzdHJpbmcgfSkgPT4gbC50YWcgPT09ICdTUScpXG4gICAgc3FMaW5lcy5mb3JFYWNoKChzcUxpbmU6IHsgZGF0YTogSGVhZGVyTGluZVtdIH0sIHJlZklkOiBudW1iZXIpID0+IHtcbiAgICAgIHNxTGluZS5kYXRhLmZvckVhY2goKGl0ZW06IEhlYWRlckxpbmUpID0+IHtcbiAgICAgICAgaWYgKGl0ZW0udGFnID09PSAnU04nKSB7XG4gICAgICAgICAgLy8gdGhpcyBpcyB0aGUgcmVmIG5hbWVcbiAgICAgICAgICBjb25zdCByZWZOYW1lID0gaXRlbS52YWx1ZVxuICAgICAgICAgIG5hbWVUb0lkW3JlZk5hbWVdID0gcmVmSWRcbiAgICAgICAgICBpZFRvTmFtZVtyZWZJZF0gPSByZWZOYW1lXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgfSlcbiAgICB0aGlzLmNoclRvSW5kZXggPSBuYW1lVG9JZFxuICAgIHRoaXMuaW5kZXhUb0NociA9IGlkVG9OYW1lXG4gICAgcmV0dXJuIHNhbUhlYWRlclxuICB9XG59XG4iXX0=
285
+ //# sourceMappingURL=htsget.js.map