@loaders.gl/core 3.1.0-beta.7 → 3.1.3

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 (116) hide show
  1. package/dist/bundle.js +5 -3380
  2. package/dist/dist.min.js +3423 -0
  3. package/dist/es5/bundle.js +1 -1
  4. package/dist/es5/bundle.js.map +1 -1
  5. package/dist/es5/index.js +56 -72
  6. package/dist/es5/index.js.map +1 -1
  7. package/dist/es5/iterators/batch-iterators/timed-batch-iterator.js +119 -14
  8. package/dist/es5/iterators/batch-iterators/timed-batch-iterator.js.map +1 -1
  9. package/dist/es5/iterators/make-iterator/make-array-buffer-iterator.js +53 -17
  10. package/dist/es5/iterators/make-iterator/make-array-buffer-iterator.js.map +1 -1
  11. package/dist/es5/iterators/make-iterator/make-blob-iterator.js +53 -12
  12. package/dist/es5/iterators/make-iterator/make-blob-iterator.js.map +1 -1
  13. package/dist/es5/iterators/make-iterator/make-iterator.js +1 -1
  14. package/dist/es5/iterators/make-iterator/make-iterator.js.map +1 -1
  15. package/dist/es5/iterators/make-iterator/make-stream-iterator.js +161 -24
  16. package/dist/es5/iterators/make-iterator/make-stream-iterator.js.map +1 -1
  17. package/dist/es5/iterators/make-iterator/make-string-iterator.js +41 -13
  18. package/dist/es5/iterators/make-iterator/make-string-iterator.js.map +1 -1
  19. package/dist/es5/iterators/make-stream/make-dom-stream.js +71 -26
  20. package/dist/es5/iterators/make-stream/make-dom-stream.js.map +1 -1
  21. package/dist/es5/iterators/make-stream/make-node-stream.js +189 -56
  22. package/dist/es5/iterators/make-stream/make-node-stream.js.map +1 -1
  23. package/dist/es5/javascript-utils/is-type.js +58 -18
  24. package/dist/es5/javascript-utils/is-type.js.map +1 -1
  25. package/dist/es5/lib/api/encode.js +242 -46
  26. package/dist/es5/lib/api/encode.js.map +1 -1
  27. package/dist/es5/lib/api/load-in-batches.js +52 -9
  28. package/dist/es5/lib/api/load-in-batches.js.map +1 -1
  29. package/dist/es5/lib/api/load.js +60 -15
  30. package/dist/es5/lib/api/load.js.map +1 -1
  31. package/dist/es5/lib/api/parse-in-batches.js +333 -81
  32. package/dist/es5/lib/api/parse-in-batches.js.map +1 -1
  33. package/dist/es5/lib/api/parse-sync.js +15 -11
  34. package/dist/es5/lib/api/parse-sync.js.map +1 -1
  35. package/dist/es5/lib/api/parse.js +142 -50
  36. package/dist/es5/lib/api/parse.js.map +1 -1
  37. package/dist/es5/lib/api/register-loaders.js +30 -8
  38. package/dist/es5/lib/api/register-loaders.js.map +1 -1
  39. package/dist/es5/lib/api/save.js +37 -4
  40. package/dist/es5/lib/api/save.js.map +1 -1
  41. package/dist/es5/lib/api/select-loader.js +209 -74
  42. package/dist/es5/lib/api/select-loader.js.map +1 -1
  43. package/dist/es5/lib/fetch/fetch-error-message.js +55 -13
  44. package/dist/es5/lib/fetch/fetch-error-message.js.map +1 -1
  45. package/dist/es5/lib/fetch/fetch-file.js +47 -10
  46. package/dist/es5/lib/fetch/fetch-file.js.map +1 -1
  47. package/dist/es5/lib/fetch/read-array-buffer.js +80 -19
  48. package/dist/es5/lib/fetch/read-array-buffer.js.map +1 -1
  49. package/dist/es5/lib/fetch/read-file.js +3 -2
  50. package/dist/es5/lib/fetch/read-file.js.map +1 -1
  51. package/dist/es5/lib/fetch/write-file.js +38 -9
  52. package/dist/es5/lib/fetch/write-file.js.map +1 -1
  53. package/dist/es5/lib/filesystems/browser-filesystem.js +266 -77
  54. package/dist/es5/lib/filesystems/browser-filesystem.js.map +1 -1
  55. package/dist/es5/lib/filesystems/read-array-buffer.js +43 -6
  56. package/dist/es5/lib/filesystems/read-array-buffer.js.map +1 -1
  57. package/dist/es5/lib/init.js +1 -1
  58. package/dist/es5/lib/init.js.map +1 -1
  59. package/dist/es5/lib/loader-utils/check-errors.js +50 -12
  60. package/dist/es5/lib/loader-utils/check-errors.js.map +1 -1
  61. package/dist/es5/lib/loader-utils/get-data.js +238 -71
  62. package/dist/es5/lib/loader-utils/get-data.js.map +1 -1
  63. package/dist/es5/lib/loader-utils/loader-context.js +19 -8
  64. package/dist/es5/lib/loader-utils/loader-context.js.map +1 -1
  65. package/dist/es5/lib/loader-utils/loggers.js +81 -36
  66. package/dist/es5/lib/loader-utils/loggers.js.map +1 -1
  67. package/dist/es5/lib/loader-utils/normalize-loader.js +13 -7
  68. package/dist/es5/lib/loader-utils/normalize-loader.js.map +1 -1
  69. package/dist/es5/lib/loader-utils/option-defaults.js +2 -2
  70. package/dist/es5/lib/loader-utils/option-defaults.js.map +1 -1
  71. package/dist/es5/lib/loader-utils/option-utils.js +85 -51
  72. package/dist/es5/lib/loader-utils/option-utils.js.map +1 -1
  73. package/dist/es5/lib/progress/fetch-progress.js +150 -49
  74. package/dist/es5/lib/progress/fetch-progress.js.map +1 -1
  75. package/dist/es5/lib/utils/mime-type-utils.js +4 -4
  76. package/dist/es5/lib/utils/mime-type-utils.js.map +1 -1
  77. package/dist/es5/lib/utils/resource-utils.js +4 -4
  78. package/dist/es5/lib/utils/resource-utils.js.map +1 -1
  79. package/dist/es5/lib/utils/response-utils.js +215 -88
  80. package/dist/es5/lib/utils/response-utils.js.map +1 -1
  81. package/dist/es5/null-loader.js +137 -10
  82. package/dist/es5/null-loader.js.map +1 -1
  83. package/dist/esm/index.js +1 -3
  84. package/dist/esm/index.js.map +1 -1
  85. package/dist/esm/iterators/make-stream/make-dom-stream.js +1 -1
  86. package/dist/esm/iterators/make-stream/make-dom-stream.js.map +1 -1
  87. package/dist/esm/iterators/make-stream/make-node-stream.js +1 -4
  88. package/dist/esm/iterators/make-stream/make-node-stream.js.map +1 -1
  89. package/dist/esm/lib/init.js +1 -1
  90. package/dist/esm/lib/init.js.map +1 -1
  91. package/dist/esm/null-loader.js +1 -1
  92. package/dist/esm/null-loader.js.map +1 -1
  93. package/dist/index.d.ts +1 -3
  94. package/dist/index.d.ts.map +1 -1
  95. package/dist/index.js +3 -7
  96. package/dist/iterators/make-stream/make-dom-stream.d.ts +8 -3
  97. package/dist/iterators/make-stream/make-dom-stream.d.ts.map +1 -1
  98. package/dist/iterators/make-stream/make-dom-stream.js +9 -4
  99. package/dist/iterators/make-stream/make-node-stream.d.ts +2 -3
  100. package/dist/iterators/make-stream/make-node-stream.d.ts.map +1 -1
  101. package/dist/iterators/make-stream/make-node-stream.js +3 -5
  102. package/dist/lib/fetch/fetch-file.js +1 -1
  103. package/dist/lib/fetch/read-file.d.ts +1 -1
  104. package/dist/lib/fetch/read-file.d.ts.map +1 -1
  105. package/package.json +8 -9
  106. package/src/index.ts +1 -3
  107. package/src/iterators/make-stream/make-dom-stream.ts +9 -4
  108. package/src/iterators/make-stream/make-node-stream.ts +2 -7
  109. package/dist/es5/iterators/make-stream/make-stream.js +0 -19
  110. package/dist/es5/iterators/make-stream/make-stream.js.map +0 -1
  111. package/dist/esm/iterators/make-stream/make-stream.js +0 -7
  112. package/dist/esm/iterators/make-stream/make-stream.js.map +0 -1
  113. package/dist/iterators/make-stream/make-stream.d.ts +0 -9
  114. package/dist/iterators/make-stream/make-stream.d.ts.map +0 -1
  115. package/dist/iterators/make-stream/make-stream.js +0 -16
  116. package/src/iterators/make-stream/make-stream.ts +0 -19
