@loaders.gl/core 3.1.3 → 4.0.0-alpha.5
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/bundle.js +2 -2
- package/dist/bundle.js.map +1 -0
- package/dist/{es5/core-addons → core-addons}/README.md +0 -0
- package/dist/core-addons/write-file-browser.js +1 -59
- package/dist/{es5/core-addons → core-addons}/write-file-browser.js.map +0 -0
- package/dist/dist.min.js +18 -18
- package/dist/index.js +29 -102
- package/dist/index.js.map +1 -0
- package/dist/iterators/batch-iterators/timed-batch-iterator.js +17 -20
- package/dist/iterators/batch-iterators/timed-batch-iterator.js.map +1 -0
- package/dist/iterators/make-iterator/make-array-buffer-iterator.js +16 -25
- package/dist/iterators/make-iterator/make-array-buffer-iterator.js.map +1 -0
- package/dist/iterators/make-iterator/make-blob-iterator.js +12 -20
- package/dist/iterators/make-iterator/make-blob-iterator.js.map +1 -0
- package/dist/iterators/make-iterator/make-iterator.js +29 -36
- package/dist/iterators/make-iterator/make-iterator.js.map +1 -0
- package/dist/iterators/make-iterator/make-stream-iterator.js +32 -89
- package/dist/iterators/make-iterator/make-stream-iterator.js.map +1 -0
- package/dist/iterators/make-iterator/make-string-iterator.js +12 -22
- package/dist/iterators/make-iterator/make-string-iterator.js.map +1 -0
- package/dist/iterators/make-stream/make-dom-stream.js +32 -44
- package/dist/iterators/make-stream/make-dom-stream.js.map +1 -0
- package/dist/iterators/make-stream/make-node-stream.js +68 -50
- package/dist/iterators/make-stream/make-node-stream.js.map +1 -0
- package/dist/javascript-utils/is-type.js +21 -41
- package/dist/javascript-utils/is-type.js.map +1 -0
- package/dist/lib/api/encode.js +81 -101
- package/dist/lib/api/encode.js.map +1 -0
- package/dist/lib/api/load-in-batches.js +27 -30
- package/dist/lib/api/load-in-batches.js.map +1 -0
- package/dist/lib/api/load.js +24 -40
- package/dist/lib/api/load.js.map +1 -0
- package/dist/lib/api/parse-in-batches.js +92 -113
- package/dist/lib/api/parse-in-batches.js.map +1 -0
- package/dist/lib/api/parse-sync.js +54 -56
- package/dist/lib/api/parse-sync.js.map +1 -0
- package/dist/lib/api/parse.js +61 -71
- package/dist/lib/api/parse.js.map +1 -0
- package/dist/lib/api/register-loaders.js +23 -29
- package/dist/lib/api/register-loaders.js.map +1 -0
- package/dist/lib/api/save.js +9 -13
- package/dist/lib/api/save.js.map +1 -0
- package/dist/lib/api/select-loader.js +194 -205
- package/dist/lib/api/select-loader.js.map +1 -0
- package/dist/lib/api/set-loader-options.js +4 -11
- package/dist/lib/api/set-loader-options.js.map +1 -0
- package/dist/lib/common.js +2 -2
- package/dist/{es5/lib → lib}/common.js.map +0 -0
- package/dist/lib/fetch/fetch-error-message.js +17 -21
- package/dist/lib/fetch/fetch-error-message.js.map +1 -0
- package/dist/lib/fetch/fetch-file.js +15 -25
- package/dist/lib/fetch/fetch-file.js.map +1 -0
- package/dist/lib/fetch/read-array-buffer.js +27 -39
- package/dist/lib/fetch/read-array-buffer.js.map +1 -0
- package/dist/lib/fetch/read-file.js +16 -28
- package/dist/lib/fetch/read-file.js.map +1 -0
- package/dist/lib/fetch/write-file.js +23 -20
- package/dist/lib/fetch/write-file.js.map +1 -0
- package/dist/lib/filesystems/browser-filesystem.js +107 -118
- package/dist/lib/filesystems/browser-filesystem.js.map +1 -0
- package/dist/lib/filesystems/filesystem.js +2 -2
- package/dist/{es5/lib → lib}/filesystems/filesystem.js.map +0 -0
- package/dist/lib/filesystems/read-array-buffer.js +8 -28
- package/dist/lib/filesystems/read-array-buffer.js.map +1 -0
- package/dist/lib/init.js +4 -8
- package/dist/lib/init.js.map +1 -0
- package/dist/lib/loader-utils/check-errors.js +22 -26
- package/dist/lib/loader-utils/check-errors.js.map +1 -0
- package/dist/lib/loader-utils/get-data.js +122 -122
- package/dist/lib/loader-utils/get-data.js.map +1 -0
- package/dist/lib/loader-utils/loader-context.js +34 -47
- package/dist/lib/loader-utils/loader-context.js.map +1 -0
- package/dist/lib/loader-utils/loggers.js +46 -39
- package/dist/lib/loader-utils/loggers.js.map +1 -0
- package/dist/lib/loader-utils/normalize-loader.js +41 -50
- package/dist/lib/loader-utils/normalize-loader.js.map +1 -0
- package/dist/lib/loader-utils/option-defaults.js +35 -39
- package/dist/lib/loader-utils/option-defaults.js.map +1 -0
- package/dist/lib/loader-utils/option-utils.js +119 -156
- package/dist/lib/loader-utils/option-utils.js.map +1 -0
- package/dist/lib/progress/fetch-progress.js +56 -54
- package/dist/lib/progress/fetch-progress.js.map +1 -0
- package/dist/lib/utils/mime-type-utils.js +17 -38
- package/dist/lib/utils/mime-type-utils.js.map +1 -0
- package/dist/lib/utils/resource-utils.js +52 -70
- package/dist/lib/utils/resource-utils.js.map +1 -0
- package/dist/lib/utils/response-utils.js +105 -104
- package/dist/lib/utils/response-utils.js.map +1 -0
- package/dist/null-loader.js +31 -41
- package/dist/null-loader.js.map +1 -0
- package/dist/null-worker.js +1 -1
- package/dist/workers/null-worker.js +4 -5
- package/dist/workers/null-worker.js.map +1 -0
- package/package.json +9 -7
- package/dist/es5/bundle.js +0 -7
- package/dist/es5/bundle.js.map +0 -1
- package/dist/es5/core-addons/write-file-browser.js +0 -2
- package/dist/es5/index.js +0 -374
- package/dist/es5/index.js.map +0 -1
- package/dist/es5/iterators/batch-iterators/timed-batch-iterator.js +0 -131
- package/dist/es5/iterators/batch-iterators/timed-batch-iterator.js.map +0 -1
- package/dist/es5/iterators/make-iterator/make-array-buffer-iterator.js +0 -61
- package/dist/es5/iterators/make-iterator/make-array-buffer-iterator.js.map +0 -1
- package/dist/es5/iterators/make-iterator/make-blob-iterator.js +0 -61
- package/dist/es5/iterators/make-iterator/make-blob-iterator.js.map +0 -1
- package/dist/es5/iterators/make-iterator/make-iterator.js +0 -42
- package/dist/es5/iterators/make-iterator/make-iterator.js.map +0 -1
- package/dist/es5/iterators/make-iterator/make-stream-iterator.js +0 -184
- package/dist/es5/iterators/make-iterator/make-stream-iterator.js.map +0 -1
- package/dist/es5/iterators/make-iterator/make-string-iterator.js +0 -49
- package/dist/es5/iterators/make-iterator/make-string-iterator.js.map +0 -1
- package/dist/es5/iterators/make-stream/make-dom-stream.js +0 -86
- package/dist/es5/iterators/make-stream/make-dom-stream.js.map +0 -1
- package/dist/es5/iterators/make-stream/make-node-stream.js +0 -217
- package/dist/es5/iterators/make-stream/make-node-stream.js.map +0 -1
- package/dist/es5/javascript-utils/is-type.js +0 -115
- package/dist/es5/javascript-utils/is-type.js.map +0 -1
- package/dist/es5/lib/api/encode.js +0 -304
- package/dist/es5/lib/api/encode.js.map +0 -1
- package/dist/es5/lib/api/load-in-batches.js +0 -83
- package/dist/es5/lib/api/load-in-batches.js.map +0 -1
- package/dist/es5/lib/api/load.js +0 -81
- package/dist/es5/lib/api/load.js.map +0 -1
- package/dist/es5/lib/api/parse-in-batches.js +0 -366
- package/dist/es5/lib/api/parse-in-batches.js.map +0 -1
- package/dist/es5/lib/api/parse-sync.js +0 -75
- package/dist/es5/lib/api/parse-sync.js.map +0 -1
- package/dist/es5/lib/api/parse.js +0 -171
- package/dist/es5/lib/api/parse.js.map +0 -1
- package/dist/es5/lib/api/register-loaders.js +0 -63
- package/dist/es5/lib/api/register-loaders.js.map +0 -1
- package/dist/es5/lib/api/save.js +0 -55
- package/dist/es5/lib/api/save.js.map +0 -1
- package/dist/es5/lib/api/select-loader.js +0 -378
- package/dist/es5/lib/api/select-loader.js.map +0 -1
- package/dist/es5/lib/api/set-loader-options.js +0 -13
- package/dist/es5/lib/api/set-loader-options.js.map +0 -1
- package/dist/es5/lib/common.js +0 -2
- package/dist/es5/lib/fetch/fetch-error-message.js +0 -72
- package/dist/es5/lib/fetch/fetch-error-message.js.map +0 -1
- package/dist/es5/lib/fetch/fetch-file.js +0 -63
- package/dist/es5/lib/fetch/fetch-file.js.map +0 -1
- package/dist/es5/lib/fetch/read-array-buffer.js +0 -100
- package/dist/es5/lib/fetch/read-array-buffer.js.map +0 -1
- package/dist/es5/lib/fetch/read-file.js +0 -26
- package/dist/es5/lib/fetch/read-file.js.map +0 -1
- package/dist/es5/lib/fetch/write-file.js +0 -63
- package/dist/es5/lib/fetch/write-file.js.map +0 -1
- package/dist/es5/lib/filesystems/browser-filesystem.js +0 -312
- package/dist/es5/lib/filesystems/browser-filesystem.js.map +0 -1
- package/dist/es5/lib/filesystems/filesystem.js +0 -2
- package/dist/es5/lib/filesystems/read-array-buffer.js +0 -53
- package/dist/es5/lib/filesystems/read-array-buffer.js.map +0 -1
- package/dist/es5/lib/init.js +0 -13
- package/dist/es5/lib/init.js.map +0 -1
- package/dist/es5/lib/loader-utils/check-errors.js +0 -73
- package/dist/es5/lib/loader-utils/check-errors.js.map +0 -1
- package/dist/es5/lib/loader-utils/get-data.js +0 -314
- package/dist/es5/lib/loader-utils/get-data.js.map +0 -1
- package/dist/es5/lib/loader-utils/loader-context.js +0 -57
- package/dist/es5/lib/loader-utils/loader-context.js.map +0 -1
- package/dist/es5/lib/loader-utils/loggers.js +0 -110
- package/dist/es5/lib/loader-utils/loggers.js.map +0 -1
- package/dist/es5/lib/loader-utils/normalize-loader.js +0 -59
- package/dist/es5/lib/loader-utils/normalize-loader.js.map +0 -1
- package/dist/es5/lib/loader-utils/option-defaults.js +0 -47
- package/dist/es5/lib/loader-utils/option-defaults.js.map +0 -1
- package/dist/es5/lib/loader-utils/option-utils.js +0 -191
- package/dist/es5/lib/loader-utils/option-utils.js.map +0 -1
- package/dist/es5/lib/progress/fetch-progress.js +0 -169
- package/dist/es5/lib/progress/fetch-progress.js.map +0 -1
- package/dist/es5/lib/utils/mime-type-utils.js +0 -30
- package/dist/es5/lib/utils/mime-type-utils.js.map +0 -1
- package/dist/es5/lib/utils/resource-utils.js +0 -72
- package/dist/es5/lib/utils/resource-utils.js.map +0 -1
- package/dist/es5/lib/utils/response-utils.js +0 -255
- package/dist/es5/lib/utils/response-utils.js.map +0 -1
- package/dist/es5/null-loader.js +0 -169
- package/dist/es5/null-loader.js.map +0 -1
- package/dist/es5/workers/null-worker.js +0 -8
- package/dist/es5/workers/null-worker.js.map +0 -1
- package/dist/esm/bundle.js +0 -5
- package/dist/esm/bundle.js.map +0 -1
- package/dist/esm/core-addons/README.md +0 -1
- package/dist/esm/core-addons/write-file-browser.js +0 -2
- package/dist/esm/core-addons/write-file-browser.js.map +0 -1
- package/dist/esm/index.js +0 -29
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/iterators/batch-iterators/timed-batch-iterator.js +0 -19
- package/dist/esm/iterators/batch-iterators/timed-batch-iterator.js.map +0 -1
- package/dist/esm/iterators/make-iterator/make-array-buffer-iterator.js +0 -18
- package/dist/esm/iterators/make-iterator/make-array-buffer-iterator.js.map +0 -1
- package/dist/esm/iterators/make-iterator/make-blob-iterator.js +0 -13
- package/dist/esm/iterators/make-iterator/make-blob-iterator.js.map +0 -1
- package/dist/esm/iterators/make-iterator/make-iterator.js +0 -30
- package/dist/esm/iterators/make-iterator/make-iterator.js.map +0 -1
- package/dist/esm/iterators/make-iterator/make-stream-iterator.js +0 -39
- package/dist/esm/iterators/make-iterator/make-stream-iterator.js.map +0 -1
- package/dist/esm/iterators/make-iterator/make-string-iterator.js +0 -14
- package/dist/esm/iterators/make-iterator/make-string-iterator.js.map +0 -1
- package/dist/esm/iterators/make-stream/make-dom-stream.js +0 -34
- package/dist/esm/iterators/make-stream/make-dom-stream.js.map +0 -1
- package/dist/esm/iterators/make-stream/make-node-stream.js +0 -74
- package/dist/esm/iterators/make-stream/make-node-stream.js.map +0 -1
- package/dist/esm/javascript-utils/is-type.js +0 -21
- package/dist/esm/javascript-utils/is-type.js.map +0 -1
- package/dist/esm/lib/api/encode.js +0 -91
- package/dist/esm/lib/api/encode.js.map +0 -1
- package/dist/esm/lib/api/load-in-batches.js +0 -30
- package/dist/esm/lib/api/load-in-batches.js.map +0 -1
- package/dist/esm/lib/api/load.js +0 -25
- package/dist/esm/lib/api/load.js.map +0 -1
- package/dist/esm/lib/api/parse-in-batches.js +0 -99
- package/dist/esm/lib/api/parse-in-batches.js.map +0 -1
- package/dist/esm/lib/api/parse-sync.js +0 -57
- package/dist/esm/lib/api/parse-sync.js.map +0 -1
- package/dist/esm/lib/api/parse.js +0 -64
- package/dist/esm/lib/api/parse.js.map +0 -1
- package/dist/esm/lib/api/register-loaders.js +0 -29
- package/dist/esm/lib/api/register-loaders.js.map +0 -1
- package/dist/esm/lib/api/save.js +0 -11
- package/dist/esm/lib/api/save.js.map +0 -1
- package/dist/esm/lib/api/select-loader.js +0 -228
- package/dist/esm/lib/api/select-loader.js.map +0 -1
- package/dist/esm/lib/api/set-loader-options.js +0 -5
- package/dist/esm/lib/api/set-loader-options.js.map +0 -1
- package/dist/esm/lib/common.js +0 -2
- package/dist/esm/lib/common.js.map +0 -1
- package/dist/esm/lib/fetch/fetch-error-message.js +0 -21
- package/dist/esm/lib/fetch/fetch-error-message.js.map +0 -1
- package/dist/esm/lib/fetch/fetch-file.js +0 -17
- package/dist/esm/lib/fetch/fetch-file.js.map +0 -1
- package/dist/esm/lib/fetch/read-array-buffer.js +0 -29
- package/dist/esm/lib/fetch/read-array-buffer.js.map +0 -1
- package/dist/esm/lib/fetch/read-file.js +0 -17
- package/dist/esm/lib/fetch/read-file.js.map +0 -1
- package/dist/esm/lib/fetch/write-file.js +0 -25
- package/dist/esm/lib/fetch/write-file.js.map +0 -1
- package/dist/esm/lib/filesystems/browser-filesystem.js +0 -115
- package/dist/esm/lib/filesystems/browser-filesystem.js.map +0 -1
- package/dist/esm/lib/filesystems/filesystem.js +0 -2
- package/dist/esm/lib/filesystems/filesystem.js.map +0 -1
- package/dist/esm/lib/filesystems/read-array-buffer.js +0 -9
- package/dist/esm/lib/filesystems/read-array-buffer.js.map +0 -1
- package/dist/esm/lib/init.js +0 -6
- package/dist/esm/lib/init.js.map +0 -1
- package/dist/esm/lib/loader-utils/check-errors.js +0 -26
- package/dist/esm/lib/loader-utils/check-errors.js.map +0 -1
- package/dist/esm/lib/loader-utils/get-data.js +0 -129
- package/dist/esm/lib/loader-utils/get-data.js.map +0 -1
- package/dist/esm/lib/loader-utils/loader-context.js +0 -36
- package/dist/esm/lib/loader-utils/loader-context.js.map +0 -1
- package/dist/esm/lib/loader-utils/loggers.js +0 -48
- package/dist/esm/lib/loader-utils/loggers.js.map +0 -1
- package/dist/esm/lib/loader-utils/normalize-loader.js +0 -43
- package/dist/esm/lib/loader-utils/normalize-loader.js.map +0 -1
- package/dist/esm/lib/loader-utils/option-defaults.js +0 -37
- package/dist/esm/lib/loader-utils/option-defaults.js.map +0 -1
- package/dist/esm/lib/loader-utils/option-utils.js +0 -140
- package/dist/esm/lib/loader-utils/option-utils.js.map +0 -1
- package/dist/esm/lib/progress/fetch-progress.js +0 -61
- package/dist/esm/lib/progress/fetch-progress.js.map +0 -1
- package/dist/esm/lib/utils/mime-type-utils.js +0 -21
- package/dist/esm/lib/utils/mime-type-utils.js.map +0 -1
- package/dist/esm/lib/utils/resource-utils.js +0 -60
- package/dist/esm/lib/utils/resource-utils.js.map +0 -1
- package/dist/esm/lib/utils/response-utils.js +0 -115
- package/dist/esm/lib/utils/response-utils.js.map +0 -1
- package/dist/esm/null-loader.js +0 -34
- package/dist/esm/null-loader.js.map +0 -1
- package/dist/esm/workers/null-worker.js +0 -4
- package/dist/esm/workers/null-worker.js.map +0 -1
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { isBrowser, toArrayBuffer } from '@loaders.gl/loader-utils';
|
|
2
|
-
export function makeStreamIterator(stream, options) {
|
|
3
|
-
return isBrowser ? makeBrowserStreamIterator(stream, options) : makeNodeStreamIterator(stream, options);
|
|
4
|
-
}
|
|
5
|
-
|
|
6
|
-
async function* makeBrowserStreamIterator(stream, options) {
|
|
7
|
-
const reader = stream.getReader();
|
|
8
|
-
let nextBatchPromise;
|
|
9
|
-
|
|
10
|
-
try {
|
|
11
|
-
while (true) {
|
|
12
|
-
const currentBatchPromise = nextBatchPromise || reader.read();
|
|
13
|
-
|
|
14
|
-
if (options !== null && options !== void 0 && options._streamReadAhead) {
|
|
15
|
-
nextBatchPromise = reader.read();
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
const {
|
|
19
|
-
done,
|
|
20
|
-
value
|
|
21
|
-
} = await currentBatchPromise;
|
|
22
|
-
|
|
23
|
-
if (done) {
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
yield toArrayBuffer(value);
|
|
28
|
-
}
|
|
29
|
-
} catch (error) {
|
|
30
|
-
reader.releaseLock();
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
async function* makeNodeStreamIterator(stream, options) {
|
|
35
|
-
for await (const chunk of stream) {
|
|
36
|
-
yield toArrayBuffer(chunk);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
//# sourceMappingURL=make-stream-iterator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/iterators/make-iterator/make-stream-iterator.ts"],"names":["isBrowser","toArrayBuffer","makeStreamIterator","stream","options","makeBrowserStreamIterator","makeNodeStreamIterator","reader","getReader","nextBatchPromise","currentBatchPromise","read","_streamReadAhead","done","value","error","releaseLock","chunk"],"mappings":"AACA,SAAQA,SAAR,EAAmBC,aAAnB,QAAuC,0BAAvC;AAUA,OAAO,SAASC,kBAAT,CACLC,MADK,EAELC,OAFK,EAGuB;AAC5B,SAAOJ,SAAS,GACZK,yBAAyB,CAACF,MAAD,EAA2BC,OAA3B,CADb,GAEZE,sBAAsB,CAACH,MAAD,EAAqBC,OAArB,CAF1B;AAGD;;AAOD,gBAAgBC,yBAAhB,CACEF,MADF,EAEEC,OAFF,EAG8B;AAU5B,QAAMG,MAAM,GAAGJ,MAAM,CAACK,SAAP,EAAf;AAEA,MAAIC,gBAAJ;;AAEA,MAAI;AAEF,WAAO,IAAP,EAAa;AACX,YAAMC,mBAAmB,GAAGD,gBAAgB,IAAIF,MAAM,CAACI,IAAP,EAAhD;;AAGA,UAAIP,OAAJ,aAAIA,OAAJ,eAAIA,OAAO,CAAEQ,gBAAb,EAA+B;AAC7BH,QAAAA,gBAAgB,GAAGF,MAAM,CAACI,IAAP,EAAnB;AACD;;AAGD,YAAM;AAACE,QAAAA,IAAD;AAAOC,QAAAA;AAAP,UAAgB,MAAMJ,mBAA5B;;AAEA,UAAIG,IAAJ,EAAU;AACR;AACD;;AAED,YAAMZ,aAAa,CAACa,KAAD,CAAnB;AACD;AACF,GAnBD,CAmBE,OAAOC,KAAP,EAAc;AAGdR,IAAAA,MAAM,CAACS,WAAP;AACD;AACF;;AAOD,gBAAgBV,sBAAhB,CACEH,MADF,EAEEC,OAFF,EAG8B;AAG5B,aAAW,MAAMa,KAAjB,IAA0Bd,MAA1B,EAAkC;AAChC,UAAMF,aAAa,CAACgB,KAAD,CAAnB;AACD;AACF","sourcesContent":["import type {Readable} from 'stream';\nimport {isBrowser, toArrayBuffer} from '@loaders.gl/loader-utils';\n\nexport type StreamIteratorOptions = {\n _streamReadAhead?: boolean;\n};\n\n/**\n * Returns an async iterable that reads from a stream (works in both Node.js and browsers)\n * @param stream stream to iterator over\n */\nexport function makeStreamIterator(\n stream: ReadableStream | Readable,\n options?: StreamIteratorOptions\n): AsyncIterable<ArrayBuffer> {\n return isBrowser\n ? makeBrowserStreamIterator(stream as ReadableStream, options)\n : makeNodeStreamIterator(stream as Readable, options);\n}\n\n/**\n * Returns an async iterable that reads from a DOM (browser) stream\n * @param stream stream to iterate from\n * @see https://jakearchibald.com/2017/async-iterators-and-generators/#making-streams-iterate\n */\nasync function* makeBrowserStreamIterator(\n stream: ReadableStream,\n options?: StreamIteratorOptions\n): AsyncIterable<ArrayBuffer> {\n // WhatWG: stream is supposed to have a `getIterator` method\n // if (typeof stream.getIterator === 'function') {\n // return stream.getIterator();\n // }\n // if (typeof stream[Symbol.asyncIterator] === 'function') {\n // return makeToArrayBufferIterator(stream);\n // }\n\n // In the browser, we first need to get a lock on the stream\n const reader = stream.getReader();\n\n let nextBatchPromise: Promise<{done?: boolean; value?: Uint8Array}> | undefined;\n\n try {\n // eslint-disable-next-line no-constant-condition\n while (true) {\n const currentBatchPromise = nextBatchPromise || reader.read();\n // Issue a read for an additional batch, while we await the next batch\n // Idea is to make fetching happen in parallel with processing / parsing\n if (options?._streamReadAhead) {\n nextBatchPromise = reader.read();\n }\n // Read from the stream\n // value is a Uint8Array\n const {done, value} = await currentBatchPromise;\n // Exit if we're done\n if (done) {\n return;\n }\n // Else yield the chunk\n yield toArrayBuffer(value);\n }\n } catch (error) {\n // TODO - examples makes it look like this should always be called,\n // but that generates exceptions so only call it if we do not reach the end\n reader.releaseLock();\n }\n}\n\n/**\n * Returns an async iterable that reads from a DOM (browser) stream\n * @param stream stream to iterate from\n * @note Requires Node.js >= 10\n */\nasync function* makeNodeStreamIterator(\n stream: Readable,\n options?: StreamIteratorOptions\n): AsyncIterable<ArrayBuffer> {\n // Hacky test for node version to ensure we don't call bad polyfills\n // NODE 10+: stream is an asyncIterator\n for await (const chunk of stream) {\n yield toArrayBuffer(chunk); // Coerce each chunk to ArrayBuffer\n }\n}\n/* TODO - remove NODE < 10\n * @see https://github.com/bustle/streaming-iterables, MIT license\n *\n if (typeof stream[Symbol.asyncIterator] === 'function') {\n return;\n }\n\n // TODO - check if is this ever used in Node 10+?\n // eslint-disable-next-line no-constant-condition\n while (true) {\n const data = stream.read();\n if (data !== null) {\n yield toArrayBuffer(data);\n // eslint-disable-next-line no-continue\n continue;\n }\n if (stream._readableState?.ended) {\n return;\n }\n await onceReadable(stream);\n }\n\nasync function onceReadable(stream: Readable): Promise<any> {\n return new Promise((resolve) => {\n stream.once('readable', resolve);\n });\n}\n */\n"],"file":"make-stream-iterator.js"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
const DEFAULT_CHUNK_SIZE = 256 * 1024;
|
|
2
|
-
export function* makeStringIterator(string, options) {
|
|
3
|
-
const chunkSize = (options === null || options === void 0 ? void 0 : options.chunkSize) || DEFAULT_CHUNK_SIZE;
|
|
4
|
-
let offset = 0;
|
|
5
|
-
const textEncoder = new TextEncoder();
|
|
6
|
-
|
|
7
|
-
while (offset < string.length) {
|
|
8
|
-
const chunkLength = Math.min(string.length - offset, chunkSize);
|
|
9
|
-
const chunk = string.slice(offset, offset + chunkLength);
|
|
10
|
-
offset += chunkLength;
|
|
11
|
-
yield textEncoder.encode(chunk);
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=make-string-iterator.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/iterators/make-iterator/make-string-iterator.ts"],"names":["DEFAULT_CHUNK_SIZE","makeStringIterator","string","options","chunkSize","offset","textEncoder","TextEncoder","length","chunkLength","Math","min","chunk","slice","encode"],"mappings":"AAEA,MAAMA,kBAAkB,GAAG,MAAM,IAAjC;AAQA,OAAO,UAAUC,kBAAV,CACLC,MADK,EAELC,OAFK,EAGkB;AACvB,QAAMC,SAAS,GAAG,CAAAD,OAAO,SAAP,IAAAA,OAAO,WAAP,YAAAA,OAAO,CAAEC,SAAT,KAAsBJ,kBAAxC;AAEA,MAAIK,MAAM,GAAG,CAAb;AACA,QAAMC,WAAW,GAAG,IAAIC,WAAJ,EAApB;;AACA,SAAOF,MAAM,GAAGH,MAAM,CAACM,MAAvB,EAA+B;AAE7B,UAAMC,WAAW,GAAGC,IAAI,CAACC,GAAL,CAAST,MAAM,CAACM,MAAP,GAAgBH,MAAzB,EAAiCD,SAAjC,CAApB;AACA,UAAMQ,KAAK,GAAGV,MAAM,CAACW,KAAP,CAAaR,MAAb,EAAqBA,MAAM,GAAGI,WAA9B,CAAd;AACAJ,IAAAA,MAAM,IAAII,WAAV;AAGA,UAAMH,WAAW,CAACQ,MAAZ,CAAmBF,KAAnB,CAAN;AACD;AACF","sourcesContent":["import type {IteratorOptions} from './make-iterator';\n\nconst DEFAULT_CHUNK_SIZE = 256 * 1024;\n\n/**\n * Returns an iterator that breaks a big string into chunks and yields them one-by-one as ArrayBuffers\n * @param blob string to iterate over\n * @param options\n * @param options.chunkSize\n */\nexport function* makeStringIterator(\n string: string,\n options?: IteratorOptions\n): Iterable<ArrayBuffer> {\n const chunkSize = options?.chunkSize || DEFAULT_CHUNK_SIZE;\n\n let offset = 0;\n const textEncoder = new TextEncoder();\n while (offset < string.length) {\n // Create a chunk of the right size\n const chunkLength = Math.min(string.length - offset, chunkSize);\n const chunk = string.slice(offset, offset + chunkLength);\n offset += chunkLength;\n\n // yield an ArrayBuffer chunk\n yield textEncoder.encode(chunk);\n }\n}\n"],"file":"make-string-iterator.js"}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
export function makeStream(source, options) {
|
|
2
|
-
const iterator = source[Symbol.asyncIterator] ? source[Symbol.asyncIterator]() : source[Symbol.iterator]();
|
|
3
|
-
return new ReadableStream({
|
|
4
|
-
type: 'bytes',
|
|
5
|
-
|
|
6
|
-
async pull(controller) {
|
|
7
|
-
try {
|
|
8
|
-
const {
|
|
9
|
-
done,
|
|
10
|
-
value
|
|
11
|
-
} = await iterator.next();
|
|
12
|
-
|
|
13
|
-
if (done) {
|
|
14
|
-
controller.close();
|
|
15
|
-
} else {
|
|
16
|
-
controller.enqueue(new Uint8Array(value));
|
|
17
|
-
}
|
|
18
|
-
} catch (error) {
|
|
19
|
-
controller.error(error);
|
|
20
|
-
}
|
|
21
|
-
},
|
|
22
|
-
|
|
23
|
-
async cancel() {
|
|
24
|
-
var _iterator$return;
|
|
25
|
-
|
|
26
|
-
await (iterator === null || iterator === void 0 ? void 0 : (_iterator$return = iterator.return) === null || _iterator$return === void 0 ? void 0 : _iterator$return.call(iterator));
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
}, {
|
|
30
|
-
highWaterMark: 2 ** 24,
|
|
31
|
-
...options
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
//# sourceMappingURL=make-dom-stream.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/iterators/make-stream/make-dom-stream.ts"],"names":["makeStream","source","options","iterator","Symbol","asyncIterator","ReadableStream","type","pull","controller","done","value","next","close","enqueue","Uint8Array","error","cancel","return","highWaterMark"],"mappings":"AAaA,OAAO,SAASA,UAAT,CACLC,MADK,EAELC,OAFK,EAGW;AAChB,QAAMC,QAAQ,GAAGF,MAAM,CAACG,MAAM,CAACC,aAAR,CAAN,GACZJ,MAAD,CAAuCG,MAAM,CAACC,aAA9C,GADa,GAEZJ,MAAD,CAAkCG,MAAM,CAACD,QAAzC,GAFJ;AAIA,SAAO,IAAIG,cAAJ,CACL;AAKEC,IAAAA,IAAI,EAAE,OALR;;AAOE,UAAMC,IAAN,CAAWC,UAAX,EAAuB;AACrB,UAAI;AACF,cAAM;AAACC,UAAAA,IAAD;AAAOC,UAAAA;AAAP,YAAgB,MAAMR,QAAQ,CAACS,IAAT,EAA5B;;AACA,YAAIF,IAAJ,EAAU;AACRD,UAAAA,UAAU,CAACI,KAAX;AACD,SAFD,MAEO;AAELJ,UAAAA,UAAU,CAACK,OAAX,CAAmB,IAAIC,UAAJ,CAAeJ,KAAf,CAAnB;AACD;AACF,OARD,CAQE,OAAOK,KAAP,EAAc;AACdP,QAAAA,UAAU,CAACO,KAAX,CAAiBA,KAAjB;AACD;AACF,KAnBH;;AAqBE,UAAMC,MAAN,GAAe;AAAA;;AACb,aAAMd,QAAN,aAAMA,QAAN,2CAAMA,QAAQ,CAAEe,MAAhB,qDAAM,sBAAAf,QAAQ,CAAd;AACD;;AAvBH,GADK,EA2BL;AAEEgB,IAAAA,aAAa,EAAE,KAAK,EAFtB;AAGE,OAAGjB;AAHL,GA3BK,CAAP;AAiCD","sourcesContent":["export type MakeStreamOptions = {\n /** Stream allocates an arrayBuffer. Enables use of a default reader. */\n autoAllocateChunkSize?: number;\n /** Total number of chunks in queue before back pressure is applied */\n highWaterMark?: number;\n};\n\n/**\n * Builds a DOM stream from an iterator\n * This stream is currently used in browsers only,\n * but note that Web stream support is present in Node from Node 16\n * https://nodejs.org/api/webstreams.html#webstreams_web_streams_api\n */\nexport function makeStream<ArrayBuffer>(\n source: Iterable<ArrayBuffer> | AsyncIterable<ArrayBuffer>,\n options?: MakeStreamOptions\n): ReadableStream {\n const iterator = source[Symbol.asyncIterator]\n ? (source as AsyncIterable<ArrayBuffer>)[Symbol.asyncIterator]()\n : (source as Iterable<ArrayBuffer>)[Symbol.iterator]();\n\n return new ReadableStream<Uint8Array>(\n {\n // Create a byte stream (enables `Response(stream).arrayBuffer()`)\n // Only supported on Chrome\n // See: https://developer.mozilla.org/en-US/docs/Web/API/ReadableByteStreamController\n // @ts-expect-error Only Chrome supports byte streams\n type: 'bytes',\n\n async pull(controller) {\n try {\n const {done, value} = await iterator.next();\n if (done) {\n controller.close();\n } else {\n // TODO - ignores controller.desiredSize\n controller.enqueue(new Uint8Array(value));\n }\n } catch (error) {\n controller.error(error);\n }\n },\n\n async cancel() {\n await iterator?.return?.();\n }\n },\n // options: QueingStrategy<Uint8Array>\n {\n // This is bytes, not chunks\n highWaterMark: 2 ** 24,\n ...options\n }\n );\n}\n"],"file":"make-dom-stream.js"}
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
2
|
-
import { Readable } from 'stream';
|
|
3
|
-
export function makeStream(source, options) {
|
|
4
|
-
const iterator = source[Symbol.asyncIterator] ? source[Symbol.asyncIterator]() : source[Symbol.iterator]();
|
|
5
|
-
return new AsyncIterableReadable(iterator, options);
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
class AsyncIterableReadable extends Readable {
|
|
9
|
-
constructor(it, options) {
|
|
10
|
-
super(options);
|
|
11
|
-
|
|
12
|
-
_defineProperty(this, "_pulling", void 0);
|
|
13
|
-
|
|
14
|
-
_defineProperty(this, "_bytesMode", void 0);
|
|
15
|
-
|
|
16
|
-
_defineProperty(this, "_iterator", void 0);
|
|
17
|
-
|
|
18
|
-
this._iterator = it;
|
|
19
|
-
this._pulling = false;
|
|
20
|
-
this._bytesMode = !options || !options.objectMode;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
async _read(size) {
|
|
24
|
-
if (!this._pulling) {
|
|
25
|
-
this._pulling = true;
|
|
26
|
-
this._pulling = await this._pull(size, this._iterator);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
async _destroy(error, cb) {
|
|
31
|
-
if (!this._iterator) {
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
if (error) {
|
|
36
|
-
var _this$_iterator, _this$_iterator$throw;
|
|
37
|
-
|
|
38
|
-
await ((_this$_iterator = this._iterator) === null || _this$_iterator === void 0 ? void 0 : (_this$_iterator$throw = _this$_iterator.throw) === null || _this$_iterator$throw === void 0 ? void 0 : _this$_iterator$throw.call(_this$_iterator, error));
|
|
39
|
-
} else {
|
|
40
|
-
var _this$_iterator2, _this$_iterator2$retu;
|
|
41
|
-
|
|
42
|
-
await ((_this$_iterator2 = this._iterator) === null || _this$_iterator2 === void 0 ? void 0 : (_this$_iterator2$retu = _this$_iterator2.return) === null || _this$_iterator2$retu === void 0 ? void 0 : _this$_iterator2$retu.call(_this$_iterator2, error));
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
cb === null || cb === void 0 ? void 0 : cb(null);
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
async _pull(size, it) {
|
|
49
|
-
var _r;
|
|
50
|
-
|
|
51
|
-
const bm = this._bytesMode;
|
|
52
|
-
let r = null;
|
|
53
|
-
|
|
54
|
-
while (this.readable && !(r = await it.next()).done) {
|
|
55
|
-
if (size !== null) {
|
|
56
|
-
size -= bm && ArrayBuffer.isView(r.value) ? r.value.byteLength : 1;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
if (!this.push(new Uint8Array(r.value)) || size <= 0) {
|
|
60
|
-
break;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
if (((_r = r) !== null && _r !== void 0 && _r.done || !this.readable) && (this.push(null) || true)) {
|
|
65
|
-
var _it$return;
|
|
66
|
-
|
|
67
|
-
it === null || it === void 0 ? void 0 : (_it$return = it.return) === null || _it$return === void 0 ? void 0 : _it$return.call(it);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return !this.readable;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
}
|
|
74
|
-
//# sourceMappingURL=make-node-stream.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/iterators/make-stream/make-node-stream.ts"],"names":["Readable","makeStream","source","options","iterator","Symbol","asyncIterator","AsyncIterableReadable","constructor","it","_iterator","_pulling","_bytesMode","objectMode","_read","size","_pull","_destroy","error","cb","throw","return","bm","r","readable","next","done","ArrayBuffer","isView","value","byteLength","push","Uint8Array"],"mappings":";AAAA,SAAQA,QAAR,QAAwC,QAAxC;AAKA,OAAO,SAASC,UAAT,CACLC,MADK,EAELC,OAFK,EAGK;AACV,QAAMC,QAAQ,GAAGF,MAAM,CAACG,MAAM,CAACC,aAAR,CAAN,GACbJ,MAAM,CAACG,MAAM,CAACC,aAAR,CAAN,EADa,GAEbJ,MAAM,CAACG,MAAM,CAACD,QAAR,CAAN,EAFJ;AAGA,SAAO,IAAIG,qBAAJ,CAA0BH,QAA1B,EAAoCD,OAApC,CAAP;AACD;;AAED,MAAMI,qBAAN,SAAoCP,QAApC,CAA6C;AAK3CQ,EAAAA,WAAW,CAACC,EAAD,EAAiCN,OAAjC,EAA4D;AACrE,UAAMA,OAAN;;AADqE;;AAAA;;AAAA;;AAErE,SAAKO,SAAL,GAAiBD,EAAjB;AACA,SAAKE,QAAL,GAAgB,KAAhB;AACA,SAAKC,UAAL,GAAkB,CAACT,OAAD,IAAY,CAACA,OAAO,CAACU,UAAvC;AACD;;AAEU,QAALC,KAAK,CAACC,IAAD,EAA8B;AACvC,QAAI,CAAC,KAAKJ,QAAV,EAAoB;AAClB,WAAKA,QAAL,GAAgB,IAAhB;AACA,WAAKA,QAAL,GAAgB,MAAM,KAAKK,KAAL,CAAWD,IAAX,EAAiB,KAAKL,SAAtB,CAAtB;AACD;AACF;;AAEa,QAARO,QAAQ,CAACC,KAAD,EAAsBC,EAAtB,EAAoE;AAChF,QAAI,CAAC,KAAKT,SAAV,EAAqB;AACnB;AACD;;AACD,QAAIQ,KAAJ,EAAW;AAAA;;AACT,gCAAM,KAAKR,SAAX,6EAAM,gBAAgBU,KAAtB,0DAAM,4CAAwBF,KAAxB,CAAN;AACD,KAFD,MAEO;AAAA;;AACL,iCAAM,KAAKR,SAAX,8EAAM,iBAAgBW,MAAtB,0DAAM,6CAAyBH,KAAzB,CAAN;AACD;;AACDC,IAAAA,EAAE,SAAF,IAAAA,EAAE,WAAF,YAAAA,EAAE,CAAG,IAAH,CAAF;AACD;;AAGkB,QAALH,KAAK,CAACD,IAAD,EAAeN,EAAf,EAAiE;AAAA;;AAClF,UAAMa,EAAE,GAAG,KAAKV,UAAhB;AACA,QAAIW,CAAqC,GAAG,IAA5C;;AAEA,WAAO,KAAKC,QAAL,IAAiB,CAAC,CAACD,CAAC,GAAG,MAAMd,EAAE,CAACgB,IAAH,EAAX,EAAsBC,IAA/C,EAAqD;AACnD,UAAIX,IAAI,KAAK,IAAb,EAAmB;AACjBA,QAAAA,IAAI,IAAIO,EAAE,IAAIK,WAAW,CAACC,MAAZ,CAAmBL,CAAC,CAACM,KAArB,CAAN,GAAoCN,CAAC,CAACM,KAAF,CAAQC,UAA5C,GAAyD,CAAjE;AACD;;AACD,UAAI,CAAC,KAAKC,IAAL,CAAU,IAAIC,UAAJ,CAAeT,CAAC,CAACM,KAAjB,CAAV,CAAD,IAAuCd,IAAI,IAAI,CAAnD,EAAsD;AACpD;AACD;AACF;;AACD,QAAI,CAAC,MAAAQ,CAAC,UAAD,wBAAGG,IAAH,IAAW,CAAC,KAAKF,QAAlB,MAAgC,KAAKO,IAAL,CAAU,IAAV,KAAmB,IAAnD,CAAJ,EAA8D;AAAA;;AAC5DtB,MAAAA,EAAE,SAAF,IAAAA,EAAE,WAAF,0BAAAA,EAAE,CAAEY,MAAJ,+DAAAZ,EAAE;AACH;;AACD,WAAO,CAAC,KAAKe,QAAb;AACD;;AAhD0C","sourcesContent":["import {Readable, ReadableOptions} from 'stream';\n\nexport type MakeStreamOptions = ReadableOptions;\n\n/** Builds a node stream from an iterator */\nexport function makeStream<ArrayBuffer>(\n source: Iterable<ArrayBuffer> | AsyncIterable<ArrayBuffer>,\n options?: ReadableOptions\n): Readable {\n const iterator = source[Symbol.asyncIterator]\n ? source[Symbol.asyncIterator]()\n : source[Symbol.iterator]();\n return new AsyncIterableReadable(iterator, options);\n}\n\nclass AsyncIterableReadable extends Readable {\n private _pulling: boolean;\n private _bytesMode: boolean;\n private _iterator: AsyncIterator<ArrayBuffer>;\n\n constructor(it: AsyncIterator<ArrayBuffer>, options?: ReadableOptions) {\n super(options);\n this._iterator = it;\n this._pulling = false;\n this._bytesMode = !options || !options.objectMode;\n }\n\n async _read(size: number): Promise<void> {\n if (!this._pulling) {\n this._pulling = true;\n this._pulling = await this._pull(size, this._iterator);\n }\n }\n\n async _destroy(error: Error | null, cb: (e: Error | null) => void): Promise<void> {\n if (!this._iterator) {\n return;\n }\n if (error) {\n await this._iterator?.throw?.(error);\n } else {\n await this._iterator?.return?.(error);\n }\n cb?.(null);\n }\n\n // eslint-disable-next-line complexity\n private async _pull(size: number, it: AsyncIterator<ArrayBuffer>): Promise<boolean> {\n const bm = this._bytesMode;\n let r: IteratorResult<ArrayBuffer> | null = null;\n // while (this.readable && !(r = await it.next(bm ? size : null)).done) {\n while (this.readable && !(r = await it.next()).done) {\n if (size !== null) {\n size -= bm && ArrayBuffer.isView(r.value) ? r.value.byteLength : 1;\n }\n if (!this.push(new Uint8Array(r.value)) || size <= 0) {\n break;\n }\n }\n if ((r?.done || !this.readable) && (this.push(null) || true)) {\n it?.return?.();\n }\n return !this.readable;\n }\n}\n"],"file":"make-node-stream.js"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
const isBoolean = x => typeof x === 'boolean';
|
|
2
|
-
|
|
3
|
-
const isFunction = x => typeof x === 'function';
|
|
4
|
-
|
|
5
|
-
export const isObject = x => x !== null && typeof x === 'object';
|
|
6
|
-
export const isPureObject = x => isObject(x) && x.constructor === {}.constructor;
|
|
7
|
-
export const isPromise = x => isObject(x) && isFunction(x.then);
|
|
8
|
-
export const isIterable = x => x && typeof x[Symbol.iterator] === 'function';
|
|
9
|
-
export const isAsyncIterable = x => x && typeof x[Symbol.asyncIterator] === 'function';
|
|
10
|
-
export const isIterator = x => x && isFunction(x.next);
|
|
11
|
-
export const isResponse = x => typeof Response !== 'undefined' && x instanceof Response || x && x.arrayBuffer && x.text && x.json;
|
|
12
|
-
export const isFile = x => typeof File !== 'undefined' && x instanceof File;
|
|
13
|
-
export const isBlob = x => typeof Blob !== 'undefined' && x instanceof Blob;
|
|
14
|
-
export const isBuffer = x => x && typeof x === 'object' && x.isBuffer;
|
|
15
|
-
export const isWritableDOMStream = x => isObject(x) && isFunction(x.abort) && isFunction(x.getWriter);
|
|
16
|
-
export const isReadableDOMStream = x => typeof ReadableStream !== 'undefined' && x instanceof ReadableStream || isObject(x) && isFunction(x.tee) && isFunction(x.cancel) && isFunction(x.getReader);
|
|
17
|
-
export const isWritableNodeStream = x => isObject(x) && isFunction(x.end) && isFunction(x.write) && isBoolean(x.writable);
|
|
18
|
-
export const isReadableNodeStream = x => isObject(x) && isFunction(x.read) && isFunction(x.pipe) && isBoolean(x.readable);
|
|
19
|
-
export const isReadableStream = x => isReadableDOMStream(x) || isReadableNodeStream(x);
|
|
20
|
-
export const isWritableStream = x => isWritableDOMStream(x) || isWritableNodeStream(x);
|
|
21
|
-
//# sourceMappingURL=is-type.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/javascript-utils/is-type.ts"],"names":["isBoolean","x","isFunction","isObject","isPureObject","constructor","isPromise","then","isIterable","Symbol","iterator","isAsyncIterable","asyncIterator","isIterator","next","isResponse","Response","arrayBuffer","text","json","isFile","File","isBlob","Blob","isBuffer","isWritableDOMStream","abort","getWriter","isReadableDOMStream","ReadableStream","tee","cancel","getReader","isWritableNodeStream","end","write","writable","isReadableNodeStream","read","pipe","readable","isReadableStream","isWritableStream"],"mappings":"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","sourcesContent":["import type {Readable} from 'stream';\n\n/** A DOM or Node readable stream */\nexport type ReadableStreamType = ReadableStream | Readable;\n\nconst isBoolean: (x: any) => boolean = (x) => typeof x === 'boolean';\nconst isFunction: (x: any) => boolean = (x) => typeof x === 'function';\n\nexport const isObject: (x: any) => boolean = (x) => x !== null && typeof x === 'object';\nexport const isPureObject: (x: any) => boolean = (x) =>\n isObject(x) && x.constructor === {}.constructor;\nexport const isPromise: (x: any) => boolean = (x) => isObject(x) && isFunction(x.then);\n\nexport const isIterable: (x: any) => boolean = (x) => x && typeof x[Symbol.iterator] === 'function';\nexport const isAsyncIterable: (x: any) => boolean = (x) =>\n x && typeof x[Symbol.asyncIterator] === 'function';\nexport const isIterator: (x: any) => boolean = (x) => x && isFunction(x.next);\n\nexport const isResponse: (x: any) => boolean = (x) =>\n (typeof Response !== 'undefined' && x instanceof Response) ||\n (x && x.arrayBuffer && x.text && x.json);\n\nexport const isFile: (x: any) => boolean = (x) => typeof File !== 'undefined' && x instanceof File;\nexport const isBlob: (x: any) => boolean = (x) => typeof Blob !== 'undefined' && x instanceof Blob;\n\n/** Check for Node.js `Buffer` without triggering bundler to include buffer polyfill */\nexport const isBuffer: (x: any) => boolean = (x) => x && typeof x === 'object' && x.isBuffer;\n\nexport const isWritableDOMStream: (x: any) => boolean = (x) =>\n isObject(x) && isFunction(x.abort) && isFunction(x.getWriter);\n\nexport const isReadableDOMStream: (x: any) => boolean = (x) =>\n (typeof ReadableStream !== 'undefined' && x instanceof ReadableStream) ||\n (isObject(x) && isFunction(x.tee) && isFunction(x.cancel) && isFunction(x.getReader));\n// Not implemented in Firefox: && isFunction(x.pipeTo)\n\nexport const isWritableNodeStream: (x: any) => boolean = (x) =>\n isObject(x) && isFunction(x.end) && isFunction(x.write) && isBoolean(x.writable);\nexport const isReadableNodeStream: (x: any) => boolean = (x) =>\n isObject(x) && isFunction(x.read) && isFunction(x.pipe) && isBoolean(x.readable);\nexport const isReadableStream: (x: any) => boolean = (x) =>\n isReadableDOMStream(x) || isReadableNodeStream(x);\nexport const isWritableStream: (x: any) => boolean = (x) =>\n isWritableDOMStream(x) || isWritableNodeStream(x);\n"],"file":"is-type.js"}
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
import { concatenateArrayBuffers, resolvePath } from '@loaders.gl/loader-utils';
|
|
2
|
-
import { isBrowser } from '@loaders.gl/loader-utils';
|
|
3
|
-
import { writeFile } from '../fetch/write-file';
|
|
4
|
-
import { fetchFile } from '../fetch/fetch-file';
|
|
5
|
-
export async function encode(data, writer, options) {
|
|
6
|
-
if (writer.encode) {
|
|
7
|
-
return await writer.encode(data, options);
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
if (writer.encodeSync) {
|
|
11
|
-
return writer.encodeSync(data, options);
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
if (writer.encodeText) {
|
|
15
|
-
return new TextEncoder().encode(await writer.encodeText(data, options));
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
if (writer.encodeInBatches) {
|
|
19
|
-
const batches = encodeInBatches(data, writer, options);
|
|
20
|
-
const chunks = [];
|
|
21
|
-
|
|
22
|
-
for await (const batch of batches) {
|
|
23
|
-
chunks.push(batch);
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
return concatenateArrayBuffers(...chunks);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
if (!isBrowser && writer.encodeURLtoURL) {
|
|
30
|
-
const tmpInputFilename = getTemporaryFilename('input');
|
|
31
|
-
await writeFile(tmpInputFilename, data);
|
|
32
|
-
const tmpOutputFilename = getTemporaryFilename('output');
|
|
33
|
-
const outputFilename = await encodeURLtoURL(tmpInputFilename, tmpOutputFilename, writer, options);
|
|
34
|
-
const response = await fetchFile(outputFilename);
|
|
35
|
-
return response.arrayBuffer();
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
throw new Error('Writer could not encode data');
|
|
39
|
-
}
|
|
40
|
-
export function encodeSync(data, writer, options) {
|
|
41
|
-
if (writer.encodeSync) {
|
|
42
|
-
return writer.encodeSync(data, options);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
throw new Error('Writer could not synchronously encode data');
|
|
46
|
-
}
|
|
47
|
-
export async function encodeText(data, writer, options) {
|
|
48
|
-
if (writer.text && writer.encodeText) {
|
|
49
|
-
return await writer.encodeText(data, options);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
if (writer.text && (writer.encode || writer.encodeInBatches)) {
|
|
53
|
-
const arrayBuffer = await encode(data, writer, options);
|
|
54
|
-
return new TextDecoder().decode(arrayBuffer);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
throw new Error('Writer could not encode data as text');
|
|
58
|
-
}
|
|
59
|
-
export function encodeInBatches(data, writer, options) {
|
|
60
|
-
if (writer.encodeInBatches) {
|
|
61
|
-
const dataIterator = getIterator(data);
|
|
62
|
-
return writer.encodeInBatches(dataIterator, options);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
throw new Error('Writer could not encode data in batches');
|
|
66
|
-
}
|
|
67
|
-
export async function encodeURLtoURL(inputUrl, outputUrl, writer, options) {
|
|
68
|
-
inputUrl = resolvePath(inputUrl);
|
|
69
|
-
outputUrl = resolvePath(outputUrl);
|
|
70
|
-
|
|
71
|
-
if (isBrowser || !writer.encodeURLtoURL) {
|
|
72
|
-
throw new Error();
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
const outputFilename = await writer.encodeURLtoURL(inputUrl, outputUrl, options);
|
|
76
|
-
return outputFilename;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
function getIterator(data) {
|
|
80
|
-
const dataIterator = [{
|
|
81
|
-
table: data,
|
|
82
|
-
start: 0,
|
|
83
|
-
end: data.length
|
|
84
|
-
}];
|
|
85
|
-
return dataIterator;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
function getTemporaryFilename(filename) {
|
|
89
|
-
return "/tmp/".concat(filename);
|
|
90
|
-
}
|
|
91
|
-
//# sourceMappingURL=encode.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/api/encode.ts"],"names":["concatenateArrayBuffers","resolvePath","isBrowser","writeFile","fetchFile","encode","data","writer","options","encodeSync","encodeText","TextEncoder","encodeInBatches","batches","chunks","batch","push","encodeURLtoURL","tmpInputFilename","getTemporaryFilename","tmpOutputFilename","outputFilename","response","arrayBuffer","Error","text","TextDecoder","decode","dataIterator","getIterator","inputUrl","outputUrl","table","start","end","length","filename"],"mappings":"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","sourcesContent":["import type {Writer, LoaderOptions} from '@loaders.gl/loader-utils';\nimport {concatenateArrayBuffers, resolvePath} from '@loaders.gl/loader-utils';\nimport {isBrowser} from '@loaders.gl/loader-utils';\nimport {writeFile} from '../fetch/write-file';\nimport {fetchFile} from '../fetch/fetch-file';\n\n/**\n * Encode loaded data into a binary ArrayBuffer using the specified Writer.\n */\nexport async function encode(\n data: any,\n writer: Writer,\n options?: LoaderOptions\n): Promise<ArrayBuffer> {\n // TODO Merge default writer options with options argument like it is done in load module.\n if (writer.encode) {\n return await writer.encode(data, options);\n }\n\n if (writer.encodeSync) {\n return writer.encodeSync(data, options);\n }\n\n if (writer.encodeText) {\n return new TextEncoder().encode(await writer.encodeText(data, options));\n }\n\n if (writer.encodeInBatches) {\n // Create an iterator representing the data\n // TODO - Assumes this is a table\n const batches = encodeInBatches(data, writer, options);\n\n // Concatenate the output\n const chunks: any[] = [];\n for await (const batch of batches) {\n chunks.push(batch);\n }\n // @ts-ignore\n return concatenateArrayBuffers(...chunks);\n }\n\n if (!isBrowser && writer.encodeURLtoURL) {\n // TODO - how to generate filenames with correct extensions?\n const tmpInputFilename = getTemporaryFilename('input');\n await writeFile(tmpInputFilename, data);\n\n const tmpOutputFilename = getTemporaryFilename('output');\n\n const outputFilename = await encodeURLtoURL(\n tmpInputFilename,\n tmpOutputFilename,\n writer,\n options\n );\n\n const response = await fetchFile(outputFilename);\n return response.arrayBuffer();\n }\n\n throw new Error('Writer could not encode data');\n}\n\n/**\n * Encode loaded data into a binary ArrayBuffer using the specified Writer.\n */\nexport function encodeSync(data: any, writer: Writer, options?: LoaderOptions): ArrayBuffer {\n if (writer.encodeSync) {\n return writer.encodeSync(data, options);\n }\n throw new Error('Writer could not synchronously encode data');\n}\n\n/**\n * Encode loaded data to text using the specified Writer\n * @note This is a convenience function not intended for production use on large input data.\n * It is not optimized for performance. Data maybe converted from text to binary and back.\n * @throws if the writer does not generate text output\n */\nexport async function encodeText(\n data: any,\n writer: Writer,\n options?: LoaderOptions\n): Promise<string> {\n if (writer.text && writer.encodeText) {\n return await writer.encodeText(data, options);\n }\n\n if (writer.text && (writer.encode || writer.encodeInBatches)) {\n const arrayBuffer = await encode(data, writer, options);\n return new TextDecoder().decode(arrayBuffer);\n }\n\n throw new Error('Writer could not encode data as text');\n}\n\n/**\n * Encode loaded data into a sequence (iterator) of binary ArrayBuffers using the specified Writer.\n */\nexport function encodeInBatches(\n data: any,\n writer: Writer,\n options?: LoaderOptions\n): AsyncIterable<ArrayBuffer> {\n if (writer.encodeInBatches) {\n const dataIterator = getIterator(data);\n return writer.encodeInBatches(dataIterator, options);\n }\n // TODO -fall back to atomic encode?\n throw new Error('Writer could not encode data in batches');\n}\n\n/**\n * Encode data stored in a file (on disk) to another file.\n * @note Node.js only. This function enables using command-line converters as \"writers\".\n */\nexport async function encodeURLtoURL(\n inputUrl,\n outputUrl,\n writer: Writer,\n options\n): Promise<string> {\n inputUrl = resolvePath(inputUrl);\n outputUrl = resolvePath(outputUrl);\n if (isBrowser || !writer.encodeURLtoURL) {\n throw new Error();\n }\n const outputFilename = await writer.encodeURLtoURL(inputUrl, outputUrl, options);\n return outputFilename;\n}\n\n/**\n * @todo TODO - this is an unacceptable hack!!!\n */\nfunction getIterator(data) {\n const dataIterator = [{table: data, start: 0, end: data.length}];\n return dataIterator;\n}\n\n/**\n * @todo Move to utils\n */\nfunction getTemporaryFilename(filename: string): string {\n return `/tmp/${filename}`;\n}\n"],"file":"encode.js"}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { isLoaderObject } from '../loader-utils/normalize-loader';
|
|
2
|
-
import { getFetchFunction } from '../loader-utils/option-utils';
|
|
3
|
-
import { parseInBatches } from './parse-in-batches';
|
|
4
|
-
export function loadInBatches(files, loaders, options, context) {
|
|
5
|
-
if (!Array.isArray(loaders) && !isLoaderObject(loaders)) {
|
|
6
|
-
context = undefined;
|
|
7
|
-
options = loaders;
|
|
8
|
-
loaders = null;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
const fetch = getFetchFunction(options || {});
|
|
12
|
-
|
|
13
|
-
if (!Array.isArray(files)) {
|
|
14
|
-
return loadOneFileInBatches(files, loaders, options, fetch);
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
const promises = files.map(file => loadOneFileInBatches(file, loaders, options, fetch));
|
|
18
|
-
return promises;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
async function loadOneFileInBatches(file, loaders, options, fetch) {
|
|
22
|
-
if (typeof file === 'string') {
|
|
23
|
-
const url = file;
|
|
24
|
-
const response = await fetch(url);
|
|
25
|
-
return await parseInBatches(response, loaders, options);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
return await parseInBatches(file, loaders, options);
|
|
29
|
-
}
|
|
30
|
-
//# sourceMappingURL=load-in-batches.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/api/load-in-batches.ts"],"names":["isLoaderObject","getFetchFunction","parseInBatches","loadInBatches","files","loaders","options","context","Array","isArray","undefined","fetch","loadOneFileInBatches","promises","map","file","url","response"],"mappings":"AACA,SAAQA,cAAR,QAA6B,kCAA7B;AACA,SAAQC,gBAAR,QAA+B,8BAA/B;AAEA,SAAQC,cAAR,QAA6B,oBAA7B;AAyBA,OAAO,SAASC,aAAT,CAAuBC,KAAvB,EAA8BC,OAA9B,EAAuCC,OAAvC,EAAgDC,OAAhD,EAAyD;AAE9D,MAAI,CAACC,KAAK,CAACC,OAAN,CAAcJ,OAAd,CAAD,IAA2B,CAACL,cAAc,CAACK,OAAD,CAA9C,EAAyD;AACvDE,IAAAA,OAAO,GAAGG,SAAV;AACAJ,IAAAA,OAAO,GAAGD,OAAV;AACAA,IAAAA,OAAO,GAAG,IAAV;AACD;;AAGD,QAAMM,KAAK,GAAGV,gBAAgB,CAACK,OAAO,IAAI,EAAZ,CAA9B;;AAGA,MAAI,CAACE,KAAK,CAACC,OAAN,CAAcL,KAAd,CAAL,EAA2B;AACzB,WAAOQ,oBAAoB,CAACR,KAAD,EAAQC,OAAR,EAAiBC,OAAjB,EAA0BK,KAA1B,CAA3B;AACD;;AAGD,QAAME,QAAQ,GAAGT,KAAK,CAACU,GAAN,CAAWC,IAAD,IAAUH,oBAAoB,CAACG,IAAD,EAAOV,OAAP,EAAgBC,OAAhB,EAAyBK,KAAzB,CAAxC,CAAjB;AAGA,SAAOE,QAAP;AACD;;AAED,eAAeD,oBAAf,CAAoCG,IAApC,EAA0CV,OAA1C,EAAmDC,OAAnD,EAA4DK,KAA5D,EAAmE;AACjE,MAAI,OAAOI,IAAP,KAAgB,QAApB,EAA8B;AAC5B,UAAMC,GAAG,GAAGD,IAAZ;AACA,UAAME,QAAQ,GAAG,MAAMN,KAAK,CAACK,GAAD,CAA5B;AACA,WAAO,MAAMd,cAAc,CAACe,QAAD,EAAWZ,OAAX,EAAoBC,OAApB,CAA3B;AACD;;AACD,SAAO,MAAMJ,cAAc,CAACa,IAAD,EAAOV,OAAP,EAAgBC,OAAhB,CAA3B;AACD","sourcesContent":["import type {LoaderWithParser, LoaderOptions, LoaderContext} from '@loaders.gl/loader-utils';\nimport {isLoaderObject} from '../loader-utils/normalize-loader';\nimport {getFetchFunction} from '../loader-utils/option-utils';\n\nimport {parseInBatches} from './parse-in-batches';\n\ntype FileType = string | File | Blob | Response | (string | File | Blob | Response)[] | FileList;\n\n/**\n * Parses `data` using a specified loader\n * @param data\n * @param loaders\n * @param options\n * @param context\n */\nexport function loadInBatches(\n files: FileType,\n loaders?: LoaderWithParser | LoaderWithParser[] | LoaderOptions,\n options?: LoaderOptions,\n context?: LoaderContext\n): Promise<AsyncIterable<any>>;\n\nexport function loadInBatches(\n files: FileType[] | FileList,\n loaders?: LoaderWithParser | LoaderWithParser[] | LoaderOptions,\n options?: LoaderOptions,\n context?: LoaderContext\n): Promise<AsyncIterable<any>>;\n\nexport function loadInBatches(files, loaders, options, context) {\n // Signature: load(url, options)\n if (!Array.isArray(loaders) && !isLoaderObject(loaders)) {\n context = undefined; // context not supported in short signature\n options = loaders;\n loaders = null;\n }\n\n // Select fetch function\n const fetch = getFetchFunction(options || {});\n\n // Single url/file\n if (!Array.isArray(files)) {\n return loadOneFileInBatches(files, loaders, options, fetch);\n }\n\n // Multiple URLs / files\n const promises = files.map((file) => loadOneFileInBatches(file, loaders, options, fetch));\n\n // No point in waiting here for all responses before starting to stream individual streams?\n return promises;\n}\n\nasync function loadOneFileInBatches(file, loaders, options, fetch) {\n if (typeof file === 'string') {\n const url = file;\n const response = await fetch(url);\n return await parseInBatches(response, loaders, options);\n }\n return await parseInBatches(file, loaders, options);\n}\n"],"file":"load-in-batches.js"}
|
package/dist/esm/lib/api/load.js
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { isBlob } from '../../javascript-utils/is-type';
|
|
2
|
-
import { isLoaderObject } from '../loader-utils/normalize-loader';
|
|
3
|
-
import { getFetchFunction } from '../loader-utils/option-utils';
|
|
4
|
-
import { parse } from './parse';
|
|
5
|
-
export async function load(url, loaders, options, context) {
|
|
6
|
-
if (!Array.isArray(loaders) && !isLoaderObject(loaders)) {
|
|
7
|
-
context = undefined;
|
|
8
|
-
options = loaders;
|
|
9
|
-
loaders = undefined;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
const fetch = getFetchFunction(options);
|
|
13
|
-
let data = url;
|
|
14
|
-
|
|
15
|
-
if (typeof url === 'string') {
|
|
16
|
-
data = await fetch(url);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
if (isBlob(url)) {
|
|
20
|
-
data = await fetch(url);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
return await parse(data, loaders, options);
|
|
24
|
-
}
|
|
25
|
-
//# sourceMappingURL=load.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/api/load.ts"],"names":["isBlob","isLoaderObject","getFetchFunction","parse","load","url","loaders","options","context","Array","isArray","undefined","fetch","data"],"mappings":"AACA,SAAQA,MAAR,QAAqB,gCAArB;AACA,SAAQC,cAAR,QAA6B,kCAA7B;AACA,SAAQC,gBAAR,QAA+B,8BAA/B;AAEA,SAAQC,KAAR,QAAoB,SAApB;AAYA,OAAO,eAAeC,IAAf,CACLC,GADK,EAELC,OAFK,EAGLC,OAHK,EAILC,OAJK,EAKS;AAEd,MAAI,CAACC,KAAK,CAACC,OAAN,CAAcJ,OAAd,CAAD,IAA2B,CAACL,cAAc,CAACK,OAAD,CAA9C,EAAyD;AACvDE,IAAAA,OAAO,GAAGG,SAAV;AACAJ,IAAAA,OAAO,GAAGD,OAAV;AACAA,IAAAA,OAAO,GAAGK,SAAV;AACD;;AAGD,QAAMC,KAAK,GAAGV,gBAAgB,CAACK,OAAD,CAA9B;AAGA,MAAIM,IAAI,GAAGR,GAAX;;AAEA,MAAI,OAAOA,GAAP,KAAe,QAAnB,EAA6B;AAC3BQ,IAAAA,IAAI,GAAG,MAAMD,KAAK,CAACP,GAAD,CAAlB;AAED;;AAED,MAAIL,MAAM,CAACK,GAAD,CAAV,EAAiB;AAEfQ,IAAAA,IAAI,GAAG,MAAMD,KAAK,CAACP,GAAD,CAAlB;AACD;;AAGD,SAAO,MAAMF,KAAK,CAACU,IAAD,EAAOP,OAAP,EAAgBC,OAAhB,CAAlB;AACD","sourcesContent":["import type {DataType, Loader, LoaderContext, LoaderOptions} from '@loaders.gl/loader-utils';\nimport {isBlob} from '../../javascript-utils/is-type';\nimport {isLoaderObject} from '../loader-utils/normalize-loader';\nimport {getFetchFunction} from '../loader-utils/option-utils';\n\nimport {parse} from './parse';\n\n/**\n * Parses `data` using a specified loader\n * Note: Load does duplicate a lot of parse.\n * it can also call fetchFile on string urls, which `parse` won't do.\n * @param data\n * @param loaders\n * @param options\n * @param context\n */\n// implementation signature\nexport async function load(\n url: string | DataType,\n loaders?: Loader | Loader[] | LoaderOptions,\n options?: LoaderOptions,\n context?: LoaderContext\n): Promise<any> {\n // Signature: load(url, options)\n if (!Array.isArray(loaders) && !isLoaderObject(loaders)) {\n context = undefined; // context not supported in short signature\n options = loaders as LoaderOptions;\n loaders = undefined;\n }\n\n // Select fetch function\n const fetch = getFetchFunction(options);\n\n // at this point, `url` could be already loaded binary data\n let data = url;\n // url is a string, fetch the url\n if (typeof url === 'string') {\n data = await fetch(url);\n // URL is Blob or File, fetchFile handles it (alt: we could generate ObjectURL here)\n }\n\n if (isBlob(url)) {\n // The fetch response object will contain blob.name\n data = await fetch(url);\n }\n\n // Data is loaded (at least we have a `Response` object) so time to hand over to `parse`\n return await parse(data, loaders, options);\n}\n"],"file":"load.js"}
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
import { assert, concatenateArrayBuffersAsync } from '@loaders.gl/loader-utils';
|
|
2
|
-
import { isLoaderObject } from '../loader-utils/normalize-loader';
|
|
3
|
-
import { normalizeOptions } from '../loader-utils/option-utils';
|
|
4
|
-
import { getLoaderContext } from '../loader-utils/loader-context';
|
|
5
|
-
import { getAsyncIterableFromData } from '../loader-utils/get-data';
|
|
6
|
-
import { getResourceUrlAndType } from '../utils/resource-utils';
|
|
7
|
-
import { selectLoader } from './select-loader';
|
|
8
|
-
import { parse } from './parse';
|
|
9
|
-
export async function parseInBatches(data, loaders, options, context) {
|
|
10
|
-
assert(!context || typeof context === 'object');
|
|
11
|
-
|
|
12
|
-
if (!Array.isArray(loaders) && !isLoaderObject(loaders)) {
|
|
13
|
-
context = undefined;
|
|
14
|
-
options = loaders;
|
|
15
|
-
loaders = undefined;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
data = await data;
|
|
19
|
-
options = options || {};
|
|
20
|
-
const {
|
|
21
|
-
url
|
|
22
|
-
} = getResourceUrlAndType(data);
|
|
23
|
-
const loader = await selectLoader(data, loaders, options);
|
|
24
|
-
|
|
25
|
-
if (!loader) {
|
|
26
|
-
return null;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
options = normalizeOptions(options, loader, loaders, url);
|
|
30
|
-
context = getLoaderContext({
|
|
31
|
-
url,
|
|
32
|
-
parseInBatches,
|
|
33
|
-
parse,
|
|
34
|
-
loaders: loaders
|
|
35
|
-
}, options, context);
|
|
36
|
-
return await parseWithLoaderInBatches(loader, data, options, context);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
async function parseWithLoaderInBatches(loader, data, options, context) {
|
|
40
|
-
const outputIterator = await parseToOutputIterator(loader, data, options, context);
|
|
41
|
-
|
|
42
|
-
if (!options.metadata) {
|
|
43
|
-
return outputIterator;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
const metadataBatch = {
|
|
47
|
-
batchType: 'metadata',
|
|
48
|
-
metadata: {
|
|
49
|
-
_loader: loader,
|
|
50
|
-
_context: context
|
|
51
|
-
},
|
|
52
|
-
data: [],
|
|
53
|
-
bytesUsed: 0
|
|
54
|
-
};
|
|
55
|
-
|
|
56
|
-
async function* makeMetadataBatchIterator(iterator) {
|
|
57
|
-
yield metadataBatch;
|
|
58
|
-
yield* iterator;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
return makeMetadataBatchIterator(outputIterator);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
async function parseToOutputIterator(loader, data, options, context) {
|
|
65
|
-
const inputIterator = await getAsyncIterableFromData(data, options);
|
|
66
|
-
const transformedIterator = await applyInputTransforms(inputIterator, (options === null || options === void 0 ? void 0 : options.transforms) || []);
|
|
67
|
-
|
|
68
|
-
if (loader.parseInBatches) {
|
|
69
|
-
return loader.parseInBatches(transformedIterator, options, context);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
async function* parseChunkInBatches() {
|
|
73
|
-
const arrayBuffer = await concatenateArrayBuffersAsync(transformedIterator);
|
|
74
|
-
const parsedData = await parse(arrayBuffer, loader, { ...options,
|
|
75
|
-
mimeType: loader.mimeTypes[0]
|
|
76
|
-
}, context);
|
|
77
|
-
const batch = {
|
|
78
|
-
mimeType: loader.mimeTypes[0],
|
|
79
|
-
shape: Array.isArray(parsedData) ? 'row-table' : 'unknown',
|
|
80
|
-
batchType: 'data',
|
|
81
|
-
data: parsedData,
|
|
82
|
-
length: Array.isArray(parsedData) ? parsedData.length : 1
|
|
83
|
-
};
|
|
84
|
-
yield batch;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
return parseChunkInBatches();
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
async function applyInputTransforms(inputIterator, transforms = []) {
|
|
91
|
-
let iteratorChain = inputIterator;
|
|
92
|
-
|
|
93
|
-
for await (const transformBatches of transforms) {
|
|
94
|
-
iteratorChain = transformBatches(iteratorChain);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
return iteratorChain;
|
|
98
|
-
}
|
|
99
|
-
//# sourceMappingURL=parse-in-batches.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/api/parse-in-batches.ts"],"names":["assert","concatenateArrayBuffersAsync","isLoaderObject","normalizeOptions","getLoaderContext","getAsyncIterableFromData","getResourceUrlAndType","selectLoader","parse","parseInBatches","data","loaders","options","context","Array","isArray","undefined","url","loader","parseWithLoaderInBatches","outputIterator","parseToOutputIterator","metadata","metadataBatch","batchType","_loader","_context","bytesUsed","makeMetadataBatchIterator","iterator","inputIterator","transformedIterator","applyInputTransforms","transforms","parseChunkInBatches","arrayBuffer","parsedData","mimeType","mimeTypes","batch","shape","length","iteratorChain","transformBatches"],"mappings":"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","sourcesContent":["import type {Batch} from '@loaders.gl/schema';\nimport type {\n BatchableDataType,\n Loader,\n LoaderWithParser,\n LoaderContext,\n LoaderOptions\n} from '@loaders.gl/loader-utils';\nimport {assert, concatenateArrayBuffersAsync} from '@loaders.gl/loader-utils';\nimport {isLoaderObject} from '../loader-utils/normalize-loader';\nimport {normalizeOptions} from '../loader-utils/option-utils';\nimport {getLoaderContext} from '../loader-utils/loader-context';\nimport {getAsyncIterableFromData} from '../loader-utils/get-data';\nimport {getResourceUrlAndType} from '../utils/resource-utils';\nimport {selectLoader} from './select-loader';\n\n// Ensure `parse` is available in context if loader falls back to `parse`\nimport {parse} from './parse';\n\n/**\n * Parses `data` using a specified loader\n * @param data\n * @param loaders\n * @param options\n * @param context\n */\nexport async function parseInBatches(\n data: BatchableDataType,\n loaders?: Loader | Loader[] | LoaderOptions,\n options?: LoaderOptions,\n context?: LoaderContext\n): Promise<AsyncIterable<any>> {\n assert(!context || typeof context === 'object'); // parseInBatches no longer accepts final url\n\n // Signature: parseInBatches(data, options, url) - Uses registered loaders\n if (!Array.isArray(loaders) && !isLoaderObject(loaders)) {\n context = undefined; // context not supported in short signature\n options = loaders as LoaderOptions;\n loaders = undefined;\n }\n\n data = await data; // Resolve any promise\n options = options || {};\n\n // Extract a url for auto detection\n const {url} = getResourceUrlAndType(data);\n\n // Chooses a loader and normalizes it\n // Note - only uses URL and contentType for streams and iterator inputs\n const loader = await selectLoader(data as ArrayBuffer, loaders as Loader[], options);\n // Note: if options.nothrow was set, it is possible that no loader was found, if so just return null\n if (!loader) {\n // @ts-ignore\n return null;\n }\n\n // Normalize options\n // @ts-ignore\n options = normalizeOptions(options, loader, loaders, url);\n // @ts-ignore\n context = getLoaderContext(\n // @ts-ignore\n {url, parseInBatches, parse, loaders: loaders as Loader[]},\n options,\n context\n );\n\n return await parseWithLoaderInBatches(loader as LoaderWithParser, data, options, context);\n}\n\n/**\n * Loader has been selected and context has been prepared, see if we need to emit a metadata batch\n */\nasync function parseWithLoaderInBatches(\n loader: LoaderWithParser,\n data: BatchableDataType,\n options: LoaderOptions,\n context: LoaderContext\n): Promise<AsyncIterable<any>> {\n const outputIterator = await parseToOutputIterator(loader, data, options, context);\n\n // Generate metadata batch if requested\n if (!options.metadata) {\n return outputIterator;\n }\n\n const metadataBatch = {\n batchType: 'metadata',\n metadata: {\n _loader: loader,\n _context: context\n },\n // Populate with some default fields to avoid crashing\n data: [],\n bytesUsed: 0\n };\n\n async function* makeMetadataBatchIterator(iterator) {\n yield metadataBatch;\n yield* iterator;\n }\n\n return makeMetadataBatchIterator(outputIterator);\n}\n\n/**\n * Prep work is done, now it is time to start parsing into an output operator\n * The approach depends on which parse function the loader exposes\n * `parseInBatches` (preferred), `parse` (fallback)\n */\nasync function parseToOutputIterator(\n loader: LoaderWithParser,\n data: BatchableDataType,\n options: LoaderOptions,\n context: LoaderContext\n): Promise<AsyncIterable<any>> {\n // Get an iterator from the input\n const inputIterator = await getAsyncIterableFromData(data, options);\n\n // Apply any iterator transforms (options.transforms)\n const transformedIterator = await applyInputTransforms(inputIterator, options?.transforms || []);\n\n // If loader supports parseInBatches, we are done\n if (loader.parseInBatches) {\n return loader.parseInBatches(transformedIterator, options, context);\n }\n\n // Fallback: load atomically using `parse` concatenating input iterator into single chunk\n async function* parseChunkInBatches() {\n const arrayBuffer = await concatenateArrayBuffersAsync(transformedIterator);\n // Call `parse` instead of `loader.parse` to ensure we can call workers etc.\n const parsedData = await parse(\n arrayBuffer,\n loader,\n // TODO - Hack: supply loaders MIME type to ensure we match it\n {...options, mimeType: loader.mimeTypes[0]},\n context\n );\n // yield a single batch, the output from loader.parse()\n // TODO - run through batch builder to apply options etc...\n const batch: Batch = {\n mimeType: loader.mimeTypes[0],\n shape: Array.isArray(parsedData) ? 'row-table' : 'unknown',\n batchType: 'data',\n data: parsedData,\n length: Array.isArray(parsedData) ? parsedData.length : 1\n };\n yield batch;\n }\n\n return parseChunkInBatches();\n}\n\ntype TransformBatches = (\n asyncIterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>\n) => AsyncIterable<ArrayBuffer>;\n\n/**\n * Create an iterator chain with any transform iterators (crypto, decompression)\n * @param inputIterator\n * @param options\n */\nasync function applyInputTransforms(\n inputIterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,\n transforms: TransformBatches[] = []\n): Promise<AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>> {\n let iteratorChain = inputIterator;\n for await (const transformBatches of transforms) {\n iteratorChain = transformBatches(iteratorChain);\n }\n return iteratorChain;\n}\n"],"file":"parse-in-batches.js"}
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { assert } from '@loaders.gl/loader-utils';
|
|
2
|
-
import { selectLoaderSync } from './select-loader';
|
|
3
|
-
import { isLoaderObject } from '../loader-utils/normalize-loader';
|
|
4
|
-
import { normalizeOptions } from '../loader-utils/option-utils';
|
|
5
|
-
import { getArrayBufferOrStringFromDataSync } from '../loader-utils/get-data';
|
|
6
|
-
import { getLoaderContext, getLoadersFromContext } from '../loader-utils/loader-context';
|
|
7
|
-
import { getResourceUrlAndType } from '../utils/resource-utils';
|
|
8
|
-
export function parseSync(data, loaders, options, context) {
|
|
9
|
-
assert(!context || typeof context === 'object');
|
|
10
|
-
|
|
11
|
-
if (!Array.isArray(loaders) && !isLoaderObject(loaders)) {
|
|
12
|
-
context = undefined;
|
|
13
|
-
options = loaders;
|
|
14
|
-
loaders = undefined;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
options = options || {};
|
|
18
|
-
const typedLoaders = loaders;
|
|
19
|
-
const candidateLoaders = getLoadersFromContext(typedLoaders, context);
|
|
20
|
-
const loader = selectLoaderSync(data, candidateLoaders, options);
|
|
21
|
-
|
|
22
|
-
if (!loader) {
|
|
23
|
-
return null;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
options = normalizeOptions(options, loader, candidateLoaders);
|
|
27
|
-
const {
|
|
28
|
-
url
|
|
29
|
-
} = getResourceUrlAndType(data);
|
|
30
|
-
|
|
31
|
-
const parse = () => {
|
|
32
|
-
throw new Error('parseSync called parse');
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
context = getLoaderContext({
|
|
36
|
-
url,
|
|
37
|
-
parseSync,
|
|
38
|
-
parse,
|
|
39
|
-
loaders: loaders
|
|
40
|
-
}, options);
|
|
41
|
-
return parseWithLoaderSync(loader, data, options, context);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
function parseWithLoaderSync(loader, data, options, context) {
|
|
45
|
-
data = getArrayBufferOrStringFromDataSync(data, loader, options);
|
|
46
|
-
|
|
47
|
-
if (loader.parseTextSync && typeof data === 'string') {
|
|
48
|
-
return loader.parseTextSync(data, options);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
if (loader.parseSync && data instanceof ArrayBuffer) {
|
|
52
|
-
return loader.parseSync(data, options, context);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
throw new Error("".concat(loader.name, " loader: 'parseSync' not supported by this loader, use 'parse' instead. ").concat(context.url || ''));
|
|
56
|
-
}
|
|
57
|
-
//# sourceMappingURL=parse-sync.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/lib/api/parse-sync.ts"],"names":["assert","selectLoaderSync","isLoaderObject","normalizeOptions","getArrayBufferOrStringFromDataSync","getLoaderContext","getLoadersFromContext","getResourceUrlAndType","parseSync","data","loaders","options","context","Array","isArray","undefined","typedLoaders","candidateLoaders","loader","url","parse","Error","parseWithLoaderSync","parseTextSync","ArrayBuffer","name"],"mappings":"AAOA,SAAQA,MAAR,QAAqB,0BAArB;AACA,SAAQC,gBAAR,QAA+B,iBAA/B;AACA,SAAQC,cAAR,QAA6B,kCAA7B;AACA,SAAQC,gBAAR,QAA+B,8BAA/B;AACA,SAAQC,kCAAR,QAAiD,0BAAjD;AACA,SAAQC,gBAAR,EAA0BC,qBAA1B,QAAsD,gCAAtD;AACA,SAAQC,qBAAR,QAAoC,yBAApC;AASA,OAAO,SAASC,SAAT,CACLC,IADK,EAELC,OAFK,EAGLC,OAHK,EAILC,OAJK,EAKA;AACLZ,EAAAA,MAAM,CAAC,CAACY,OAAD,IAAY,OAAOA,OAAP,KAAmB,QAAhC,CAAN;;AAIA,MAAI,CAACC,KAAK,CAACC,OAAN,CAAcJ,OAAd,CAAD,IAA2B,CAACR,cAAc,CAACQ,OAAD,CAA9C,EAAyD;AACvDE,IAAAA,OAAO,GAAGG,SAAV;AACAJ,IAAAA,OAAO,GAAGD,OAAV;AACAA,IAAAA,OAAO,GAAGK,SAAV;AACD;;AAEDJ,EAAAA,OAAO,GAAGA,OAAO,IAAI,EAArB;AAIA,QAAMK,YAAY,GAAGN,OAArB;AACA,QAAMO,gBAAgB,GAAGX,qBAAqB,CAACU,YAAD,EAAeJ,OAAf,CAA9C;AACA,QAAMM,MAAM,GAAGjB,gBAAgB,CAACQ,IAAD,EAAOQ,gBAAP,EAAyBN,OAAzB,CAA/B;;AAEA,MAAI,CAACO,MAAL,EAAa;AACX,WAAO,IAAP;AACD;;AAGDP,EAAAA,OAAO,GAAGR,gBAAgB,CAACQ,OAAD,EAAUO,MAAV,EAAkBD,gBAAlB,CAA1B;AAGA,QAAM;AAACE,IAAAA;AAAD,MAAQZ,qBAAqB,CAACE,IAAD,CAAnC;;AAEA,QAAMW,KAAK,GAAG,MAAM;AAClB,UAAM,IAAIC,KAAJ,CAAU,wBAAV,CAAN;AACD,GAFD;;AAGAT,EAAAA,OAAO,GAAGP,gBAAgB,CAAC;AAACc,IAAAA,GAAD;AAAMX,IAAAA,SAAN;AAAiBY,IAAAA,KAAjB;AAAwBV,IAAAA,OAAO,EAAEA;AAAjC,GAAD,EAAwDC,OAAxD,CAA1B;AAEA,SAAOW,mBAAmB,CAACJ,MAAD,EAA6BT,IAA7B,EAAmCE,OAAnC,EAA4CC,OAA5C,CAA1B;AACD;;AAGD,SAASU,mBAAT,CACEJ,MADF,EAEET,IAFF,EAGEE,OAHF,EAIEC,OAJF,EAKE;AACAH,EAAAA,IAAI,GAAGL,kCAAkC,CAACK,IAAD,EAAOS,MAAP,EAAeP,OAAf,CAAzC;;AAEA,MAAIO,MAAM,CAACK,aAAP,IAAwB,OAAOd,IAAP,KAAgB,QAA5C,EAAsD;AACpD,WAAOS,MAAM,CAACK,aAAP,CAAqBd,IAArB,EAA2BE,OAA3B,CAAP;AACD;;AAED,MAAIO,MAAM,CAACV,SAAP,IAAoBC,IAAI,YAAYe,WAAxC,EAAqD;AACnD,WAAON,MAAM,CAACV,SAAP,CAAiBC,IAAjB,EAAuBE,OAAvB,EAAgCC,OAAhC,CAAP;AACD;;AAGD,QAAM,IAAIS,KAAJ,WACDH,MAAM,CAACO,IADN,qFAEFb,OAAO,CAACO,GAAR,IAAe,EAFb,EAAN;AAKD","sourcesContent":["import type {\n SyncDataType,\n Loader,\n LoaderWithParser,\n LoaderContext,\n LoaderOptions\n} from '@loaders.gl/loader-utils';\nimport {assert} from '@loaders.gl/loader-utils';\nimport {selectLoaderSync} from './select-loader';\nimport {isLoaderObject} from '../loader-utils/normalize-loader';\nimport {normalizeOptions} from '../loader-utils/option-utils';\nimport {getArrayBufferOrStringFromDataSync} from '../loader-utils/get-data';\nimport {getLoaderContext, getLoadersFromContext} from '../loader-utils/loader-context';\nimport {getResourceUrlAndType} from '../utils/resource-utils';\n\n/**\n * Parses `data` synchronously using a specified loader\n * @param data\n * @param loaders\n * @param options\n * @param context\n */\nexport function parseSync(\n data: SyncDataType,\n loaders?: Loader | Loader[] | LoaderOptions,\n options?: LoaderOptions,\n context?: LoaderContext\n): any {\n assert(!context || typeof context === 'object'); // parseSync no longer accepts final url\n\n // Signature: parseSync(data, options)\n // Uses registered loaders\n if (!Array.isArray(loaders) && !isLoaderObject(loaders)) {\n context = undefined; // context not supported in short signature\n options = loaders as LoaderOptions;\n loaders = undefined;\n }\n\n options = options || {};\n\n // Chooses a loader (and normalizes it)\n // Also use any loaders in the context, new loaders take priority\n const typedLoaders = loaders as Loader | Loader[] | undefined;\n const candidateLoaders = getLoadersFromContext(typedLoaders, context);\n const loader = selectLoaderSync(data, candidateLoaders, options);\n // Note: if nothrow option was set, it is possible that no loader was found, if so just return null\n if (!loader) {\n return null;\n }\n\n // Normalize options\n options = normalizeOptions(options, loader, candidateLoaders);\n\n // Extract a url for auto detection\n const {url} = getResourceUrlAndType(data);\n\n const parse = () => {\n throw new Error('parseSync called parse');\n };\n context = getLoaderContext({url, parseSync, parse, loaders: loaders as Loader[]}, options);\n\n return parseWithLoaderSync(loader as LoaderWithParser, data, options, context);\n}\n\n// TODO - should accept loader.parseSync/parse and generate 1 chunk asyncIterator\nfunction parseWithLoaderSync(\n loader: LoaderWithParser,\n data: SyncDataType,\n options: LoaderOptions,\n context: LoaderContext\n) {\n data = getArrayBufferOrStringFromDataSync(data, loader, options);\n\n if (loader.parseTextSync && typeof data === 'string') {\n return loader.parseTextSync(data, options); // , context, loader);\n }\n\n if (loader.parseSync && data instanceof ArrayBuffer) {\n return loader.parseSync(data, options, context); // , loader);\n }\n\n // TBD - If synchronous parser not available, return null\n throw new Error(\n `${loader.name} loader: 'parseSync' not supported by this loader, use 'parse' instead. ${\n context.url || ''\n }`\n );\n}\n"],"file":"parse-sync.js"}
|