@loaders.gl/polyfills 4.0.0-beta.2 → 4.0.0-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/buffer/btoa.node.d.ts.map +1 -0
- package/dist/buffer/btoa.node.js.map +1 -0
- package/dist/buffer/to-array-buffer.node.d.ts.map +1 -0
- package/dist/buffer/to-array-buffer.node.js.map +1 -0
- package/dist/crypto/node-hash.d.ts +28 -0
- package/dist/crypto/node-hash.d.ts.map +1 -0
- package/dist/crypto/node-hash.js +56 -0
- package/dist/crypto/node-hash.js.map +1 -0
- package/dist/dist.dev.js +43 -0
- package/dist/{node/fetch/utils/decode-data-uri.node.d.ts → fetch/decode-data-uri.d.ts} +1 -1
- package/dist/fetch/decode-data-uri.d.ts.map +1 -0
- package/dist/{esm/node/fetch/utils/decode-data-uri.node.js → fetch/decode-data-uri.js} +3 -3
- package/dist/fetch/decode-data-uri.js.map +1 -0
- package/dist/{node/fetch/fetch.node.d.ts → fetch/fetch-polyfill.d.ts} +2 -2
- package/dist/fetch/fetch-polyfill.d.ts.map +1 -0
- package/dist/{esm/node/fetch/fetch.node.js → fetch/fetch-polyfill.js} +4 -4
- package/dist/fetch/fetch-polyfill.js.map +1 -0
- package/dist/{node/fetch/headers.node.d.ts → fetch/headers-polyfill.d.ts} +1 -1
- package/dist/{node/fetch/headers.node.d.ts.map → fetch/headers-polyfill.d.ts.map} +1 -1
- package/dist/{esm/node/fetch/headers.node.js → fetch/headers-polyfill.js} +3 -4
- package/dist/fetch/headers-polyfill.js.map +1 -0
- package/dist/{node/fetch/response.node.d.ts → fetch/response-polyfill.d.ts} +2 -2
- package/dist/{node/fetch/response.node.d.ts.map → fetch/response-polyfill.d.ts.map} +1 -1
- package/dist/{esm/node/fetch/response.node.js → fetch/response-polyfill.js} +14 -15
- package/dist/fetch/response-polyfill.js.map +1 -0
- package/dist/file/blob-stream-controller.d.ts.map +1 -0
- package/dist/{esm/node/file → file}/blob-stream-controller.js +3 -4
- package/dist/file/blob-stream-controller.js.map +1 -0
- package/dist/file/blob-stream.d.ts.map +1 -0
- package/dist/{esm/node/file → file}/blob-stream.js +3 -4
- package/dist/file/blob-stream.js.map +1 -0
- package/dist/file/blob.d.ts.map +1 -0
- package/dist/{esm/node/file → file}/blob.js +4 -5
- package/dist/file/blob.js.map +1 -0
- package/dist/file/file-reader.d.ts.map +1 -0
- package/dist/file/file-reader.js +59 -0
- package/dist/file/file-reader.js.map +1 -0
- package/dist/{node/file → file}/file.d.ts +1 -2
- package/dist/file/file.d.ts.map +1 -0
- package/dist/{esm/node/file → file}/file.js +4 -6
- package/dist/file/file.js.map +1 -0
- package/dist/file/install-blob-polyfills.d.ts +9 -0
- package/dist/file/install-blob-polyfills.d.ts.map +1 -0
- package/dist/file/install-blob-polyfills.js +9 -0
- package/dist/file/install-blob-polyfills.js.map +1 -0
- package/dist/file/install-file-polyfills.d.ts +3 -0
- package/dist/file/install-file-polyfills.d.ts.map +1 -0
- package/dist/file/install-file-polyfills.js +13 -0
- package/dist/file/install-file-polyfills.js.map +1 -0
- package/dist/file/readable-stream.d.ts.map +1 -0
- package/dist/{esm/node/file → file}/readable-stream.js +1 -1
- package/dist/file/readable-stream.js.map +1 -0
- package/dist/filesystems/fetch-node.d.ts +8 -0
- package/dist/filesystems/fetch-node.d.ts.map +1 -0
- package/dist/filesystems/fetch-node.js +77 -0
- package/dist/filesystems/fetch-node.js.map +1 -0
- package/dist/filesystems/node-file.d.ts +13 -0
- package/dist/filesystems/node-file.d.ts.map +1 -0
- package/dist/filesystems/node-file.js +72 -0
- package/dist/filesystems/node-file.js.map +1 -0
- package/dist/filesystems/node-filesystem.d.ts +11 -31
- package/dist/filesystems/node-filesystem.d.ts.map +1 -1
- package/dist/filesystems/node-filesystem.js +40 -0
- package/dist/filesystems/node-filesystem.js.map +1 -0
- package/dist/{node/fetch/utils → filesystems}/stream-utils.node.d.ts +8 -1
- package/dist/filesystems/stream-utils.node.d.ts.map +1 -0
- package/dist/{esm/node/fetch/utils → filesystems}/stream-utils.node.js +24 -2
- package/dist/filesystems/stream-utils.node.js.map +1 -0
- package/dist/images/encode-image.node.d.ts.map +1 -0
- package/dist/{esm/node/images → images}/encode-image.node.js +1 -1
- package/dist/images/encode-image.node.js.map +1 -0
- package/dist/images/parse-image.node.d.ts.map +1 -0
- package/dist/images/parse-image.node.js.map +1 -0
- package/dist/index.browser.d.ts +1 -0
- package/dist/index.browser.d.ts.map +1 -1
- package/dist/index.browser.js +6 -0
- package/dist/index.browser.js.map +1 -0
- package/dist/index.cjs +33 -0
- package/dist/index.d.ts +4 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +56 -0
- package/dist/index.js.map +1 -0
- package/dist/libs/encoding-indexes-asian.js +2 -0
- package/dist/libs/encoding-indexes-asian.js.map +1 -0
- package/dist/streams/make-node-stream.d.ts +11 -0
- package/dist/streams/make-node-stream.d.ts.map +1 -0
- package/dist/streams/make-node-stream.js +56 -0
- package/dist/streams/make-node-stream.js.map +1 -0
- package/dist/text-encoder/encoding-indexes.d.ts.map +1 -0
- package/dist/{esm/lib → text-encoder}/encoding-indexes.js.map +1 -1
- package/dist/{lib/encoding.d.ts → text-encoder/text-encoder.d.ts} +1 -1
- package/dist/text-encoder/text-encoder.d.ts.map +1 -0
- package/dist/{esm/lib/encoding.js → text-encoder/text-encoder.js} +7 -7
- package/dist/text-encoder/text-encoder.js.map +1 -0
- package/dist/utils/assert.js +6 -0
- package/dist/utils/assert.js.map +1 -0
- package/dist/utils/is-browser.d.ts +2 -0
- package/dist/utils/is-browser.d.ts.map +1 -0
- package/dist/utils/is-browser.js +2 -0
- package/dist/utils/is-browser.js.map +1 -0
- package/package.json +16 -6
- package/src/crypto/node-hash.ts +71 -0
- package/src/{node/fetch/fetch.node.ts → fetch/fetch-polyfill.ts} +3 -3
- package/src/{node/fetch/response.node.ts → fetch/response-polyfill.ts} +6 -6
- package/src/{node/file → file}/file.ts +1 -2
- package/src/file/install-blob-polyfills.ts +13 -0
- package/src/file/install-file-polyfills.ts +20 -0
- package/src/{node/file → file}/readable-stream.ts +1 -1
- package/src/filesystems/fetch-node.ts +96 -0
- package/src/filesystems/node-file.ts +137 -0
- package/src/filesystems/node-filesystem.ts +26 -61
- package/src/{node/fetch/utils → filesystems}/stream-utils.node.ts +42 -3
- package/src/index.browser.ts +4 -8
- package/src/index.ts +56 -46
- package/src/streams/make-node-stream.ts +74 -0
- package/src/{lib/encoding.ts → text-encoder/text-encoder.ts} +7 -7
- package/src/utils/is-browser.ts +6 -0
- package/dist/bundle.d.ts +0 -2
- package/dist/bundle.d.ts.map +0 -1
- package/dist/dist.min.js +0 -63
- package/dist/es5/bundle.js +0 -6
- package/dist/es5/bundle.js.map +0 -1
- package/dist/es5/filesystems/node-filesystem.js +0 -214
- package/dist/es5/filesystems/node-filesystem.js.map +0 -1
- package/dist/es5/index.browser.js +0 -15
- package/dist/es5/index.browser.js.map +0 -1
- package/dist/es5/index.js +0 -82
- package/dist/es5/index.js.map +0 -1
- package/dist/es5/lib/encoding-indexes.js +0 -37
- package/dist/es5/lib/encoding-indexes.js.map +0 -1
- package/dist/es5/lib/encoding.js +0 -1214
- package/dist/es5/lib/encoding.js.map +0 -1
- package/dist/es5/libs/encoding-indexes-asian.js +0 -13
- package/dist/es5/node/buffer/btoa.node.js +0 -14
- package/dist/es5/node/buffer/btoa.node.js.map +0 -1
- package/dist/es5/node/buffer/to-array-buffer.node.js +0 -14
- package/dist/es5/node/buffer/to-array-buffer.node.js.map +0 -1
- package/dist/es5/node/fetch/fetch.node.js +0 -193
- package/dist/es5/node/fetch/fetch.node.js.map +0 -1
- package/dist/es5/node/fetch/headers.node.js +0 -151
- package/dist/es5/node/fetch/headers.node.js.map +0 -1
- package/dist/es5/node/fetch/response.node.js +0 -182
- package/dist/es5/node/fetch/response.node.js.map +0 -1
- package/dist/es5/node/fetch/utils/decode-data-uri.node.js +0 -58
- package/dist/es5/node/fetch/utils/decode-data-uri.node.js.map +0 -1
- package/dist/es5/node/fetch/utils/stream-utils.node.js +0 -92
- package/dist/es5/node/fetch/utils/stream-utils.node.js.map +0 -1
- package/dist/es5/node/file/blob-stream-controller.js +0 -90
- package/dist/es5/node/file/blob-stream-controller.js.map +0 -1
- package/dist/es5/node/file/blob-stream.js +0 -64
- package/dist/es5/node/file/blob-stream.js.map +0 -1
- package/dist/es5/node/file/blob.js +0 -212
- package/dist/es5/node/file/blob.js.map +0 -1
- package/dist/es5/node/file/file-reader.js +0 -153
- package/dist/es5/node/file/file-reader.js.map +0 -1
- package/dist/es5/node/file/file.js +0 -44
- package/dist/es5/node/file/file.js.map +0 -1
- package/dist/es5/node/file/install-file-polyfills.js +0 -22
- package/dist/es5/node/file/install-file-polyfills.js.map +0 -1
- package/dist/es5/node/file/readable-stream.js +0 -27
- package/dist/es5/node/file/readable-stream.js.map +0 -1
- package/dist/es5/node/images/encode-image.node.js +0 -30
- package/dist/es5/node/images/encode-image.node.js.map +0 -1
- package/dist/es5/node/images/parse-image.node.js +0 -64
- package/dist/es5/node/images/parse-image.node.js.map +0 -1
- package/dist/es5/promise/all-settled.js +0 -28
- package/dist/es5/promise/all-settled.js.map +0 -1
- package/dist/es5/utils/assert.js +0 -12
- package/dist/es5/utils/assert.js.map +0 -1
- package/dist/es5/utils/globals.js +0 -18
- package/dist/es5/utils/globals.js.map +0 -1
- package/dist/esm/bundle.js +0 -4
- package/dist/esm/bundle.js.map +0 -1
- package/dist/esm/filesystems/node-filesystem.js +0 -56
- package/dist/esm/filesystems/node-filesystem.js.map +0 -1
- package/dist/esm/index.browser.js +0 -7
- package/dist/esm/index.browser.js.map +0 -1
- package/dist/esm/index.js +0 -51
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/lib/encoding.js.map +0 -1
- package/dist/esm/libs/encoding-indexes-asian.js +0 -13
- package/dist/esm/node/buffer/btoa.node.js.map +0 -1
- package/dist/esm/node/buffer/to-array-buffer.node.js.map +0 -1
- package/dist/esm/node/fetch/fetch.node.js.map +0 -1
- package/dist/esm/node/fetch/headers.node.js.map +0 -1
- package/dist/esm/node/fetch/response.node.js.map +0 -1
- package/dist/esm/node/fetch/utils/decode-data-uri.node.js.map +0 -1
- package/dist/esm/node/fetch/utils/stream-utils.node.js.map +0 -1
- package/dist/esm/node/file/blob-stream-controller.js.map +0 -1
- package/dist/esm/node/file/blob-stream.js.map +0 -1
- package/dist/esm/node/file/blob.js.map +0 -1
- package/dist/esm/node/file/file-reader.js +0 -60
- package/dist/esm/node/file/file-reader.js.map +0 -1
- package/dist/esm/node/file/file.js.map +0 -1
- package/dist/esm/node/file/install-file-polyfills.js +0 -16
- package/dist/esm/node/file/install-file-polyfills.js.map +0 -1
- package/dist/esm/node/file/readable-stream.js.map +0 -1
- package/dist/esm/node/images/encode-image.node.js.map +0 -1
- package/dist/esm/node/images/parse-image.node.js.map +0 -1
- package/dist/esm/promise/all-settled.js +0 -19
- package/dist/esm/promise/all-settled.js.map +0 -1
- package/dist/esm/utils/assert.js +0 -6
- package/dist/esm/utils/assert.js.map +0 -1
- package/dist/esm/utils/globals.js +0 -9
- package/dist/esm/utils/globals.js.map +0 -1
- package/dist/lib/encoding-indexes.d.ts.map +0 -1
- package/dist/lib/encoding.d.ts.map +0 -1
- package/dist/node/buffer/btoa.node.d.ts.map +0 -1
- package/dist/node/buffer/to-array-buffer.node.d.ts.map +0 -1
- package/dist/node/fetch/fetch.node.d.ts.map +0 -1
- package/dist/node/fetch/utils/decode-data-uri.node.d.ts.map +0 -1
- package/dist/node/fetch/utils/stream-utils.node.d.ts.map +0 -1
- package/dist/node/file/blob-stream-controller.d.ts.map +0 -1
- package/dist/node/file/blob-stream.d.ts.map +0 -1
- package/dist/node/file/blob.d.ts.map +0 -1
- package/dist/node/file/file-reader.d.ts.map +0 -1
- package/dist/node/file/file.d.ts.map +0 -1
- package/dist/node/file/install-file-polyfills.d.ts +0 -2
- package/dist/node/file/install-file-polyfills.d.ts.map +0 -1
- package/dist/node/file/readable-stream.d.ts.map +0 -1
- package/dist/node/images/encode-image.node.d.ts.map +0 -1
- package/dist/node/images/parse-image.node.d.ts.map +0 -1
- package/dist/promise/all-settled.d.ts +0 -10
- package/dist/promise/all-settled.d.ts.map +0 -1
- package/dist/utils/globals.d.ts +0 -4
- package/dist/utils/globals.d.ts.map +0 -1
- package/src/bundle.ts +0 -4
- package/src/node/file/install-file-polyfills.ts +0 -27
- package/src/promise/all-settled.ts +0 -21
- package/src/utils/globals.ts +0 -37
- /package/dist/{node/buffer → buffer}/btoa.node.d.ts +0 -0
- /package/dist/{esm/node/buffer → buffer}/btoa.node.js +0 -0
- /package/dist/{node/buffer → buffer}/to-array-buffer.node.d.ts +0 -0
- /package/dist/{esm/node/buffer → buffer}/to-array-buffer.node.js +0 -0
- /package/dist/{node/file → file}/blob-stream-controller.d.ts +0 -0
- /package/dist/{node/file → file}/blob-stream.d.ts +0 -0
- /package/dist/{node/file → file}/blob.d.ts +0 -0
- /package/dist/{node/file → file}/file-reader.d.ts +0 -0
- /package/dist/{node/file → file}/readable-stream.d.ts +0 -0
- /package/dist/{node/images → images}/encode-image.node.d.ts +0 -0
- /package/dist/{node/images → images}/parse-image.node.d.ts +0 -0
- /package/dist/{esm/node/images → images}/parse-image.node.js +0 -0
- /package/dist/{lib → text-encoder}/encoding-indexes.d.ts +0 -0
- /package/dist/{esm/lib → text-encoder}/encoding-indexes.js +0 -0
- /package/src/{node/buffer → buffer}/btoa.node.ts +0 -0
- /package/src/{node/buffer → buffer}/to-array-buffer.node.ts +0 -0
- /package/src/{node/fetch/utils/decode-data-uri.node.ts → fetch/decode-data-uri.ts} +0 -0
- /package/src/{node/fetch/headers.node.ts → fetch/headers-polyfill.ts} +0 -0
- /package/src/{node/file → file}/blob-stream-controller.ts +0 -0
- /package/src/{node/file → file}/blob-stream.ts +0 -0
- /package/src/{node/file → file}/blob.ts +0 -0
- /package/src/{node/file → file}/file-reader.ts +0 -0
- /package/src/{node/images → images}/encode-image.node.ts +0 -0
- /package/src/{node/images → images}/parse-image.node.ts +0 -0
- /package/src/{lib → text-encoder}/encoding-indexes.ts +0 -0
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
import { BlobPolyfill } from './blob';
|
|
2
1
|
/**
|
|
3
2
|
* Forked from @gozala's web-file under MIT license
|
|
4
3
|
* @see https://github.com/Gozala/web-file
|
|
5
4
|
*/
|
|
6
|
-
export declare class FilePolyfill extends
|
|
5
|
+
export declare class FilePolyfill extends globalThis.Blob {
|
|
7
6
|
/** The name of the file referenced by the File object. */
|
|
8
7
|
name: string;
|
|
9
8
|
/** The path the URL of the File is relative to. */
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file.d.ts","sourceRoot":"","sources":["../../src/file/file.ts"],"names":[],"mappings":"AAEA;;;GAGG;AAEH,qBAAa,YAAa,SAAQ,UAAU,CAAC,IAAI;IAG/C,0DAA0D;IAC1D,IAAI,EAAE,MAAM,CAAM;IAClB,mDAAmD;IACnD,kBAAkB,EAAE,MAAM,CAAM;IAEhC;;;OAGG;IACH,YAAY,EAAE,MAAM,CAAC;IAErB;;;;;OAKG;gBACS,IAAI,EAAE,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,GAAE,eAAoB;IAUzE,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,WAEvB;CACF"}
|
|
@@ -1,14 +1,12 @@
|
|
|
1
|
-
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
2
1
|
let _Symbol$toStringTag;
|
|
3
|
-
import { BlobPolyfill } from './blob';
|
|
4
2
|
_Symbol$toStringTag = Symbol.toStringTag;
|
|
5
|
-
export class FilePolyfill extends
|
|
3
|
+
export class FilePolyfill extends globalThis.Blob {
|
|
6
4
|
constructor(init, name) {
|
|
7
5
|
let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
8
6
|
super(init, options);
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
7
|
+
this.name = '';
|
|
8
|
+
this.webkitRelativePath = '';
|
|
9
|
+
this.lastModified = void 0;
|
|
12
10
|
this.name = String(name).replace(/\//g, ':');
|
|
13
11
|
this.lastModified = (options === null || options === void 0 ? void 0 : options.lastModified) || Date.now();
|
|
14
12
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file.js","names":["Symbol","toStringTag","FilePolyfill","globalThis","Blob","constructor","init","name","options","arguments","length","undefined","webkitRelativePath","lastModified","String","replace","Date","now","_Symbol$toStringTag"],"sources":["../../src/file/file.ts"],"sourcesContent":["// Forked from @gozala's web-file under MIT license https://github.com/Gozala/web-file\n\n/**\n * Forked from @gozala's web-file under MIT license\n * @see https://github.com/Gozala/web-file\n */\n// @ts-ignore\nexport class FilePolyfill extends globalThis.Blob {\n // implements File {\n // public API\n /** The name of the file referenced by the File object. */\n name: string = '';\n /** The path the URL of the File is relative to. */\n webkitRelativePath: string = '';\n\n /**\n * Returns the last modified time of the file, in millisecond since the UNIX\n * epoch (January 1st, 1970 at Midnight).\n */\n lastModified: number;\n\n /**\n * @param init\n * @param name - A USVString representing the file name or the path\n * to the file.\n * @param [options]\n */\n constructor(init: BlobPart[], name: string, options: FilePropertyBag = {}) {\n super(init, options);\n // Per File API spec https://w3c.github.io/FileAPI/#file-constructor\n // Every \"/\" character of file name must be replaced with a \":\".\n /** @private */\n this.name = String(name).replace(/\\//g, ':');\n /** @private */\n this.lastModified = options?.lastModified || Date.now();\n }\n\n get [Symbol.toStringTag]() {\n return 'File';\n }\n}\n"],"mappings":";sBAqCOA,MAAM,CAACC,WAAW;AA9BzB,OAAO,MAAMC,YAAY,SAASC,UAAU,CAACC,IAAI,CAAC;EAoBhDC,WAAWA,CAACC,IAAgB,EAAEC,IAAY,EAAiC;IAAA,IAA/BC,OAAwB,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;IACvE,KAAK,CAACH,IAAI,EAAEE,OAAO,CAAC;IAAC,KAjBvBD,IAAI,GAAW,EAAE;IAAA,KAEjBK,kBAAkB,GAAW,EAAE;IAAA,KAM/BC,YAAY;IAaV,IAAI,CAACN,IAAI,GAAGO,MAAM,CAACP,IAAI,CAAC,CAACQ,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC;IAE5C,IAAI,CAACF,YAAY,GAAG,CAAAL,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEK,YAAY,KAAIG,IAAI,CAACC,GAAG,CAAC,CAAC;EACzD;EAEA,KAAAC,mBAAA,IAA2B;IACzB,OAAO,MAAM;EACf;AACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export declare function instalBlobPolyfills(): {
|
|
2
|
+
new (blobParts?: BlobPart[] | undefined, options?: BlobPropertyBag | undefined): Blob;
|
|
3
|
+
prototype: Blob;
|
|
4
|
+
};
|
|
5
|
+
export declare const Blob_: {
|
|
6
|
+
new (blobParts?: BlobPart[] | undefined, options?: BlobPropertyBag | undefined): Blob;
|
|
7
|
+
prototype: Blob;
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=install-blob-polyfills.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"install-blob-polyfills.d.ts","sourceRoot":"","sources":["../../src/file/install-blob-polyfills.ts"],"names":[],"mappings":"AAGA,wBAAgB,mBAAmB;;;EAOlC;AAED,eAAO,MAAM,KAAK;;;CAAwB,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { BlobPolyfill } from "./blob.js";
|
|
2
|
+
export function instalBlobPolyfills() {
|
|
3
|
+
if (typeof Blob === 'undefined' && !globalThis.Blob) {
|
|
4
|
+
globalThis.Blob = BlobPolyfill;
|
|
5
|
+
}
|
|
6
|
+
return globalThis.Blob;
|
|
7
|
+
}
|
|
8
|
+
export const Blob_ = instalBlobPolyfills();
|
|
9
|
+
//# sourceMappingURL=install-blob-polyfills.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"install-blob-polyfills.js","names":["BlobPolyfill","instalBlobPolyfills","Blob","globalThis","Blob_"],"sources":["../../src/file/install-blob-polyfills.ts"],"sourcesContent":["// import {ReadableStreamPolyfill} from './readable-stream';\nimport {BlobPolyfill} from './blob';\n\nexport function instalBlobPolyfills() {\n if (typeof Blob === 'undefined' && !globalThis.Blob) {\n // @ts-ignore;\n globalThis.Blob = BlobPolyfill;\n }\n\n return globalThis.Blob;\n}\n\nexport const Blob_ = instalBlobPolyfills();\n"],"mappings":"SACQA,YAAY;AAEpB,OAAO,SAASC,mBAAmBA,CAAA,EAAG;EACpC,IAAI,OAAOC,IAAI,KAAK,WAAW,IAAI,CAACC,UAAU,CAACD,IAAI,EAAE;IAEnDC,UAAU,CAACD,IAAI,GAAGF,YAAY;EAChC;EAEA,OAAOG,UAAU,CAACD,IAAI;AACxB;AAEA,OAAO,MAAME,KAAK,GAAGH,mBAAmB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"install-file-polyfills.d.ts","sourceRoot":"","sources":["../../src/file/install-file-polyfills.ts"],"names":[],"mappings":"AAIA,wBAAgB,oBAAoB,sBAanC;AAED,eAAO,MAAM,KAAK,mBAAyB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { FileReaderPolyfill } from "./file-reader.js";
|
|
2
|
+
import { FilePolyfill } from "./file.js";
|
|
3
|
+
export function installFilePolyfills() {
|
|
4
|
+
if (typeof FileReader === 'undefined' && !globalThis.FileReader) {
|
|
5
|
+
globalThis.FileReader = FileReaderPolyfill;
|
|
6
|
+
}
|
|
7
|
+
if (typeof File === 'undefined' && !globalThis.File) {
|
|
8
|
+
globalThis.File = FilePolyfill;
|
|
9
|
+
}
|
|
10
|
+
return global;
|
|
11
|
+
}
|
|
12
|
+
export const File_ = installFilePolyfills();
|
|
13
|
+
//# sourceMappingURL=install-file-polyfills.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"install-file-polyfills.js","names":["FileReaderPolyfill","FilePolyfill","installFilePolyfills","FileReader","globalThis","File","global","File_"],"sources":["../../src/file/install-file-polyfills.ts"],"sourcesContent":["// import {ReadableStreamPolyfill} from './readable-stream';\nimport {FileReaderPolyfill} from './file-reader';\nimport {FilePolyfill} from './file';\n\nexport function installFilePolyfills() {\n if (typeof FileReader === 'undefined' && !globalThis.FileReader) {\n // @ts-ignore;\n globalThis.FileReader = FileReaderPolyfill;\n }\n\n // Install minimal Node.js File polyfill\n if (typeof File === 'undefined' && !globalThis.File) {\n // @ts-ignore;\n globalThis.File = FilePolyfill;\n }\n\n return global;\n}\n\nexport const File_ = installFilePolyfills();\n"],"mappings":"SACQA,kBAAkB;AAAA,SAClBC,YAAY;AAEpB,OAAO,SAASC,oBAAoBA,CAAA,EAAG;EACrC,IAAI,OAAOC,UAAU,KAAK,WAAW,IAAI,CAACC,UAAU,CAACD,UAAU,EAAE;IAE/DC,UAAU,CAACD,UAAU,GAAGH,kBAAkB;EAC5C;EAGA,IAAI,OAAOK,IAAI,KAAK,WAAW,IAAI,CAACD,UAAU,CAACC,IAAI,EAAE;IAEnDD,UAAU,CAACC,IAAI,GAAGJ,YAAY;EAChC;EAEA,OAAOK,MAAM;AACf;AAEA,OAAO,MAAMC,KAAK,GAAGL,oBAAoB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"readable-stream.d.ts","sourceRoot":"","sources":["../../src/file/readable-stream.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,cAAc,IAAI,iBAAiB,EAAC,MAAM,sBAAsB,CAAC;AAOzE,qBAAa,sBAAsB,CAAC,CAAC,CAAE,SAAQ,iBAAiB,CAAC,CAAC,CAAE,YAAW,cAAc;CAAG"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"readable-stream.js","names":["ReadableStream","WSPReadableStream","globalThis","ReadableStreamPolyfill"],"sources":["../../src/file/readable-stream.ts"],"sourcesContent":["import {ReadableStream as WSPReadableStream} from 'web-streams-polyfill';\n\n// Want a polyfill, but please don't install it\n// @ts-ignore\ndelete globalThis.ReadableStream;\n\n// @ts-ignore\nexport class ReadableStreamPolyfill<T> extends WSPReadableStream<T> implements ReadableStream {}\n"],"mappings":"AAAA,SAAQA,cAAc,IAAIC,iBAAiB,QAAO,sBAAsB;AAIxE,OAAOC,UAAU,CAACF,cAAc;AAGhC,OAAO,MAAMG,sBAAsB,SAAYF,iBAAiB,CAA8B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetch-node.d.ts","sourceRoot":"","sources":["../../src/filesystems/fetch-node.ts"],"names":[],"mappings":"AAaA;;;;;GAKG;AAEH,wBAAsB,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,QAAQ,CAAC,CAyDrF"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import fs from 'fs';
|
|
2
|
+
import { Readable } from 'stream';
|
|
3
|
+
import { resolvePath } from '@loaders.gl/loader-utils';
|
|
4
|
+
import { decompressReadStream } from "./stream-utils.node.js";
|
|
5
|
+
const isBoolean = x => typeof x === 'boolean';
|
|
6
|
+
const isFunction = x => typeof x === 'function';
|
|
7
|
+
const isObject = x => x !== null && typeof x === 'object';
|
|
8
|
+
const isReadableNodeStream = x => isObject(x) && isFunction(x.read) && isFunction(x.pipe) && isBoolean(x.readable);
|
|
9
|
+
export async function fetchNode(url, options) {
|
|
10
|
+
const FILE_PROTOCOL_REGEX = /^file:\/\//;
|
|
11
|
+
url.replace(FILE_PROTOCOL_REGEX, '/');
|
|
12
|
+
let noqueryUrl = url.split('?')[0];
|
|
13
|
+
noqueryUrl = resolvePath(noqueryUrl);
|
|
14
|
+
const responseHeaders = new Headers();
|
|
15
|
+
if (url.endsWith('.gz')) {
|
|
16
|
+
responseHeaders['content-encoding'] = 'gzip';
|
|
17
|
+
}
|
|
18
|
+
if (url.endsWith('.br')) {
|
|
19
|
+
responseHeaders['content-encoding'] = 'br';
|
|
20
|
+
}
|
|
21
|
+
try {
|
|
22
|
+
const body = await new Promise((resolve, reject) => {
|
|
23
|
+
const stream = fs.createReadStream(noqueryUrl, {
|
|
24
|
+
encoding: null
|
|
25
|
+
});
|
|
26
|
+
stream.once('readable', () => resolve(stream));
|
|
27
|
+
stream.on('error', error => reject(error));
|
|
28
|
+
});
|
|
29
|
+
let bodyStream = body;
|
|
30
|
+
if (isReadableNodeStream(body)) {
|
|
31
|
+
bodyStream = decompressReadStream(body, responseHeaders);
|
|
32
|
+
} else if (typeof body === 'string') {
|
|
33
|
+
bodyStream = Readable.from([new TextEncoder().encode(body)]);
|
|
34
|
+
} else {
|
|
35
|
+
bodyStream = Readable.from([body || new ArrayBuffer(0)]);
|
|
36
|
+
}
|
|
37
|
+
const status = 200;
|
|
38
|
+
const statusText = 'OK';
|
|
39
|
+
const headers = getHeadersForFile(noqueryUrl);
|
|
40
|
+
const response = new Response(bodyStream, {
|
|
41
|
+
headers,
|
|
42
|
+
status,
|
|
43
|
+
statusText
|
|
44
|
+
});
|
|
45
|
+
Object.defineProperty(response, 'url', {
|
|
46
|
+
value: url
|
|
47
|
+
});
|
|
48
|
+
return response;
|
|
49
|
+
} catch (error) {
|
|
50
|
+
const errorMessage = error.message;
|
|
51
|
+
const status = 400;
|
|
52
|
+
const statusText = errorMessage;
|
|
53
|
+
const headers = {};
|
|
54
|
+
const response = new Response(errorMessage, {
|
|
55
|
+
headers,
|
|
56
|
+
status,
|
|
57
|
+
statusText
|
|
58
|
+
});
|
|
59
|
+
Object.defineProperty(response, 'url', {
|
|
60
|
+
value: url
|
|
61
|
+
});
|
|
62
|
+
return response;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
function getHeadersForFile(noqueryUrl) {
|
|
66
|
+
const headers = {};
|
|
67
|
+
if (!headers['content-length']) {
|
|
68
|
+
const stats = fs.statSync(noqueryUrl);
|
|
69
|
+
headers['content-length'] = stats.size;
|
|
70
|
+
}
|
|
71
|
+
if (noqueryUrl.endsWith('.gz')) {
|
|
72
|
+
noqueryUrl = noqueryUrl.slice(0, -3);
|
|
73
|
+
headers['content-encoding'] = 'gzip';
|
|
74
|
+
}
|
|
75
|
+
return new Headers(headers);
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=fetch-node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetch-node.js","names":["fs","Readable","resolvePath","decompressReadStream","isBoolean","x","isFunction","isObject","isReadableNodeStream","read","pipe","readable","fetchNode","url","options","FILE_PROTOCOL_REGEX","replace","noqueryUrl","split","responseHeaders","Headers","endsWith","body","Promise","resolve","reject","stream","createReadStream","encoding","once","on","error","bodyStream","from","TextEncoder","encode","ArrayBuffer","status","statusText","headers","getHeadersForFile","response","Response","Object","defineProperty","value","errorMessage","message","stats","statSync","size","slice"],"sources":["../../src/filesystems/fetch-node.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport fs from 'fs';\nimport {Readable} from 'stream';\nimport {resolvePath} from '@loaders.gl/loader-utils';\nimport {decompressReadStream} from './stream-utils.node';\n\nconst isBoolean = (x) => typeof x === 'boolean';\nconst isFunction = (x) => typeof x === 'function';\nconst isObject = (x) => x !== null && typeof x === 'object';\nconst isReadableNodeStream = (x) =>\n isObject(x) && isFunction(x.read) && isFunction(x.pipe) && isBoolean(x.readable);\n\n/**\n * Enables\n * @param url\n * @param options\n * @returns\n */\n// eslint-disable-next-line max-statements\nexport async function fetchNode(url: string, options?: RequestInit): Promise<Response> {\n // Support `file://` protocol\n const FILE_PROTOCOL_REGEX = /^file:\\/\\//;\n url.replace(FILE_PROTOCOL_REGEX, '/');\n\n // Remove any query parameters, as they have no meaning\n let noqueryUrl = url.split('?')[0];\n noqueryUrl = resolvePath(noqueryUrl);\n\n const responseHeaders = new Headers();\n // Automatically decompress gzipped files with .gz extension\n if (url.endsWith('.gz')) {\n // url = url.slice(0, -3);\n responseHeaders['content-encoding'] = 'gzip';\n }\n if (url.endsWith('.br')) {\n // url = url.slice(0, -3);\n responseHeaders['content-encoding'] = 'br';\n }\n\n try {\n // Now open the stream\n const body = await new Promise<fs.ReadStream>((resolve, reject) => {\n // @ts-ignore\n const stream = fs.createReadStream(noqueryUrl, {encoding: null});\n stream.once('readable', () => resolve(stream));\n stream.on('error', (error) => reject(error));\n });\n\n let bodyStream: Readable = body;\n\n // Check for content-encoding and create a decompression stream\n if (isReadableNodeStream(body)) {\n bodyStream = decompressReadStream(body, responseHeaders);\n } else if (typeof body === 'string') {\n bodyStream = Readable.from([new TextEncoder().encode(body)]);\n } else {\n bodyStream = Readable.from([body || new ArrayBuffer(0)]);\n }\n\n const status = 200;\n const statusText = 'OK';\n const headers = getHeadersForFile(noqueryUrl);\n // @ts-expect-error\n const response = new Response(bodyStream, {headers, status, statusText});\n Object.defineProperty(response, 'url', {value: url});\n return response;\n } catch (error) {\n // console.error(error);\n const errorMessage = (error as Error).message;\n const status = 400;\n const statusText = errorMessage;\n const headers = {};\n const response = new Response(errorMessage, {headers, status, statusText});\n Object.defineProperty(response, 'url', {value: url});\n return response;\n }\n}\n\nfunction getHeadersForFile(noqueryUrl: string): Headers {\n const headers = {};\n\n // Fix up content length if we can for best progress experience\n if (!headers['content-length']) {\n const stats = fs.statSync(noqueryUrl);\n headers['content-length'] = stats.size;\n }\n\n // Automatically decompress gzipped files with .gz extension\n if (noqueryUrl.endsWith('.gz')) {\n noqueryUrl = noqueryUrl.slice(0, -3);\n headers['content-encoding'] = 'gzip';\n }\n\n return new Headers(headers);\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { ReadableFile, WritableFile, Stat } from '@loaders.gl/loader-utils';
|
|
2
|
+
export declare class NodeFile implements ReadableFile, WritableFile {
|
|
3
|
+
handle: number;
|
|
4
|
+
size: number;
|
|
5
|
+
bigsize: bigint;
|
|
6
|
+
url: string;
|
|
7
|
+
constructor(path: string, flags: 'r' | 'w' | 'wx', mode?: number);
|
|
8
|
+
close(): Promise<void>;
|
|
9
|
+
stat(): Promise<Stat>;
|
|
10
|
+
read(offset: number | bigint, length: number): Promise<ArrayBuffer>;
|
|
11
|
+
write(arrayBuffer: ArrayBuffer, offset?: number | bigint, length?: number): Promise<number>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=node-file.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node-file.d.ts","sourceRoot":"","sources":["../../src/filesystems/node-file.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,YAAY,EAAE,YAAY,EAAE,IAAI,EAAC,MAAM,0BAA0B,CAAC;AAI/E,qBAAa,QAAS,YAAW,YAAY,EAAE,YAAY;IACzD,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;gBAEA,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,EAAE,IAAI,CAAC,EAAE,MAAM;IAS1D,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAMtB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAiBrB,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IA6BnE,KAAK,CACT,WAAW,EAAE,WAAW,EACxB,MAAM,GAAE,MAAM,GAAG,MAAU,EAC3B,MAAM,GAAE,MAA+B,GACtC,OAAO,CAAC,MAAM,CAAC;CAUnB"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { resolvePath } from '@loaders.gl/loader-utils';
|
|
2
|
+
import fs from 'fs';
|
|
3
|
+
export class NodeFile {
|
|
4
|
+
constructor(path, flags, mode) {
|
|
5
|
+
this.handle = void 0;
|
|
6
|
+
this.size = void 0;
|
|
7
|
+
this.bigsize = void 0;
|
|
8
|
+
this.url = void 0;
|
|
9
|
+
path = resolvePath(path);
|
|
10
|
+
this.handle = fs.openSync(path, flags, mode);
|
|
11
|
+
const stats = fs.fstatSync(this.handle, {
|
|
12
|
+
bigint: true
|
|
13
|
+
});
|
|
14
|
+
this.size = Number(stats.size);
|
|
15
|
+
this.bigsize = stats.size;
|
|
16
|
+
this.url = path;
|
|
17
|
+
}
|
|
18
|
+
async close() {
|
|
19
|
+
return new Promise((resolve, reject) => {
|
|
20
|
+
fs.close(this.handle, err => err ? reject(err) : resolve());
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
async stat() {
|
|
24
|
+
return await new Promise((resolve, reject) => fs.fstat(this.handle, {
|
|
25
|
+
bigint: true
|
|
26
|
+
}, (err, info) => {
|
|
27
|
+
const stats = {
|
|
28
|
+
size: Number(info.size),
|
|
29
|
+
bigsize: info.size,
|
|
30
|
+
isDirectory: info.isDirectory()
|
|
31
|
+
};
|
|
32
|
+
if (err) {
|
|
33
|
+
reject(err);
|
|
34
|
+
} else {
|
|
35
|
+
resolve(stats);
|
|
36
|
+
}
|
|
37
|
+
}));
|
|
38
|
+
}
|
|
39
|
+
async read(offset, length) {
|
|
40
|
+
const arrayBuffer = new ArrayBuffer(length);
|
|
41
|
+
let bigOffset = BigInt(offset);
|
|
42
|
+
let totalBytesRead = 0;
|
|
43
|
+
const uint8Array = new Uint8Array(arrayBuffer);
|
|
44
|
+
let position;
|
|
45
|
+
while (length > 0) {
|
|
46
|
+
const bytesRead = await readBytes(this.handle, uint8Array, 0, length, bigOffset);
|
|
47
|
+
if (bytesRead === 0) {
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
totalBytesRead += bytesRead;
|
|
51
|
+
bigOffset += BigInt(bytesRead);
|
|
52
|
+
length -= bytesRead;
|
|
53
|
+
if (position !== undefined) {
|
|
54
|
+
position += bytesRead;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
return totalBytesRead < length ? arrayBuffer.slice(0, totalBytesRead) : arrayBuffer;
|
|
58
|
+
}
|
|
59
|
+
async write(arrayBuffer) {
|
|
60
|
+
let offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
61
|
+
let length = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : arrayBuffer.byteLength;
|
|
62
|
+
return new Promise((resolve, reject) => {
|
|
63
|
+
const nOffset = Number(offset);
|
|
64
|
+
const uint8Array = new Uint8Array(arrayBuffer, Number(offset), length);
|
|
65
|
+
fs.write(this.handle, uint8Array, 0, length, nOffset, (err, bytesWritten) => err ? reject(err) : resolve(bytesWritten));
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
async function readBytes(fd, uint8Array, offset, length, position) {
|
|
70
|
+
return await new Promise((resolve, reject) => fs.read(fd, uint8Array, offset, length, position, (err, bytesRead) => err ? reject(err) : resolve(bytesRead)));
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=node-file.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node-file.js","names":["resolvePath","fs","NodeFile","constructor","path","flags","mode","handle","size","bigsize","url","openSync","stats","fstatSync","bigint","Number","close","Promise","resolve","reject","err","stat","fstat","info","isDirectory","read","offset","length","arrayBuffer","ArrayBuffer","bigOffset","BigInt","totalBytesRead","uint8Array","Uint8Array","position","bytesRead","readBytes","undefined","slice","write","arguments","byteLength","nOffset","bytesWritten","fd"],"sources":["../../src/filesystems/node-file.ts"],"sourcesContent":["import type {ReadableFile, WritableFile, Stat} from '@loaders.gl/loader-utils';\nimport {resolvePath} from '@loaders.gl/loader-utils';\nimport fs from 'fs';\n\nexport class NodeFile implements ReadableFile, WritableFile {\n handle: number;\n size: number;\n bigsize: bigint;\n url: string;\n\n constructor(path: string, flags: 'r' | 'w' | 'wx', mode?: number) {\n path = resolvePath(path);\n this.handle = fs.openSync(path, flags, mode);\n const stats = fs.fstatSync(this.handle, {bigint: true});\n this.size = Number(stats.size);\n this.bigsize = stats.size;\n this.url = path;\n }\n\n async close(): Promise<void> {\n return new Promise((resolve, reject) => {\n fs.close(this.handle, (err) => (err ? reject(err) : resolve()));\n });\n }\n\n async stat(): Promise<Stat> {\n return await new Promise((resolve, reject) =>\n fs.fstat(this.handle, {bigint: true}, (err, info) => {\n const stats: Stat = {\n size: Number(info.size),\n bigsize: info.size,\n isDirectory: info.isDirectory()\n };\n if (err) {\n reject(err);\n } else {\n resolve(stats);\n }\n })\n );\n }\n\n async read(offset: number | bigint, length: number): Promise<ArrayBuffer> {\n const arrayBuffer = new ArrayBuffer(length);\n let bigOffset = BigInt(offset);\n\n let totalBytesRead = 0;\n const uint8Array = new Uint8Array(arrayBuffer);\n\n let position;\n // Read in loop until we get required number of bytes\n while (length > 0) {\n const bytesRead = await readBytes(this.handle, uint8Array, 0, length, bigOffset);\n\n // Check if end of file reached\n if (bytesRead === 0) {\n break;\n }\n\n totalBytesRead += bytesRead;\n bigOffset += BigInt(bytesRead);\n length -= bytesRead;\n\n // Advance position unless we are using built-in position advancement\n if (position !== undefined) {\n position += bytesRead;\n }\n }\n return totalBytesRead < length ? arrayBuffer.slice(0, totalBytesRead) : arrayBuffer;\n }\n\n async write(\n arrayBuffer: ArrayBuffer,\n offset: number | bigint = 0,\n length: number = arrayBuffer.byteLength\n ): Promise<number> {\n return new Promise((resolve, reject) => {\n // TODO - Node.js doesn't offer write with bigint offsets???\n const nOffset = Number(offset);\n const uint8Array = new Uint8Array(arrayBuffer, Number(offset), length);\n fs.write(this.handle, uint8Array, 0, length, nOffset, (err, bytesWritten) =>\n err ? reject(err) : resolve(bytesWritten)\n );\n });\n }\n}\n\nasync function readBytes(\n fd: number,\n uint8Array: Uint8Array,\n offset: number,\n length: number,\n position: number | bigint | null\n): Promise<number> {\n return await new Promise<number>((resolve, reject) =>\n fs.read(fd, uint8Array, offset, length, position, (err, bytesRead) =>\n err ? reject(err) : resolve(bytesRead)\n )\n );\n}\n\n// TODO - implement streaming write\n/*\nexport interface WriteStreamOptions {\n flags?: string;\n encoding?: 'utf8';\n fd?: number;\n mode?: number;\n autoClose?: boolean;\n start?: number;\n}\n\nexport class NodeStreamWritableFile implements WritableFile {\n outputStream: fs.WriteStream | Writable;\n\n constructor(pathOrStream: string | Writable, options?: WriteStreamOptions) {\n this.outputStream =\n typeof pathOrStream === 'string' ? fs.createWriteStream(pathOrStream, options) : pathOrStream;\n }\n\n async write(buffer: ArrayBuffer): Promise<void> {\n return new Promise((resolve, reject) => {\n const uint8Array = new Uint8Array(buffer);\n this.outputStream.write(uint8Array, (err) => (err ? reject(err) : resolve()));\n });\n }\n\n async close(): Promise<void> {\n if (this.outputStream instanceof fs.WriteStream) {\n return new Promise((resolve, reject) => {\n const stream = this.outputStream as fs.WriteStream;\n stream.close((err) => (err ? reject(err) : resolve()));\n });\n }\n }\n}\n*/\n"],"mappings":"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"}
|
|
@@ -1,39 +1,19 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import { FileSystem, RandomAccessReadFileSystem } from '@loaders.gl/loader-utils';
|
|
4
|
-
import fs from 'fs';
|
|
5
|
-
type Stat = {
|
|
6
|
-
size: number;
|
|
7
|
-
isDirectory: () => boolean;
|
|
8
|
-
info?: fs.Stats;
|
|
9
|
-
};
|
|
10
|
-
type ReadOptions = {
|
|
11
|
-
buffer?: Buffer;
|
|
12
|
-
offset?: number;
|
|
13
|
-
length?: number;
|
|
14
|
-
position?: number;
|
|
15
|
-
};
|
|
1
|
+
import { Stat, RandomAccessFileSystem } from '@loaders.gl/loader-utils';
|
|
2
|
+
import { NodeFile } from './node-file';
|
|
16
3
|
/**
|
|
17
4
|
* FileSystem pass-through for Node.js
|
|
18
5
|
* Compatible with BrowserFileSystem.
|
|
19
6
|
* @param options
|
|
20
7
|
*/
|
|
21
|
-
export declare class NodeFileSystem implements
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
8
|
+
export declare class NodeFileSystem implements RandomAccessFileSystem {
|
|
9
|
+
readable: boolean;
|
|
10
|
+
writable: boolean;
|
|
11
|
+
constructor();
|
|
25
12
|
readdir(dirname?: string, options?: {}): Promise<any[]>;
|
|
26
|
-
stat(path: string
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
close(fd: number): Promise<void>;
|
|
32
|
-
fstat(fd: number): Promise<Stat>;
|
|
33
|
-
read(fd: number, { buffer, offset, length, position }: ReadOptions): Promise<{
|
|
34
|
-
bytesRead: number;
|
|
35
|
-
buffer: Uint8Array;
|
|
36
|
-
}>;
|
|
13
|
+
stat(path: string): Promise<Stat>;
|
|
14
|
+
unlink(path: string): Promise<void>;
|
|
15
|
+
fetch(path: string, options: RequestInit): Promise<Response>;
|
|
16
|
+
openReadableFile(path: string, flags?: 'r'): Promise<NodeFile>;
|
|
17
|
+
openWritableFile(path: string, flags?: 'w' | 'wx', mode?: any): Promise<NodeFile>;
|
|
37
18
|
}
|
|
38
|
-
export {};
|
|
39
19
|
//# sourceMappingURL=node-filesystem.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"node-filesystem.d.ts","sourceRoot":"","sources":["../../src/filesystems/node-filesystem.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"node-filesystem.d.ts","sourceRoot":"","sources":["../../src/filesystems/node-filesystem.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,IAAI,EAAE,sBAAsB,EAAC,MAAM,0BAA0B,CAAC;AAEtE,OAAO,EAAC,QAAQ,EAAC,MAAM,aAAa,CAAC;AAMrC;;;;GAIG;AACH,qBAAa,cAAe,YAAW,sBAAsB;IAC3D,QAAQ,EAAE,OAAO,CAAQ;IACzB,QAAQ,EAAE,OAAO,CAAQ;;IAKnB,OAAO,CAAC,OAAO,SAAM,EAAE,OAAO,CAAC,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;IAIpD,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IASjC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAInC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,QAAQ,CAAC;IAK5D,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,GAAE,GAAS,GAAG,OAAO,CAAC,QAAQ,CAAC;IAInE,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,GAAE,GAAG,GAAG,IAAU,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,OAAO,CAAC,QAAQ,CAAC;CAG7F"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import fsPromise from 'fs/promises';
|
|
2
|
+
import { NodeFile } from "./node-file.js";
|
|
3
|
+
import { fetchNode } from "./fetch-node.js";
|
|
4
|
+
export class NodeFileSystem {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.readable = true;
|
|
7
|
+
this.writable = true;
|
|
8
|
+
}
|
|
9
|
+
async readdir() {
|
|
10
|
+
let dirname = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '.';
|
|
11
|
+
let options = arguments.length > 1 ? arguments[1] : undefined;
|
|
12
|
+
return await fsPromise.readdir(dirname, options);
|
|
13
|
+
}
|
|
14
|
+
async stat(path) {
|
|
15
|
+
const info = await fsPromise.stat(path, {
|
|
16
|
+
bigint: true
|
|
17
|
+
});
|
|
18
|
+
return {
|
|
19
|
+
size: Number(info.size),
|
|
20
|
+
bigsize: info.size,
|
|
21
|
+
isDirectory: info.isDirectory()
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
async unlink(path) {
|
|
25
|
+
return await fsPromise.unlink(path);
|
|
26
|
+
}
|
|
27
|
+
async fetch(path, options) {
|
|
28
|
+
return await fetchNode(path, options);
|
|
29
|
+
}
|
|
30
|
+
async openReadableFile(path) {
|
|
31
|
+
let flags = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'r';
|
|
32
|
+
return new NodeFile(path, flags);
|
|
33
|
+
}
|
|
34
|
+
async openWritableFile(path) {
|
|
35
|
+
let flags = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'w';
|
|
36
|
+
let mode = arguments.length > 2 ? arguments[2] : undefined;
|
|
37
|
+
return new NodeFile(path, flags, mode);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=node-filesystem.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node-filesystem.js","names":["fsPromise","NodeFile","fetchNode","NodeFileSystem","constructor","readable","writable","readdir","dirname","arguments","length","undefined","options","stat","path","info","bigint","size","Number","bigsize","isDirectory","unlink","fetch","openReadableFile","flags","openWritableFile","mode"],"sources":["../../src/filesystems/node-filesystem.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport {Stat, RandomAccessFileSystem} from '@loaders.gl/loader-utils';\nimport fsPromise from 'fs/promises';\nimport {NodeFile} from './node-file';\nimport {fetchNode} from './fetch-node';\n\n// import {fetchFile} from \"../fetch/fetch-file\"\n// import {selectLoader} from \"../api/select-loader\";\n\n/**\n * FileSystem pass-through for Node.js\n * Compatible with BrowserFileSystem.\n * @param options\n */\nexport class NodeFileSystem implements RandomAccessFileSystem {\n readable: boolean = true;\n writable: boolean = true;\n\n // implements FileSystem\n constructor() {}\n\n async readdir(dirname = '.', options?: {}): Promise<any[]> {\n return await fsPromise.readdir(dirname, options);\n }\n\n async stat(path: string): Promise<Stat> {\n const info = await fsPromise.stat(path, {bigint: true});\n return {\n size: Number(info.size),\n bigsize: info.size,\n isDirectory: info.isDirectory()\n };\n }\n\n async unlink(path: string): Promise<void> {\n return await fsPromise.unlink(path);\n }\n\n async fetch(path: string, options: RequestInit): Promise<Response> {\n return await fetchNode(path, options);\n }\n\n // implements IRandomAccessFileSystem\n async openReadableFile(path: string, flags: 'r' = 'r'): Promise<NodeFile> {\n return new NodeFile(path, flags);\n }\n\n async openWritableFile(path: string, flags: 'w' | 'wx' = 'w', mode?: any): Promise<NodeFile> {\n return new NodeFile(path, flags, mode);\n }\n}\n"],"mappings":"AAGA,OAAOA,SAAS,MAAM,aAAa;AAAC,SAC5BC,QAAQ;AAAA,SACRC,SAAS;AAUjB,OAAO,MAAMC,cAAc,CAAmC;EAK5DC,WAAWA,CAAA,EAAG;IAAA,KAJdC,QAAQ,GAAY,IAAI;IAAA,KACxBC,QAAQ,GAAY,IAAI;EAGT;EAEf,MAAMC,OAAOA,CAAA,EAA8C;IAAA,IAA7CC,OAAO,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,GAAG;IAAA,IAAEG,OAAY,GAAAH,SAAA,CAAAC,MAAA,OAAAD,SAAA,MAAAE,SAAA;IACvC,OAAO,MAAMX,SAAS,CAACO,OAAO,CAACC,OAAO,EAAEI,OAAO,CAAC;EAClD;EAEA,MAAMC,IAAIA,CAACC,IAAY,EAAiB;IACtC,MAAMC,IAAI,GAAG,MAAMf,SAAS,CAACa,IAAI,CAACC,IAAI,EAAE;MAACE,MAAM,EAAE;IAAI,CAAC,CAAC;IACvD,OAAO;MACLC,IAAI,EAAEC,MAAM,CAACH,IAAI,CAACE,IAAI,CAAC;MACvBE,OAAO,EAAEJ,IAAI,CAACE,IAAI;MAClBG,WAAW,EAAEL,IAAI,CAACK,WAAW,CAAC;IAChC,CAAC;EACH;EAEA,MAAMC,MAAMA,CAACP,IAAY,EAAiB;IACxC,OAAO,MAAMd,SAAS,CAACqB,MAAM,CAACP,IAAI,CAAC;EACrC;EAEA,MAAMQ,KAAKA,CAACR,IAAY,EAAEF,OAAoB,EAAqB;IACjE,OAAO,MAAMV,SAAS,CAACY,IAAI,EAAEF,OAAO,CAAC;EACvC;EAGA,MAAMW,gBAAgBA,CAACT,IAAY,EAAuC;IAAA,IAArCU,KAAU,GAAAf,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,GAAG;IACnD,OAAO,IAAIR,QAAQ,CAACa,IAAI,EAAEU,KAAK,CAAC;EAClC;EAEA,MAAMC,gBAAgBA,CAACX,IAAY,EAA0D;IAAA,IAAxDU,KAAiB,GAAAf,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,GAAG;IAAA,IAAEiB,IAAU,GAAAjB,SAAA,CAAAC,MAAA,OAAAD,SAAA,MAAAE,SAAA;IACtE,OAAO,IAAIV,QAAQ,CAACa,IAAI,EAAEU,KAAK,EAAEE,IAAI,CAAC;EACxC;AACF"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { Readable } from 'stream';
|
|
1
3
|
/**
|
|
2
4
|
*
|
|
3
5
|
*/
|
|
4
|
-
export declare function decompressReadStream(readStream:
|
|
6
|
+
export declare function decompressReadStream(readStream: Readable, headers?: Headers): Readable;
|
|
5
7
|
/**
|
|
6
8
|
*
|
|
7
9
|
* @param readStream
|
|
@@ -14,4 +16,9 @@ export declare function concatenateReadStream(readStream: any): Promise<ArrayBuf
|
|
|
14
16
|
* @note duplicates loader-utils since polyfills should be independent
|
|
15
17
|
*/
|
|
16
18
|
export declare function concatenateArrayBuffers(sources: (ArrayBuffer | Uint8Array)[]): ArrayBuffer;
|
|
19
|
+
/**
|
|
20
|
+
* @param data
|
|
21
|
+
* @todo Duplicate of core
|
|
22
|
+
*/
|
|
23
|
+
export declare function toArrayBuffer(data: unknown): ArrayBuffer;
|
|
17
24
|
//# sourceMappingURL=stream-utils.node.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream-utils.node.d.ts","sourceRoot":"","sources":["../../src/filesystems/stream-utils.node.ts"],"names":[],"mappings":";AAGA,OAAO,EAAC,QAAQ,EAAC,MAAM,QAAQ,CAAC;AAKhC;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,UAAU,EAAE,QAAQ,EAAE,OAAO,CAAC,EAAE,OAAO,YAY3E;AAED;;;;GAIG;AACH,wBAAsB,qBAAqB,CAAC,UAAU,KAAA,GAAG,OAAO,CAAC,WAAW,CAAC,CAsB5E;AAED;;;;GAIG;AACH,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,CAAC,WAAW,GAAG,UAAU,CAAC,EAAE,GAAG,WAAW,CAqB1F;AAED;;;GAGG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,OAAO,GAAG,WAAW,CA+BxD"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import zlib from 'zlib';
|
|
2
|
-
|
|
2
|
+
const isArrayBuffer = x => x && x instanceof ArrayBuffer;
|
|
3
|
+
const isBuffer = x => x && x instanceof Buffer;
|
|
3
4
|
export function decompressReadStream(readStream, headers) {
|
|
4
|
-
switch (headers.get('content-encoding')) {
|
|
5
|
+
switch (headers === null || headers === void 0 ? void 0 : headers.get('content-encoding')) {
|
|
5
6
|
case 'br':
|
|
6
7
|
return readStream.pipe(zlib.createBrotliDecompress());
|
|
7
8
|
case 'gzip':
|
|
@@ -40,4 +41,25 @@ export function concatenateArrayBuffers(sources) {
|
|
|
40
41
|
}
|
|
41
42
|
return result.buffer;
|
|
42
43
|
}
|
|
44
|
+
export function toArrayBuffer(data) {
|
|
45
|
+
if (isArrayBuffer(data)) {
|
|
46
|
+
return data;
|
|
47
|
+
}
|
|
48
|
+
if (isBuffer(data)) {
|
|
49
|
+
const typedArray = new Uint8Array(data);
|
|
50
|
+
return typedArray.buffer;
|
|
51
|
+
}
|
|
52
|
+
if (ArrayBuffer.isView(data)) {
|
|
53
|
+
return data.buffer;
|
|
54
|
+
}
|
|
55
|
+
if (typeof data === 'string') {
|
|
56
|
+
const text = data;
|
|
57
|
+
const uint8Array = new TextEncoder().encode(text);
|
|
58
|
+
return uint8Array.buffer;
|
|
59
|
+
}
|
|
60
|
+
if (data && typeof data === 'object' && data._toArrayBuffer) {
|
|
61
|
+
return data._toArrayBuffer();
|
|
62
|
+
}
|
|
63
|
+
throw new Error(`toArrayBuffer(${JSON.stringify(data, null, 2).slice(10)})`);
|
|
64
|
+
}
|
|
43
65
|
//# sourceMappingURL=stream-utils.node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream-utils.node.js","names":["zlib","isArrayBuffer","x","ArrayBuffer","isBuffer","Buffer","decompressReadStream","readStream","headers","get","pipe","createBrotliDecompress","createGunzip","createDeflate","concatenateReadStream","arrayBufferChunks","Promise","resolve","reject","on","error","read","chunk","Error","push","toArrayBuffer","arrayBuffer","concatenateArrayBuffers","sources","sourceArrays","map","source2","Uint8Array","byteLength","reduce","length","typedArray","result","offset","sourceArray","set","buffer","data","isView","text","uint8Array","TextEncoder","encode","_toArrayBuffer","JSON","stringify","slice"],"sources":["../../src/filesystems/stream-utils.node.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport zlib from 'zlib';\nimport {Readable} from 'stream';\n\nconst isArrayBuffer = (x) => x && x instanceof ArrayBuffer;\nconst isBuffer = (x) => x && x instanceof Buffer;\n\n/**\n *\n */\nexport function decompressReadStream(readStream: Readable, headers?: Headers) {\n switch (headers?.get('content-encoding')) {\n case 'br':\n return readStream.pipe(zlib.createBrotliDecompress());\n case 'gzip':\n return readStream.pipe(zlib.createGunzip());\n case 'deflate':\n return readStream.pipe(zlib.createDeflate());\n default:\n // No compression or an unknown one, just return it as is\n return readStream;\n }\n}\n\n/**\n *\n * @param readStream\n * @returns\n */\nexport async function concatenateReadStream(readStream): Promise<ArrayBuffer> {\n const arrayBufferChunks: ArrayBuffer[] = [];\n\n return await new Promise((resolve, reject) => {\n readStream.on('error', (error) => reject(error));\n\n // Once the readable callback has been added, stream switches to \"flowing mode\"\n // In Node 10 (but not 12 and 14) this causes `data` and `end` to never be called unless we read data here\n readStream.on('readable', () => readStream.read());\n\n readStream.on('data', (chunk) => {\n if (typeof chunk === 'string') {\n reject(new Error('Read stream not binary'));\n }\n arrayBufferChunks.push(toArrayBuffer(chunk));\n });\n\n readStream.on('end', () => {\n const arrayBuffer = concatenateArrayBuffers(arrayBufferChunks);\n resolve(arrayBuffer);\n });\n });\n}\n\n/**\n * Concatenate a sequence of ArrayBuffers\n * @return A concatenated ArrayBuffer\n * @note duplicates loader-utils since polyfills should be independent\n */\nexport function concatenateArrayBuffers(sources: (ArrayBuffer | Uint8Array)[]): ArrayBuffer {\n // Make sure all inputs are wrapped in typed arrays\n const sourceArrays = sources.map((source2) =>\n source2 instanceof ArrayBuffer ? new Uint8Array(source2) : source2\n );\n\n // Get length of all inputs\n const byteLength = sourceArrays.reduce((length, typedArray) => length + typedArray.byteLength, 0);\n\n // Allocate array with space for all inputs\n const result = new Uint8Array(byteLength);\n\n // Copy the subarrays\n let offset = 0;\n for (const sourceArray of sourceArrays) {\n result.set(sourceArray, offset);\n offset += sourceArray.byteLength;\n }\n\n // We work with ArrayBuffers, discard the typed array wrapper\n return result.buffer;\n}\n\n/**\n * @param data\n * @todo Duplicate of core\n */\nexport function toArrayBuffer(data: unknown): ArrayBuffer {\n if (isArrayBuffer(data)) {\n return data as ArrayBuffer;\n }\n\n // TODO - per docs we should just be able to call buffer.buffer, but there are issues\n if (isBuffer(data)) {\n // @ts-expect-error\n const typedArray = new Uint8Array(data);\n return typedArray.buffer;\n }\n\n // Careful - Node Buffers will look like ArrayBuffers (keep after isBuffer)\n if (ArrayBuffer.isView(data)) {\n return data.buffer;\n }\n\n if (typeof data === 'string') {\n const text = data;\n const uint8Array = new TextEncoder().encode(text);\n return uint8Array.buffer;\n }\n\n // HACK to support Blob polyfill\n // @ts-expect-error\n if (data && typeof data === 'object' && data._toArrayBuffer) {\n // @ts-expect-error\n return data._toArrayBuffer();\n }\n\n throw new Error(`toArrayBuffer(${JSON.stringify(data, null, 2).slice(10)})`);\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encode-image.node.d.ts","sourceRoot":"","sources":["../../src/images/encode-image.node.ts"],"names":[],"mappings":"AAMA;;;;;;;;;GASG;AACH,wBAAgB,uBAAuB,CACrC,KAAK,EAAE;IAAC,IAAI,EAAE,GAAG,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAC,EACjD,OAAO,EAAE;IAAC,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,MAAM,CAAA;CAAC,OAQ3C;AAED,wBAAgB,eAAe,CAAC,KAAK,KAAA,EAAE,OAAO,KAAA,oBAY7C"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import savePixels from 'save-pixels';
|
|
2
2
|
import ndarray from 'ndarray';
|
|
3
|
-
import { bufferToArrayBuffer } from
|
|
3
|
+
import { bufferToArrayBuffer } from "../buffer/to-array-buffer.node.js";
|
|
4
4
|
export function encodeImageToStreamNode(image, options) {
|
|
5
5
|
const type = options.type ? options.type.replace('image/', '') : 'jpeg';
|
|
6
6
|
const pixels = ndarray(image.data, [image.width, image.height, 4], [4, image.width * 4, 1], 0);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encode-image.node.js","names":["savePixels","ndarray","bufferToArrayBuffer","encodeImageToStreamNode","image","options","type","replace","pixels","data","width","height","encodeImageNode","imageStream","Promise","resolve","buffers","on","buffer","push","Buffer","concat"],"sources":["../../src/images/encode-image.node.ts"],"sourcesContent":["// Use stackgl modules for DOM-less reading and writing of images\n\nimport savePixels from 'save-pixels';\nimport ndarray from 'ndarray';\nimport {bufferToArrayBuffer} from '../buffer/to-array-buffer.node';\n\n/**\n * Returns data bytes representing a compressed image in PNG or JPG format,\n * This data can be saved using file system (f) methods or\n * used in a request.\n * @param image to save\n * @param options\n * @param options.type='png' - png, jpg or image/png, image/jpg are valid\n * @param options.dataURI - Whether to include a data URI header\n * @return {*} bytes\n */\nexport function encodeImageToStreamNode(\n image: {data: any; width: number; height: number},\n options: {type?: string; dataURI?: string}\n) {\n // Support MIME type strings\n const type = options.type ? options.type.replace('image/', '') : 'jpeg';\n const pixels = ndarray(image.data, [image.width, image.height, 4], [4, image.width * 4, 1], 0);\n\n // Note: savePixels returns a stream\n return savePixels(pixels, type, options);\n}\n\nexport function encodeImageNode(image, options) {\n const imageStream = encodeImageToStreamNode(image, options);\n\n return new Promise((resolve) => {\n const buffers: any[] = [];\n imageStream.on('data', (buffer) => buffers.push(buffer));\n // TODO - convert to arraybuffer?\n imageStream.on('end', () => {\n const buffer = Buffer.concat(buffers);\n resolve(bufferToArrayBuffer(buffer));\n });\n });\n}\n"],"mappings":"AAEA,OAAOA,UAAU,MAAM,aAAa;AACpC,OAAOC,OAAO,MAAM,SAAS;AAAC,SACtBC,mBAAmB;AAY3B,OAAO,SAASC,uBAAuBA,CACrCC,KAAiD,EACjDC,OAA0C,EAC1C;EAEA,MAAMC,IAAI,GAAGD,OAAO,CAACC,IAAI,GAAGD,OAAO,CAACC,IAAI,CAACC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,GAAG,MAAM;EACvE,MAAMC,MAAM,GAAGP,OAAO,CAACG,KAAK,CAACK,IAAI,EAAE,CAACL,KAAK,CAACM,KAAK,EAAEN,KAAK,CAACO,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAEP,KAAK,CAACM,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;EAG9F,OAAOV,UAAU,CAACQ,MAAM,EAAEF,IAAI,EAAED,OAAO,CAAC;AAC1C;AAEA,OAAO,SAASO,eAAeA,CAACR,KAAK,EAAEC,OAAO,EAAE;EAC9C,MAAMQ,WAAW,GAAGV,uBAAuB,CAACC,KAAK,EAAEC,OAAO,CAAC;EAE3D,OAAO,IAAIS,OAAO,CAAEC,OAAO,IAAK;IAC9B,MAAMC,OAAc,GAAG,EAAE;IACzBH,WAAW,CAACI,EAAE,CAAC,MAAM,EAAGC,MAAM,IAAKF,OAAO,CAACG,IAAI,CAACD,MAAM,CAAC,CAAC;IAExDL,WAAW,CAACI,EAAE,CAAC,KAAK,EAAE,MAAM;MAC1B,MAAMC,MAAM,GAAGE,MAAM,CAACC,MAAM,CAACL,OAAO,CAAC;MACrCD,OAAO,CAACb,mBAAmB,CAACgB,MAAM,CAAC,CAAC;IACtC,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-image.node.d.ts","sourceRoot":"","sources":["../../src/images/parse-image.node.ts"],"names":[],"mappings":"AAIA,2EAA2E;AAC3E,eAAO,MAAM,mBAAmB,UAA2C,CAAC;AAG5E,KAAK,OAAO,GAAG;IACb,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,IAAI,EAAE,UAAU,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB,CAAC;AAEF,wBAAsB,cAAc,CAAC,WAAW,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAQjG"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-image.node.js","names":["getPixels","NODE_FORMAT_SUPPORT","parseImageNode","arrayBuffer","mimeType","Error","buffer","Buffer","from","ndarray","getPixelsAsync","Promise","resolve","err","shape","layers","length","shift","data","Uint8Array","width","height","components"],"sources":["../../src/images/parse-image.node.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport getPixels from 'get-pixels';\n\n/** Declares which image format mime types this loader polyfill supports */\nexport const NODE_FORMAT_SUPPORT = ['image/png', 'image/jpeg', 'image/gif'];\n\n// Note: These types are also defined in @loaders.gl/images and need to be kept in sync\ntype NDArray = {\n shape: number[];\n data: Uint8Array;\n width: number;\n height: number;\n components: number;\n layers: number[];\n};\n\nexport async function parseImageNode(arrayBuffer: ArrayBuffer, mimeType: string): Promise<NDArray> {\n if (!mimeType) {\n throw new Error('MIMEType is required to parse image under Node.js');\n }\n\n const buffer = arrayBuffer instanceof Buffer ? arrayBuffer : Buffer.from(arrayBuffer);\n const ndarray = await getPixelsAsync(buffer, mimeType);\n return ndarray;\n}\n\n// TODO - check if getPixels callback is asynchronous if provided with buffer input\n// if not, parseImage can be a sync function\nfunction getPixelsAsync(buffer: Buffer, mimeType: string): Promise<NDArray> {\n return new Promise<NDArray>((resolve) =>\n getPixels(buffer, mimeType, (err, ndarray) => {\n if (err) {\n throw err;\n }\n\n const shape = [...ndarray.shape];\n const layers = ndarray.shape.length === 4 ? ndarray.shape.shift() : 1;\n const data = ndarray.data instanceof Buffer ? new Uint8Array(ndarray.data) : ndarray.data;\n\n // extract width/height etc\n resolve({\n shape,\n data,\n width: ndarray.shape[0],\n height: ndarray.shape[1],\n components: ndarray.shape[2],\n // TODO - error\n layers: layers ? [layers] : []\n });\n })\n );\n}\n"],"mappings":"AAEA,OAAOA,SAAS,MAAM,YAAY;AAGlC,OAAO,MAAMC,mBAAmB,GAAG,CAAC,WAAW,EAAE,YAAY,EAAE,WAAW,CAAC;AAY3E,OAAO,eAAeC,cAAcA,CAACC,WAAwB,EAAEC,QAAgB,EAAoB;EACjG,IAAI,CAACA,QAAQ,EAAE;IACb,MAAM,IAAIC,KAAK,CAAC,mDAAmD,CAAC;EACtE;EAEA,MAAMC,MAAM,GAAGH,WAAW,YAAYI,MAAM,GAAGJ,WAAW,GAAGI,MAAM,CAACC,IAAI,CAACL,WAAW,CAAC;EACrF,MAAMM,OAAO,GAAG,MAAMC,cAAc,CAACJ,MAAM,EAAEF,QAAQ,CAAC;EACtD,OAAOK,OAAO;AAChB;AAIA,SAASC,cAAcA,CAACJ,MAAc,EAAEF,QAAgB,EAAoB;EAC1E,OAAO,IAAIO,OAAO,CAAWC,OAAO,IAClCZ,SAAS,CAACM,MAAM,EAAEF,QAAQ,EAAE,CAACS,GAAG,EAAEJ,OAAO,KAAK;IAC5C,IAAII,GAAG,EAAE;MACP,MAAMA,GAAG;IACX;IAEA,MAAMC,KAAK,GAAG,CAAC,GAAGL,OAAO,CAACK,KAAK,CAAC;IAChC,MAAMC,MAAM,GAAGN,OAAO,CAACK,KAAK,CAACE,MAAM,KAAK,CAAC,GAAGP,OAAO,CAACK,KAAK,CAACG,KAAK,CAAC,CAAC,GAAG,CAAC;IACrE,MAAMC,IAAI,GAAGT,OAAO,CAACS,IAAI,YAAYX,MAAM,GAAG,IAAIY,UAAU,CAACV,OAAO,CAACS,IAAI,CAAC,GAAGT,OAAO,CAACS,IAAI;IAGzFN,OAAO,CAAC;MACNE,KAAK;MACLI,IAAI;MACJE,KAAK,EAAEX,OAAO,CAACK,KAAK,CAAC,CAAC,CAAC;MACvBO,MAAM,EAAEZ,OAAO,CAACK,KAAK,CAAC,CAAC,CAAC;MACxBQ,UAAU,EAAEb,OAAO,CAACK,KAAK,CAAC,CAAC,CAAC;MAE5BC,MAAM,EAAEA,MAAM,GAAG,CAACA,MAAM,CAAC,GAAG;IAC9B,CAAC,CAAC;EACJ,CAAC,CACH,CAAC;AACH"}
|
package/dist/index.browser.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.browser.d.ts","sourceRoot":"","sources":["../src/index.browser.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.browser.d.ts","sourceRoot":"","sources":["../src/index.browser.ts"],"names":[],"mappings":"AAEA,wBAAgB,oBAAoB,SAAK;AAGzC,eAAO,MAAM,cAAc,MAAO,CAAC;AAEnC,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,QAAQ,CAAC,CAE/E"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.browser.js","names":["installFilePolyfills","NodeFileSystem","fetchNode","path","options","Error"],"sources":["../src/index.browser.ts"],"sourcesContent":["// loaders.gl, MIT License\n\nexport function installFilePolyfills() {}\n\n// Dummy export to avoid import errors in browser tests\nexport const NodeFileSystem = null;\n\nexport function fetchNode(path: string, options: RequestInit): Promise<Response> {\n throw new Error('fetchNode not available in browser');\n}\n"],"mappings":"AAEA,OAAO,SAASA,oBAAoBA,CAAA,EAAG,CAAC;AAGxC,OAAO,MAAMC,cAAc,GAAG,IAAI;AAElC,OAAO,SAASC,SAASA,CAACC,IAAY,EAAEC,OAAoB,EAAqB;EAC/E,MAAM,IAAIC,KAAK,CAAC,oCAAoC,CAAC;AACvD"}
|