@@ -7,18 +7,27 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.default = void 0;
9
9
 
10
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
+
12
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
13
+
14
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
15
+
16
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
17
+
10
18
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
19
 
12
- class BrowserFileSystem {
13
- constructor(files, options) {
20
+ var BrowserFileSystem = function () {
21
+ function BrowserFileSystem(files, options) {
22
+ (0, _classCallCheck2.default)(this, BrowserFileSystem);
14
23
  (0, _defineProperty2.default)(this, "_fetch", void 0);
15
24
  (0, _defineProperty2.default)(this, "files", {});
16
25
  (0, _defineProperty2.default)(this, "lowerCaseFiles", {});
17
26
  (0, _defineProperty2.default)(this, "usedFiles", {});
18
27
  this._fetch = (options === null || options === void 0 ? void 0 : options.fetch) || fetch;
19
28
 
20
- for (let i = 0; i < files.length; ++i) {
21
- const file = files[i];
29
+ for (var i = 0; i < files.length; ++i) {
30
+ var file = files[i];
22
31
  this.files[file.name] = file;
23
32
  this.lowerCaseFiles[file.name.toLowerCase()] = file;
24
33
  this.usedFiles[file.name] = false;
@@ -27,97 +36,277 @@ class BrowserFileSystem {
27
36
  this.fetch = this.fetch.bind(this);
28
37
  }
29
38
 
30
- async fetch(path, options) {
31
- if (path.includes('://')) {
32
- return this._fetch(path, options);
33
- }
39
+ (0, _createClass2.default)(BrowserFileSystem, [{
40
+ key: "fetch",
41
+ value: function () {
42
+ var _fetch = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(path, options) {
43
+ var file, headers, range, bytes, start, end, data, _response, response;
34
44
 
35
- const file = this.files[path];
45
+ return _regenerator.default.wrap(function _callee$(_context) {
46
+ while (1) {
47
+ switch (_context.prev = _context.next) {
48
+ case 0:
49
+ if (!path.includes('://')) {
50
+ _context.next = 2;
51
+ break;
52
+ }
36
53
 
37
- if (!file) {
38
- return new Response(path, {
39
- status: 400,
40
- statusText: 'NOT FOUND'
41
- });
42
- }
54
+ return _context.abrupt("return", this._fetch(path, options));
43
55
 
44
- const headers = new Headers(options === null || options === void 0 ? void 0 : options.headers);
45
- const range = headers.get('Range');
46
- const bytes = range && /bytes=($1)-($2)/.exec(range);
47
-
48
- if (bytes) {
49
- const start = parseInt(bytes[1]);
50
- const end = parseInt(bytes[2]);
51
- const data = await file.slice(start, end).arrayBuffer();
52
- const response = new Response(data);
53
- Object.defineProperty(response, 'url', {
54
- value: path
55
- });
56
- return response;
57
- }
56
+ case 2:
57
+ file = this.files[path];
58
58
 
59
- const response = new Response(file);
60
- Object.defineProperty(response, 'url', {
61
- value: path
62
- });
63
- return response;
64
- }
59
+ if (file) {
60
+ _context.next = 5;
61
+ break;
62
+ }
65
63
 
66
- async readdir(dirname) {
67
- const files = [];
64
+ return _context.abrupt("return", new Response(path, {
65
+ status: 400,
66
+ statusText: 'NOT FOUND'
67
+ }));
68
68
 
69
- for (const path in this.files) {
70
- files.push(path);
71
- }
69
+ case 5:
70
+ headers = new Headers(options === null || options === void 0 ? void 0 : options.headers);
71
+ range = headers.get('Range');
72
+ bytes = range && /bytes=($1)-($2)/.exec(range);
72
73
 
73
- return files;
74
- }
74
+ if (!bytes) {
75
+ _context.next = 17;
76
+ break;
77
+ }
75
78
 
76
- async stat(path, options) {
77
- const file = this.files[path];
79
+ start = parseInt(bytes[1]);
80
+ end = parseInt(bytes[2]);
81
+ _context.next = 13;
82
+ return file.slice(start, end).arrayBuffer();
78
83
 
79
- if (!file) {
80
- throw new Error(path);
81
- }
84
+ case 13:
85
+ data = _context.sent;
86
+ _response = new Response(data);
87
+ Object.defineProperty(_response, 'url', {
88
+ value: path
89
+ });
90
+ return _context.abrupt("return", _response);
82
91
 
83
- return {
84
- size: file.size
85
- };
86
- }
92
+ case 17:
93
+ response = new Response(file);
94
+ Object.defineProperty(response, 'url', {
95
+ value: path
96
+ });
97
+ return _context.abrupt("return", response);
87
98
 
88
- async unlink(path) {
89
- delete this.files[path];
90
- delete this.lowerCaseFiles[path];
91
- this.usedFiles[path] = true;
92
- }
99
+ case 20:
100
+ case "end":
101
+ return _context.stop();
102
+ }
103
+ }
104
+ }, _callee, this);
105
+ }));
93
106
 
94
- async open(pathname, flags, mode) {
95
- return this.files[pathname];
96
- }
107
+ function fetch(_x, _x2) {
108
+ return _fetch.apply(this, arguments);
109
+ }
97
110
 
98
- async read(fd, buffer, offset = 0, length = buffer.byteLength, position = null) {
99
- const file = fd;
100
- const startPosition = 0;
101
- const arrayBuffer = await file.slice(startPosition, startPosition + length).arrayBuffer();
102
- return {
103
- bytesRead: length,
104
- buffer: arrayBuffer
105
- };
106
- }
111
+ return fetch;
112
+ }()
113
+ }, {
114
+ key: "readdir",
115
+ value: function () {
116
+ var _readdir = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(dirname) {
117
+ var files, path;
118
+ return _regenerator.default.wrap(function _callee2$(_context2) {
119
+ while (1) {
120
+ switch (_context2.prev = _context2.next) {
121
+ case 0:
122
+ files = [];
107
123
 
108
- async close(fd) {}
124
+ for (path in this.files) {
125
+ files.push(path);
126
+ }
109
127
 
110
- _getFile(path, used) {
111
- const file = this.files[path] || this.lowerCaseFiles[path];
128
+ return _context2.abrupt("return", files);
112
129
 
113
- if (file && used) {
114
- this.usedFiles[path] = true;
115
- }
130
+ case 3:
131
+ case "end":
132
+ return _context2.stop();
133
+ }
134
+ }
135
+ }, _callee2, this);
136
+ }));
116
137
 
117
- return file;
118
- }
138
+ function readdir(_x3) {
139
+ return _readdir.apply(this, arguments);
140
+ }
141
+
142
+ return readdir;
143
+ }()
144
+ }, {
145
+ key: "stat",
146
+ value: function () {
147
+ var _stat = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee3(path, options) {
148
+ var file;
149
+ return _regenerator.default.wrap(function _callee3$(_context3) {
150
+ while (1) {
151
+ switch (_context3.prev = _context3.next) {
152
+ case 0:
153
+ file = this.files[path];
154
+
155
+ if (file) {
156
+ _context3.next = 3;
157
+ break;
158
+ }
119
159
 
120
- }
160
+ throw new Error(path);
161
+
162
+ case 3:
163
+ return _context3.abrupt("return", {
164
+ size: file.size
165
+ });
166
+
167
+ case 4:
168
+ case "end":
169
+ return _context3.stop();
170
+ }
171
+ }
172
+ }, _callee3, this);
173
+ }));
174
+
175
+ function stat(_x4, _x5) {
176
+ return _stat.apply(this, arguments);
177
+ }
178
+
179
+ return stat;
180
+ }()
181
+ }, {
182
+ key: "unlink",
183
+ value: function () {
184
+ var _unlink = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee4(path) {
185
+ return _regenerator.default.wrap(function _callee4$(_context4) {
186
+ while (1) {
187
+ switch (_context4.prev = _context4.next) {
188
+ case 0:
189
+ delete this.files[path];
190
+ delete this.lowerCaseFiles[path];
191
+ this.usedFiles[path] = true;
192
+
193
+ case 3:
194
+ case "end":
195
+ return _context4.stop();
196
+ }
197
+ }
198
+ }, _callee4, this);
199
+ }));
200
+
201
+ function unlink(_x6) {
202
+ return _unlink.apply(this, arguments);
203
+ }
204
+
205
+ return unlink;
206
+ }()
207
+ }, {
208
+ key: "open",
209
+ value: function () {
210
+ var _open = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee5(pathname, flags, mode) {
211
+ return _regenerator.default.wrap(function _callee5$(_context5) {
212
+ while (1) {
213
+ switch (_context5.prev = _context5.next) {
214
+ case 0:
215
+ return _context5.abrupt("return", this.files[pathname]);
216
+
217
+ case 1:
218
+ case "end":
219
+ return _context5.stop();
220
+ }
221
+ }
222
+ }, _callee5, this);
223
+ }));
224
+
225
+ function open(_x7, _x8, _x9) {
226
+ return _open.apply(this, arguments);
227
+ }
228
+
229
+ return open;
230
+ }()
231
+ }, {
232
+ key: "read",
233
+ value: function () {
234
+ var _read = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee6(fd, buffer) {
235
+ var offset,
236
+ length,
237
+ position,
238
+ file,
239
+ startPosition,
240
+ arrayBuffer,
241
+ _args6 = arguments;
242
+ return _regenerator.default.wrap(function _callee6$(_context6) {
243
+ while (1) {
244
+ switch (_context6.prev = _context6.next) {
245
+ case 0:
246
+ offset = _args6.length > 2 && _args6[2] !== undefined ? _args6[2] : 0;
247
+ length = _args6.length > 3 && _args6[3] !== undefined ? _args6[3] : buffer.byteLength;
248
+ position = _args6.length > 4 && _args6[4] !== undefined ? _args6[4] : null;
249
+ file = fd;
250
+ startPosition = 0;
251
+ _context6.next = 7;
252
+ return file.slice(startPosition, startPosition + length).arrayBuffer();
253
+
254
+ case 7:
255
+ arrayBuffer = _context6.sent;
256
+ return _context6.abrupt("return", {
257
+ bytesRead: length,
258
+ buffer: arrayBuffer
259
+ });
260
+
261
+ case 9:
262
+ case "end":
263
+ return _context6.stop();
264
+ }
265
+ }
266
+ }, _callee6);
267
+ }));
268
+
269
+ function read(_x10, _x11) {
270
+ return _read.apply(this, arguments);
271
+ }
272
+
273
+ return read;
274
+ }()
275
+ }, {
276
+ key: "close",
277
+ value: function () {
278
+ var _close = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee7(fd) {
279
+ return _regenerator.default.wrap(function _callee7$(_context7) {
280
+ while (1) {
281
+ switch (_context7.prev = _context7.next) {
282
+ case 0:
283
+ case "end":
284
+ return _context7.stop();
285
+ }
286
+ }
287
+ }, _callee7);
288
+ }));
289
+
290
+ function close(_x12) {
291
+ return _close.apply(this, arguments);
292
+ }
293
+
294
+ return close;
295
+ }()
296
+ }, {
297
+ key: "_getFile",
298
+ value: function _getFile(path, used) {
299
+ var file = this.files[path] || this.lowerCaseFiles[path];
300
+
301
+ if (file && used) {
302
+ this.usedFiles[path] = true;
303
+ }
304
+
305
+ return file;
306
+ }
307
+ }]);
308
+ return BrowserFileSystem;
309
+ }();
121
310
 
