@loaders.gl/core 4.0.0-alpha.5 → 4.0.0-alpha.6
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/core-addons/write-file-browser.js +59 -1
- package/dist/dist.min.js +855 -404
- package/dist/es5/bundle.js +6 -0
- package/dist/es5/bundle.js.map +1 -0
- package/dist/es5/core-addons/write-file-browser.js +2 -0
- package/dist/es5/core-addons/write-file-browser.js.map +1 -0
- package/dist/es5/index.js +377 -0
- package/dist/es5/index.js.map +1 -0
- package/dist/es5/iterators/batch-iterators/timed-batch-iterator.js +94 -0
- package/dist/es5/iterators/batch-iterators/timed-batch-iterator.js.map +1 -0
- package/dist/es5/iterators/make-iterator/make-array-buffer-iterator.js +42 -0
- package/dist/es5/iterators/make-iterator/make-array-buffer-iterator.js.map +1 -0
- package/dist/es5/iterators/make-iterator/make-blob-iterator.js +47 -0
- package/dist/es5/iterators/make-iterator/make-blob-iterator.js.map +1 -0
- package/dist/es5/iterators/make-iterator/make-iterator.js +31 -0
- package/dist/es5/iterators/make-iterator/make-iterator.js.map +1 -0
- package/dist/es5/iterators/make-iterator/make-stream-iterator.js +133 -0
- package/dist/es5/iterators/make-iterator/make-stream-iterator.js.map +1 -0
- package/dist/es5/iterators/make-iterator/make-string-iterator.js +38 -0
- package/dist/es5/iterators/make-iterator/make-string-iterator.js.map +1 -0
- package/dist/es5/iterators/make-stream/make-dom-stream.js +67 -0
- package/dist/es5/iterators/make-stream/make-dom-stream.js.map +1 -0
- package/dist/es5/iterators/make-stream/make-node-stream.js +168 -0
- package/dist/es5/iterators/make-stream/make-node-stream.js.map +1 -0
- package/dist/es5/javascript-utils/is-type.js +79 -0
- package/dist/es5/javascript-utils/is-type.js.map +1 -0
- package/dist/es5/lib/api/encode-table.js +159 -0
- package/dist/es5/lib/api/encode-table.js.map +1 -0
- package/dist/es5/lib/api/encode.js +244 -0
- package/dist/es5/lib/api/encode.js.map +1 -0
- package/dist/es5/lib/api/load-in-batches.js +63 -0
- package/dist/es5/lib/api/load-in-batches.js.map +1 -0
- package/dist/es5/lib/api/load.js +76 -0
- package/dist/es5/lib/api/load.js.map +1 -0
- package/dist/es5/lib/api/loader-options.js +19 -0
- package/dist/es5/lib/api/loader-options.js.map +1 -0
- package/dist/es5/lib/api/parse-in-batches.js +277 -0
- package/dist/es5/lib/api/parse-in-batches.js.map +1 -0
- package/dist/es5/lib/api/parse-sync.js +54 -0
- package/dist/es5/lib/api/parse-sync.js.map +1 -0
- package/dist/es5/lib/api/parse.js +143 -0
- package/dist/es5/lib/api/parse.js.map +1 -0
- package/dist/es5/lib/api/register-loaders.js +50 -0
- package/dist/es5/lib/api/register-loaders.js.map +1 -0
- package/dist/es5/lib/api/save.js +42 -0
- package/dist/es5/lib/api/save.js.map +1 -0
- package/dist/es5/lib/api/select-loader.js +303 -0
- package/dist/es5/lib/api/select-loader.js.map +1 -0
- package/dist/es5/lib/common.js +2 -0
- package/dist/es5/lib/common.js.map +1 -0
- package/dist/es5/lib/fetch/fetch-error-message.js +56 -0
- package/dist/es5/lib/fetch/fetch-error-message.js.map +1 -0
- package/dist/es5/lib/fetch/fetch-file.js +47 -0
- package/dist/es5/lib/fetch/fetch-file.js.map +1 -0
- package/dist/es5/lib/fetch/read-array-buffer.js +76 -0
- package/dist/es5/lib/fetch/read-array-buffer.js.map +1 -0
- package/dist/es5/lib/fetch/read-file.js +20 -0
- package/dist/es5/lib/fetch/read-file.js.map +1 -0
- package/dist/es5/lib/fetch/write-file.js +48 -0
- package/dist/es5/lib/fetch/write-file.js.map +1 -0
- package/dist/es5/lib/filesystems/browser-filesystem.js +249 -0
- package/dist/es5/lib/filesystems/browser-filesystem.js.map +1 -0
- package/dist/es5/lib/filesystems/filesystem.js +2 -0
- package/dist/es5/lib/filesystems/filesystem.js.map +1 -0
- package/dist/es5/lib/filesystems/read-array-buffer.js +41 -0
- package/dist/es5/lib/filesystems/read-array-buffer.js.map +1 -0
- package/dist/es5/lib/init.js +18 -0
- package/dist/es5/lib/init.js.map +1 -0
- package/dist/es5/lib/loader-utils/check-errors.js +57 -0
- package/dist/es5/lib/loader-utils/check-errors.js.map +1 -0
- package/dist/es5/lib/loader-utils/get-data.js +237 -0
- package/dist/es5/lib/loader-utils/get-data.js.map +1 -0
- package/dist/es5/lib/loader-utils/get-fetch-function.js +26 -0
- package/dist/es5/lib/loader-utils/get-fetch-function.js.map +1 -0
- package/dist/es5/lib/loader-utils/loader-context.js +41 -0
- package/dist/es5/lib/loader-utils/loader-context.js.map +1 -0
- package/dist/es5/lib/loader-utils/loggers.js +90 -0
- package/dist/es5/lib/loader-utils/loggers.js.map +1 -0
- package/dist/es5/lib/loader-utils/normalize-loader.js +44 -0
- package/dist/es5/lib/loader-utils/normalize-loader.js.map +1 -0
- package/dist/es5/lib/loader-utils/option-defaults.js +47 -0
- package/dist/es5/lib/loader-utils/option-defaults.js.map +1 -0
- package/dist/es5/lib/loader-utils/option-utils.js +132 -0
- package/dist/es5/lib/loader-utils/option-utils.js.map +1 -0
- package/dist/es5/lib/progress/fetch-progress.js +134 -0
- package/dist/es5/lib/progress/fetch-progress.js.map +1 -0
- package/dist/es5/lib/utils/log.js +12 -0
- package/dist/es5/lib/utils/log.js.map +1 -0
- package/dist/es5/lib/utils/mime-type-utils.js +24 -0
- package/dist/es5/lib/utils/mime-type-utils.js.map +1 -0
- package/dist/es5/lib/utils/resource-utils.js +58 -0
- package/dist/es5/lib/utils/resource-utils.js.map +1 -0
- package/dist/es5/lib/utils/response-utils.js +196 -0
- package/dist/es5/lib/utils/response-utils.js.map +1 -0
- package/dist/es5/null-loader.js +139 -0
- package/dist/es5/null-loader.js.map +1 -0
- package/dist/es5/workers/null-worker.js +6 -0
- package/dist/es5/workers/null-worker.js.map +1 -0
- package/dist/esm/bundle.js +4 -0
- package/dist/esm/bundle.js.map +1 -0
- package/dist/esm/core-addons/README.md +1 -0
- package/dist/esm/core-addons/write-file-browser.js +2 -0
- package/dist/esm/core-addons/write-file-browser.js.map +1 -0
- package/dist/esm/index.js +30 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/iterators/batch-iterators/timed-batch-iterator.js +16 -0
- package/dist/esm/iterators/batch-iterators/timed-batch-iterator.js.map +1 -0
- package/dist/esm/iterators/make-iterator/make-array-buffer-iterator.js +20 -0
- package/dist/esm/iterators/make-iterator/make-array-buffer-iterator.js.map +1 -0
- package/dist/esm/iterators/make-iterator/make-blob-iterator.js +12 -0
- package/dist/esm/iterators/make-iterator/make-blob-iterator.js.map +1 -0
- package/dist/esm/iterators/make-iterator/make-iterator.js +25 -0
- package/dist/esm/iterators/make-iterator/make-iterator.js.map +1 -0
- package/dist/esm/iterators/make-iterator/make-stream-iterator.js +32 -0
- package/dist/esm/iterators/make-iterator/make-stream-iterator.js.map +1 -0
- package/dist/esm/iterators/make-iterator/make-string-iterator.js +13 -0
- package/dist/esm/iterators/make-iterator/make-string-iterator.js.map +1 -0
- package/dist/esm/iterators/make-stream/make-dom-stream.js +29 -0
- package/dist/esm/iterators/make-stream/make-dom-stream.js.map +1 -0
- package/dist/esm/iterators/make-stream/make-node-stream.js +57 -0
- package/dist/esm/iterators/make-stream/make-node-stream.js.map +1 -0
- package/dist/esm/javascript-utils/is-type.js +19 -0
- package/dist/esm/javascript-utils/is-type.js.map +1 -0
- package/dist/esm/lib/api/encode-table.js +45 -0
- package/dist/esm/lib/api/encode-table.js.map +1 -0
- package/dist/esm/lib/api/encode.js +87 -0
- package/dist/esm/lib/api/encode.js.map +1 -0
- package/dist/esm/lib/api/load-in-batches.js +25 -0
- package/dist/esm/lib/api/load-in-batches.js.map +1 -0
- package/dist/esm/lib/api/load.js +26 -0
- package/dist/esm/lib/api/load.js.map +1 -0
- package/dist/esm/lib/api/loader-options.js +3 -0
- package/dist/esm/lib/api/loader-options.js.map +1 -0
- package/dist/esm/lib/api/parse-in-batches.js +85 -0
- package/dist/esm/lib/api/parse-in-batches.js.map +1 -0
- package/dist/esm/lib/api/parse-sync.js +47 -0
- package/dist/esm/lib/api/parse-sync.js.map +1 -0
- package/dist/esm/lib/api/parse.js +76 -0
- package/dist/esm/lib/api/parse.js.map +1 -0
- package/dist/esm/lib/api/register-loaders.js +25 -0
- package/dist/esm/lib/api/register-loaders.js.map +1 -0
- package/dist/esm/lib/api/save.js +11 -0
- package/dist/esm/lib/api/save.js.map +1 -0
- package/dist/esm/lib/api/select-loader.js +204 -0
- package/dist/esm/lib/api/select-loader.js.map +1 -0
- package/dist/esm/lib/common.js +2 -0
- package/dist/esm/lib/common.js.map +1 -0
- package/dist/esm/lib/fetch/fetch-error-message.js +18 -0
- package/dist/esm/lib/fetch/fetch-error-message.js.map +1 -0
- package/dist/esm/lib/fetch/fetch-file.js +14 -0
- package/dist/esm/lib/fetch/fetch-file.js.map +1 -0
- package/dist/esm/lib/fetch/read-array-buffer.js +23 -0
- package/dist/esm/lib/fetch/read-array-buffer.js.map +1 -0
- package/dist/esm/lib/fetch/read-file.js +15 -0
- package/dist/esm/lib/fetch/read-file.js.map +1 -0
- package/dist/esm/lib/fetch/write-file.js +21 -0
- package/dist/esm/lib/fetch/write-file.js.map +1 -0
- package/dist/esm/lib/filesystems/browser-filesystem.js +92 -0
- package/dist/esm/lib/filesystems/browser-filesystem.js.map +1 -0
- package/dist/esm/lib/filesystems/filesystem.js +2 -0
- package/dist/esm/lib/filesystems/filesystem.js.map +1 -0
- package/dist/esm/lib/filesystems/read-array-buffer.js +8 -0
- package/dist/esm/lib/filesystems/read-array-buffer.js.map +1 -0
- package/dist/esm/lib/init.js +11 -0
- package/dist/esm/lib/init.js.map +1 -0
- package/dist/esm/lib/loader-utils/check-errors.js +22 -0
- package/dist/esm/lib/loader-utils/check-errors.js.map +1 -0
- package/dist/esm/lib/loader-utils/get-data.js +103 -0
- package/dist/esm/lib/loader-utils/get-data.js.map +1 -0
- package/dist/esm/lib/loader-utils/get-fetch-function.js +18 -0
- package/dist/esm/lib/loader-utils/get-fetch-function.js.map +1 -0
- package/dist/esm/lib/loader-utils/loader-context.js +30 -0
- package/dist/esm/lib/loader-utils/loader-context.js.map +1 -0
- package/dist/esm/lib/loader-utils/loggers.js +50 -0
- package/dist/esm/lib/loader-utils/loggers.js.map +1 -0
- package/dist/esm/lib/loader-utils/normalize-loader.js +37 -0
- package/dist/esm/lib/loader-utils/normalize-loader.js.map +1 -0
- package/dist/esm/lib/loader-utils/option-defaults.js +39 -0
- package/dist/esm/lib/loader-utils/option-defaults.js.map +1 -0
- package/dist/esm/lib/loader-utils/option-utils.js +106 -0
- package/dist/esm/lib/loader-utils/option-utils.js.map +1 -0
- package/dist/esm/lib/progress/fetch-progress.js +52 -0
- package/dist/esm/lib/progress/fetch-progress.js.map +1 -0
- package/dist/esm/lib/utils/log.js +5 -0
- package/dist/esm/lib/utils/log.js.map +1 -0
- package/dist/esm/lib/utils/mime-type-utils.js +17 -0
- package/dist/esm/lib/utils/mime-type-utils.js.map +1 -0
- package/dist/esm/lib/utils/resource-utils.js +51 -0
- package/dist/esm/lib/utils/resource-utils.js.map +1 -0
- package/dist/esm/lib/utils/response-utils.js +91 -0
- package/dist/esm/lib/utils/response-utils.js.map +1 -0
- package/dist/esm/null-loader.js +45 -0
- package/dist/esm/null-loader.js.map +1 -0
- package/dist/esm/workers/null-worker.js +4 -0
- package/dist/esm/workers/null-worker.js.map +1 -0
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +108 -29
- package/dist/iterators/batch-iterators/timed-batch-iterator.js +20 -17
- package/dist/iterators/make-iterator/make-array-buffer-iterator.js +25 -16
- package/dist/iterators/make-iterator/make-blob-iterator.js +20 -12
- package/dist/iterators/make-iterator/make-iterator.d.ts +1 -1
- package/dist/iterators/make-iterator/make-iterator.d.ts.map +1 -1
- package/dist/iterators/make-iterator/make-iterator.js +36 -29
- package/dist/iterators/make-iterator/make-stream-iterator.d.ts +1 -1
- package/dist/iterators/make-iterator/make-stream-iterator.d.ts.map +1 -1
- package/dist/iterators/make-iterator/make-stream-iterator.js +89 -32
- package/dist/iterators/make-iterator/make-string-iterator.js +22 -12
- package/dist/iterators/make-stream/make-dom-stream.d.ts +1 -1
- package/dist/iterators/make-stream/make-dom-stream.d.ts.map +1 -1
- package/dist/iterators/make-stream/make-dom-stream.js +44 -32
- package/dist/iterators/make-stream/make-node-stream.d.ts +8 -3
- package/dist/iterators/make-stream/make-node-stream.d.ts.map +1 -1
- package/dist/iterators/make-stream/make-node-stream.js +75 -67
- package/dist/javascript-utils/is-type.d.ts +1 -1
- package/dist/javascript-utils/is-type.d.ts.map +1 -1
- package/dist/javascript-utils/is-type.js +41 -21
- package/dist/lib/api/encode-table.d.ts +6 -0
- package/dist/lib/api/encode-table.d.ts.map +1 -0
- package/dist/lib/api/encode-table.js +54 -0
- package/dist/lib/api/encode.d.ts +5 -5
- package/dist/lib/api/encode.d.ts.map +1 -1
- package/dist/lib/api/encode.js +111 -81
- package/dist/lib/api/load-in-batches.d.ts +1 -1
- package/dist/lib/api/load-in-batches.d.ts.map +1 -1
- package/dist/lib/api/load-in-batches.js +30 -27
- package/dist/lib/api/load.d.ts +3 -1
- package/dist/lib/api/load.d.ts.map +1 -1
- package/dist/lib/api/load.js +42 -24
- package/dist/lib/api/loader-options.d.ts +3 -0
- package/dist/lib/api/loader-options.d.ts.map +1 -0
- package/dist/lib/api/loader-options.js +7 -0
- package/dist/lib/api/parse-in-batches.js +113 -92
- package/dist/lib/api/parse-sync.js +56 -54
- package/dist/lib/api/parse.d.ts +4 -8
- package/dist/lib/api/parse.d.ts.map +1 -1
- package/dist/lib/api/parse.js +81 -61
- package/dist/lib/api/register-loaders.d.ts +1 -1
- package/dist/lib/api/register-loaders.d.ts.map +1 -1
- package/dist/lib/api/register-loaders.js +29 -23
- package/dist/lib/api/save.js +13 -9
- package/dist/lib/api/select-loader.d.ts.map +1 -1
- package/dist/lib/api/select-loader.js +216 -194
- package/dist/lib/common.js +2 -2
- package/dist/lib/fetch/fetch-error-message.js +21 -17
- package/dist/lib/fetch/fetch-file.js +25 -15
- package/dist/lib/fetch/read-array-buffer.js +39 -27
- package/dist/lib/fetch/read-file.js +28 -16
- package/dist/lib/fetch/write-file.js +20 -23
- package/dist/lib/filesystems/browser-filesystem.d.ts +1 -1
- package/dist/lib/filesystems/browser-filesystem.d.ts.map +1 -1
- package/dist/lib/filesystems/browser-filesystem.js +118 -107
- package/dist/lib/filesystems/filesystem.d.ts +2 -2
- package/dist/lib/filesystems/filesystem.d.ts.map +1 -1
- package/dist/lib/filesystems/filesystem.js +2 -2
- package/dist/lib/filesystems/read-array-buffer.js +28 -8
- package/dist/lib/init.d.ts.map +1 -1
- package/dist/lib/init.js +16 -6
- package/dist/lib/loader-utils/check-errors.js +26 -22
- package/dist/lib/loader-utils/get-data.js +122 -122
- package/dist/lib/loader-utils/get-fetch-function.d.ts +9 -0
- package/dist/lib/loader-utils/get-fetch-function.d.ts.map +1 -0
- package/dist/lib/loader-utils/get-fetch-function.js +31 -0
- package/dist/lib/loader-utils/loader-context.js +47 -34
- package/dist/lib/loader-utils/loggers.d.ts +2 -1
- package/dist/lib/loader-utils/loggers.d.ts.map +1 -1
- package/dist/lib/loader-utils/loggers.js +39 -46
- package/dist/lib/loader-utils/normalize-loader.js +50 -41
- package/dist/lib/loader-utils/option-defaults.d.ts.map +1 -1
- package/dist/lib/loader-utils/option-defaults.js +41 -35
- package/dist/lib/loader-utils/option-utils.d.ts +11 -13
- package/dist/lib/loader-utils/option-utils.d.ts.map +1 -1
- package/dist/lib/loader-utils/option-utils.js +140 -120
- package/dist/lib/progress/fetch-progress.js +54 -56
- package/dist/lib/utils/log.d.ts +3 -0
- package/dist/lib/utils/log.d.ts.map +1 -0
- package/dist/lib/utils/log.js +6 -0
- package/dist/lib/utils/mime-type-utils.js +38 -17
- package/dist/lib/utils/resource-utils.js +70 -52
- package/dist/lib/utils/response-utils.js +104 -105
- package/dist/null-loader.d.ts.map +1 -1
- package/dist/null-loader.js +53 -31
- package/dist/null-worker.js +61 -21
- package/dist/workers/null-worker.js +5 -4
- package/package.json +8 -8
- package/src/index.ts +19 -1
- package/src/iterators/make-stream/make-dom-stream.ts +1 -1
- package/src/iterators/make-stream/make-node-stream.ts +8 -2
- package/src/lib/api/encode-table.ts +71 -0
- package/src/lib/api/encode.ts +15 -5
- package/src/lib/api/load-in-batches.ts +1 -1
- package/src/lib/api/load.ts +39 -8
- package/src/lib/api/loader-options.ts +2 -0
- package/src/lib/api/parse.ts +39 -2
- package/src/lib/api/register-loaders.ts +1 -1
- package/src/lib/api/select-loader.ts +16 -0
- package/src/lib/init.ts +10 -3
- package/src/lib/loader-utils/get-fetch-function.ts +38 -0
- package/src/lib/loader-utils/loader-context.ts +1 -1
- package/src/lib/loader-utils/loggers.ts +1 -1
- package/src/lib/loader-utils/option-defaults.ts +3 -1
- package/src/lib/loader-utils/option-utils.ts +22 -46
- package/src/lib/progress/fetch-progress.ts +2 -2
- package/src/lib/utils/log.ts +4 -0
- package/src/lib/utils/response-utils.ts +2 -2
- package/src/null-loader.ts +17 -5
- package/dist/bundle.js.map +0 -1
- package/dist/core-addons/write-file-browser.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/iterators/batch-iterators/timed-batch-iterator.js.map +0 -1
- package/dist/iterators/make-iterator/make-array-buffer-iterator.js.map +0 -1
- package/dist/iterators/make-iterator/make-blob-iterator.js.map +0 -1
- package/dist/iterators/make-iterator/make-iterator.js.map +0 -1
- package/dist/iterators/make-iterator/make-stream-iterator.js.map +0 -1
- package/dist/iterators/make-iterator/make-string-iterator.js.map +0 -1
- package/dist/iterators/make-stream/make-dom-stream.js.map +0 -1
- package/dist/iterators/make-stream/make-node-stream.js.map +0 -1
- package/dist/javascript-utils/is-type.js.map +0 -1
- package/dist/lib/api/encode.js.map +0 -1
- package/dist/lib/api/load-in-batches.js.map +0 -1
- package/dist/lib/api/load.js.map +0 -1
- package/dist/lib/api/parse-in-batches.js.map +0 -1
- package/dist/lib/api/parse-sync.js.map +0 -1
- package/dist/lib/api/parse.js.map +0 -1
- package/dist/lib/api/register-loaders.js.map +0 -1
- package/dist/lib/api/save.js.map +0 -1
- package/dist/lib/api/select-loader.js.map +0 -1
- package/dist/lib/api/set-loader-options.d.ts +0 -6
- package/dist/lib/api/set-loader-options.d.ts.map +0 -1
- package/dist/lib/api/set-loader-options.js +0 -5
- package/dist/lib/api/set-loader-options.js.map +0 -1
- package/dist/lib/common.js.map +0 -1
- package/dist/lib/fetch/fetch-error-message.js.map +0 -1
- package/dist/lib/fetch/fetch-file.js.map +0 -1
- package/dist/lib/fetch/read-array-buffer.js.map +0 -1
- package/dist/lib/fetch/read-file.js.map +0 -1
- package/dist/lib/fetch/write-file.js.map +0 -1
- package/dist/lib/filesystems/browser-filesystem.js.map +0 -1
- package/dist/lib/filesystems/filesystem.js.map +0 -1
- package/dist/lib/filesystems/read-array-buffer.js.map +0 -1
- package/dist/lib/init.js.map +0 -1
- package/dist/lib/loader-utils/check-errors.js.map +0 -1
- package/dist/lib/loader-utils/get-data.js.map +0 -1
- package/dist/lib/loader-utils/loader-context.js.map +0 -1
- package/dist/lib/loader-utils/loggers.js.map +0 -1
- package/dist/lib/loader-utils/normalize-loader.js.map +0 -1
- package/dist/lib/loader-utils/option-defaults.js.map +0 -1
- package/dist/lib/loader-utils/option-utils.js.map +0 -1
- package/dist/lib/progress/fetch-progress.js.map +0 -1
- package/dist/lib/utils/mime-type-utils.js.map +0 -1
- package/dist/lib/utils/resource-utils.js.map +0 -1
- package/dist/lib/utils/response-utils.js.map +0 -1
- package/dist/null-loader.js.map +0 -1
- package/dist/workers/null-worker.js.map +0 -1
- package/src/lib/api/set-loader-options.ts +0 -9
- /package/dist/{core-addons → es5/core-addons}/README.md +0 -0
package/dist/lib/api/encode.js
CHANGED
|
@@ -1,91 +1,121 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
const chunks = [];
|
|
21
|
-
|
|
22
|
-
for await (const batch of batches) {
|
|
23
|
-
chunks.push(batch);
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.encodeURLtoURL = exports.encodeInBatches = exports.encodeText = exports.encodeSync = exports.encode = void 0;
|
|
4
|
+
const loader_utils_1 = require("@loaders.gl/loader-utils");
|
|
5
|
+
const worker_utils_1 = require("@loaders.gl/worker-utils");
|
|
6
|
+
const loader_utils_2 = require("@loaders.gl/loader-utils");
|
|
7
|
+
const loader_utils_3 = require("@loaders.gl/loader-utils");
|
|
8
|
+
const write_file_1 = require("../fetch/write-file");
|
|
9
|
+
const fetch_file_1 = require("../fetch/fetch-file");
|
|
10
|
+
const loader_options_1 = require("./loader-options");
|
|
11
|
+
/**
|
|
12
|
+
* Encode loaded data into a binary ArrayBuffer using the specified Writer.
|
|
13
|
+
*/
|
|
14
|
+
async function encode(data, writer, options) {
|
|
15
|
+
const globalOptions = (0, loader_options_1.getLoaderOptions)();
|
|
16
|
+
// const globalOptions: WriterOptions = {}; // getWriterOptions();
|
|
17
|
+
options = { ...globalOptions, ...options };
|
|
18
|
+
if ((0, loader_utils_1.canEncodeWithWorker)(writer, options)) {
|
|
19
|
+
return await (0, worker_utils_1.processOnWorker)(writer, data, options);
|
|
24
20
|
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
21
|
+
// TODO Merge default writer options with options argument like it is done in load module.
|
|
22
|
+
if (writer.encode) {
|
|
23
|
+
return await writer.encode(data, options);
|
|
24
|
+
}
|
|
25
|
+
if (writer.encodeSync) {
|
|
26
|
+
return writer.encodeSync(data, options);
|
|
27
|
+
}
|
|
28
|
+
if (writer.encodeText) {
|
|
29
|
+
return new TextEncoder().encode(await writer.encodeText(data, options));
|
|
30
|
+
}
|
|
31
|
+
if (writer.encodeInBatches) {
|
|
32
|
+
// Create an iterator representing the data
|
|
33
|
+
// TODO - Assumes this is a table
|
|
34
|
+
const batches = encodeInBatches(data, writer, options);
|
|
35
|
+
// Concatenate the output
|
|
36
|
+
const chunks = [];
|
|
37
|
+
for await (const batch of batches) {
|
|
38
|
+
chunks.push(batch);
|
|
39
|
+
}
|
|
40
|
+
// @ts-ignore
|
|
41
|
+
return (0, loader_utils_2.concatenateArrayBuffers)(...chunks);
|
|
42
|
+
}
|
|
43
|
+
if (!loader_utils_3.isBrowser && writer.encodeURLtoURL) {
|
|
44
|
+
// TODO - how to generate filenames with correct extensions?
|
|
45
|
+
const tmpInputFilename = getTemporaryFilename('input');
|
|
46
|
+
await (0, write_file_1.writeFile)(tmpInputFilename, data);
|
|
47
|
+
const tmpOutputFilename = getTemporaryFilename('output');
|
|
48
|
+
const outputFilename = await encodeURLtoURL(tmpInputFilename, tmpOutputFilename, writer, options);
|
|
49
|
+
const response = await (0, fetch_file_1.fetchFile)(outputFilename);
|
|
50
|
+
return response.arrayBuffer();
|
|
51
|
+
}
|
|
52
|
+
throw new Error('Writer could not encode data');
|
|
39
53
|
}
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
54
|
+
exports.encode = encode;
|
|
55
|
+
/**
|
|
56
|
+
* Encode loaded data into a binary ArrayBuffer using the specified Writer.
|
|
57
|
+
*/
|
|
58
|
+
function encodeSync(data, writer, options) {
|
|
59
|
+
if (writer.encodeSync) {
|
|
60
|
+
return writer.encodeSync(data, options);
|
|
61
|
+
}
|
|
62
|
+
throw new Error('Writer could not synchronously encode data');
|
|
46
63
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
64
|
+
exports.encodeSync = encodeSync;
|
|
65
|
+
/**
|
|
66
|
+
* Encode loaded data to text using the specified Writer
|
|
67
|
+
* @note This is a convenience function not intended for production use on large input data.
|
|
68
|
+
* It is not optimized for performance. Data maybe converted from text to binary and back.
|
|
69
|
+
* @throws if the writer does not generate text output
|
|
70
|
+
*/
|
|
71
|
+
async function encodeText(data, writer, options) {
|
|
72
|
+
if (writer.text && writer.encodeText) {
|
|
73
|
+
return await writer.encodeText(data, options);
|
|
74
|
+
}
|
|
75
|
+
if (writer.text && (writer.encode || writer.encodeInBatches)) {
|
|
76
|
+
const arrayBuffer = await encode(data, writer, options);
|
|
77
|
+
return new TextDecoder().decode(arrayBuffer);
|
|
78
|
+
}
|
|
79
|
+
throw new Error('Writer could not encode data as text');
|
|
58
80
|
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
81
|
+
exports.encodeText = encodeText;
|
|
82
|
+
/**
|
|
83
|
+
* Encode loaded data into a sequence (iterator) of binary ArrayBuffers using the specified Writer.
|
|
84
|
+
*/
|
|
85
|
+
function encodeInBatches(data, writer, options) {
|
|
86
|
+
if (writer.encodeInBatches) {
|
|
87
|
+
const dataIterator = getIterator(data);
|
|
88
|
+
// @ts-expect-error
|
|
89
|
+
return writer.encodeInBatches(dataIterator, options);
|
|
90
|
+
}
|
|
91
|
+
// TODO -fall back to atomic encode?
|
|
92
|
+
throw new Error('Writer could not encode data in batches');
|
|
66
93
|
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
94
|
+
exports.encodeInBatches = encodeInBatches;
|
|
95
|
+
/**
|
|
96
|
+
* Encode data stored in a file (on disk) to another file.
|
|
97
|
+
* @note Node.js only. This function enables using command-line converters as "writers".
|
|
98
|
+
*/
|
|
99
|
+
async function encodeURLtoURL(inputUrl, outputUrl, writer, options) {
|
|
100
|
+
inputUrl = (0, loader_utils_2.resolvePath)(inputUrl);
|
|
101
|
+
outputUrl = (0, loader_utils_2.resolvePath)(outputUrl);
|
|
102
|
+
if (loader_utils_3.isBrowser || !writer.encodeURLtoURL) {
|
|
103
|
+
throw new Error();
|
|
104
|
+
}
|
|
105
|
+
const outputFilename = await writer.encodeURLtoURL(inputUrl, outputUrl, options);
|
|
106
|
+
return outputFilename;
|
|
77
107
|
}
|
|
78
|
-
|
|
108
|
+
exports.encodeURLtoURL = encodeURLtoURL;
|
|
109
|
+
/**
|
|
110
|
+
* @todo TODO - this is an unacceptable hack!!!
|
|
111
|
+
*/
|
|
79
112
|
function getIterator(data) {
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
start: 0,
|
|
83
|
-
end: data.length
|
|
84
|
-
}];
|
|
85
|
-
return dataIterator;
|
|
113
|
+
const dataIterator = [{ table: data, start: 0, end: data.length }];
|
|
114
|
+
return dataIterator;
|
|
86
115
|
}
|
|
87
|
-
|
|
116
|
+
/**
|
|
117
|
+
* @todo Move to utils
|
|
118
|
+
*/
|
|
88
119
|
function getTemporaryFilename(filename) {
|
|
89
|
-
|
|
120
|
+
return `/tmp/${filename}`;
|
|
90
121
|
}
|
|
91
|
-
//# sourceMappingURL=encode.js.map
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { LoaderWithParser, LoaderOptions, LoaderContext } from '@loaders.gl/loader-utils';
|
|
2
|
-
|
|
2
|
+
type FileType = string | File | Blob | Response | (string | File | Blob | Response)[] | FileList;
|
|
3
3
|
/**
|
|
4
4
|
* Parses `data` using a specified loader
|
|
5
5
|
* @param data
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"load-in-batches.d.ts","sourceRoot":"","sources":["../../../src/lib/api/load-in-batches.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,gBAAgB,EAAE,aAAa,EAAE,aAAa,EAAC,MAAM,0BAA0B,CAAC;AAM7F,
|
|
1
|
+
{"version":3,"file":"load-in-batches.d.ts","sourceRoot":"","sources":["../../../src/lib/api/load-in-batches.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,gBAAgB,EAAE,aAAa,EAAE,aAAa,EAAC,MAAM,0BAA0B,CAAC;AAM7F,KAAK,QAAQ,GAAG,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,QAAQ,GAAG,CAAC,MAAM,GAAG,IAAI,GAAG,IAAI,GAAG,QAAQ,CAAC,EAAE,GAAG,QAAQ,CAAC;AAEjG;;;;;;GAMG;AACH,wBAAgB,aAAa,CAC3B,KAAK,EAAE,QAAQ,EACf,OAAO,CAAC,EAAE,gBAAgB,GAAG,gBAAgB,EAAE,GAAG,aAAa,EAC/D,OAAO,CAAC,EAAE,aAAa,EACvB,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;AAE/B,wBAAgB,aAAa,CAC3B,KAAK,EAAE,QAAQ,EAAE,GAAG,QAAQ,EAC5B,OAAO,CAAC,EAAE,gBAAgB,GAAG,gBAAgB,EAAE,GAAG,aAAa,EAC/D,OAAO,CAAC,EAAE,aAAa,EACvB,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC"}
|
|
@@ -1,30 +1,33 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.loadInBatches = void 0;
|
|
4
|
+
const normalize_loader_1 = require("../loader-utils/normalize-loader");
|
|
5
|
+
const get_fetch_function_1 = require("../loader-utils/get-fetch-function");
|
|
6
|
+
const parse_in_batches_1 = require("./parse-in-batches");
|
|
7
|
+
function loadInBatches(files, loaders, options, context) {
|
|
8
|
+
// Signature: load(url, options)
|
|
9
|
+
if (!Array.isArray(loaders) && !(0, normalize_loader_1.isLoaderObject)(loaders)) {
|
|
10
|
+
context = undefined; // context not supported in short signature
|
|
11
|
+
options = loaders;
|
|
12
|
+
loaders = null;
|
|
13
|
+
}
|
|
14
|
+
// Select fetch function
|
|
15
|
+
const fetch = (0, get_fetch_function_1.getFetchFunction)(options || {});
|
|
16
|
+
// Single url/file
|
|
17
|
+
if (!Array.isArray(files)) {
|
|
18
|
+
return loadOneFileInBatches(files, loaders, options, fetch);
|
|
19
|
+
}
|
|
20
|
+
// Multiple URLs / files
|
|
21
|
+
const promises = files.map((file) => loadOneFileInBatches(file, loaders, options, fetch));
|
|
22
|
+
// No point in waiting here for all responses before starting to stream individual streams?
|
|
23
|
+
return promises;
|
|
19
24
|
}
|
|
20
|
-
|
|
25
|
+
exports.loadInBatches = loadInBatches;
|
|
21
26
|
async function loadOneFileInBatches(file, loaders, options, fetch) {
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
return await parseInBatches(file, loaders, options);
|
|
27
|
+
if (typeof file === 'string') {
|
|
28
|
+
const url = file;
|
|
29
|
+
const response = await fetch(url);
|
|
30
|
+
return await (0, parse_in_batches_1.parseInBatches)(response, loaders, options);
|
|
31
|
+
}
|
|
32
|
+
return await (0, parse_in_batches_1.parseInBatches)(file, loaders, options);
|
|
29
33
|
}
|
|
30
|
-
//# sourceMappingURL=load-in-batches.js.map
|
package/dist/lib/api/load.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { DataType, Loader, LoaderContext, LoaderOptions } from '@loaders.gl/loader-utils';
|
|
2
|
+
import type { LoaderOptionsType, LoaderReturnType } from '@loaders.gl/loader-utils';
|
|
2
3
|
/**
|
|
3
4
|
* Parses `data` using a specified loader
|
|
4
5
|
* Note: Load does duplicate a lot of parse.
|
|
@@ -8,5 +9,6 @@ import type { DataType, Loader, LoaderContext, LoaderOptions } from '@loaders.gl
|
|
|
8
9
|
* @param options
|
|
9
10
|
* @param context
|
|
10
11
|
*/
|
|
11
|
-
export declare function load(url: string | DataType,
|
|
12
|
+
export declare function load<LoaderT extends Loader>(url: string | DataType, loader: LoaderT, options?: LoaderOptionsType<LoaderT>, context?: LoaderContext): Promise<LoaderReturnType<LoaderT>>;
|
|
13
|
+
export declare function load<LoaderT extends Loader, LoaderOptionsT extends LoaderOptions = LoaderOptions>(url: string | DataType, loaders: Loader[] | LoaderOptions, options?: LoaderOptionsT, context?: LoaderContext): Promise<any>;
|
|
12
14
|
//# sourceMappingURL=load.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"load.d.ts","sourceRoot":"","sources":["../../../src/lib/api/load.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"load.d.ts","sourceRoot":"","sources":["../../../src/lib/api/load.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAC,QAAQ,EAAE,MAAM,EAAE,aAAa,EAAE,aAAa,EAAC,MAAM,0BAA0B,CAAC;AAC7F,OAAO,KAAK,EAAC,iBAAiB,EAAE,gBAAgB,EAAC,MAAM,0BAA0B,CAAC;AAOlF;;;;;;;;GAQG;AAEH,wBAAsB,IAAI,CAAC,OAAO,SAAS,MAAM,EAC/C,GAAG,EAAE,MAAM,GAAG,QAAQ,EACtB,MAAM,EAAE,OAAO,EACf,OAAO,CAAC,EAAE,iBAAiB,CAAC,OAAO,CAAC,EACpC,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC;AAEtC,wBAAsB,IAAI,CACxB,OAAO,SAAS,MAAM,EACtB,cAAc,SAAS,aAAa,GAAG,aAAa,EAEpD,GAAG,EAAE,MAAM,GAAG,QAAQ,EACtB,OAAO,EAAE,MAAM,EAAE,GAAG,aAAa,EACjC,OAAO,CAAC,EAAE,cAAc,EACxB,OAAO,CAAC,EAAE,aAAa,GACtB,OAAO,CAAC,GAAG,CAAC,CAAC"}
|
package/dist/lib/api/load.js
CHANGED
|
@@ -1,25 +1,43 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
// loaders.gl, MIT license
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.load = void 0;
|
|
5
|
+
const is_type_1 = require("../../javascript-utils/is-type");
|
|
6
|
+
const normalize_loader_1 = require("../loader-utils/normalize-loader");
|
|
7
|
+
const get_fetch_function_1 = require("../loader-utils/get-fetch-function");
|
|
8
|
+
const parse_1 = require("./parse");
|
|
9
|
+
// implementation signature
|
|
10
|
+
async function load(url, loaders, options, context) {
|
|
11
|
+
let resolvedLoaders;
|
|
12
|
+
let resolvedOptions;
|
|
13
|
+
// Signature: load(url, options)
|
|
14
|
+
if (!Array.isArray(loaders) && !(0, normalize_loader_1.isLoaderObject)(loaders)) {
|
|
15
|
+
resolvedLoaders = [];
|
|
16
|
+
resolvedOptions = loaders;
|
|
17
|
+
context = undefined; // context not supported in short signature
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
resolvedLoaders = loaders;
|
|
21
|
+
resolvedOptions = options;
|
|
22
|
+
}
|
|
23
|
+
// Select fetch function
|
|
24
|
+
const fetch = (0, get_fetch_function_1.getFetchFunction)(resolvedOptions);
|
|
25
|
+
// at this point, `url` could be already loaded binary data
|
|
26
|
+
let data = url;
|
|
27
|
+
// url is a string, fetch the url
|
|
28
|
+
if (typeof url === 'string') {
|
|
29
|
+
data = await fetch(url);
|
|
30
|
+
// URL is Blob or File, fetchFile handles it (alt: we could generate ObjectURL here)
|
|
31
|
+
}
|
|
32
|
+
if ((0, is_type_1.isBlob)(url)) {
|
|
33
|
+
// The fetch response object will contain blob.name
|
|
34
|
+
// @ts-expect-error TODO - This may not work for overridden fetch functions
|
|
35
|
+
data = await fetch(url);
|
|
36
|
+
}
|
|
37
|
+
// Data is loaded (at least we have a `Response` object) so time to hand over to `parse`
|
|
38
|
+
// return await parse(data, loaders as Loader[], options);
|
|
39
|
+
return Array.isArray(resolvedLoaders)
|
|
40
|
+
? await (0, parse_1.parse)(data, resolvedLoaders, resolvedOptions) // loader array overload
|
|
41
|
+
: await (0, parse_1.parse)(data, resolvedLoaders, resolvedOptions); // single loader overload
|
|
24
42
|
}
|
|
25
|
-
|
|
43
|
+
exports.load = load;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loader-options.d.ts","sourceRoot":"","sources":["../../../src/lib/api/loader-options.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,IAAI,gBAAgB,EAAC,MAAM,8BAA8B,CAAC;AAClF,OAAO,EAAC,sBAAsB,IAAI,gBAAgB,EAAC,MAAM,8BAA8B,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getLoaderOptions = exports.setLoaderOptions = void 0;
|
|
4
|
+
var option_utils_1 = require("../loader-utils/option-utils");
|
|
5
|
+
Object.defineProperty(exports, "setLoaderOptions", { enumerable: true, get: function () { return option_utils_1.setGlobalOptions; } });
|
|
6
|
+
var option_utils_2 = require("../loader-utils/option-utils");
|
|
7
|
+
Object.defineProperty(exports, "getLoaderOptions", { enumerable: true, get: function () { return option_utils_2.getGlobalLoaderOptions; } });
|
|
@@ -1,99 +1,120 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
url
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
url,
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
loaders
|
|
35
|
-
|
|
36
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.parseInBatches = void 0;
|
|
4
|
+
const loader_utils_1 = require("@loaders.gl/loader-utils");
|
|
5
|
+
const normalize_loader_1 = require("../loader-utils/normalize-loader");
|
|
6
|
+
const option_utils_1 = require("../loader-utils/option-utils");
|
|
7
|
+
const loader_context_1 = require("../loader-utils/loader-context");
|
|
8
|
+
const get_data_1 = require("../loader-utils/get-data");
|
|
9
|
+
const resource_utils_1 = require("../utils/resource-utils");
|
|
10
|
+
const select_loader_1 = require("./select-loader");
|
|
11
|
+
// Ensure `parse` is available in context if loader falls back to `parse`
|
|
12
|
+
const parse_1 = require("./parse");
|
|
13
|
+
/**
|
|
14
|
+
* Parses `data` using a specified loader
|
|
15
|
+
* @param data
|
|
16
|
+
* @param loaders
|
|
17
|
+
* @param options
|
|
18
|
+
* @param context
|
|
19
|
+
*/
|
|
20
|
+
async function parseInBatches(data, loaders, options, context) {
|
|
21
|
+
(0, loader_utils_1.assert)(!context || typeof context === 'object'); // parseInBatches no longer accepts final url
|
|
22
|
+
// Signature: parseInBatches(data, options, url) - Uses registered loaders
|
|
23
|
+
if (!Array.isArray(loaders) && !(0, normalize_loader_1.isLoaderObject)(loaders)) {
|
|
24
|
+
context = undefined; // context not supported in short signature
|
|
25
|
+
options = loaders;
|
|
26
|
+
loaders = undefined;
|
|
27
|
+
}
|
|
28
|
+
data = await data; // Resolve any promise
|
|
29
|
+
options = options || {};
|
|
30
|
+
// Extract a url for auto detection
|
|
31
|
+
const { url } = (0, resource_utils_1.getResourceUrlAndType)(data);
|
|
32
|
+
// Chooses a loader and normalizes it
|
|
33
|
+
// Note - only uses URL and contentType for streams and iterator inputs
|
|
34
|
+
const loader = await (0, select_loader_1.selectLoader)(data, loaders, options);
|
|
35
|
+
// Note: if options.nothrow was set, it is possible that no loader was found, if so just return null
|
|
36
|
+
if (!loader) {
|
|
37
|
+
// @ts-ignore
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
// Normalize options
|
|
41
|
+
// @ts-ignore
|
|
42
|
+
options = (0, option_utils_1.normalizeOptions)(options, loader, loaders, url);
|
|
43
|
+
// @ts-ignore
|
|
44
|
+
context = (0, loader_context_1.getLoaderContext)(
|
|
45
|
+
// @ts-ignore
|
|
46
|
+
{ url, parseInBatches, parse: parse_1.parse, loaders: loaders }, options, context);
|
|
47
|
+
return await parseWithLoaderInBatches(loader, data, options, context);
|
|
37
48
|
}
|
|
38
|
-
|
|
49
|
+
exports.parseInBatches = parseInBatches;
|
|
50
|
+
/**
|
|
51
|
+
* Loader has been selected and context has been prepared, see if we need to emit a metadata batch
|
|
52
|
+
*/
|
|
39
53
|
async function parseWithLoaderInBatches(loader, data, options, context) {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
return makeMetadataBatchIterator(outputIterator);
|
|
54
|
+
const outputIterator = await parseToOutputIterator(loader, data, options, context);
|
|
55
|
+
// Generate metadata batch if requested
|
|
56
|
+
if (!options.metadata) {
|
|
57
|
+
return outputIterator;
|
|
58
|
+
}
|
|
59
|
+
const metadataBatch = {
|
|
60
|
+
batchType: 'metadata',
|
|
61
|
+
metadata: {
|
|
62
|
+
_loader: loader,
|
|
63
|
+
_context: context
|
|
64
|
+
},
|
|
65
|
+
// Populate with some default fields to avoid crashing
|
|
66
|
+
data: [],
|
|
67
|
+
bytesUsed: 0
|
|
68
|
+
};
|
|
69
|
+
async function* makeMetadataBatchIterator(iterator) {
|
|
70
|
+
yield metadataBatch;
|
|
71
|
+
yield* iterator;
|
|
72
|
+
}
|
|
73
|
+
return makeMetadataBatchIterator(outputIterator);
|
|
62
74
|
}
|
|
63
|
-
|
|
75
|
+
/**
|
|
76
|
+
* Prep work is done, now it is time to start parsing into an output operator
|
|
77
|
+
* The approach depends on which parse function the loader exposes
|
|
78
|
+
* `parseInBatches` (preferred), `parse` (fallback)
|
|
79
|
+
*/
|
|
64
80
|
async function parseToOutputIterator(loader, data, options, context) {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
81
|
+
// Get an iterator from the input
|
|
82
|
+
const inputIterator = await (0, get_data_1.getAsyncIterableFromData)(data, options);
|
|
83
|
+
// Apply any iterator transforms (options.transforms)
|
|
84
|
+
const transformedIterator = await applyInputTransforms(inputIterator, options?.transforms || []);
|
|
85
|
+
// If loader supports parseInBatches, we are done
|
|
86
|
+
if (loader.parseInBatches) {
|
|
87
|
+
return loader.parseInBatches(transformedIterator, options, context);
|
|
88
|
+
}
|
|
89
|
+
// Fallback: load atomically using `parse` concatenating input iterator into single chunk
|
|
90
|
+
async function* parseChunkInBatches() {
|
|
91
|
+
const arrayBuffer = await (0, loader_utils_1.concatenateArrayBuffersAsync)(transformedIterator);
|
|
92
|
+
// Call `parse` instead of `loader.parse` to ensure we can call workers etc.
|
|
93
|
+
const parsedData = await (0, parse_1.parse)(arrayBuffer, loader,
|
|
94
|
+
// TODO - Hack: supply loaders MIME type to ensure we match it
|
|
95
|
+
{ ...options, mimeType: loader.mimeTypes[0] }, context);
|
|
96
|
+
// yield a single batch, the output from loader.parse()
|
|
97
|
+
// TODO - run through batch builder to apply options etc...
|
|
98
|
+
const batch = {
|
|
99
|
+
mimeType: loader.mimeTypes[0],
|
|
100
|
+
shape: Array.isArray(parsedData) ? 'row-table' : 'unknown',
|
|
101
|
+
batchType: 'data',
|
|
102
|
+
data: parsedData,
|
|
103
|
+
length: Array.isArray(parsedData) ? parsedData.length : 1
|
|
104
|
+
};
|
|
105
|
+
yield batch;
|
|
106
|
+
}
|
|
107
|
+
return parseChunkInBatches();
|
|
88
108
|
}
|
|
89
|
-
|
|
109
|
+
/**
|
|
110
|
+
* Create an iterator chain with any transform iterators (crypto, decompression)
|
|
111
|
+
* @param inputIterator
|
|
112
|
+
* @param options
|
|
113
|
+
*/
|
|
90
114
|
async function applyInputTransforms(inputIterator, transforms = []) {
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
return iteratorChain;
|
|
115
|
+
let iteratorChain = inputIterator;
|
|
116
|
+
for await (const transformBatches of transforms) {
|
|
117
|
+
iteratorChain = transformBatches(iteratorChain);
|
|
118
|
+
}
|
|
119
|
+
return iteratorChain;
|
|
98
120
|
}
|
|
99
|
-
//# sourceMappingURL=parse-in-batches.js.map
|