@gmod/bbi 1.0.30 → 1.0.31

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,42 +1,7 @@
1
1
  "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- Object.defineProperty(exports, "BigWig", {
7
- enumerable: true,
8
- get: function get() {
9
- return _bigwig.BigWig;
10
- }
11
- });
12
- Object.defineProperty(exports, "BigBed", {
13
- enumerable: true,
14
- get: function get() {
15
- return _bigbed.BigBed;
16
- }
17
- });
18
- Object.defineProperty(exports, "Feature", {
19
- enumerable: true,
20
- get: function get() {
21
- return _bbi.Feature;
22
- }
23
- });
24
- Object.defineProperty(exports, "Header", {
25
- enumerable: true,
26
- get: function get() {
27
- return _bbi.Header;
28
- }
29
- });
30
- Object.defineProperty(exports, "RequestOptions", {
31
- enumerable: true,
32
- get: function get() {
33
- return _bbi.RequestOptions;
34
- }
35
- });
36
-
37
- var _bigwig = require("./bigwig");
38
-
39
- var _bigbed = require("./bigbed");
40
-
41
- var _bbi = require("./bbi");
42
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEJpZ1dpZyB9IGZyb20gJy4vYmlnd2lnJ1xuZXhwb3J0IHsgQmlnQmVkIH0gZnJvbSAnLi9iaWdiZWQnXG5leHBvcnQgeyBGZWF0dXJlLCBIZWFkZXIsIFJlcXVlc3RPcHRpb25zIH0gZnJvbSAnLi9iYmknXG4iXX0=
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BigBed = exports.BigWig = void 0;
4
+ var bigwig_1 = require("./bigwig");
5
+ Object.defineProperty(exports, "BigWig", { enumerable: true, get: function () { return bigwig_1.BigWig; } });
6
+ var bigbed_1 = require("./bigbed");
7
+ Object.defineProperty(exports, "BigBed", { enumerable: true, get: function () { return bigbed_1.BigBed; } });
package/dist/range.js CHANGED
@@ -1,188 +1,127 @@
1
1
  "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.default = void 0;
9
-
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
-
16
2
  /* eslint prefer-rest-params:0, no-nested-ternary:0 */
17
-
3
+ Object.defineProperty(exports, "__esModule", { value: true });
18
4
  /**
19
5
  * Adapted from a combination of Range and _Compound in the
20
6
  * Dalliance Genome Explorer, (c) Thomas Down 2006-2010.
21
7
  */