122
311
  exports.default = BrowserFileSystem;
123
312
  //# sourceMappingURL=browser-filesystem.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/filesystems/browser-filesystem.ts"],"names":["BrowserFileSystem","constructor","files","options","_fetch","fetch","i","length","file","name","lowerCaseFiles","toLowerCase","usedFiles","bind","path","includes","Response","status","statusText","headers","Headers","range","get","bytes","exec","start","parseInt","end","data","slice","arrayBuffer","response","Object","defineProperty","value","readdir","dirname","push","stat","Error","size","unlink","open","pathname","flags","mode","read","fd","buffer","offset","byteLength","position","startPosition","bytesRead","close","_getFile","used"],"mappings":"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","sourcesContent":["import type {FileSystem} from './filesystem';\n\ntype BrowserFileSystemOptions = {\n fetch?: typeof fetch;\n};\n\n/**\n * FileSystem adapter for a browser FileList.\n * Holds a list of browser 'File' objects.\n */\nexport default class BrowserFileSystem implements FileSystem {\n private _fetch: typeof fetch;\n private files: {[filename: string]: File} = {};\n private lowerCaseFiles: {[filename: string]: File} = {};\n private usedFiles: {[filename: string]: boolean} = {};\n\n /**\n * A FileSystem API wrapper around a list of browser 'File' objects\n * @param files\n * @param options\n */\n constructor(files: FileList | File[], options?: BrowserFileSystemOptions) {\n this._fetch = options?.fetch || fetch;\n\n for (let i = 0; i < files.length; ++i) {\n const file = files[i];\n this.files[file.name] = file;\n this.lowerCaseFiles[file.name.toLowerCase()] = file;\n this.usedFiles[file.name] = false;\n }\n\n this.fetch = this.fetch.bind(this);\n }\n\n // implements IFileSystem\n\n /**\n * Implementation of fetch against this file system\n * Delegates to global fetch for http{s}:// or data://\n */\n async fetch(path: string, options?: RequestInit): Promise<Response> {\n // Fallback to handle https:/http:/data: etc fetches\n if (path.includes('://')) {\n return this._fetch(path, options);\n }\n\n // Local fetches are served from the list of files\n const file = this.files[path];\n if (!file) {\n return new Response(path, {status: 400, statusText: 'NOT FOUND'});\n }\n\n const headers = new Headers(options?.headers);\n const range = headers.get('Range');\n const bytes = range && /bytes=($1)-($2)/.exec(range);\n\n if (bytes) {\n const start = parseInt(bytes[1]);\n const end = parseInt(bytes[2]);\n // The trick when reading File objects is to read successive \"slices\" of the File\n // Per spec https://w3c.github.io/FileAPI/, slicing a File should only update the start and end fields\n // Actually reading from file should happen in `readAsArrayBuffer` (and as far we can tell it does)\n const data = await file.slice(start, end).arrayBuffer();\n const response = new Response(data);\n Object.defineProperty(response, 'url', {value: path});\n return response;\n }\n\n // return makeResponse()\n const response = new Response(file);\n Object.defineProperty(response, 'url', {value: path});\n return response;\n }\n\n /**\n * List filenames in this filesystem\n * @param dirname\n * @returns\n */\n async readdir(dirname?: string): Promise<string[]> {\n const files: string[] = [];\n for (const path in this.files) {\n files.push(path);\n }\n // TODO filter by dirname\n return files;\n }\n\n /**\n * Return information (size) about files in this file system\n */\n async stat(path: string, options?: object): Promise<{size: number}> {\n const file = this.files[path];\n if (!file) {\n throw new Error(path);\n }\n return {size: file.size};\n }\n\n /**\n * Just removes the file from the list\n */\n async unlink(path: string): Promise<void> {\n delete this.files[path];\n delete this.lowerCaseFiles[path];\n this.usedFiles[path] = true;\n }\n\n // implements IRandomAccessFileSystem\n\n // RANDOM ACCESS\n async open(pathname: string, flags, mode?): Promise<any> {\n return this.files[pathname];\n }\n\n /**\n * Read a range into a buffer\n * @todo - handle position memory\n * @param buffer is the buffer that the data (read from the fd) will be written to.\n * @param offset is the offset in the buffer to start writing at.\n * @param length is an integer specifying the number of bytes to read.\n * @param position is an argument specifying where to begin reading from in the file. If position is null, data will be read from the current file position, and the file position will be updated. If position is an integer, the file position will remain unchanged.\n */\n async read(\n fd: any,\n buffer: ArrayBuffer,\n offset: number = 0,\n length: number = buffer.byteLength,\n position: number | null = null\n ): Promise<{bytesRead: number; buffer: ArrayBuffer}> {\n const file = fd as File;\n const startPosition = 0; // position\n const arrayBuffer = await file.slice(startPosition, startPosition + length).arrayBuffer();\n // copy into target buffer\n return {bytesRead: length, buffer: arrayBuffer};\n }\n\n async close(fd: number): Promise<void> {\n // NO OP\n }\n\n // fstat(fd: number): Promise<object>; // Stat\n\n // PRIVATE\n\n // Supports case independent paths, and file usage tracking\n _getFile(path, used) {\n // Prefer case match, but fall back to case indepent.\n const file = this.files[path] || this.lowerCaseFiles[path];\n if (file && used) {\n this.usedFiles[path] = true;\n }\n return file;\n }\n}\n"],"file":"browser-filesystem.js"}
