@loaders.gl/loader-utils 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/es5/index.js +328 -0
- package/dist/es5/index.js.map +1 -0
- package/dist/es5/json-loader.js +44 -0
- package/dist/es5/json-loader.js.map +1 -0
- package/dist/es5/lib/binary-utils/array-buffer-utils.js +80 -0
- package/dist/es5/lib/binary-utils/array-buffer-utils.js.map +1 -0
- package/dist/es5/lib/binary-utils/dataview-copy-utils.js +58 -0
- package/dist/es5/lib/binary-utils/dataview-copy-utils.js.map +1 -0
- package/dist/es5/lib/binary-utils/get-first-characters.js +31 -0
- package/dist/es5/lib/binary-utils/get-first-characters.js.map +1 -0
- package/dist/es5/lib/binary-utils/memory-conversion-utils.js +44 -0
- package/dist/es5/lib/binary-utils/memory-conversion-utils.js.map +1 -0
- package/dist/es5/lib/binary-utils/memory-copy-utils.js +34 -0
- package/dist/es5/lib/binary-utils/memory-copy-utils.js.map +1 -0
- package/dist/es5/lib/env-utils/assert.js +12 -0
- package/dist/es5/lib/env-utils/assert.js.map +1 -0
- package/dist/es5/lib/env-utils/globals.js +30 -0
- package/dist/es5/lib/env-utils/globals.js.map +1 -0
- package/dist/es5/lib/filesystems/node-filesystem.js +210 -0
- package/dist/es5/lib/filesystems/node-filesystem.js.map +1 -0
- package/dist/es5/lib/filesystems/readable-file.js +91 -0
- package/dist/es5/lib/filesystems/readable-file.js.map +1 -0
- package/dist/es5/lib/filesystems/writable-file.js +82 -0
- package/dist/es5/lib/filesystems/writable-file.js.map +1 -0
- package/dist/es5/lib/iterators/async-iteration.js +190 -0
- package/dist/es5/lib/iterators/async-iteration.js.map +1 -0
- package/dist/es5/lib/iterators/text-iterators.js +305 -0
- package/dist/es5/lib/iterators/text-iterators.js.map +1 -0
- package/dist/es5/lib/node/buffer.browser.js +14 -0
- package/dist/es5/lib/node/buffer.browser.js.map +1 -0
- package/dist/es5/lib/node/buffer.js +27 -0
- package/dist/es5/lib/node/buffer.js.map +1 -0
- package/dist/es5/lib/node/fs.js +88 -0
- package/dist/es5/lib/node/fs.js.map +1 -0
- package/dist/es5/lib/node/promisify.js +36 -0
- package/dist/es5/lib/node/promisify.js.map +1 -0
- package/dist/es5/lib/node/stream.js +16 -0
- package/dist/es5/lib/node/stream.js.map +1 -0
- package/dist/es5/lib/option-utils/merge-loader-options.js +30 -0
- package/dist/es5/lib/option-utils/merge-loader-options.js.map +1 -0
- package/dist/es5/lib/parser-utils/parse-json.js +15 -0
- package/dist/es5/lib/parser-utils/parse-json.js.map +1 -0
- package/dist/es5/lib/path-utils/file-aliases.js +33 -0
- package/dist/es5/lib/path-utils/file-aliases.js.map +1 -0
- package/dist/es5/lib/path-utils/get-cwd.js +15 -0
- package/dist/es5/lib/path-utils/get-cwd.js.map +1 -0
- package/dist/es5/lib/path-utils/path.js +136 -0
- package/dist/es5/lib/path-utils/path.js.map +1 -0
- package/dist/es5/lib/request-utils/request-scheduler.js +150 -0
- package/dist/es5/lib/request-utils/request-scheduler.js.map +1 -0
- package/dist/es5/lib/worker-loader-utils/create-loader-worker.js +142 -0
- package/dist/es5/lib/worker-loader-utils/create-loader-worker.js.map +1 -0
- package/dist/es5/lib/worker-loader-utils/encode-with-worker.js +18 -0
- package/dist/es5/lib/worker-loader-utils/encode-with-worker.js.map +1 -0
- package/dist/es5/lib/worker-loader-utils/parse-with-worker.js +115 -0
- package/dist/es5/lib/worker-loader-utils/parse-with-worker.js.map +1 -0
- package/dist/es5/types.js +2 -0
- package/dist/es5/types.js.map +1 -0
- package/dist/es5/workers/json-worker.js +6 -0
- package/dist/es5/workers/json-worker.js.map +1 -0
- package/dist/esm/index.js +29 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/json-loader.js +18 -0
- package/dist/esm/json-loader.js.map +1 -0
- package/dist/esm/lib/binary-utils/array-buffer-utils.js +52 -0
- package/dist/esm/lib/binary-utils/array-buffer-utils.js.map +1 -0
- package/dist/{lib/binary-utils/binary-copy-utils.js → esm/lib/binary-utils/dataview-copy-utils.js} +27 -4
- package/dist/esm/lib/binary-utils/dataview-copy-utils.js.map +1 -0
- package/dist/esm/lib/binary-utils/get-first-characters.js +24 -0
- package/dist/esm/lib/binary-utils/get-first-characters.js.map +1 -0
- package/dist/esm/lib/binary-utils/memory-conversion-utils.js +31 -0
- package/dist/esm/lib/binary-utils/memory-conversion-utils.js.map +1 -0
- package/dist/esm/lib/binary-utils/memory-copy-utils.js +26 -0
- package/dist/esm/lib/binary-utils/memory-copy-utils.js.map +1 -0
- package/dist/esm/lib/env-utils/assert.js +6 -0
- package/dist/esm/lib/env-utils/assert.js.map +1 -0
- package/dist/esm/lib/env-utils/globals.js +16 -0
- package/dist/esm/lib/env-utils/globals.js.map +1 -0
- package/dist/esm/lib/filesystems/node-filesystem.js +53 -0
- package/dist/esm/lib/filesystems/node-filesystem.js.map +1 -0
- package/dist/esm/lib/filesystems/readable-file.js +20 -0
- package/dist/esm/lib/filesystems/readable-file.js.map +1 -0
- package/dist/esm/lib/filesystems/writable-file.js +20 -0
- package/dist/esm/lib/filesystems/writable-file.js.map +1 -0
- package/dist/esm/lib/iterators/async-iteration.js +32 -0
- package/dist/esm/lib/iterators/async-iteration.js.map +1 -0
- package/dist/esm/lib/iterators/text-iterators.js +47 -0
- package/dist/esm/lib/iterators/text-iterators.js.map +1 -0
- package/dist/esm/lib/node/buffer.browser.js +7 -0
- package/dist/esm/lib/node/buffer.browser.js.map +1 -0
- package/dist/esm/lib/node/buffer.js +20 -0
- package/dist/esm/lib/node/buffer.js.map +1 -0
- package/dist/esm/lib/node/fs.js +40 -0
- package/dist/esm/lib/node/fs.js.map +1 -0
- package/dist/esm/lib/node/promisify.js +10 -0
- package/dist/esm/lib/node/promisify.js.map +1 -0
- package/dist/esm/lib/node/stream.js +7 -0
- package/dist/esm/lib/node/stream.js.map +1 -0
- package/dist/esm/lib/option-utils/merge-loader-options.js +17 -0
- package/dist/esm/lib/option-utils/merge-loader-options.js.map +1 -0
- package/dist/esm/lib/parser-utils/parse-json.js +9 -0
- package/dist/esm/lib/parser-utils/parse-json.js.map +1 -0
- package/dist/esm/lib/path-utils/file-aliases.js +24 -0
- package/dist/esm/lib/path-utils/file-aliases.js.map +1 -0
- package/dist/esm/lib/path-utils/get-cwd.js +9 -0
- package/dist/esm/lib/path-utils/get-cwd.js.map +1 -0
- package/dist/esm/lib/path-utils/path.js +127 -0
- package/dist/esm/lib/path-utils/path.js.map +1 -0
- package/dist/esm/lib/request-utils/request-scheduler.js +120 -0
- package/dist/esm/lib/request-utils/request-scheduler.js.map +1 -0
- package/dist/esm/lib/worker-loader-utils/create-loader-worker.js +95 -0
- package/dist/esm/lib/worker-loader-utils/create-loader-worker.js.map +1 -0
- package/dist/esm/lib/worker-loader-utils/encode-with-worker.js +12 -0
- package/dist/esm/lib/worker-loader-utils/encode-with-worker.js.map +1 -0
- package/dist/esm/lib/worker-loader-utils/parse-with-worker.js +63 -0
- package/dist/esm/lib/worker-loader-utils/parse-with-worker.js.map +1 -0
- package/dist/esm/types.js +2 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/esm/workers/json-worker.js +4 -0
- package/dist/esm/workers/json-worker.js.map +1 -0
- package/dist/index.d.ts +13 -8
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +122 -26
- package/dist/json-loader.d.ts +4 -17
- package/dist/json-loader.d.ts.map +1 -1
- package/dist/json-loader.js +24 -18
- package/dist/lib/binary-utils/array-buffer-utils.d.ts +4 -8
- package/dist/lib/binary-utils/array-buffer-utils.d.ts.map +1 -1
- package/dist/lib/binary-utils/array-buffer-utils.js +78 -80
- package/dist/lib/binary-utils/dataview-copy-utils.d.ts +43 -0
- package/dist/lib/binary-utils/dataview-copy-utils.d.ts.map +1 -0
- package/dist/lib/binary-utils/dataview-copy-utils.js +97 -0
- package/dist/lib/binary-utils/get-first-characters.d.ts +15 -1
- package/dist/lib/binary-utils/get-first-characters.d.ts.map +1 -1
- package/dist/lib/binary-utils/get-first-characters.js +43 -25
- package/dist/lib/binary-utils/{buffer-utils.d.ts → memory-conversion-utils.d.ts} +3 -4
- package/dist/lib/binary-utils/memory-conversion-utils.d.ts.map +1 -0
- package/dist/lib/binary-utils/memory-conversion-utils.js +73 -0
- package/dist/lib/binary-utils/memory-copy-utils.js +58 -24
- package/dist/lib/env-utils/assert.js +12 -5
- package/dist/lib/env-utils/globals.d.ts +1 -1
- package/dist/lib/env-utils/globals.d.ts.map +1 -1
- package/dist/lib/env-utils/globals.js +23 -9
- package/dist/lib/filesystems/node-filesystem.d.ts +3 -2
- package/dist/lib/filesystems/node-filesystem.d.ts.map +1 -1
- package/dist/lib/filesystems/node-filesystem.js +72 -59
- package/dist/lib/filesystems/readable-file.d.ts +10 -0
- package/dist/lib/filesystems/readable-file.d.ts.map +1 -0
- package/dist/lib/filesystems/readable-file.js +25 -0
- package/dist/lib/filesystems/writable-file.d.ts +18 -0
- package/dist/lib/filesystems/writable-file.d.ts.map +1 -0
- package/dist/lib/filesystems/writable-file.js +48 -0
- package/dist/lib/iterators/async-iteration.js +49 -35
- package/dist/lib/iterators/text-iterators.js +56 -41
- package/dist/lib/node/buffer.browser.d.ts +12 -0
- package/dist/lib/node/buffer.browser.d.ts.map +1 -0
- package/dist/lib/node/buffer.browser.js +22 -0
- package/dist/lib/node/buffer.d.ts +3 -1
- package/dist/lib/node/buffer.d.ts.map +1 -1
- package/dist/lib/node/buffer.js +33 -25
- package/dist/lib/node/fs.d.ts +4 -2
- package/dist/lib/node/fs.d.ts.map +1 -1
- package/dist/lib/node/fs.js +47 -40
- package/dist/lib/node/promisify.d.ts +13 -0
- package/dist/lib/node/promisify.d.ts.map +1 -0
- package/dist/lib/node/promisify.js +22 -0
- package/dist/lib/node/stream.d.ts +4 -0
- package/dist/lib/node/stream.d.ts.map +1 -0
- package/dist/lib/node/stream.js +17 -0
- package/dist/lib/option-utils/merge-loader-options.d.ts +9 -0
- package/dist/lib/option-utils/merge-loader-options.d.ts.map +1 -0
- package/dist/lib/option-utils/merge-loader-options.js +27 -0
- package/dist/lib/parser-utils/parse-json.js +15 -8
- package/dist/lib/path-utils/file-aliases.js +40 -19
- package/dist/lib/path-utils/get-cwd.d.ts +2 -0
- package/dist/lib/path-utils/get-cwd.d.ts.map +1 -0
- package/dist/lib/path-utils/get-cwd.js +12 -0
- package/dist/lib/path-utils/path.d.ts +8 -0
- package/dist/lib/path-utils/path.d.ts.map +1 -1
- package/dist/lib/path-utils/path.js +173 -19
- package/dist/lib/request-utils/request-scheduler.d.ts +6 -6
- package/dist/lib/request-utils/request-scheduler.d.ts.map +1 -1
- package/dist/lib/request-utils/request-scheduler.js +127 -131
- package/dist/lib/worker-loader-utils/create-loader-worker.d.ts.map +1 -1
- package/dist/lib/worker-loader-utils/create-loader-worker.js +92 -96
- package/dist/lib/worker-loader-utils/encode-with-worker.d.ts +8 -0
- package/dist/lib/worker-loader-utils/encode-with-worker.d.ts.map +1 -0
- package/dist/lib/worker-loader-utils/encode-with-worker.js +21 -0
- package/dist/lib/worker-loader-utils/parse-with-worker.d.ts.map +1 -1
- package/dist/lib/worker-loader-utils/parse-with-worker.js +77 -60
- package/dist/types.d.ts +85 -72
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +3 -2
- package/dist/workers/json-worker.js +5 -4
- package/package.json +12 -19
- package/src/index.ts +32 -18
- package/src/json-loader.ts +5 -4
- package/src/lib/binary-utils/array-buffer-utils.ts +4 -40
- package/src/lib/binary-utils/{binary-copy-utils.ts → dataview-copy-utils.ts} +57 -5
- package/src/lib/binary-utils/get-first-characters.ts +17 -1
- package/src/lib/binary-utils/memory-conversion-utils.ts +53 -0
- package/src/lib/filesystems/readable-file.ts +30 -0
- package/src/lib/filesystems/writable-file.ts +44 -0
- package/src/lib/node/buffer.browser.ts +20 -0
- package/src/lib/node/buffer.ts +12 -11
- package/src/lib/node/fs.ts +16 -11
- package/src/lib/node/promisify.ts +70 -0
- package/src/lib/node/stream.ts +18 -0
- package/src/lib/option-utils/merge-loader-options.ts +35 -0
- package/src/lib/path-utils/get-cwd.ts +9 -0
- package/src/lib/path-utils/path.ts +138 -4
- package/src/lib/worker-loader-utils/create-loader-worker.ts +3 -2
- package/src/lib/worker-loader-utils/encode-with-worker.ts +21 -0
- package/src/lib/worker-loader-utils/parse-with-worker.ts +15 -2
- package/src/types.ts +156 -93
- package/dist/index.js.map +0 -1
- package/dist/json-loader.js.map +0 -1
- package/dist/lib/binary-utils/array-buffer-utils.js.map +0 -1
- package/dist/lib/binary-utils/binary-copy-utils.d.ts +0 -24
- package/dist/lib/binary-utils/binary-copy-utils.d.ts.map +0 -1
- package/dist/lib/binary-utils/binary-copy-utils.js.map +0 -1
- package/dist/lib/binary-utils/buffer-utils.d.ts.map +0 -1
- package/dist/lib/binary-utils/buffer-utils.js +0 -16
- package/dist/lib/binary-utils/buffer-utils.js.map +0 -1
- package/dist/lib/binary-utils/encode-utils.d.ts +0 -4
- package/dist/lib/binary-utils/encode-utils.d.ts.map +0 -1
- package/dist/lib/binary-utils/encode-utils.js +0 -31
- package/dist/lib/binary-utils/encode-utils.js.map +0 -1
- package/dist/lib/binary-utils/get-first-characters.js.map +0 -1
- package/dist/lib/binary-utils/memory-copy-utils.js.map +0 -1
- package/dist/lib/env-utils/assert.js.map +0 -1
- package/dist/lib/env-utils/globals.js.map +0 -1
- package/dist/lib/filesystems/node-filesystem.js.map +0 -1
- package/dist/lib/iterators/async-iteration.js.map +0 -1
- package/dist/lib/iterators/text-iterators.js.map +0 -1
- package/dist/lib/node/buffer.js.map +0 -1
- package/dist/lib/node/fs.js.map +0 -1
- package/dist/lib/node/util.d.ts +0 -5
- package/dist/lib/node/util.d.ts.map +0 -1
- package/dist/lib/node/util.js +0 -3
- package/dist/lib/node/util.js.map +0 -1
- package/dist/lib/parser-utils/parse-json.js.map +0 -1
- package/dist/lib/path-utils/file-aliases.js.map +0 -1
- package/dist/lib/path-utils/path.js.map +0 -1
- package/dist/lib/request-utils/request-scheduler.js.map +0 -1
- package/dist/lib/worker-loader-utils/create-loader-worker.js.map +0 -1
- package/dist/lib/worker-loader-utils/parse-with-worker.js.map +0 -1
- package/dist/types.js.map +0 -1
- package/dist/workers/json-worker.js.map +0 -1
- package/src/lib/binary-utils/buffer-utils.ts +0 -28
- package/src/lib/binary-utils/encode-utils.ts +0 -32
- package/src/lib/node/util.ts +0 -4
package/src/lib/node/fs.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
// fs wrapper (promisified fs + avoids bundling fs in browsers)
|
|
2
2
|
import fs from 'fs';
|
|
3
3
|
import {toArrayBuffer} from './buffer';
|
|
4
|
-
import {
|
|
4
|
+
import {promisify2, promisify3} from './promisify';
|
|
5
5
|
|
|
6
|
-
export type {Stats} from 'fs';
|
|
6
|
+
export type {Stats, WriteStream} from 'fs';
|
|
7
7
|
|
|
8
8
|
export let readdir;
|
|
9
9
|
/** Wrapper for Node.js fs method */
|
|
@@ -23,41 +23,46 @@ export let writeFileSync;
|
|
|
23
23
|
/** Wrapper for Node.js fs method */
|
|
24
24
|
export let open;
|
|
25
25
|
/** Wrapper for Node.js fs method */
|
|
26
|
-
export let close
|
|
26
|
+
export let close: (fd: number) => Promise<void>;
|
|
27
27
|
/** Wrapper for Node.js fs method */
|
|
28
28
|
export let read;
|
|
29
29
|
/** Wrapper for Node.js fs method */
|
|
30
30
|
export let fstat;
|
|
31
31
|
|
|
32
|
+
export let createWriteStream: typeof fs.createWriteStream;
|
|
33
|
+
|
|
32
34
|
export let isSupported = Boolean(fs);
|
|
33
35
|
|
|
34
36
|
// paths
|
|
35
37
|
|
|
36
38
|
try {
|
|
37
39
|
/** Wrapper for Node.js fs method */
|
|
38
|
-
readdir =
|
|
40
|
+
readdir = promisify2(fs.readdir);
|
|
39
41
|
/** Wrapper for Node.js fs method */
|
|
40
|
-
stat =
|
|
42
|
+
stat = promisify2(fs.stat);
|
|
41
43
|
|
|
42
44
|
/** Wrapper for Node.js fs method */
|
|
43
|
-
readFile =
|
|
45
|
+
readFile = fs.readFile;
|
|
44
46
|
/** Wrapper for Node.js fs method */
|
|
45
47
|
readFileSync = fs.readFileSync;
|
|
46
48
|
/** Wrapper for Node.js fs method */
|
|
47
|
-
writeFile =
|
|
49
|
+
writeFile = promisify3(fs.writeFile);
|
|
48
50
|
/** Wrapper for Node.js fs method */
|
|
49
51
|
writeFileSync = fs.writeFileSync;
|
|
50
52
|
|
|
51
53
|
// file descriptors
|
|
52
54
|
|
|
53
55
|
/** Wrapper for Node.js fs method */
|
|
54
|
-
open =
|
|
56
|
+
open = fs.open;
|
|
55
57
|
/** Wrapper for Node.js fs method */
|
|
56
|
-
close =
|
|
58
|
+
close = (fd: number) =>
|
|
59
|
+
new Promise((resolve, reject) => fs.close(fd, (err) => (err ? reject(err) : resolve())));
|
|
57
60
|
/** Wrapper for Node.js fs method */
|
|
58
|
-
read =
|
|
61
|
+
read = fs.read;
|
|
59
62
|
/** Wrapper for Node.js fs method */
|
|
60
|
-
fstat =
|
|
63
|
+
fstat = fs.fstat;
|
|
64
|
+
|
|
65
|
+
createWriteStream = fs.createWriteStream;
|
|
61
66
|
|
|
62
67
|
isSupported = Boolean(fs);
|
|
63
68
|
} catch {
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
// @loaders.gl, MIT license
|
|
2
|
+
|
|
3
|
+
// type Parameter1<T extends (arg1: any, ...args: unknown[]) => unknown> = T extends (
|
|
4
|
+
// arg1: infer P,
|
|
5
|
+
// ...args: unknown[]
|
|
6
|
+
// ) => unknown
|
|
7
|
+
// ? P
|
|
8
|
+
// : never;
|
|
9
|
+
|
|
10
|
+
// type Parameter2<T extends (arg1: unknown, arg2: any, ...args: unknown[]) => unknown> = T extends (
|
|
11
|
+
// arg1: unknown,
|
|
12
|
+
// arg2: infer P,
|
|
13
|
+
// ...args: unknown[]
|
|
14
|
+
// ) => unknown
|
|
15
|
+
// ? P
|
|
16
|
+
// : never;
|
|
17
|
+
|
|
18
|
+
// type CallbackParameter2<
|
|
19
|
+
// T extends (arg: unknown, cb: (error: any, value: any) => void) => unknown
|
|
20
|
+
// > = T extends (arg: unknown, cb: (error: any, value: infer P) => void) => unknown ? P : never;
|
|
21
|
+
|
|
22
|
+
// type CallbackParameter3<
|
|
23
|
+
// T extends (arg: unknown, arg2: unknown, cb: (error: any, value: any) => void) => unknown
|
|
24
|
+
// > = T extends (arg: unknown, arg2: unknown, cb: (error: any, value: infer P) => void) => unknown
|
|
25
|
+
// ? P
|
|
26
|
+
// : never;
|
|
27
|
+
|
|
28
|
+
// /** Extract the parameters of a function type in a tuple */
|
|
29
|
+
// export type Promisified<F extends (arg1, cb: (error: unknown, value: any) => void) => any> = (
|
|
30
|
+
// arg1: Parameter1<F>
|
|
31
|
+
// ) => Promise<CallbackParameter2<F>>;
|
|
32
|
+
// /** Extract the parameters of a function type in a tuple */
|
|
33
|
+
// export type Promisified2<F extends (arg1, arg2, cb: (error: unknown, value: any) => void) => any> = (
|
|
34
|
+
// arg1: Parameter1<F>,
|
|
35
|
+
// arg2: Parameter2<F>
|
|
36
|
+
// ) => Promise<CallbackParameter3<F>>;
|
|
37
|
+
|
|
38
|
+
/** Wrapper for Node.js promisify */
|
|
39
|
+
type Callback<A> = (error: unknown, args: A) => void;
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Typesafe promisify implementation
|
|
43
|
+
* @link https://dev.to/_gdelgado/implement-a-type-safe-version-of-node-s-promisify-in-7-lines-of-code-in-typescript-2j34
|
|
44
|
+
* @param fn
|
|
45
|
+
* @returns
|
|
46
|
+
*/
|
|
47
|
+
export function promisify1<T, A>(fn: (args: T, cb: Callback<A>) => void): (args: T) => Promise<A> {
|
|
48
|
+
return (args: T) =>
|
|
49
|
+
new Promise((resolve, reject) =>
|
|
50
|
+
fn(args, (error, callbackArgs) => (error ? reject(error) : resolve(callbackArgs)))
|
|
51
|
+
);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export function promisify2<T1, T2, A>(
|
|
55
|
+
fn: (arg1: T1, arg2: T2, cb: Callback<A>) => void
|
|
56
|
+
): (arg1: T1, arg2: T2) => Promise<A> {
|
|
57
|
+
return (arg1: T1, arg2: T2) =>
|
|
58
|
+
new Promise((resolve, reject) =>
|
|
59
|
+
fn(arg1, arg2, (error, callbackArgs) => (error ? reject(error) : resolve(callbackArgs)))
|
|
60
|
+
);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
export function promisify3<T1, T2, T3, A>(
|
|
64
|
+
fn: (arg1: T1, arg2: T2, arg3: T3, cb: Callback<A>) => void
|
|
65
|
+
): (arg1: T1, arg2: T2, arg3: T3) => Promise<A> {
|
|
66
|
+
return (arg1: T1, arg2: T2, arg3: T3) =>
|
|
67
|
+
new Promise((resolve, reject) =>
|
|
68
|
+
fn(arg1, arg2, arg3, (error, callbackArgs) => (error ? reject(error) : resolve(callbackArgs)))
|
|
69
|
+
);
|
|
70
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// loaders.gl, MIT license
|
|
2
|
+
|
|
3
|
+
import stream from 'stream';
|
|
4
|
+
|
|
5
|
+
export type {Writable} from 'stream';
|
|
6
|
+
|
|
7
|
+
export let Transform;
|
|
8
|
+
|
|
9
|
+
export const isSupported = Boolean(stream);
|
|
10
|
+
|
|
11
|
+
// paths
|
|
12
|
+
|
|
13
|
+
try {
|
|
14
|
+
/** Wrapper for Node.js fs method */
|
|
15
|
+
Transform = stream.Transform;
|
|
16
|
+
} catch {
|
|
17
|
+
// ignore
|
|
18
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
// loaders.gl, MIT license
|
|
2
|
+
|
|
3
|
+
import {LoaderOptions} from '../../types';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
*
|
|
7
|
+
* @param baseOptions Can be undefined, in which case a fresh options object will be minted
|
|
8
|
+
* @param newOptions
|
|
9
|
+
* @returns
|
|
10
|
+
*/
|
|
11
|
+
export function mergeLoaderOptions<Options extends LoaderOptions>(
|
|
12
|
+
baseOptions: Options | undefined,
|
|
13
|
+
newOptions: Options
|
|
14
|
+
): Options {
|
|
15
|
+
return mergeOptionsRecursively(baseOptions || {}, newOptions) as Options;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function mergeOptionsRecursively(
|
|
19
|
+
baseOptions: Record<string, unknown>,
|
|
20
|
+
newOptions: Record<string, unknown>
|
|
21
|
+
): Record<string, unknown> {
|
|
22
|
+
const options = {...baseOptions};
|
|
23
|
+
for (const [key, newValue] of Object.entries(newOptions)) {
|
|
24
|
+
if (newValue && typeof newValue === 'object') {
|
|
25
|
+
options[key] = mergeOptionsRecursively(
|
|
26
|
+
(options[key] as Record<string, unknown>) || {},
|
|
27
|
+
newOptions[key] as Record<string, unknown>
|
|
28
|
+
);
|
|
29
|
+
// Object.assign(options[key] as object, newOptions[key]);
|
|
30
|
+
} else {
|
|
31
|
+
options[key] = newOptions[key];
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
return options as Record<string, unknown>;
|
|
35
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
// loaders.gl MIT license
|
|
2
|
+
|
|
3
|
+
export function getCWD() {
|
|
4
|
+
if (typeof process !== 'undefined' && typeof process.cwd !== 'undefined') {
|
|
5
|
+
return process.cwd();
|
|
6
|
+
}
|
|
7
|
+
const pathname = window.location?.pathname;
|
|
8
|
+
return pathname?.slice(0, pathname.lastIndexOf('/') + 1) || '';
|
|
9
|
+
}
|
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
// Beginning of a minimal implementation of the Node.js path API, that doesn't pull in big polyfills.
|
|
2
2
|
|
|
3
|
+
import {getCWD} from './get-cwd';
|
|
4
|
+
|
|
3
5
|
/**
|
|
4
6
|
* Replacement for Node.js path.filename
|
|
5
7
|
* @param url
|
|
6
8
|
*/
|
|
7
9
|
export function filename(url: string): string {
|
|
8
|
-
const slashIndex = url
|
|
9
|
-
return slashIndex >= 0 ? url.substr(
|
|
10
|
+
const slashIndex = url ? url.lastIndexOf('/') : -1;
|
|
11
|
+
return slashIndex >= 0 ? url.substr(slashIndex + 1) : '';
|
|
10
12
|
}
|
|
11
13
|
|
|
12
14
|
/**
|
|
@@ -14,8 +16,8 @@ export function filename(url: string): string {
|
|
|
14
16
|
* @param url
|
|
15
17
|
*/
|
|
16
18
|
export function dirname(url: string): string {
|
|
17
|
-
const slashIndex = url
|
|
18
|
-
return slashIndex >= 0 ? url.substr(0, slashIndex
|
|
19
|
+
const slashIndex = url ? url.lastIndexOf('/') : -1;
|
|
20
|
+
return slashIndex >= 0 ? url.substr(0, slashIndex) : '';
|
|
19
21
|
}
|
|
20
22
|
|
|
21
23
|
/**
|
|
@@ -35,3 +37,135 @@ export function join(...parts: string[]): string {
|
|
|
35
37
|
});
|
|
36
38
|
return parts.join(separator);
|
|
37
39
|
}
|
|
40
|
+
|
|
41
|
+
/* eslint-disable no-continue */
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* https://nodejs.org/api/path.html#path_path_resolve_paths
|
|
45
|
+
* @param paths A sequence of paths or path segments.
|
|
46
|
+
* @return resolved path
|
|
47
|
+
* Forked from BTOdell/path-resolve under MIT license
|
|
48
|
+
* @see https://github.com/BTOdell/path-resolve/blob/master/LICENSE
|
|
49
|
+
*/
|
|
50
|
+
export function resolve(...components: string[]): string {
|
|
51
|
+
const paths: string[] = [];
|
|
52
|
+
for (let _i = 0; _i < components.length; _i++) {
|
|
53
|
+
paths[_i] = components[_i];
|
|
54
|
+
}
|
|
55
|
+
let resolvedPath = '';
|
|
56
|
+
let resolvedAbsolute = false;
|
|
57
|
+
let cwd: string | undefined;
|
|
58
|
+
for (let i = paths.length - 1; i >= -1 && !resolvedAbsolute; i--) {
|
|
59
|
+
let path: string | undefined;
|
|
60
|
+
if (i >= 0) {
|
|
61
|
+
path = paths[i];
|
|
62
|
+
} else {
|
|
63
|
+
if (cwd === undefined) {
|
|
64
|
+
cwd = getCWD();
|
|
65
|
+
}
|
|
66
|
+
path = cwd;
|
|
67
|
+
}
|
|
68
|
+
// Skip empty entries
|
|
69
|
+
if (path.length === 0) {
|
|
70
|
+
continue;
|
|
71
|
+
}
|
|
72
|
+
resolvedPath = `${path}/${resolvedPath}`;
|
|
73
|
+
resolvedAbsolute = path.charCodeAt(0) === SLASH;
|
|
74
|
+
}
|
|
75
|
+
// At this point the path should be resolved to a full absolute path, but
|
|
76
|
+
// handle relative paths to be safe (might happen when process.cwd() fails)
|
|
77
|
+
// Normalize the path (removes leading slash)
|
|
78
|
+
resolvedPath = normalizeStringPosix(resolvedPath, !resolvedAbsolute);
|
|
79
|
+
if (resolvedAbsolute) {
|
|
80
|
+
return `/${resolvedPath}`;
|
|
81
|
+
} else if (resolvedPath.length > 0) {
|
|
82
|
+
return resolvedPath;
|
|
83
|
+
}
|
|
84
|
+
return '.';
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
const SLASH = 47;
|
|
88
|
+
const DOT = 46;
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* Resolves . and .. elements in a path with directory names
|
|
92
|
+
* Forked from BTOdell/path-resolve under MIT license
|
|
93
|
+
* @see https://github.com/BTOdell/path-resolve/blob/master/LICENSE
|
|
94
|
+
*/
|
|
95
|
+
/* eslint-disable max-depth */
|
|
96
|
+
// eslint-disable-next-line complexity, max-statements
|
|
97
|
+
function normalizeStringPosix(path: string, allowAboveRoot: boolean): string {
|
|
98
|
+
let res = '';
|
|
99
|
+
let lastSlash = -1;
|
|
100
|
+
let dots = 0;
|
|
101
|
+
let code: number | undefined;
|
|
102
|
+
let isAboveRoot = false;
|
|
103
|
+
|
|
104
|
+
for (let i = 0; i <= path.length; ++i) {
|
|
105
|
+
if (i < path.length) {
|
|
106
|
+
code = path.charCodeAt(i);
|
|
107
|
+
} else if (code === SLASH) {
|
|
108
|
+
break;
|
|
109
|
+
} else {
|
|
110
|
+
code = SLASH;
|
|
111
|
+
}
|
|
112
|
+
if (code === SLASH) {
|
|
113
|
+
if (lastSlash === i - 1 || dots === 1) {
|
|
114
|
+
// NOOP
|
|
115
|
+
} else if (lastSlash !== i - 1 && dots === 2) {
|
|
116
|
+
if (
|
|
117
|
+
res.length < 2 ||
|
|
118
|
+
!isAboveRoot ||
|
|
119
|
+
res.charCodeAt(res.length - 1) !== DOT ||
|
|
120
|
+
res.charCodeAt(res.length - 2) !== DOT
|
|
121
|
+
) {
|
|
122
|
+
if (res.length > 2) {
|
|
123
|
+
const start = res.length - 1;
|
|
124
|
+
let j = start;
|
|
125
|
+
for (; j >= 0; --j) {
|
|
126
|
+
if (res.charCodeAt(j) === SLASH) {
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
if (j !== start) {
|
|
131
|
+
res = j === -1 ? '' : res.slice(0, j);
|
|
132
|
+
lastSlash = i;
|
|
133
|
+
dots = 0;
|
|
134
|
+
isAboveRoot = false;
|
|
135
|
+
continue;
|
|
136
|
+
}
|
|
137
|
+
} else if (res.length === 2 || res.length === 1) {
|
|
138
|
+
res = '';
|
|
139
|
+
lastSlash = i;
|
|
140
|
+
dots = 0;
|
|
141
|
+
isAboveRoot = false;
|
|
142
|
+
continue;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
if (allowAboveRoot) {
|
|
146
|
+
if (res.length > 0) {
|
|
147
|
+
res += '/..';
|
|
148
|
+
} else {
|
|
149
|
+
res = '..';
|
|
150
|
+
}
|
|
151
|
+
isAboveRoot = true;
|
|
152
|
+
}
|
|
153
|
+
} else {
|
|
154
|
+
const slice = path.slice(lastSlash + 1, i);
|
|
155
|
+
if (res.length > 0) {
|
|
156
|
+
res += `/${slice}`;
|
|
157
|
+
} else {
|
|
158
|
+
res = slice;
|
|
159
|
+
}
|
|
160
|
+
isAboveRoot = false;
|
|
161
|
+
}
|
|
162
|
+
lastSlash = i;
|
|
163
|
+
dots = 0;
|
|
164
|
+
} else if (code === DOT && dots !== -1) {
|
|
165
|
+
++dots;
|
|
166
|
+
} else {
|
|
167
|
+
dots = -1;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
return res;
|
|
171
|
+
}
|
|
@@ -11,7 +11,7 @@ let requestId = 0;
|
|
|
11
11
|
*/
|
|
12
12
|
export function createLoaderWorker(loader: LoaderWithParser) {
|
|
13
13
|
// Check that we are actually in a worker thread
|
|
14
|
-
if (
|
|
14
|
+
if (!WorkerBody.inWorkerThread()) {
|
|
15
15
|
return;
|
|
16
16
|
}
|
|
17
17
|
|
|
@@ -21,13 +21,14 @@ export function createLoaderWorker(loader: LoaderWithParser) {
|
|
|
21
21
|
try {
|
|
22
22
|
// validateLoaderVersion(loader, data.source.split('@')[1]);
|
|
23
23
|
|
|
24
|
-
const {input, options = {}} = payload;
|
|
24
|
+
const {input, options = {}, context = {}} = payload;
|
|
25
25
|
|
|
26
26
|
const result = await parseData({
|
|
27
27
|
loader,
|
|
28
28
|
arrayBuffer: input,
|
|
29
29
|
options,
|
|
30
30
|
context: {
|
|
31
|
+
...context,
|
|
31
32
|
parse: parseOnMainThread
|
|
32
33
|
}
|
|
33
34
|
});
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import {WorkerFarm} from '@loaders.gl/worker-utils';
|
|
2
|
+
import {Writer, WriterOptions} from '../../types';
|
|
3
|
+
import {isBrowser} from '../env-utils/globals';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Determines if a loader can parse with worker
|
|
7
|
+
* @param loader
|
|
8
|
+
* @param options
|
|
9
|
+
*/
|
|
10
|
+
export function canEncodeWithWorker(writer: Writer, options?: WriterOptions) {
|
|
11
|
+
if (!WorkerFarm.isSupported()) {
|
|
12
|
+
return false;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
// Node workers are still experimental
|
|
16
|
+
if (!isBrowser && !options?._nodeWorkers) {
|
|
17
|
+
return false;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
return writer.worker && options?.worker;
|
|
21
|
+
}
|
|
@@ -1,4 +1,9 @@
|
|
|
1
|
-
import
|
|
1
|
+
import {
|
|
2
|
+
WorkerJob,
|
|
3
|
+
WorkerMessageType,
|
|
4
|
+
WorkerMessagePayload,
|
|
5
|
+
isBrowser
|
|
6
|
+
} from '@loaders.gl/worker-utils';
|
|
2
7
|
import type {Loader, LoaderOptions, LoaderContext} from '../../types';
|
|
3
8
|
import {WorkerFarm, getWorkerURL} from '@loaders.gl/worker-utils';
|
|
4
9
|
|
|
@@ -12,6 +17,11 @@ export function canParseWithWorker(loader: Loader, options?: LoaderOptions) {
|
|
|
12
17
|
return false;
|
|
13
18
|
}
|
|
14
19
|
|
|
20
|
+
// Node workers are still experimental
|
|
21
|
+
if (!isBrowser && !options?._nodeWorkers) {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
|
|
15
25
|
return loader.worker && options?.worker;
|
|
16
26
|
}
|
|
17
27
|
|
|
@@ -33,8 +43,10 @@ export async function parseWithWorker(
|
|
|
33
43
|
const workerPool = workerFarm.getWorkerPool({name, url});
|
|
34
44
|
|
|
35
45
|
// options.log object contains functions which cannot be transferred
|
|
46
|
+
// context.fetch & context.parse functions cannot be transferred
|
|
36
47
|
// TODO - decide how to handle logging on workers
|
|
37
48
|
options = JSON.parse(JSON.stringify(options));
|
|
49
|
+
context = JSON.parse(JSON.stringify(context || {}));
|
|
38
50
|
|
|
39
51
|
const job = await workerPool.startJob(
|
|
40
52
|
'process-on-worker',
|
|
@@ -45,7 +57,8 @@ export async function parseWithWorker(
|
|
|
45
57
|
job.postMessage('process', {
|
|
46
58
|
// @ts-ignore
|
|
47
59
|
input: data,
|
|
48
|
-
options
|
|
60
|
+
options,
|
|
61
|
+
context
|
|
49
62
|
});
|
|
50
63
|
|
|
51
64
|
const result = await job.result;
|