22
- var Range = /*#__PURE__*/function () {
23
- function Range(arg1, arg2) {
24
- (0, _classCallCheck2.default)(this, Range);
25
- (0, _defineProperty2.default)(this, "ranges", void 0);
26
- this.ranges = arguments.length === 2 ? [{
27
- min: arg1,
28
- max: arg2
29
- }] : 0 in arg1 ? Object.assign({}, arg1) : [arg1];
30
- }
31
-
32
- (0, _createClass2.default)(Range, [{
33
- key: "min",
34
- value: function min() {
35
- return this.ranges[0].min;
8
+ var Range = /** @class */ (function () {
9
+ function Range(arg1, arg2) {
10
+ this.ranges =
11
+ arguments.length === 2
12
+ ? [{ min: arg1, max: arg2 }]
13
+ : 0 in arg1
14
+ ? Object.assign({}, arg1)
15
+ : [arg1];
36
16
  }
37
- }, {
38
- key: "max",
39
- value: function max() {
40
- return this.ranges[this.ranges.length - 1].max;
41
- }
42
- }, {
43
- key: "contains",
44
- value: function contains(pos) {
45
- for (var s = 0; s < this.ranges.length; s += 1) {
46
- var r = this.ranges[s];
47
-
48
- if (r.min <= pos && r.max >= pos) {
49
- return true;
17
+ Range.prototype.min = function () {
18
+ return this.ranges[0].min;
19
+ };
20
+ Range.prototype.max = function () {
21
+ return this.ranges[this.ranges.length - 1].max;
22
+ };
23
+ Range.prototype.contains = function (pos) {
24
+ for (var s = 0; s < this.ranges.length; s += 1) {
25
+ var r = this.ranges[s];
26
+ if (r.min <= pos && r.max >= pos) {
27
+ return true;
28
+ }
50
29
  }
51
- }
52
-
53
- return false;
54
- }
55
- }, {
56
- key: "isContiguous",
57
- value: function isContiguous() {
58
- return this.ranges.length > 1;
59
- }
60
- }, {
61
- key: "getRanges",
62
- value: function getRanges() {
63
- return this.ranges.map(function (r) {
64
- return new Range(r.min, r.max);
65
- });
66
- }
67
- }, {
68
- key: "toString",
69
- value: function toString() {
70
- return this.ranges.map(function (r) {
71
- return "[".concat(r.min, "-").concat(r.max, "]");
72
- }).join(',');
73
- }
74
- }, {
75
- key: "union",
76
- value: function union(s1) {
77
- var ranges = this.getRanges().concat(s1.getRanges()).sort(this.rangeOrder);
78
- var oranges = [];
79
- var current = ranges[0];
80
-
81
- for (var i = 1; i < ranges.length; i += 1) {
82
- var nxt = ranges[i];
83
-
84
- if (nxt.min() > current.max() + 1) {
85
- oranges.push(current);
86
- current = nxt;
87
- } else if (nxt.max() > current.max()) {
88
- current = new Range(current.min(), nxt.max());
30
+ return false;
31
+ };
32
+ Range.prototype.isContiguous = function () {
33
+ return this.ranges.length > 1;
34
+ };
35
+ Range.prototype.getRanges = function () {
36
+ return this.ranges.map(function (r) { return new Range(r.min, r.max); });
37
+ };
38
+ Range.prototype.toString = function () {
39
+ return this.ranges.map(function (r) { return "[".concat(r.min, "-").concat(r.max, "]"); }).join(',');
40
+ };
41
+ Range.prototype.union = function (s1) {
42
+ var ranges = this.getRanges().concat(s1.getRanges()).sort(this.rangeOrder);
43
+ var oranges = [];
44
+ var current = ranges[0];
45
+ for (var i = 1; i < ranges.length; i += 1) {
46
+ var nxt = ranges[i];
47
+ if (nxt.min() > current.max() + 1) {
48
+ oranges.push(current);
49
+ current = nxt;
50
+ }
51
+ else if (nxt.max() > current.max()) {
52
+ current = new Range(current.min(), nxt.max());
53
+ }
89
54
  }
90
- }
91
-
92
- oranges.push(current);
93
-
94
- if (oranges.length === 1) {
95
- return oranges[0];
96
- }
97
-
98
- return new Range(oranges);
99
- }
100
- }, {
101
- key: "intersection",
102
- value: function intersection(arg) {
103
- // eslint-disable-next-line @typescript-eslint/no-this-alias
104
- var s0 = this;
105
- var s1 = arg;
106
- var r0 = this.ranges();
107
- var r1 = s1.ranges();
108
- var l0 = r0.length;
109
- var l1 = r1.length;
110
- var i0 = 0;
111
- var i1 = 0;
112
- var or = [];
113
-
114
- while (i0 < l0 && i1 < l1) {
115
- s0 = r0[i0];
116
- s1 = r1[i1];
117
- var lapMin = Math.max(s0.min(), s1.min());
118
- var lapMax = Math.min(s0.max(), s1.max());
119
-
120
- if (lapMax >= lapMin) {
121
- or.push(new Range(lapMin, lapMax));
55
+ oranges.push(current);
56
+ if (oranges.length === 1) {
57
+ return oranges[0];
122
58
  }
123
-
124
- if (s0.max() > s1.max()) {
125
- i1 += 1;
126
- } else {
127
- i0 += 1;
59
+ return new Range(oranges);
60
+ };
61
+ Range.prototype.intersection = function (arg) {
62
+ // eslint-disable-next-line @typescript-eslint/no-this-alias
63
+ var s0 = this;
64
+ var s1 = arg;
65
+ var r0 = this.ranges();
66
+ var r1 = s1.ranges();
67
+ var l0 = r0.length;
68
+ var l1 = r1.length;
69
+ var i0 = 0;
70
+ var i1 = 0;
71
+ var or = [];
72
+ while (i0 < l0 && i1 < l1) {
73
+ s0 = r0[i0];
74
+ s1 = r1[i1];
75
+ var lapMin = Math.max(s0.min(), s1.min());
76
+ var lapMax = Math.min(s0.max(), s1.max());
77
+ if (lapMax >= lapMin) {
78
+ or.push(new Range(lapMin, lapMax));
79
+ }
80
+ if (s0.max() > s1.max()) {
81
+ i1 += 1;
82
+ }
83
+ else {
84
+ i0 += 1;
85
+ }
128
86
  }
129
- }
130
-
131
- if (or.length === 0) {
132
- throw new Error('found range of length 0');
133
- }
134
-
135
- if (or.length === 1) {
136
- return or[0];
137
- }
138
-
139
- return new Range(or);
140
- }
141
- }, {
142
- key: "coverage",
143
- value: function coverage() {
144
- var tot = 0;
145
- var rl = this.ranges();
146
-
147
- for (var ri = 0; ri < rl.length; ri += 1) {
148
- var r = rl[ri];
149
- tot += r.max() - r.min() + 1;
150
- }
151
-
152
- return tot;
153
- }
154
- }, {
155
- key: "rangeOrder",
156
- value: function rangeOrder(tmpa, tmpb) {
157
- var a = tmpa;
158
- var b = tmpb;
159
-
160
- if (arguments.length < 2) {
161
- b = a;
162
- a = this;
163
- }
164
-
165
- if (a.min() < b.min()) {
166
- return -1;
167
- }
168
-
169
- if (a.min() > b.min()) {
170
- return 1;
171
- }
172
-
173
- if (a.max() < b.max()) {
174
- return -1;
175
- }
176
-
177
- if (b.max() > a.max()) {
178
- return 1;
179
- }
180
-
181
- return 0;
182
- }
183
- }]);
184
- return Range;
185
- }();
186
-
87
+ if (or.length === 0) {
88
+ throw new Error('found range of length 0');
89
+ }
90
+ if (or.length === 1) {
91
+ return or[0];
92
+ }
93
+ return new Range(or);
94
+ };
95
+ Range.prototype.coverage = function () {
96
+ var tot = 0;
97
+ var rl = this.ranges();
98
+ for (var ri = 0; ri < rl.length; ri += 1) {
99
+ var r = rl[ri];
100
+ tot += r.max() - r.min() + 1;
101
+ }
102
+ return tot;
103
+ };
104
+ Range.prototype.rangeOrder = function (tmpa, tmpb) {
105
+ var a = tmpa;
106
+ var b = tmpb;
107
+ if (arguments.length < 2) {
108
+ b = a;
109
+ a = this;
110
+ }
111
+ if (a.min() < b.min()) {
112
+ return -1;
113
+ }
114
+ if (a.min() > b.min()) {
115
+ return 1;
116
+ }
117
+ if (a.max() < b.max()) {
118
+ return -1;
119
+ }
120
+ if (b.max() > a.max()) {
121
+ return 1;
122
+ }
123
+ return 0;
124
+ };
125
+ return Range;
126
+ }());
187
127
  exports.default = Range;
188
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/range.ts"],"names":["Range","arg1","arg2","ranges","arguments","length","min","max","Object","assign","pos","s","r","map","join","s1","getRanges","concat","sort","rangeOrder","oranges","current","i","nxt","push","arg","s0","r0","r1","l0","l1","i0","i1","or","lapMin","Math","lapMax","Error","tot","rl","ri","tmpa","tmpb","a","b"],"mappings":"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","sourcesContent":["/* eslint prefer-rest-params:0, no-nested-ternary:0 */\n\n/**\n * Adapted from a combination of Range and _Compound in the\n * Dalliance Genome Explorer, (c) Thomas Down 2006-2010.\n */\nexport default class Range {\n  public ranges: any\n\n  public constructor(arg1: any, arg2?: any) {\n    this.ranges =\n      arguments.length === 2\n        ? [{ min: arg1, max: arg2 }]\n        : 0 in arg1\n        ? Object.assign({}, arg1)\n        : [arg1]\n  }\n\n  public min(): number {\n    return this.ranges[0].min\n  }\n\n  public max(): number {\n    return this.ranges[this.ranges.length - 1].max\n  }\n\n  public contains(pos: number): boolean {\n    for (let s = 0; s < this.ranges.length; s += 1) {\n      const r = this.ranges[s]\n      if (r.min <= pos && r.max >= pos) {\n        return true\n      }\n    }\n    return false\n  }\n\n  public isContiguous(): boolean {\n    return this.ranges.length > 1\n  }\n\n  public getRanges(): Range[] {\n    return this.ranges.map((r: Range) => new Range(r.min, r.max))\n  }\n\n  public toString(): string {\n    return this.ranges.map((r: Range) => `[${r.min}-${r.max}]`).join(',')\n  }\n\n  public union(s1: Range): Range {\n    const ranges = this.getRanges()\n      .concat(s1.getRanges())\n      .sort(this.rangeOrder)\n    const oranges = []\n    let current = ranges[0]\n\n    for (let i = 1; i < ranges.length; i += 1) {\n      const nxt = ranges[i]\n      if (nxt.min() > current.max() + 1) {\n        oranges.push(current)\n        current = nxt\n      } else if (nxt.max() > current.max()) {\n        current = new Range(current.min(), nxt.max())\n      }\n    }\n    oranges.push(current)\n\n    if (oranges.length === 1) {\n      return oranges[0]\n    }\n    return new Range(oranges)\n  }\n\n  public intersection(arg: Range): Range {\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    let s0 = this\n    let s1 = arg\n    const r0 = this.ranges()\n    const r1 = s1.ranges()\n    const l0 = r0.length\n\n    const l1 = r1.length\n    let i0 = 0\n\n    let i1 = 0\n    const or = []\n\n    while (i0 < l0 && i1 < l1) {\n      s0 = r0[i0]\n      s1 = r1[i1]\n      const lapMin = Math.max(s0.min(), s1.min())\n      const lapMax = Math.min(s0.max(), s1.max())\n      if (lapMax >= lapMin) {\n        or.push(new Range(lapMin, lapMax))\n      }\n      if (s0.max() > s1.max()) {\n        i1 += 1\n      } else {\n        i0 += 1\n      }\n    }\n\n    if (or.length === 0) {\n      throw new Error('found range of length 0')\n    }\n    if (or.length === 1) {\n      return or[0]\n    }\n    return new Range(or)\n  }\n\n  public coverage(): number {\n    let tot = 0\n    const rl = this.ranges()\n    for (let ri = 0; ri < rl.length; ri += 1) {\n      const r = rl[ri]\n      tot += r.max() - r.min() + 1\n    }\n    return tot\n  }\n\n  public rangeOrder(tmpa: Range, tmpb: Range): number {\n    let a = tmpa\n    let b = tmpb\n    if (arguments.length < 2) {\n      b = a\n      a = this\n    }\n\n    if (a.min() < b.min()) {\n      return -1\n    }\n    if (a.min() > b.min()) {\n      return 1\n    }\n    if (a.max() < b.max()) {\n      return -1\n    }\n    if (b.max() > a.max()) {\n      return 1\n    }\n    return 0\n  }\n}\n"]}
package/dist/util.js CHANGED
@@ -1,85 +1,92 @@
1
1
  "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.groupBlocks = groupBlocks;
9
- exports.checkAbortSignal = checkAbortSignal;
10
- exports.abortBreakPoint = abortBreakPoint;
11
- exports.AbortError = void 0;
12
-
13
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
14
-
15
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
16
-
17
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
18
-
19
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
20
-
21
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
22
-
23
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
24
-
25
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
26
-
27
- var _wrapNativeSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapNativeSuper"));
28
-
29
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
30
-
31
- 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 = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
32
-
33
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }
34
-
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 __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
18
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
19
+ return new (P || (P = Promise))(function (resolve, reject) {
20
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
21
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
22
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
23
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
24
+ });
25
+ };
26
+ var __generator = (this && this.__generator) || function (thisArg, body) {
27
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
28
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
29
+ function verb(n) { return function (v) { return step([n, v]); }; }
30
+ function step(op) {
31
+ if (f) throw new TypeError("Generator is already executing.");
32
+ while (_) try {
33
+ 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;
34
+ if (y = 0, t) op = [op[0] & 2, t.value];
35
+ switch (op[0]) {
36
+ case 0: case 1: t = op; break;
37
+ case 4: _.label++; return { value: op[1], done: false };
38
+ case 5: _.label++; y = op[1]; op = [0]; continue;
39
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
40
+ default:
41
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
42
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
43
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
44
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
45
+ if (t[2]) _.ops.pop();
46
+ _.trys.pop(); continue;
47
+ }
48
+ op = body.call(thisArg, _);
49
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
50
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
51
+ }
52
+ };
53
+ Object.defineProperty(exports, "__esModule", { value: true });
54
+ exports.abortBreakPoint = exports.checkAbortSignal = exports.groupBlocks = exports.AbortError = void 0;
35
55
  /* eslint no-bitwise: ["error", { "allow": ["|"] }] */
36
- var AbortError = /*#__PURE__*/function (_Error) {
37
- (0, _inherits2.default)(AbortError, _Error);
38
-
39
- var _super = _createSuper(AbortError);
40
-
41
- function AbortError(message) {
42
- var _this;
43
-
44
- (0, _classCallCheck2.default)(this, AbortError);
45
- _this = _super.call(this, message);
46
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "code", void 0);
47
- _this.code = 'ERR_ABORTED';
48
- return _this;
49
- }
50
-
51
- return AbortError;
52
- }( /*#__PURE__*/(0, _wrapNativeSuper2.default)(Error)); // sort blocks by file offset and
53
- // group blocks that are within 2KB of eachother
54
-
55
-
56
+ var AbortError = /** @class */ (function (_super) {
57
+ __extends(AbortError, _super);
58
+ function AbortError(message) {
59
+ var _this = _super.call(this, message) || this;
60
+ _this.code = 'ERR_ABORTED';
61
+ return _this;
62
+ }
63
+ return AbortError;
64
+ }(Error));
56
65
  exports.AbortError = AbortError;
57
-
66
+ // sort blocks by file offset and
67
+ // group blocks that are within 2KB of eachother
58
68
  function groupBlocks(blocks) {
59
- blocks.sort(function (b0, b1) {
60
- return (b0.offset | 0) - (b1.offset | 0);
61
- });
62
- var blockGroups = [];
63
- var lastBlock;
64
- var lastBlockEnd;
65
-
66
- for (var i = 0; i < blocks.length; i += 1) {
67
- if (lastBlock && blocks[i].offset - lastBlockEnd <= 2000) {
68
- lastBlock.length += blocks[i].length - lastBlockEnd + blocks[i].offset;
69
- lastBlock.blocks.push(blocks[i]);
70
- } else {
71
- blockGroups.push(lastBlock = {
72
- blocks: [blocks[i]],
73
- length: blocks[i].length,
74
- offset: blocks[i].offset
75
- });
69
+ blocks.sort(function (b0, b1) { return (b0.offset | 0) - (b1.offset | 0); });
70
+ var blockGroups = [];
71
+ var lastBlock;
72
+ var lastBlockEnd;
73
+ for (var i = 0; i < blocks.length; i += 1) {
74
+ if (lastBlock && blocks[i].offset - lastBlockEnd <= 2000) {
75
+ lastBlock.length += blocks[i].length - lastBlockEnd + blocks[i].offset;
76
+ lastBlock.blocks.push(blocks[i]);
77
+ }
78
+ else {
79
+ blockGroups.push((lastBlock = {
80
+ blocks: [blocks[i]],
81
+ length: blocks[i].length,
82
+ offset: blocks[i].offset,
83
+ }));
84
+ }
85
+ lastBlockEnd = lastBlock.offset + lastBlock.length;
76
86
  }
77
-
78
- lastBlockEnd = lastBlock.offset + lastBlock.length;
79
- }
80
-
81
- return blockGroups;
87
+ return blockGroups;
82
88
  }
89
+ exports.groupBlocks = groupBlocks;
83
90
  /**
84
91
  * Properly check if the given AbortSignal is aborted.
85
92
  * Per the standard, if the signal reads as aborted,
@@ -91,53 +98,40 @@ function groupBlocks(blocks) {
91
98
  * @param {AbortSignal} [signal] an AbortSignal, or anything with an `aborted` attribute
92
99
  * @returns nothing
93
100
  */
94
-
95
-
96
101
  function checkAbortSignal(signal) {
97
- if (!signal) return;
98
-
99
- if (signal.aborted) {
100
- // console.log('bam aborted!')
101
- if (typeof DOMException !== 'undefined') {
102
- throw new DOMException('aborted', 'AbortError');
103
- } else {
104
- var e = new AbortError('aborted');
105
- e.code = 'ERR_ABORTED';
106
- throw e;
102
+ if (!signal) {
103
+ return;
104
+ }
105
+ if (signal.aborted) {
106
+ // console.log('bam aborted!')
107
+ if (typeof DOMException !== 'undefined') {
108
+ throw new DOMException('aborted', 'AbortError');
109
+ }
110
+ else {
111
+ var e = new AbortError('aborted');
112
+ e.code = 'ERR_ABORTED';
113
+ throw e;
114
+ }
107
115
  }
108
- }
109
116
  }
117
+ exports.checkAbortSignal = checkAbortSignal;
110
118
  /**
111
119
  * Skips to the next tick, then runs `checkAbortSignal`.
112
120
  * Await this to inside an otherwise synchronous loop to
113
121
  * provide a place to break when an abort signal is received.
114
122
  * @param {AbortSignal} signal
115
123
  */
116
-
117
-
118
- function abortBreakPoint(_x) {
119
- return _abortBreakPoint.apply(this, arguments);
120
- }
121
-
122
- function _abortBreakPoint() {
123
- _abortBreakPoint = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(signal) {
124
- return _regenerator.default.wrap(function _callee$(_context) {
125
- while (1) {
126
- switch (_context.prev = _context.next) {
127
- case 0:
128
- _context.next = 2;
129
- return Promise.resolve();
130
-
131
- case 2:
132
- checkAbortSignal(signal);
133
-
134
- case 3:
135
- case "end":
136
- return _context.stop();
137
- }
138
- }
139
- }, _callee);
140
- }));
141
- return _abortBreakPoint.apply(this, arguments);
124
+ function abortBreakPoint(signal) {
125
+ return __awaiter(this, void 0, void 0, function () {
126
+ return __generator(this, function (_a) {
127
+ switch (_a.label) {
128
+ case 0: return [4 /*yield*/, Promise.resolve()];
129
+ case 1:
130
+ _a.sent();
131
+ checkAbortSignal(signal);
132
+ return [2 /*return*/];
133
+ }
134
+ });
135
+ });
142
136
  }
143
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbIkFib3J0RXJyb3IiLCJtZXNzYWdlIiwiY29kZSIsIkVycm9yIiwiZ3JvdXBCbG9ja3MiLCJibG9ja3MiLCJzb3J0IiwiYjAiLCJiMSIsIm9mZnNldCIsImJsb2NrR3JvdXBzIiwibGFzdEJsb2NrIiwibGFzdEJsb2NrRW5kIiwiaSIsImxlbmd0aCIsInB1c2giLCJjaGVja0Fib3J0U2lnbmFsIiwic2lnbmFsIiwiYWJvcnRlZCIsIkRPTUV4Y2VwdGlvbiIsImUiLCJhYm9ydEJyZWFrUG9pbnQiLCJQcm9taXNlIiwicmVzb2x2ZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0lBQ2FBLFU7Ozs7O0FBR1gsc0JBQW1CQyxPQUFuQixFQUFvQztBQUFBOztBQUFBO0FBQ2xDLDhCQUFNQSxPQUFOO0FBRGtDO0FBRWxDLFVBQUtDLElBQUwsR0FBWSxhQUFaO0FBRmtDO0FBR25DOzs7K0NBTjZCQyxLLElBUWhDO0FBQ0E7Ozs7O0FBQ08sU0FBU0MsV0FBVCxDQUFxQkMsTUFBckIsRUFBMkM7QUFDaERBLEVBQUFBLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZLFVBQUNDLEVBQUQsRUFBS0MsRUFBTDtBQUFBLFdBQVksQ0FBQ0QsRUFBRSxDQUFDRSxNQUFILEdBQVksQ0FBYixLQUFtQkQsRUFBRSxDQUFDQyxNQUFILEdBQVksQ0FBL0IsQ0FBWjtBQUFBLEdBQVo7QUFFQSxNQUFNQyxXQUFXLEdBQUcsRUFBcEI7QUFDQSxNQUFJQyxTQUFKO0FBQ0EsTUFBSUMsWUFBSjs7QUFDQSxPQUFLLElBQUlDLENBQUMsR0FBRyxDQUFiLEVBQWdCQSxDQUFDLEdBQUdSLE1BQU0sQ0FBQ1MsTUFBM0IsRUFBbUNELENBQUMsSUFBSSxDQUF4QyxFQUEyQztBQUN6QyxRQUFJRixTQUFTLElBQUlOLE1BQU0sQ0FBQ1EsQ0FBRCxDQUFOLENBQVVKLE1BQVYsR0FBbUJHLFlBQW5CLElBQW1DLElBQXBELEVBQTBEO0FBQ3hERCxNQUFBQSxTQUFTLENBQUNHLE1BQVYsSUFBb0JULE1BQU0sQ0FBQ1EsQ0FBRCxDQUFOLENBQVVDLE1BQVYsR0FBbUJGLFlBQW5CLEdBQWtDUCxNQUFNLENBQUNRLENBQUQsQ0FBTixDQUFVSixNQUFoRTtBQUNBRSxNQUFBQSxTQUFTLENBQUNOLE1BQVYsQ0FBaUJVLElBQWpCLENBQXNCVixNQUFNLENBQUNRLENBQUQsQ0FBNUI7QUFDRCxLQUhELE1BR087QUFDTEgsTUFBQUEsV0FBVyxDQUFDSyxJQUFaLENBQ0dKLFNBQVMsR0FBRztBQUNYTixRQUFBQSxNQUFNLEVBQUUsQ0FBQ0EsTUFBTSxDQUFDUSxDQUFELENBQVAsQ0FERztBQUVYQyxRQUFBQSxNQUFNLEVBQUVULE1BQU0sQ0FBQ1EsQ0FBRCxDQUFOLENBQVVDLE1BRlA7QUFHWEwsUUFBQUEsTUFBTSxFQUFFSixNQUFNLENBQUNRLENBQUQsQ0FBTixDQUFVSjtBQUhQLE9BRGY7QUFPRDs7QUFDREcsSUFBQUEsWUFBWSxHQUFHRCxTQUFTLENBQUNGLE1BQVYsR0FBbUJFLFNBQVMsQ0FBQ0csTUFBNUM7QUFDRDs7QUFFRCxTQUFPSixXQUFQO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs7OztBQVdPLFNBQVNNLGdCQUFULENBQTBCQyxNQUExQixFQUFzRDtBQUMzRCxNQUFJLENBQUNBLE1BQUwsRUFBYTs7QUFFYixNQUFJQSxNQUFNLENBQUNDLE9BQVgsRUFBb0I7QUFDbEI7QUFDQSxRQUFJLE9BQU9DLFlBQVAsS0FBd0IsV0FBNUIsRUFBeUM7QUFDdkMsWUFBTSxJQUFJQSxZQUFKLENBQWlCLFNBQWpCLEVBQTRCLFlBQTVCLENBQU47QUFDRCxLQUZELE1BRU87QUFDTCxVQUFNQyxDQUFDLEdBQUcsSUFBSXBCLFVBQUosQ0FBZSxTQUFmLENBQVY7QUFDQW9CLE1BQUFBLENBQUMsQ0FBQ2xCLElBQUYsR0FBUyxhQUFUO0FBQ0EsWUFBTWtCLENBQU47QUFDRDtBQUNGO0FBQ0Y7QUFFRDs7Ozs7Ozs7U0FNc0JDLGU7Ozs7OzZGQUFmLGlCQUErQkosTUFBL0I7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsbUJBQ0NLLE9BQU8sQ0FBQ0MsT0FBUixFQUREOztBQUFBO0FBRUxQLFlBQUFBLGdCQUFnQixDQUFDQyxNQUFELENBQWhCOztBQUZLO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEciLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQgbm8tYml0d2lzZTogW1wiZXJyb3JcIiwgeyBcImFsbG93XCI6IFtcInxcIl0gfV0gKi9cbmV4cG9ydCBjbGFzcyBBYm9ydEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBwdWJsaWMgY29kZTogc3RyaW5nXG5cbiAgcHVibGljIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpXG4gICAgdGhpcy5jb2RlID0gJ0VSUl9BQk9SVEVEJ1xuICB9XG59XG4vLyBzb3J0IGJsb2NrcyBieSBmaWxlIG9mZnNldCBhbmRcbi8vIGdyb3VwIGJsb2NrcyB0aGF0IGFyZSB3aXRoaW4gMktCIG9mIGVhY2hvdGhlclxuZXhwb3J0IGZ1bmN0aW9uIGdyb3VwQmxvY2tzKGJsb2NrczogYW55W10pOiBhbnlbXSB7XG4gIGJsb2Nrcy5zb3J0KChiMCwgYjEpID0+IChiMC5vZmZzZXQgfCAwKSAtIChiMS5vZmZzZXQgfCAwKSlcblxuICBjb25zdCBibG9ja0dyb3VwcyA9IFtdXG4gIGxldCBsYXN0QmxvY2tcbiAgbGV0IGxhc3RCbG9ja0VuZFxuICBmb3IgKGxldCBpID0gMDsgaSA8IGJsb2Nrcy5sZW5ndGg7IGkgKz0gMSkge1xuICAgIGlmIChsYXN0QmxvY2sgJiYgYmxvY2tzW2ldLm9mZnNldCAtIGxhc3RCbG9ja0VuZCA8PSAyMDAwKSB7XG4gICAgICBsYXN0QmxvY2subGVuZ3RoICs9IGJsb2Nrc1tpXS5sZW5ndGggLSBsYXN0QmxvY2tFbmQgKyBibG9ja3NbaV0ub2Zmc2V0XG4gICAgICBsYXN0QmxvY2suYmxvY2tzLnB1c2goYmxvY2tzW2ldKVxuICAgIH0gZWxzZSB7XG4gICAgICBibG9ja0dyb3Vwcy5wdXNoKFxuICAgICAgICAobGFzdEJsb2NrID0ge1xuICAgICAgICAgIGJsb2NrczogW2Jsb2Nrc1tpXV0sXG4gICAgICAgICAgbGVuZ3RoOiBibG9ja3NbaV0ubGVuZ3RoLFxuICAgICAgICAgIG9mZnNldDogYmxvY2tzW2ldLm9mZnNldCxcbiAgICAgICAgfSksXG4gICAgICApXG4gICAgfVxuICAgIGxhc3RCbG9ja0VuZCA9IGxhc3RCbG9jay5vZmZzZXQgKyBsYXN0QmxvY2subGVuZ3RoXG4gIH1cblxuICByZXR1cm4gYmxvY2tHcm91cHNcbn1cblxuLyoqXG4gKiBQcm9wZXJseSBjaGVjayBpZiB0aGUgZ2l2ZW4gQWJvcnRTaWduYWwgaXMgYWJvcnRlZC5cbiAqIFBlciB0aGUgc3RhbmRhcmQsIGlmIHRoZSBzaWduYWwgcmVhZHMgYXMgYWJvcnRlZCxcbiAqIHRoaXMgZnVuY3Rpb24gdGhyb3dzIGVpdGhlciBhIERPTUV4Y2VwdGlvbiBBYm9ydEVycm9yLCBvciBhIHJlZ3VsYXIgZXJyb3JcbiAqIHdpdGggYSBgY29kZWAgYXR0cmlidXRlIHNldCB0byBgRVJSX0FCT1JURURgLlxuICpcbiAqIEZvciBjb252ZW5pZW5jZSwgcGFzc2luZyBgdW5kZWZpbmVkYCBpcyBhIG5vLW9wXG4gKlxuICogQHBhcmFtIHtBYm9ydFNpZ25hbH0gW3NpZ25hbF0gYW4gQWJvcnRTaWduYWwsIG9yIGFueXRoaW5nIHdpdGggYW4gYGFib3J0ZWRgIGF0dHJpYnV0ZVxuICogQHJldHVybnMgbm90aGluZ1xuICovXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tBYm9ydFNpZ25hbChzaWduYWw/OiBBYm9ydFNpZ25hbCk6IHZvaWQge1xuICBpZiAoIXNpZ25hbCkgcmV0dXJuXG5cbiAgaWYgKHNpZ25hbC5hYm9ydGVkKSB7XG4gICAgLy8gY29uc29sZS5sb2coJ2JhbSBhYm9ydGVkIScpXG4gICAgaWYgKHR5cGVvZiBET01FeGNlcHRpb24gIT09ICd1bmRlZmluZWQnKSB7XG4gICAgICB0aHJvdyBuZXcgRE9NRXhjZXB0aW9uKCdhYm9ydGVkJywgJ0Fib3J0RXJyb3InKVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBlID0gbmV3IEFib3J0RXJyb3IoJ2Fib3J0ZWQnKVxuICAgICAgZS5jb2RlID0gJ0VSUl9BQk9SVEVEJ1xuICAgICAgdGhyb3cgZVxuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIFNraXBzIHRvIHRoZSBuZXh0IHRpY2ssIHRoZW4gcnVucyBgY2hlY2tBYm9ydFNpZ25hbGAuXG4gKiBBd2FpdCB0aGlzIHRvIGluc2lkZSBhbiBvdGhlcndpc2Ugc3luY2hyb25vdXMgbG9vcCB0b1xuICogcHJvdmlkZSBhIHBsYWNlIHRvIGJyZWFrIHdoZW4gYW4gYWJvcnQgc2lnbmFsIGlzIHJlY2VpdmVkLlxuICogQHBhcmFtIHtBYm9ydFNpZ25hbH0gc2lnbmFsXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBhYm9ydEJyZWFrUG9pbnQoc2lnbmFsPzogQWJvcnRTaWduYWwpOiBQcm9taXNlPHZvaWQ+IHtcbiAgYXdhaXQgUHJvbWlzZS5yZXNvbHZlKClcbiAgY2hlY2tBYm9ydFNpZ25hbChzaWduYWwpXG59XG4iXX0=
137
+ exports.abortBreakPoint = abortBreakPoint;