1
+ {"version":3,"sources":["../../../../src/lib/filesystems/browser-filesystem.ts"],"names":["BrowserFileSystem","files","options","_fetch","fetch","i","length","file","name","lowerCaseFiles","toLowerCase","usedFiles","bind","path","includes","Response","status","statusText","headers","Headers","range","get","bytes","exec","start","parseInt","end","slice","arrayBuffer","data","response","Object","defineProperty","value","dirname","push","Error","size","pathname","flags","mode","fd","buffer","offset","byteLength","position","startPosition","bytesRead","used"],"mappings":"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","sourcesContent":["import type {FileSystem} from './filesystem';\n\ntype BrowserFileSystemOptions = {\n fetch?: typeof fetch;\n};\n\n/**\n * FileSystem adapter for a browser FileList.\n * Holds a list of browser 'File' objects.\n */\nexport default class BrowserFileSystem implements FileSystem {\n private _fetch: typeof fetch;\n private files: {[filename: string]: File} = {};\n private lowerCaseFiles: {[filename: string]: File} = {};\n private usedFiles: {[filename: string]: boolean} = {};\n\n /**\n * A FileSystem API wrapper around a list of browser 'File' objects\n * @param files\n * @param options\n */\n constructor(files: FileList | File[], options?: BrowserFileSystemOptions) {\n this._fetch = options?.fetch || fetch;\n\n for (let i = 0; i < files.length; ++i) {\n const file = files[i];\n this.files[file.name] = file;\n this.lowerCaseFiles[file.name.toLowerCase()] = file;\n this.usedFiles[file.name] = false;\n }\n\n this.fetch = this.fetch.bind(this);\n }\n\n // implements IFileSystem\n\n /**\n * Implementation of fetch against this file system\n * Delegates to global fetch for http{s}:// or data://\n */\n async fetch(path: string, options?: RequestInit): Promise<Response> {\n // Fallback to handle https:/http:/data: etc fetches\n if (path.includes('://')) {\n return this._fetch(path, options);\n }\n\n // Local fetches are served from the list of files\n const file = this.files[path];\n if (!file) {\n return new Response(path, {status: 400, statusText: 'NOT FOUND'});\n }\n\n const headers = new Headers(options?.headers);\n const range = headers.get('Range');\n const bytes = range && /bytes=($1)-($2)/.exec(range);\n\n if (bytes) {\n const start = parseInt(bytes[1]);\n const end = parseInt(bytes[2]);\n // The trick when reading File objects is to read successive \"slices\" of the File\n // Per spec https://w3c.github.io/FileAPI/, slicing a File should only update the start and end fields\n // Actually reading from file should happen in `readAsArrayBuffer` (and as far we can tell it does)\n const data = await file.slice(start, end).arrayBuffer();\n const response = new Response(data);\n Object.defineProperty(response, 'url', {value: path});\n return response;\n }\n\n // return makeResponse()\n const response = new Response(file);\n Object.defineProperty(response, 'url', {value: path});\n return response;\n }\n\n /**\n * List filenames in this filesystem\n * @param dirname\n * @returns\n */\n async readdir(dirname?: string): Promise<string[]> {\n const files: string[] = [];\n for (const path in this.files) {\n files.push(path);\n }\n // TODO filter by dirname\n return files;\n }\n\n /**\n * Return information (size) about files in this file system\n */\n async stat(path: string, options?: object): Promise<{size: number}> {\n const file = this.files[path];\n if (!file) {\n throw new Error(path);\n }\n return {size: file.size};\n }\n\n /**\n * Just removes the file from the list\n */\n async unlink(path: string): Promise<void> {\n delete this.files[path];\n delete this.lowerCaseFiles[path];\n this.usedFiles[path] = true;\n }\n\n // implements IRandomAccessFileSystem\n\n // RANDOM ACCESS\n async open(pathname: string, flags, mode?): Promise<any> {\n return this.files[pathname];\n }\n\n /**\n * Read a range into a buffer\n * @todo - handle position memory\n * @param buffer is the buffer that the data (read from the fd) will be written to.\n * @param offset is the offset in the buffer to start writing at.\n * @param length is an integer specifying the number of bytes to read.\n * @param position is an argument specifying where to begin reading from in the file. If position is null, data will be read from the current file position, and the file position will be updated. If position is an integer, the file position will remain unchanged.\n */\n async read(\n fd: any,\n buffer: ArrayBuffer,\n offset: number = 0,\n length: number = buffer.byteLength,\n position: number | null = null\n ): Promise<{bytesRead: number; buffer: ArrayBuffer}> {\n const file = fd as File;\n const startPosition = 0; // position\n const arrayBuffer = await file.slice(startPosition, startPosition + length).arrayBuffer();\n // copy into target buffer\n return {bytesRead: length, buffer: arrayBuffer};\n }\n\n async close(fd: number): Promise<void> {\n // NO OP\n }\n\n // fstat(fd: number): Promise<object>; // Stat\n\n // PRIVATE\n\n // Supports case independent paths, and file usage tracking\n _getFile(path, used) {\n // Prefer case match, but fall back to case indepent.\n const file = this.files[path] || this.lowerCaseFiles[path];\n if (file && used) {\n this.usedFiles[path] = true;\n }\n return file;\n }\n}\n"],"file":"browser-filesystem.js"}
@@ -1,16 +1,53 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
8
  exports.readArrayBuffer = readArrayBuffer;
