@loaders.gl/loader-utils 4.0.0-alpha.4 → 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 +32 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +122 -26
- package/dist/json-loader.d.ts +9 -0
- package/dist/json-loader.d.ts.map +1 -0
- package/dist/json-loader.js +24 -18
- package/dist/lib/binary-utils/array-buffer-utils.d.ts +27 -0
- package/dist/lib/binary-utils/array-buffer-utils.d.ts.map +1 -0
- 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 +17 -0
- package/dist/lib/binary-utils/get-first-characters.d.ts.map +1 -0
- package/dist/lib/binary-utils/get-first-characters.js +43 -25
- package/dist/lib/binary-utils/memory-conversion-utils.d.ts +15 -0
- 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.d.ts +25 -0
- package/dist/lib/binary-utils/memory-copy-utils.d.ts.map +1 -0
- package/dist/lib/binary-utils/memory-copy-utils.js +58 -24
- package/dist/lib/env-utils/assert.d.ts +6 -0
- package/dist/lib/env-utils/assert.d.ts.map +1 -0
- package/dist/lib/env-utils/assert.js +12 -5
- package/dist/lib/env-utils/globals.d.ts +15 -0
- package/dist/lib/env-utils/globals.d.ts.map +1 -0
- package/dist/lib/env-utils/globals.js +23 -9
- package/dist/lib/filesystems/node-filesystem.d.ts +39 -0
- package/dist/lib/filesystems/node-filesystem.d.ts.map +1 -0
- 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.d.ts +20 -0
- package/dist/lib/iterators/async-iteration.d.ts.map +1 -0
- package/dist/lib/iterators/async-iteration.js +49 -35
- package/dist/lib/iterators/text-iterators.d.ts +19 -0
- package/dist/lib/iterators/text-iterators.d.ts.map +1 -0
- 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 +12 -0
- package/dist/lib/node/buffer.d.ts.map +1 -0
- package/dist/lib/node/buffer.js +33 -25
- package/dist/lib/node/fs.d.ts +25 -0
- package/dist/lib/node/fs.d.ts.map +1 -0
- package/dist/lib/node/fs.js +48 -26
- 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.d.ts +5 -0
- package/dist/lib/parser-utils/parse-json.d.ts.map +1 -0
- package/dist/lib/parser-utils/parse-json.js +15 -8
- package/dist/lib/path-utils/file-aliases.d.ts +17 -0
- package/dist/lib/path-utils/file-aliases.d.ts.map +1 -0
- 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 +24 -0
- package/dist/lib/path-utils/path.d.ts.map +1 -0
- package/dist/lib/path-utils/path.js +173 -19
- package/dist/lib/request-utils/request-scheduler.d.ts +62 -0
- package/dist/lib/request-utils/request-scheduler.d.ts.map +1 -0
- package/dist/lib/request-utils/request-scheduler.js +127 -131
- package/dist/lib/worker-loader-utils/create-loader-worker.d.ts +7 -0
- package/dist/lib/worker-loader-utils/create-loader-worker.d.ts.map +1 -0
- 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 +15 -0
- package/dist/lib/worker-loader-utils/parse-with-worker.d.ts.map +1 -0
- package/dist/lib/worker-loader-utils/parse-with-worker.js +77 -60
- package/dist/types.d.ts +220 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +3 -2
- package/dist/workers/json-worker.d.ts +2 -0
- package/dist/workers/json-worker.d.ts.map +1 -0
- package/dist/workers/json-worker.js +5 -4
- package/package.json +14 -24
- 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 +51 -16
- 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 +16 -3
- 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.js.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.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.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
|
@@ -1,13 +1,65 @@
|
|
|
1
|
+
// loaders./gl, MIT license
|
|
2
|
+
|
|
1
3
|
import {TypedArray} from '../../types';
|
|
2
4
|
import {padToNBytes} from './memory-copy-utils';
|
|
3
5
|
|
|
6
|
+
/**
|
|
7
|
+
* Helper function that pads a string with spaces to fit a certain byte alignment
|
|
8
|
+
* @param string
|
|
9
|
+
* @param byteAlignment
|
|
10
|
+
* @returns
|
|
11
|
+
*
|
|
12
|
+
* @todo PERFORMANCE IDEA: No need to copy string twice...
|
|
13
|
+
*/
|
|
14
|
+
export function padStringToByteAlignment(string: string, byteAlignment: number): string {
|
|
15
|
+
const length = string.length;
|
|
16
|
+
const paddedLength = Math.ceil(length / byteAlignment) * byteAlignment; // Round up to the required alignment
|
|
17
|
+
const padding = paddedLength - length;
|
|
18
|
+
let whitespace = '';
|
|
19
|
+
for (let i = 0; i < padding; ++i) {
|
|
20
|
+
whitespace += ' ';
|
|
21
|
+
}
|
|
22
|
+
return string + whitespace;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
*
|
|
27
|
+
* @param dataView
|
|
28
|
+
* @param byteOffset
|
|
29
|
+
* @param string
|
|
30
|
+
* @param byteLength
|
|
31
|
+
* @returns
|
|
32
|
+
*/
|
|
33
|
+
export function copyStringToDataView(
|
|
34
|
+
dataView: DataView,
|
|
35
|
+
byteOffset: number,
|
|
36
|
+
string: string,
|
|
37
|
+
byteLength: number
|
|
38
|
+
): number {
|
|
39
|
+
if (dataView) {
|
|
40
|
+
for (let i = 0; i < byteLength; i++) {
|
|
41
|
+
dataView.setUint8(byteOffset + i, string.charCodeAt(i));
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
return byteOffset + byteLength;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
export function copyBinaryToDataView(dataView, byteOffset, binary, byteLength) {
|
|
48
|
+
if (dataView) {
|
|
49
|
+
for (let i = 0; i < byteLength; i++) {
|
|
50
|
+
dataView.setUint8(byteOffset + i, binary[i]);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return byteOffset + byteLength;
|
|
54
|
+
}
|
|
55
|
+
|
|
4
56
|
/**
|
|
5
57
|
* Copy sourceBuffer to dataView with some padding
|
|
6
58
|
*
|
|
7
|
-
* @param
|
|
8
|
-
* @param
|
|
9
|
-
* @param
|
|
10
|
-
* @param
|
|
59
|
+
* @param dataView - destination data container. If null - only new offset is calculated
|
|
60
|
+
* @param byteOffset - destination byte offset to copy to
|
|
61
|
+
* @param sourceBuffer - source data buffer
|
|
62
|
+
* @param padding - pad the resulting array to multiple of "padding" bytes. Additional bytes are filled with 0x20 (ASCII space)
|
|
11
63
|
*
|
|
12
64
|
* @return new byteOffset of resulting dataView
|
|
13
65
|
*/
|
|
@@ -16,7 +68,7 @@ export function copyPaddedArrayBufferToDataView(
|
|
|
16
68
|
byteOffset: number,
|
|
17
69
|
sourceBuffer: TypedArray,
|
|
18
70
|
padding: number
|
|
19
|
-
) {
|
|
71
|
+
): number {
|
|
20
72
|
const paddedLength = padToNBytes(sourceBuffer.byteLength, padding);
|
|
21
73
|
const padLength = paddedLength - sourceBuffer.byteLength;
|
|
22
74
|
|
|
@@ -1,4 +1,12 @@
|
|
|
1
|
-
|
|
1
|
+
// loaders.gl, MIT license
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Get the first characters from a binary file (interpret the first bytes as an ASCII string)
|
|
5
|
+
* @param data
|
|
6
|
+
* @param length
|
|
7
|
+
* @returns
|
|
8
|
+
*/
|
|
9
|
+
export function getFirstCharacters(data: string | ArrayBuffer, length: number = 5): string {
|
|
2
10
|
if (typeof data === 'string') {
|
|
3
11
|
return data.slice(0, length);
|
|
4
12
|
} else if (ArrayBuffer.isView(data)) {
|
|
@@ -11,6 +19,14 @@ export function getFirstCharacters(data, length = 5): string {
|
|
|
11
19
|
return '';
|
|
12
20
|
}
|
|
13
21
|
|
|
22
|
+
/**
|
|
23
|
+
* Gets a magic string from a "file"
|
|
24
|
+
* Typically used to check or detect file format
|
|
25
|
+
* @param arrayBuffer
|
|
26
|
+
* @param byteOffset
|
|
27
|
+
* @param length
|
|
28
|
+
* @returns
|
|
29
|
+
*/
|
|
14
30
|
export function getMagicString(
|
|
15
31
|
arrayBuffer: ArrayBuffer,
|
|
16
32
|
byteOffset: number,
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
// loaders.gl, MIT license
|
|
2
|
+
|
|
3
|
+
import * as node from '../node/buffer';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Check for Node.js `Buffer` (without triggering bundler to include Buffer polyfill on browser)
|
|
7
|
+
*/
|
|
8
|
+
export function isBuffer(value: any): boolean {
|
|
9
|
+
return value && typeof value === 'object' && value.isBuffer;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Converts to Node.js `Buffer` (without triggering bundler to include Buffer polyfill on browser)
|
|
14
|
+
* @todo better data type
|
|
15
|
+
*/
|
|
16
|
+
export function toBuffer(data: any): Buffer {
|
|
17
|
+
return node.toBuffer ? node.toBuffer(data) : data;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* Convert an object to an array buffer
|
|
22
|
+
*/
|
|
23
|
+
export function toArrayBuffer(data: unknown): ArrayBuffer {
|
|
24
|
+
// Note: Should be called first, Buffers can trigger other detections below
|
|
25
|
+
if (isBuffer(data)) {
|
|
26
|
+
return node.toArrayBuffer(data);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
if (data instanceof ArrayBuffer) {
|
|
30
|
+
return data;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
// Careful - Node Buffers look like Uint8Arrays (keep after isBuffer)
|
|
34
|
+
if (ArrayBuffer.isView(data)) {
|
|
35
|
+
if (data.byteOffset === 0 && data.byteLength === data.buffer.byteLength) {
|
|
36
|
+
return data.buffer;
|
|
37
|
+
}
|
|
38
|
+
return data.buffer.slice(data.byteOffset, data.byteOffset + data.byteLength);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
if (typeof data === 'string') {
|
|
42
|
+
const text = data;
|
|
43
|
+
const uint8Array = new TextEncoder().encode(text);
|
|
44
|
+
return uint8Array.buffer;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// HACK to support Blob polyfill
|
|
48
|
+
if (data && typeof data === 'object' && (data as any)._toArrayBuffer) {
|
|
49
|
+
return (data as any)._toArrayBuffer();
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
throw new Error('toArrayBuffer');
|
|
53
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
// loaders.gl, MIT license
|
|
2
|
+
|
|
3
|
+
export type ReadableFile = {
|
|
4
|
+
read: (position: number, length: number) => Promise<Buffer>;
|
|
5
|
+
close: () => Promise<void>;
|
|
6
|
+
/** Length of file in bytes */
|
|
7
|
+
size: number;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
/** Helper function to create an envelope reader for a binary memory input */
|
|
11
|
+
export function makeReadableFile(data: Blob | ArrayBuffer): ReadableFile {
|
|
12
|
+
if (data instanceof ArrayBuffer) {
|
|
13
|
+
const arrayBuffer: ArrayBuffer = data;
|
|
14
|
+
return {
|
|
15
|
+
read: async (start: number, length: number) => Buffer.from(data, start, length),
|
|
16
|
+
close: async () => {},
|
|
17
|
+
size: arrayBuffer.byteLength
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const blob: Blob = data;
|
|
22
|
+
return {
|
|
23
|
+
read: async (start: number, length: number) => {
|
|
24
|
+
const arrayBuffer = await blob.slice(start, start + length).arrayBuffer();
|
|
25
|
+
return Buffer.from(arrayBuffer);
|
|
26
|
+
},
|
|
27
|
+
close: async () => {},
|
|
28
|
+
size: blob.size
|
|
29
|
+
};
|
|
30
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
// Forked from https://github.com/kbajalc/parquets under MIT license (Copyright (c) 2017 ironSource Ltd.)
|
|
2
|
+
import {isBrowser} from '../env-utils/globals';
|
|
3
|
+
import * as fs from '../node/fs';
|
|
4
|
+
import type {Writable} from 'stream';
|
|
5
|
+
|
|
6
|
+
export type WritableFile = {
|
|
7
|
+
write: (buf: Buffer) => Promise<void>;
|
|
8
|
+
close: () => Promise<void>;
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export interface WriteStreamOptions {
|
|
12
|
+
flags?: string;
|
|
13
|
+
encoding?: 'utf8';
|
|
14
|
+
fd?: number;
|
|
15
|
+
mode?: number;
|
|
16
|
+
autoClose?: boolean;
|
|
17
|
+
start?: number;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
/** Helper function to create an envelope reader for a binary memory input */
|
|
21
|
+
export function makeWritableFile(
|
|
22
|
+
pathOrStream: string | Writable,
|
|
23
|
+
options?: WriteStreamOptions
|
|
24
|
+
): WritableFile {
|
|
25
|
+
if (isBrowser) {
|
|
26
|
+
return {
|
|
27
|
+
write: async () => {},
|
|
28
|
+
close: async () => {}
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
const outputStream: Writable =
|
|
33
|
+
typeof pathOrStream === 'string' ? fs.createWriteStream(pathOrStream, options) : pathOrStream;
|
|
34
|
+
return {
|
|
35
|
+
write: async (buffer: Buffer) =>
|
|
36
|
+
new Promise((resolve, reject) => {
|
|
37
|
+
outputStream.write(buffer, (err) => (err ? reject(err) : resolve()));
|
|
38
|
+
}),
|
|
39
|
+
close: () =>
|
|
40
|
+
new Promise((resolve, reject) => {
|
|
41
|
+
(outputStream as any).close((err) => (err ? reject(err) : resolve()));
|
|
42
|
+
})
|
|
43
|
+
};
|
|
44
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
// loaders.gl, MIT license
|
|
2
|
+
|
|
3
|
+
// Isolates Buffer references to ensure they are only bundled under Node.js (avoids big webpack polyfill)
|
|
4
|
+
// this file is selected by the package.json "browser" field).
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Convert Buffer to ArrayBuffer
|
|
8
|
+
* Converts Node.js `Buffer` to `ArrayBuffer` (without triggering bundler to include Buffer polyfill on browser)
|
|
9
|
+
* @todo better data type
|
|
10
|
+
*/
|
|
11
|
+
export function toArrayBuffer(buffer) {
|
|
12
|
+
return buffer;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Convert (copy) ArrayBuffer to Buffer
|
|
17
|
+
*/
|
|
18
|
+
export function toBuffer(binaryData: ArrayBuffer | ArrayBuffer | Buffer): Buffer {
|
|
19
|
+
throw new Error('Buffer not supported in browser');
|
|
20
|
+
}
|
package/src/lib/node/buffer.ts
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
|
-
//
|
|
2
|
-
// this file is not visible to webpack (it is excluded in the package.json "browser" field).
|
|
1
|
+
// loaders.gl, MIT license
|
|
3
2
|
|
|
4
|
-
|
|
3
|
+
// Isolates Buffer references to ensure they are only bundled under Node.js (avoids big webpack polyfill)
|
|
4
|
+
// this file is selected by the package.json "browser" field).
|
|
5
5
|
|
|
6
6
|
/**
|
|
7
7
|
* Convert Buffer to ArrayBuffer
|
|
8
|
+
* Converts Node.js `Buffer` to `ArrayBuffer` (without triggering bundler to include Buffer polyfill on browser)
|
|
9
|
+
* @todo better data type
|
|
8
10
|
*/
|
|
9
11
|
export function toArrayBuffer(buffer) {
|
|
10
12
|
// TODO - per docs we should just be able to call buffer.buffer, but there are issues
|
|
@@ -18,19 +20,18 @@ export function toArrayBuffer(buffer) {
|
|
|
18
20
|
/**
|
|
19
21
|
* Convert (copy) ArrayBuffer to Buffer
|
|
20
22
|
*/
|
|
21
|
-
export function toBuffer(binaryData) {
|
|
23
|
+
export function toBuffer(binaryData: ArrayBuffer | ArrayBuffer | Buffer): Buffer {
|
|
24
|
+
if (Buffer.isBuffer(binaryData)) {
|
|
25
|
+
return binaryData;
|
|
26
|
+
}
|
|
27
|
+
|
|
22
28
|
if (ArrayBuffer.isView(binaryData)) {
|
|
23
29
|
binaryData = binaryData.buffer;
|
|
24
30
|
}
|
|
25
31
|
|
|
26
32
|
if (typeof Buffer !== 'undefined' && binaryData instanceof ArrayBuffer) {
|
|
27
|
-
|
|
28
|
-
const view = new Uint8Array(binaryData);
|
|
29
|
-
for (let i = 0; i < buffer.length; ++i) {
|
|
30
|
-
buffer[i] = view[i];
|
|
31
|
-
}
|
|
32
|
-
return buffer;
|
|
33
|
+
return Buffer.from(binaryData);
|
|
33
34
|
}
|
|
34
35
|
|
|
35
|
-
|
|
36
|
+
throw new Error('toBuffer');
|
|
36
37
|
}
|
package/src/lib/node/fs.ts
CHANGED
|
@@ -1,38 +1,73 @@
|
|
|
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';
|
|
7
|
-
|
|
8
|
-
// paths
|
|
6
|
+
export type {Stats, WriteStream} from 'fs';
|
|
9
7
|
|
|
8
|
+
export let readdir;
|
|
10
9
|
/** Wrapper for Node.js fs method */
|
|
11
|
-
export
|
|
12
|
-
/** Wrapper for Node.js fs method */
|
|
13
|
-
export const stat = promisify(fs.stat);
|
|
10
|
+
export let stat;
|
|
14
11
|
|
|
15
12
|
/** Wrapper for Node.js fs method */
|
|
16
|
-
export
|
|
13
|
+
export let readFile;
|
|
17
14
|
/** Wrapper for Node.js fs method */
|
|
18
|
-
export
|
|
15
|
+
export let readFileSync;
|
|
19
16
|
/** Wrapper for Node.js fs method */
|
|
20
|
-
export
|
|
17
|
+
export let writeFile;
|
|
21
18
|
/** Wrapper for Node.js fs method */
|
|
22
|
-
export
|
|
19
|
+
export let writeFileSync;
|
|
23
20
|
|
|
24
21
|
// file descriptors
|
|
25
22
|
|
|
26
23
|
/** Wrapper for Node.js fs method */
|
|
27
|
-
export
|
|
24
|
+
export let open;
|
|
28
25
|
/** Wrapper for Node.js fs method */
|
|
29
|
-
export
|
|
26
|
+
export let close: (fd: number) => Promise<void>;
|
|
30
27
|
/** Wrapper for Node.js fs method */
|
|
31
|
-
export
|
|
28
|
+
export let read;
|
|
32
29
|
/** Wrapper for Node.js fs method */
|
|
33
|
-
export
|
|
30
|
+
export let fstat;
|
|
31
|
+
|
|
32
|
+
export let createWriteStream: typeof fs.createWriteStream;
|
|
33
|
+
|
|
34
|
+
export let isSupported = Boolean(fs);
|
|
35
|
+
|
|
36
|
+
// paths
|
|
34
37
|
|
|
35
|
-
|
|
38
|
+
try {
|
|
39
|
+
/** Wrapper for Node.js fs method */
|
|
40
|
+
readdir = promisify2(fs.readdir);
|
|
41
|
+
/** Wrapper for Node.js fs method */
|
|
42
|
+
stat = promisify2(fs.stat);
|
|
43
|
+
|
|
44
|
+
/** Wrapper for Node.js fs method */
|
|
45
|
+
readFile = fs.readFile;
|
|
46
|
+
/** Wrapper for Node.js fs method */
|
|
47
|
+
readFileSync = fs.readFileSync;
|
|
48
|
+
/** Wrapper for Node.js fs method */
|
|
49
|
+
writeFile = promisify3(fs.writeFile);
|
|
50
|
+
/** Wrapper for Node.js fs method */
|
|
51
|
+
writeFileSync = fs.writeFileSync;
|
|
52
|
+
|
|
53
|
+
// file descriptors
|
|
54
|
+
|
|
55
|
+
/** Wrapper for Node.js fs method */
|
|
56
|
+
open = fs.open;
|
|
57
|
+
/** Wrapper for Node.js fs method */
|
|
58
|
+
close = (fd: number) =>
|
|
59
|
+
new Promise((resolve, reject) => fs.close(fd, (err) => (err ? reject(err) : resolve())));
|
|
60
|
+
/** Wrapper for Node.js fs method */
|
|
61
|
+
read = fs.read;
|
|
62
|
+
/** Wrapper for Node.js fs method */
|
|
63
|
+
fstat = fs.fstat;
|
|
64
|
+
|
|
65
|
+
createWriteStream = fs.createWriteStream;
|
|
66
|
+
|
|
67
|
+
isSupported = Boolean(fs);
|
|
68
|
+
} catch {
|
|
69
|
+
// ignore
|
|
70
|
+
}
|
|
36
71
|
|
|
37
72
|
export async function _readToArrayBuffer(fd: number, start: number, length: number) {
|
|
38
73
|
const buffer = Buffer.alloc(length);
|
|
@@ -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
|
+
}
|