7
9
 
8
- async function readArrayBuffer(file, start, length) {
9
- if (file instanceof Blob) {
10
- const slice = file.slice(start, start + length);
11
- return await slice.arrayBuffer();
12
- }
10
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
+
12
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
13
+
14
+ function readArrayBuffer(_x, _x2, _x3) {
15
+ return _readArrayBuffer.apply(this, arguments);
16
+ }
17
+
18
+ function _readArrayBuffer() {
19
+ _readArrayBuffer = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(file, start, length) {
20
+ var slice;
21
+ return _regenerator.default.wrap(function _callee$(_context) {
22
+ while (1) {
23
+ switch (_context.prev = _context.next) {
24
+ case 0:
25
+ if (!(file instanceof Blob)) {
26
+ _context.next = 5;
27
+ break;
28
+ }
29
+
30
+ slice = file.slice(start, start + length);
31
+ _context.next = 4;
32
+ return slice.arrayBuffer();
33
+
34
+ case 4:
35
+ return _context.abrupt("return", _context.sent);
36
+
37
+ case 5:
38
+ _context.next = 7;
39
+ return file.read(start, start + length);
40
+
41
+ case 7:
42
+ return _context.abrupt("return", _context.sent);
13
43
 
14
- return await file.read(start, start + length);
44
+ case 8:
45
+ case "end":
46
+ return _context.stop();
47
+ }
48
+ }
49
+ }, _callee);
50
+ }));
51
+ return _readArrayBuffer.apply(this, arguments);
15
52
  }
16
53
  //# sourceMappingURL=read-array-buffer.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/filesystems/read-array-buffer.ts"],"names":["readArrayBuffer","file","start","length","Blob","slice","arrayBuffer","read"],"mappings":";;;;;;;AAEO,eAAeA,eAAf,CACLC,IADK,EAELC,KAFK,EAGLC,MAHK,EAIiB;AACtB,MAAIF,IAAI,YAAYG,IAApB,EAA0B;AACxB,UAAMC,KAAK,GAAGJ,IAAI,CAACI,KAAL,CAAWH,KAAX,EAAkBA,KAAK,GAAGC,MAA1B,CAAd;AACA,WAAO,MAAME,KAAK,CAACC,WAAN,EAAb;AACD;;AACD,SAAO,MAAML,IAAI,CAACM,IAAL,CAAUL,KAAV,EAAiBA,KAAK,GAAGC,MAAzB,CAAb;AACD","sourcesContent":["// Random-Access read\n\nexport async function readArrayBuffer(\n file: Blob | ArrayBuffer | any,\n start: number,\n length: number\n): Promise<ArrayBuffer> {\n if (file instanceof Blob) {\n const slice = file.slice(start, start + length);\n return await slice.arrayBuffer();\n }\n return await file.read(start, start + length);\n}\n\n/**\n * Read a slice of a Blob or File, without loading the entire file into memory\n * The trick when reading File objects is to read successive \"slices\" of the File\n * Per spec https://w3c.github.io/FileAPI/, slicing a File only updates the start and end fields\n * Actually reading from file happens in `readAsArrayBuffer`\n * @param blob to read\n export async function readBlob(blob: Blob): Promise<ArrayBuffer> {\n return await new Promise((resolve, reject) => {\n const fileReader = new FileReader();\n fileReader.onload = (event: ProgressEvent<FileReader>) =>\n resolve(event?.target?.result as ArrayBuffer);\n // TODO - reject with a proper Error\n fileReader.onerror = (error: ProgressEvent<FileReader>) => reject(error);\n fileReader.readAsArrayBuffer(blob);\n });\n}\n*/\n"],"file":"read-array-buffer.js"}
1
+ {"version":3,"sources":["../../../../src/lib/filesystems/read-array-buffer.ts"],"names":["readArrayBuffer","file","start","length","Blob","slice","arrayBuffer","read"],"mappings":";;;;;;;;;;;;;SAEsBA,e;;;;;+EAAf,iBACLC,IADK,EAELC,KAFK,EAGLC,MAHK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kBAKDF,IAAI,YAAYG,IALf;AAAA;AAAA;AAAA;;AAMGC,YAAAA,KANH,GAMWJ,IAAI,CAACI,KAAL,CAAWH,KAAX,EAAkBA,KAAK,GAAGC,MAA1B,CANX;AAAA;AAAA,mBAOUE,KAAK,CAACC,WAAN,EAPV;;AAAA;AAAA;;AAAA;AAAA;AAAA,mBASQL,IAAI,CAACM,IAAL,CAAUL,KAAV,EAAiBA,KAAK,GAAGC,MAAzB,CATR;;AAAA;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G","sourcesContent":["// Random-Access read\n\nexport async function readArrayBuffer(\n file: Blob | ArrayBuffer | any,\n start: number,\n length: number\n): Promise<ArrayBuffer> {\n if (file instanceof Blob) {\n const slice = file.slice(start, start + length);\n return await slice.arrayBuffer();\n }\n return await file.read(start, start + length);\n}\n\n/**\n * Read a slice of a Blob or File, without loading the entire file into memory\n * The trick when reading File objects is to read successive \"slices\" of the File\n * Per spec https://w3c.github.io/FileAPI/, slicing a File only updates the start and end fields\n * Actually reading from file happens in `readAsArrayBuffer`\n * @param blob to read\n export async function readBlob(blob: Blob): Promise<ArrayBuffer> {\n return await new Promise((resolve, reject) => {\n const fileReader = new FileReader();\n fileReader.onload = (event: ProgressEvent<FileReader>) =>\n resolve(event?.target?.result as ArrayBuffer);\n // TODO - reject with a proper Error\n fileReader.onerror = (error: ProgressEvent<FileReader>) => reject(error);\n fileReader.readAsArrayBuffer(blob);\n });\n}\n*/\n"],"file":"read-array-buffer.js"}
@@ -4,7 +4,7 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
- const version = typeof "3.1.0-beta.7" !== 'undefined' ? "3.1.0-beta.7" : '';
7
+ var version = typeof "3.1.3" !== 'undefined' ? "3.1.3" : '';
8
8
  globalThis.loaders = Object.assign(globalThis.loaders || {}, {
9
9
  VERSION: version
10
10
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/init.ts"],"names":["version","globalThis","loaders","Object","assign","VERSION"],"mappings":";;;;;;AACA,MAAMA,OAAO,GAAG,0BAAuB,WAAvB,oBAAmD,EAAnE;AAGAC,UAAU,CAACC,OAAX,GAAqBC,MAAM,CAACC,MAAP,CAAcH,UAAU,CAACC,OAAX,IAAsB,EAApC,EAAwC;AAC3DG,EAAAA,OAAO,EAAEL;AADkD,CAAxC,CAArB;eAKeC,UAAU,CAACC,O","sourcesContent":["// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst version = typeof __VERSION__ !== 'undefined' ? __VERSION__ : '';\n\n// @ts-ignore\nglobalThis.loaders = Object.assign(globalThis.loaders || {}, {\n VERSION: version\n});\n\n// @ts-ignore\nexport default globalThis.loaders;\n"],"file":"init.js"}
1
+ {"version":3,"sources":["../../../src/lib/init.ts"],"names":["version","globalThis","loaders","Object","assign","VERSION"],"mappings":";;;;;;AACA,IAAMA,OAAO,GAAG,mBAAuB,WAAvB,aAAmD,EAAnE;AAGAC,UAAU,CAACC,OAAX,GAAqBC,MAAM,CAACC,MAAP,CAAcH,UAAU,CAACC,OAAX,IAAsB,EAApC,EAAwC;AAC3DG,EAAAA,OAAO,EAAEL;AADkD,CAAxC,CAArB;eAKeC,UAAU,CAACC,O","sourcesContent":["// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst version = typeof __VERSION__ !== 'undefined' ? __VERSION__ : '';\n\n// @ts-ignore\nglobalThis.loaders = Object.assign(globalThis.loaders || {}, {\n VERSION: version\n});\n\n// @ts-ignore\nexport default globalThis.loaders;\n"],"file":"init.js"}
@@ -1,25 +1,63 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
8
  exports.checkFetchResponseStatus = checkFetchResponseStatus;
7
9
  exports.checkFetchResponseStatusSync = checkFetchResponseStatusSync;
8
10
 
9
- async function checkFetchResponseStatus(response) {
10
- if (!response.ok) {
11
- let errorMessage = "fetch failed ".concat(response.status, " ").concat(response.statusText);
11
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
12
12
 
13
- try {
14
- const text = await response.text();
13
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
15
14
 
16
- if (text) {
17
- errorMessage += ": ".concat(getErrorText(text));
18
- }
19
- } catch (error) {}
15
+ function checkFetchResponseStatus(_x) {
16
+ return _checkFetchResponseStatus.apply(this, arguments);
17
+ }
20
18
 
21
- throw new Error(errorMessage);
22
- }
19
+ function _checkFetchResponseStatus() {
20
+ _checkFetchResponseStatus = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(response) {
21
+ var errorMessage, text;
22
+ return _regenerator.default.wrap(function _callee$(_context) {
23
+ while (1) {
24
+ switch (_context.prev = _context.next) {
25
+ case 0:
26
+ if (response.ok) {
27
+ _context.next = 12;
28
+ break;
29
+ }
30
+
31
+ errorMessage = "fetch failed ".concat(response.status, " ").concat(response.statusText);
32
+ _context.prev = 2;
33
+ _context.next = 5;
34
+ return response.text();
35
+
36
+ case 5:
37
+ text = _context.sent;
38
+
39
+ if (text) {
40
+ errorMessage += ": ".concat(getErrorText(text));
41
+ }
42
+
43
+ _context.next = 11;
44
+ break;
45
+
46
+ case 9:
47
+ _context.prev = 9;
48
+ _context.t0 = _context["catch"](2);
49
+
50
+ case 11:
51
+ throw new Error(errorMessage);
52
+
53
+ case 12:
54
+ case "end":
55
+ return _context.stop();
56
+ }
57
+ }
58
+ }, _callee, null, [[2, 9]]);
59
+ }));
60
+ return _checkFetchResponseStatus.apply(this, arguments);
23
61
  }
24
62
 
25
63
  function checkFetchResponseStatusSync(response) {
@@ -29,7 +67,7 @@ function checkFetchResponseStatusSync(response) {
29
67
  }
30
68
 
31
69
  function getErrorText(text) {
32
- const matches = text.match('<pre>(.*)</pre>');
70
+ var matches = text.match('<pre>(.*)</pre>');
33
71
  return matches ? matches[1] : " ".concat(text.slice(0, 10), "...");
34
72
  }
35
73
  //# sourceMappingURL=check-errors.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/lib/loader-utils/check-errors.ts"],"names":["checkFetchResponseStatus","response","ok","errorMessage","status","statusText","text","getErrorText","error","Error","checkFetchResponseStatusSync","matches","match","slice"],"mappings":";;;;;;;;AAAO,eAAeA,wBAAf,CAAwCC,QAAxC,EAAkD;AACvD,MAAI,CAACA,QAAQ,CAACC,EAAd,EAAkB;AAChB,QAAIC,YAAY,0BAAmBF,QAAQ,CAACG,MAA5B,cAAsCH,QAAQ,CAACI,UAA/C,CAAhB;;AACA,QAAI;AACF,YAAMC,IAAI,GAAG,MAAML,QAAQ,CAACK,IAAT,EAAnB;;AACA,UAAIA,IAAJ,EAAU;AACRH,QAAAA,YAAY,gBAASI,YAAY,CAACD,IAAD,CAArB,CAAZ;AACD;AACF,KALD,CAKE,OAAOE,KAAP,EAAc,CAEf;;AACD,UAAM,IAAIC,KAAJ,CAAUN,YAAV,CAAN;AACD;AACF;;AAEM,SAASO,4BAAT,CAAsCT,QAAtC,EAAgD;AACrD,MAAI,CAACA,QAAQ,CAACC,EAAd,EAAkB;AAChB,UAAM,IAAIO,KAAJ,wBAA0BR,QAAQ,CAACG,MAAnC,EAAN;AACD;AACF;;AAED,SAASG,YAAT,CAAsBD,IAAtB,EAA4B;AAE1B,QAAMK,OAAO,GAAGL,IAAI,CAACM,KAAL,CAAW,iBAAX,CAAhB;AACA,SAAOD,OAAO,GAAGA,OAAO,CAAC,CAAD,CAAV,cAAoBL,IAAI,CAACO,KAAL,CAAW,CAAX,EAAc,EAAd,CAApB,QAAd;AACD","sourcesContent":["export async function checkFetchResponseStatus(response) {\n if (!response.ok) {\n let errorMessage = `fetch failed ${response.status} ${response.statusText}`;\n try {\n const text = await response.text();\n if (text) {\n errorMessage += `: ${getErrorText(text)}`;\n }\n } catch (error) {\n // ignore error\n }\n throw new Error(errorMessage);\n }\n}\n\nexport function checkFetchResponseStatusSync(response) {\n if (!response.ok) {\n throw new Error(`fetch failed ${response.status}`);\n }\n}\n\nfunction getErrorText(text) {\n // Look for HTML error texts\n const matches = text.match('<pre>(.*)</pre>');\n return matches ? matches[1] : ` ${text.slice(0, 10)}...`;\n}\n"],"file":"check-errors.js"}
1
+ {"version":3,"sources":["../../../../src/lib/loader-utils/check-errors.ts"],"names":["checkFetchResponseStatus","response","ok","errorMessage","status","statusText","text","getErrorText","Error","checkFetchResponseStatusSync","matches","match","slice"],"mappings":";;;;;;;;;;;;;;SAAsBA,wB;;;;;wFAAf,iBAAwCC,QAAxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBACAA,QAAQ,CAACC,EADT;AAAA;AAAA;AAAA;;AAECC,YAAAA,YAFD,0BAEgCF,QAAQ,CAACG,MAFzC,cAEmDH,QAAQ,CAACI,UAF5D;AAAA;AAAA;AAAA,mBAIkBJ,QAAQ,CAACK,IAAT,EAJlB;;AAAA;AAIKA,YAAAA,IAJL;;AAKD,gBAAIA,IAAJ,EAAU;AACRH,cAAAA,YAAY,gBAASI,YAAY,CAACD,IAAD,CAArB,CAAZ;AACD;;AAPA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA,kBAWG,IAAIE,KAAJ,CAAUL,YAAV,CAXH;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,G;;;;AAeA,SAASM,4BAAT,CAAsCR,QAAtC,EAAgD;AACrD,MAAI,CAACA,QAAQ,CAACC,EAAd,EAAkB;AAChB,UAAM,IAAIM,KAAJ,wBAA0BP,QAAQ,CAACG,MAAnC,EAAN;AACD;AACF;;AAED,SAASG,YAAT,CAAsBD,IAAtB,EAA4B;AAE1B,MAAMI,OAAO,GAAGJ,IAAI,CAACK,KAAL,CAAW,iBAAX,CAAhB;AACA,SAAOD,OAAO,GAAGA,OAAO,CAAC,CAAD,CAAV,cAAoBJ,IAAI,CAACM,KAAL,CAAW,CAAX,EAAc,EAAd,CAApB,QAAd;AACD","sourcesContent":["export async function checkFetchResponseStatus(response) {\n if (!response.ok) {\n let errorMessage = `fetch failed ${response.status} ${response.statusText}`;\n try {\n const text = await response.text();\n if (text) {\n errorMessage += `: ${getErrorText(text)}`;\n }\n } catch (error) {\n // ignore error\n }\n throw new Error(errorMessage);\n }\n}\n\nexport function checkFetchResponseStatusSync(response) {\n if (!response.ok) {\n throw new Error(`fetch failed ${response.status}`);\n }\n}\n\nfunction getErrorText(text) {\n // Look for HTML error texts\n const matches = text.match('<pre>(.*)</pre>');\n return matches ? matches[1] : ` ${text.slice(0, 10)}...`;\n}\n"],"file":"check-errors.js"}