@loaders.gl/loader-utils 3.4.0-alpha.1 → 3.4.0-alpha.2
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 +43 -22
- package/dist/es5/index.js.map +1 -1
- package/dist/es5/json-loader.js +1 -1
- package/dist/es5/lib/binary-utils/array-buffer-utils.js +0 -30
- package/dist/es5/lib/binary-utils/array-buffer-utils.js.map +1 -1
- package/dist/es5/lib/binary-utils/{binary-copy-utils.js → dataview-copy-utils.js} +33 -1
- package/dist/es5/lib/binary-utils/dataview-copy-utils.js.map +1 -0
- package/dist/es5/lib/binary-utils/get-first-characters.js +2 -0
- package/dist/es5/lib/binary-utils/get-first-characters.js.map +1 -1
- package/dist/es5/lib/binary-utils/{buffer-utils.js → memory-conversion-utils.js} +26 -7
- package/dist/es5/lib/binary-utils/memory-conversion-utils.js.map +1 -0
- package/dist/es5/lib/filesystems/readable-file.js +100 -0
- package/dist/es5/lib/filesystems/readable-file.js.map +1 -0
- package/dist/es5/lib/filesystems/writable-file.js +89 -0
- package/dist/es5/lib/filesystems/writable-file.js.map +1 -0
- package/dist/es5/lib/node/buffer.browser.js +16 -0
- package/dist/es5/lib/node/buffer.browser.js.map +1 -0
- package/dist/es5/lib/node/buffer.js +5 -8
- package/dist/es5/lib/node/buffer.js.map +1 -1
- package/dist/es5/lib/node/fs.js +19 -10
- package/dist/es5/lib/node/fs.js.map +1 -1
- package/dist/es5/lib/node/promisify.js +37 -0
- package/dist/es5/lib/node/promisify.js.map +1 -0
- package/dist/es5/lib/node/stream.js +20 -0
- package/dist/es5/lib/node/stream.js.map +1 -0
- package/dist/es5/lib/option-utils/merge-loader-options.js +29 -0
- package/dist/es5/lib/option-utils/merge-loader-options.js.map +1 -0
- package/dist/es5/types.js.map +1 -1
- package/dist/esm/index.js +12 -9
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/json-loader.js +1 -1
- package/dist/esm/lib/binary-utils/array-buffer-utils.js +0 -27
- package/dist/esm/lib/binary-utils/array-buffer-utils.js.map +1 -1
- package/dist/esm/lib/binary-utils/{binary-copy-utils.js → dataview-copy-utils.js} +31 -1
- package/dist/esm/lib/binary-utils/dataview-copy-utils.js.map +1 -0
- package/dist/esm/lib/binary-utils/get-first-characters.js +3 -0
- package/dist/esm/lib/binary-utils/get-first-characters.js.map +1 -1
- package/dist/esm/lib/binary-utils/memory-conversion-utils.js +38 -0
- package/dist/esm/lib/binary-utils/memory-conversion-utils.js.map +1 -0
- package/dist/esm/lib/filesystems/readable-file.js +22 -0
- package/dist/esm/lib/filesystems/readable-file.js.map +1 -0
- package/dist/esm/lib/filesystems/writable-file.js +21 -0
- package/dist/esm/lib/filesystems/writable-file.js.map +1 -0
- package/dist/esm/lib/node/buffer.browser.js +10 -0
- package/dist/esm/lib/node/buffer.browser.js.map +1 -0
- package/dist/esm/lib/node/buffer.js +5 -9
- package/dist/esm/lib/node/buffer.js.map +1 -1
- package/dist/esm/lib/node/fs.js +11 -9
- package/dist/esm/lib/node/fs.js.map +1 -1
- package/dist/esm/lib/node/promisify.js +12 -0
- package/dist/esm/lib/node/promisify.js.map +1 -0
- package/dist/esm/lib/node/stream.js +11 -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/types.js.map +1 -1
- package/dist/index.d.ts +11 -7
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +28 -23
- 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 +5 -36
- 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/{binary-copy-utils.js → dataview-copy-utils.js} +51 -5
- 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 +15 -0
- 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/{buffer-utils.js → memory-conversion-utils.js} +28 -9
- 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/{node/util.js → filesystems/writable-file.js} +23 -4
- 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 +10 -10
- 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 +11 -10
- 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 +24 -0
- package/dist/types.d.ts +19 -19
- package/dist/types.d.ts.map +1 -1
- package/package.json +10 -17
- package/src/index.ts +24 -18
- 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 +25 -0
- package/src/types.ts +19 -19
- package/dist/es5/lib/binary-utils/binary-copy-utils.js.map +0 -1
- package/dist/es5/lib/binary-utils/buffer-utils.js.map +0 -1
- package/dist/es5/lib/binary-utils/encode-utils.js +0 -36
- package/dist/es5/lib/binary-utils/encode-utils.js.map +0 -1
- package/dist/es5/lib/node/util.js +0 -13
- package/dist/es5/lib/node/util.js.map +0 -1
- package/dist/esm/lib/binary-utils/binary-copy-utils.js.map +0 -1
- package/dist/esm/lib/binary-utils/buffer-utils.js +0 -18
- package/dist/esm/lib/binary-utils/buffer-utils.js.map +0 -1
- package/dist/esm/lib/binary-utils/encode-utils.js +0 -29
- package/dist/esm/lib/binary-utils/encode-utils.js.map +0 -1
- package/dist/esm/lib/node/util.js +0 -4
- package/dist/esm/lib/node/util.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/buffer-utils.d.ts.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 -35
- package/dist/lib/node/util.d.ts +0 -5
- package/dist/lib/node/util.d.ts.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,42 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.sliceArrayBuffer = exports.concatenateTypedArrays = exports.concatenateArrayBuffers = exports.compareArrayBuffers =
|
|
4
|
-
const buffer_utils_1 = require("./buffer-utils");
|
|
5
|
-
/**
|
|
6
|
-
* Convert an object to an array buffer
|
|
7
|
-
*/
|
|
8
|
-
function toArrayBuffer(data) {
|
|
9
|
-
// Note: Should be called first, Buffers can trigger other detections below
|
|
10
|
-
if ((0, buffer_utils_1.isBuffer)(data)) {
|
|
11
|
-
return (0, buffer_utils_1.bufferToArrayBuffer)(data);
|
|
12
|
-
}
|
|
13
|
-
if (data instanceof ArrayBuffer) {
|
|
14
|
-
return data;
|
|
15
|
-
}
|
|
16
|
-
// Careful - Node Buffers look like Uint8Arrays (keep after isBuffer)
|
|
17
|
-
if (ArrayBuffer.isView(data)) {
|
|
18
|
-
if (data.byteOffset === 0 && data.byteLength === data.buffer.byteLength) {
|
|
19
|
-
return data.buffer;
|
|
20
|
-
}
|
|
21
|
-
return data.buffer.slice(data.byteOffset, data.byteOffset + data.byteLength);
|
|
22
|
-
}
|
|
23
|
-
if (typeof data === 'string') {
|
|
24
|
-
const text = data;
|
|
25
|
-
const uint8Array = new TextEncoder().encode(text);
|
|
26
|
-
return uint8Array.buffer;
|
|
27
|
-
}
|
|
28
|
-
// HACK to support Blob polyfill
|
|
29
|
-
if (data && typeof data === 'object' && data._toArrayBuffer) {
|
|
30
|
-
return data._toArrayBuffer();
|
|
31
|
-
}
|
|
32
|
-
throw new Error('toArrayBuffer');
|
|
33
|
-
}
|
|
34
|
-
exports.toArrayBuffer = toArrayBuffer;
|
|
3
|
+
exports.sliceArrayBuffer = exports.concatenateTypedArrays = exports.concatenateArrayBuffers = exports.compareArrayBuffers = void 0;
|
|
35
4
|
/**
|
|
36
5
|
* compare two binary arrays for equality
|
|
37
|
-
* @param
|
|
38
|
-
* @param
|
|
39
|
-
* @param
|
|
6
|
+
* @param a
|
|
7
|
+
* @param b
|
|
8
|
+
* @param byteLength
|
|
40
9
|
*/
|
|
41
10
|
function compareArrayBuffers(arrayBuffer1, arrayBuffer2, byteLength) {
|
|
42
11
|
byteLength = byteLength || arrayBuffer1.byteLength;
|
|
@@ -77,7 +46,7 @@ exports.concatenateArrayBuffers = concatenateArrayBuffers;
|
|
|
77
46
|
/**
|
|
78
47
|
* Concatenate arbitrary count of typed arrays
|
|
79
48
|
* https://developer.mozilla.org/en-US/docs/Web/JavaScript/Typed_arrays
|
|
80
|
-
* @param
|
|
49
|
+
* @param - list of arrays. All arrays should be the same type
|
|
81
50
|
* @return A concatenated TypedArray
|
|
82
51
|
*/
|
|
83
52
|
function concatenateTypedArrays(...typedArrays) {
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { TypedArray } from '../../types';
|
|
2
|
+
/**
|
|
3
|
+
* Helper function that pads a string with spaces to fit a certain byte alignment
|
|
4
|
+
* @param string
|
|
5
|
+
* @param byteAlignment
|
|
6
|
+
* @returns
|
|
7
|
+
*
|
|
8
|
+
* @todo PERFORMANCE IDEA: No need to copy string twice...
|
|
9
|
+
*/
|
|
10
|
+
export declare function padStringToByteAlignment(string: string, byteAlignment: number): string;
|
|
11
|
+
/**
|
|
12
|
+
*
|
|
13
|
+
* @param dataView
|
|
14
|
+
* @param byteOffset
|
|
15
|
+
* @param string
|
|
16
|
+
* @param byteLength
|
|
17
|
+
* @returns
|
|
18
|
+
*/
|
|
19
|
+
export declare function copyStringToDataView(dataView: DataView, byteOffset: number, string: string, byteLength: number): number;
|
|
20
|
+
export declare function copyBinaryToDataView(dataView: any, byteOffset: any, binary: any, byteLength: any): any;
|
|
21
|
+
/**
|
|
22
|
+
* Copy sourceBuffer to dataView with some padding
|
|
23
|
+
*
|
|
24
|
+
* @param dataView - destination data container. If null - only new offset is calculated
|
|
25
|
+
* @param byteOffset - destination byte offset to copy to
|
|
26
|
+
* @param sourceBuffer - source data buffer
|
|
27
|
+
* @param padding - pad the resulting array to multiple of "padding" bytes. Additional bytes are filled with 0x20 (ASCII space)
|
|
28
|
+
*
|
|
29
|
+
* @return new byteOffset of resulting dataView
|
|
30
|
+
*/
|
|
31
|
+
export declare function copyPaddedArrayBufferToDataView(dataView: DataView | null, byteOffset: number, sourceBuffer: TypedArray, padding: number): number;
|
|
32
|
+
/**
|
|
33
|
+
* Copy string to dataView with some padding
|
|
34
|
+
*
|
|
35
|
+
* @param {DataView | null} dataView - destination data container. If null - only new offset is calculated
|
|
36
|
+
* @param {number} byteOffset - destination byte offset to copy to
|
|
37
|
+
* @param {string} string - source string
|
|
38
|
+
* @param {number} padding - pad the resulting array to multiple of "padding" bytes. Additional bytes are filled with 0x20 (ASCII space)
|
|
39
|
+
*
|
|
40
|
+
* @return new byteOffset of resulting dataView
|
|
41
|
+
*/
|
|
42
|
+
export declare function copyPaddedStringToDataView(dataView: DataView | null, byteOffset: number, string: string, padding: number): number;
|
|
43
|
+
//# sourceMappingURL=dataview-copy-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dataview-copy-utils.d.ts","sourceRoot":"","sources":["../../../src/lib/binary-utils/dataview-copy-utils.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,UAAU,EAAC,MAAM,aAAa,CAAC;AAGvC;;;;;;;GAOG;AACH,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,MAAM,CAStF;AAED;;;;;;;GAOG;AACH,wBAAgB,oBAAoB,CAClC,QAAQ,EAAE,QAAQ,EAClB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,MAAM,GACjB,MAAM,CAOR;AAED,wBAAgB,oBAAoB,CAAC,QAAQ,KAAA,EAAE,UAAU,KAAA,EAAE,MAAM,KAAA,EAAE,UAAU,KAAA,OAO5E;AAED;;;;;;;;;GASG;AACH,wBAAgB,+BAA+B,CAC7C,QAAQ,EAAE,QAAQ,GAAG,IAAI,EACzB,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,UAAU,EACxB,OAAO,EAAE,MAAM,GACd,MAAM,CAsBR;AAED;;;;;;;;;GASG;AACH,wBAAgB,0BAA0B,CACxC,QAAQ,EAAE,QAAQ,GAAG,IAAI,EACzB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,GACd,MAAM,CASR"}
|
|
@@ -1,14 +1,60 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
// loaders./gl, MIT license
|
|
2
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.copyPaddedStringToDataView = exports.copyPaddedArrayBufferToDataView = void 0;
|
|
4
|
+
exports.copyPaddedStringToDataView = exports.copyPaddedArrayBufferToDataView = exports.copyBinaryToDataView = exports.copyStringToDataView = exports.padStringToByteAlignment = void 0;
|
|
4
5
|
const memory_copy_utils_1 = require("./memory-copy-utils");
|
|
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
|
+
function padStringToByteAlignment(string, byteAlignment) {
|
|
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
|
+
exports.padStringToByteAlignment = padStringToByteAlignment;
|
|
25
|
+
/**
|
|
26
|
+
*
|
|
27
|
+
* @param dataView
|
|
28
|
+
* @param byteOffset
|
|
29
|
+
* @param string
|
|
30
|
+
* @param byteLength
|
|
31
|
+
* @returns
|
|
32
|
+
*/
|
|
33
|
+
function copyStringToDataView(dataView, byteOffset, string, byteLength) {
|
|
34
|
+
if (dataView) {
|
|
35
|
+
for (let i = 0; i < byteLength; i++) {
|
|
36
|
+
dataView.setUint8(byteOffset + i, string.charCodeAt(i));
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return byteOffset + byteLength;
|
|
40
|
+
}
|
|
41
|
+
exports.copyStringToDataView = copyStringToDataView;
|
|
42
|
+
function copyBinaryToDataView(dataView, byteOffset, binary, byteLength) {
|
|
43
|
+
if (dataView) {
|
|
44
|
+
for (let i = 0; i < byteLength; i++) {
|
|
45
|
+
dataView.setUint8(byteOffset + i, binary[i]);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return byteOffset + byteLength;
|
|
49
|
+
}
|
|
50
|
+
exports.copyBinaryToDataView = copyBinaryToDataView;
|
|
5
51
|
/**
|
|
6
52
|
* Copy sourceBuffer to dataView with some padding
|
|
7
53
|
*
|
|
8
|
-
* @param
|
|
9
|
-
* @param
|
|
10
|
-
* @param
|
|
11
|
-
* @param
|
|
54
|
+
* @param dataView - destination data container. If null - only new offset is calculated
|
|
55
|
+
* @param byteOffset - destination byte offset to copy to
|
|
56
|
+
* @param sourceBuffer - source data buffer
|
|
57
|
+
* @param padding - pad the resulting array to multiple of "padding" bytes. Additional bytes are filled with 0x20 (ASCII space)
|
|
12
58
|
*
|
|
13
59
|
* @return new byteOffset of resulting dataView
|
|
14
60
|
*/
|
|
@@ -1,3 +1,17 @@
|
|
|
1
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Get the first characters from a binary file (interpret the first bytes as an ASCII string)
|
|
3
|
+
* @param data
|
|
4
|
+
* @param length
|
|
5
|
+
* @returns
|
|
6
|
+
*/
|
|
7
|
+
export declare function getFirstCharacters(data: string | ArrayBuffer, length?: number): string;
|
|
8
|
+
/**
|
|
9
|
+
* Gets a magic string from a "file"
|
|
10
|
+
* Typically used to check or detect file format
|
|
11
|
+
* @param arrayBuffer
|
|
12
|
+
* @param byteOffset
|
|
13
|
+
* @param length
|
|
14
|
+
* @returns
|
|
15
|
+
*/
|
|
2
16
|
export declare function getMagicString(arrayBuffer: ArrayBuffer, byteOffset: number, length: number): string;
|
|
3
17
|
//# sourceMappingURL=get-first-characters.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-first-characters.d.ts","sourceRoot":"","sources":["../../../src/lib/binary-utils/get-first-characters.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"get-first-characters.d.ts","sourceRoot":"","sources":["../../../src/lib/binary-utils/get-first-characters.ts"],"names":[],"mappings":"AAEA;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,EAAE,MAAM,GAAE,MAAU,GAAG,MAAM,CAWzF;AAED;;;;;;;GAOG;AACH,wBAAgB,cAAc,CAC5B,WAAW,EAAE,WAAW,EACxB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,GACb,MAAM,CAUR"}
|
|
@@ -1,6 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
// loaders.gl, MIT license
|
|
2
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
4
|
exports.getMagicString = exports.getFirstCharacters = void 0;
|
|
5
|
+
/**
|
|
6
|
+
* Get the first characters from a binary file (interpret the first bytes as an ASCII string)
|
|
7
|
+
* @param data
|
|
8
|
+
* @param length
|
|
9
|
+
* @returns
|
|
10
|
+
*/
|
|
4
11
|
function getFirstCharacters(data, length = 5) {
|
|
5
12
|
if (typeof data === 'string') {
|
|
6
13
|
return data.slice(0, length);
|
|
@@ -16,6 +23,14 @@ function getFirstCharacters(data, length = 5) {
|
|
|
16
23
|
return '';
|
|
17
24
|
}
|
|
18
25
|
exports.getFirstCharacters = getFirstCharacters;
|
|
26
|
+
/**
|
|
27
|
+
* Gets a magic string from a "file"
|
|
28
|
+
* Typically used to check or detect file format
|
|
29
|
+
* @param arrayBuffer
|
|
30
|
+
* @param byteOffset
|
|
31
|
+
* @param length
|
|
32
|
+
* @returns
|
|
33
|
+
*/
|
|
19
34
|
function getMagicString(arrayBuffer, byteOffset, length) {
|
|
20
35
|
if (arrayBuffer.byteLength <= byteOffset + length) {
|
|
21
36
|
return '';
|
|
@@ -9,8 +9,7 @@ export declare function isBuffer(value: any): boolean;
|
|
|
9
9
|
*/
|
|
10
10
|
export declare function toBuffer(data: any): Buffer;
|
|
11
11
|
/**
|
|
12
|
-
*
|
|
13
|
-
* @todo better data type
|
|
12
|
+
* Convert an object to an array buffer
|
|
14
13
|
*/
|
|
15
|
-
export declare function
|
|
16
|
-
//# sourceMappingURL=
|
|
14
|
+
export declare function toArrayBuffer(data: unknown): ArrayBuffer;
|
|
15
|
+
//# sourceMappingURL=memory-conversion-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory-conversion-utils.d.ts","sourceRoot":"","sources":["../../../src/lib/binary-utils/memory-conversion-utils.ts"],"names":[],"mappings":";AAIA;;GAEG;AACH,wBAAgB,QAAQ,CAAC,KAAK,EAAE,GAAG,GAAG,OAAO,CAE5C;AAED;;;GAGG;AACH,wBAAgB,QAAQ,CAAC,IAAI,EAAE,GAAG,GAAG,MAAM,CAE1C;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,OAAO,GAAG,WAAW,CA8BxD"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
// loaders.gl, MIT license
|
|
2
3
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
4
|
if (k2 === undefined) k2 = k;
|
|
4
5
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
@@ -23,7 +24,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
23
24
|
return result;
|
|
24
25
|
};
|
|
25
26
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.
|
|
27
|
+
exports.toArrayBuffer = exports.toBuffer = exports.isBuffer = void 0;
|
|
27
28
|
const node = __importStar(require("../node/buffer"));
|
|
28
29
|
/**
|
|
29
30
|
* Check for Node.js `Buffer` (without triggering bundler to include Buffer polyfill on browser)
|
|
@@ -41,14 +42,32 @@ function toBuffer(data) {
|
|
|
41
42
|
}
|
|
42
43
|
exports.toBuffer = toBuffer;
|
|
43
44
|
/**
|
|
44
|
-
*
|
|
45
|
-
* @todo better data type
|
|
45
|
+
* Convert an object to an array buffer
|
|
46
46
|
*/
|
|
47
|
-
function
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
return
|
|
47
|
+
function toArrayBuffer(data) {
|
|
48
|
+
// Note: Should be called first, Buffers can trigger other detections below
|
|
49
|
+
if (isBuffer(data)) {
|
|
50
|
+
return node.toArrayBuffer(data);
|
|
51
|
+
}
|
|
52
|
+
if (data instanceof ArrayBuffer) {
|
|
53
|
+
return data;
|
|
54
|
+
}
|
|
55
|
+
// Careful - Node Buffers look like Uint8Arrays (keep after isBuffer)
|
|
56
|
+
if (ArrayBuffer.isView(data)) {
|
|
57
|
+
if (data.byteOffset === 0 && data.byteLength === data.buffer.byteLength) {
|
|
58
|
+
return data.buffer;
|
|
59
|
+
}
|
|
60
|
+
return data.buffer.slice(data.byteOffset, data.byteOffset + data.byteLength);
|
|
61
|
+
}
|
|
62
|
+
if (typeof data === 'string') {
|
|
63
|
+
const text = data;
|
|
64
|
+
const uint8Array = new TextEncoder().encode(text);
|
|
65
|
+
return uint8Array.buffer;
|
|
66
|
+
}
|
|
67
|
+
// HACK to support Blob polyfill
|
|
68
|
+
if (data && typeof data === 'object' && data._toArrayBuffer) {
|
|
69
|
+
return data._toArrayBuffer();
|
|
51
70
|
}
|
|
52
|
-
|
|
71
|
+
throw new Error('toArrayBuffer');
|
|
53
72
|
}
|
|
54
|
-
exports.
|
|
73
|
+
exports.toArrayBuffer = toArrayBuffer;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
export type ReadableFile = {
|
|
3
|
+
read: (position: number, length: number) => Promise<Buffer>;
|
|
4
|
+
close: () => Promise<void>;
|
|
5
|
+
/** Length of file in bytes */
|
|
6
|
+
size: number;
|
|
7
|
+
};
|
|
8
|
+
/** Helper function to create an envelope reader for a binary memory input */
|
|
9
|
+
export declare function makeReadableFile(data: Blob | ArrayBuffer): ReadableFile;
|
|
10
|
+
//# sourceMappingURL=readable-file.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"readable-file.d.ts","sourceRoot":"","sources":["../../../src/lib/filesystems/readable-file.ts"],"names":[],"mappings":";AAEA,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IAC5D,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3B,8BAA8B;IAC9B,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,6EAA6E;AAC7E,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,IAAI,GAAG,WAAW,GAAG,YAAY,CAmBvE"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// loaders.gl, MIT license
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.makeReadableFile = void 0;
|
|
5
|
+
/** Helper function to create an envelope reader for a binary memory input */
|
|
6
|
+
function makeReadableFile(data) {
|
|
7
|
+
if (data instanceof ArrayBuffer) {
|
|
8
|
+
const arrayBuffer = data;
|
|
9
|
+
return {
|
|
10
|
+
read: async (start, length) => Buffer.from(data, start, length),
|
|
11
|
+
close: async () => { },
|
|
12
|
+
size: arrayBuffer.byteLength
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
const blob = data;
|
|
16
|
+
return {
|
|
17
|
+
read: async (start, length) => {
|
|
18
|
+
const arrayBuffer = await blob.slice(start, start + length).arrayBuffer();
|
|
19
|
+
return Buffer.from(arrayBuffer);
|
|
20
|
+
},
|
|
21
|
+
close: async () => { },
|
|
22
|
+
size: blob.size
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
exports.makeReadableFile = makeReadableFile;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
import type { Writable } from 'stream';
|
|
4
|
+
export type WritableFile = {
|
|
5
|
+
write: (buf: Buffer) => Promise<void>;
|
|
6
|
+
close: () => Promise<void>;
|
|
7
|
+
};
|
|
8
|
+
export interface WriteStreamOptions {
|
|
9
|
+
flags?: string;
|
|
10
|
+
encoding?: 'utf8';
|
|
11
|
+
fd?: number;
|
|
12
|
+
mode?: number;
|
|
13
|
+
autoClose?: boolean;
|
|
14
|
+
start?: number;
|
|
15
|
+
}
|
|
16
|
+
/** Helper function to create an envelope reader for a binary memory input */
|
|
17
|
+
export declare function makeWritableFile(pathOrStream: string | Writable, options?: WriteStreamOptions): WritableFile;
|
|
18
|
+
//# sourceMappingURL=writable-file.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"writable-file.d.ts","sourceRoot":"","sources":["../../../src/lib/filesystems/writable-file.ts"],"names":[],"mappings":";;AAGA,OAAO,KAAK,EAAC,QAAQ,EAAC,MAAM,QAAQ,CAAC;AAErC,MAAM,MAAM,YAAY,GAAG;IACzB,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACtC,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CAC5B,CAAC;AAEF,MAAM,WAAW,kBAAkB;IACjC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,6EAA6E;AAC7E,wBAAgB,gBAAgB,CAC9B,YAAY,EAAE,MAAM,GAAG,QAAQ,EAC/B,OAAO,CAAC,EAAE,kBAAkB,GAC3B,YAAY,CAoBd"}
|
|
@@ -23,7 +23,26 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
26
|
+
exports.makeWritableFile = void 0;
|
|
27
|
+
// Forked from https://github.com/kbajalc/parquets under MIT license (Copyright (c) 2017 ironSource Ltd.)
|
|
28
|
+
const globals_1 = require("../env-utils/globals");
|
|
29
|
+
const fs = __importStar(require("../node/fs"));
|
|
30
|
+
/** Helper function to create an envelope reader for a binary memory input */
|
|
31
|
+
function makeWritableFile(pathOrStream, options) {
|
|
32
|
+
if (globals_1.isBrowser) {
|
|
33
|
+
return {
|
|
34
|
+
write: async () => { },
|
|
35
|
+
close: async () => { }
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
const outputStream = typeof pathOrStream === 'string' ? fs.createWriteStream(pathOrStream, options) : pathOrStream;
|
|
39
|
+
return {
|
|
40
|
+
write: async (buffer) => new Promise((resolve, reject) => {
|
|
41
|
+
outputStream.write(buffer, (err) => (err ? reject(err) : resolve()));
|
|
42
|
+
}),
|
|
43
|
+
close: () => new Promise((resolve, reject) => {
|
|
44
|
+
outputStream.close((err) => (err ? reject(err) : resolve()));
|
|
45
|
+
})
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
exports.makeWritableFile = makeWritableFile;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/**
|
|
3
|
+
* Convert Buffer to ArrayBuffer
|
|
4
|
+
* Converts Node.js `Buffer` to `ArrayBuffer` (without triggering bundler to include Buffer polyfill on browser)
|
|
5
|
+
* @todo better data type
|
|
6
|
+
*/
|
|
7
|
+
export declare function toArrayBuffer(buffer: any): any;
|
|
8
|
+
/**
|
|
9
|
+
* Convert (copy) ArrayBuffer to Buffer
|
|
10
|
+
*/
|
|
11
|
+
export declare function toBuffer(binaryData: ArrayBuffer | ArrayBuffer | Buffer): Buffer;
|
|
12
|
+
//# sourceMappingURL=buffer.browser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buffer.browser.d.ts","sourceRoot":"","sources":["../../../src/lib/node/buffer.browser.ts"],"names":[],"mappings":";AAKA;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,MAAM,KAAA,OAEnC;AAED;;GAEG;AACH,wBAAgB,QAAQ,CAAC,UAAU,EAAE,WAAW,GAAG,WAAW,GAAG,MAAM,GAAG,MAAM,CAE/E"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// loaders.gl, MIT license
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.toBuffer = exports.toArrayBuffer = void 0;
|
|
5
|
+
// Isolates Buffer references to ensure they are only bundled under Node.js (avoids big webpack polyfill)
|
|
6
|
+
// this file is selected by the package.json "browser" field).
|
|
7
|
+
/**
|
|
8
|
+
* Convert Buffer to ArrayBuffer
|
|
9
|
+
* Converts Node.js `Buffer` to `ArrayBuffer` (without triggering bundler to include Buffer polyfill on browser)
|
|
10
|
+
* @todo better data type
|
|
11
|
+
*/
|
|
12
|
+
function toArrayBuffer(buffer) {
|
|
13
|
+
return buffer;
|
|
14
|
+
}
|
|
15
|
+
exports.toArrayBuffer = toArrayBuffer;
|
|
16
|
+
/**
|
|
17
|
+
* Convert (copy) ArrayBuffer to Buffer
|
|
18
|
+
*/
|
|
19
|
+
function toBuffer(binaryData) {
|
|
20
|
+
throw new Error('Buffer not supported in browser');
|
|
21
|
+
}
|
|
22
|
+
exports.toBuffer = toBuffer;
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
/**
|
|
3
3
|
* Convert Buffer to ArrayBuffer
|
|
4
|
+
* Converts Node.js `Buffer` to `ArrayBuffer` (without triggering bundler to include Buffer polyfill on browser)
|
|
5
|
+
* @todo better data type
|
|
4
6
|
*/
|
|
5
7
|
export declare function toArrayBuffer(buffer: any): any;
|
|
6
8
|
/**
|
|
7
9
|
* Convert (copy) ArrayBuffer to Buffer
|
|
8
10
|
*/
|
|
9
|
-
export declare function toBuffer(binaryData:
|
|
11
|
+
export declare function toBuffer(binaryData: ArrayBuffer | ArrayBuffer | Buffer): Buffer;
|
|
10
12
|
//# sourceMappingURL=buffer.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"buffer.d.ts","sourceRoot":"","sources":["../../../src/lib/node/buffer.ts"],"names":[],"mappings":";AAKA
|
|
1
|
+
{"version":3,"file":"buffer.d.ts","sourceRoot":"","sources":["../../../src/lib/node/buffer.ts"],"names":[],"mappings":";AAKA;;;;GAIG;AACH,wBAAgB,aAAa,CAAC,MAAM,KAAA,OAOnC;AAED;;GAEG;AACH,wBAAgB,QAAQ,CAAC,UAAU,EAAE,WAAW,GAAG,WAAW,GAAG,MAAM,GAAG,MAAM,CAc/E"}
|
package/dist/lib/node/buffer.js
CHANGED
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
//
|
|
3
|
-
// this file is not visible to webpack (it is excluded in the package.json "browser" field).
|
|
2
|
+
// loaders.gl, MIT license
|
|
4
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
4
|
exports.toBuffer = exports.toArrayBuffer = void 0;
|
|
6
|
-
|
|
5
|
+
// Isolates Buffer references to ensure they are only bundled under Node.js (avoids big webpack polyfill)
|
|
6
|
+
// this file is selected by the package.json "browser" field).
|
|
7
7
|
/**
|
|
8
8
|
* Convert Buffer to ArrayBuffer
|
|
9
|
+
* Converts Node.js `Buffer` to `ArrayBuffer` (without triggering bundler to include Buffer polyfill on browser)
|
|
10
|
+
* @todo better data type
|
|
9
11
|
*/
|
|
10
12
|
function toArrayBuffer(buffer) {
|
|
11
13
|
// TODO - per docs we should just be able to call buffer.buffer, but there are issues
|
|
@@ -20,17 +22,15 @@ exports.toArrayBuffer = toArrayBuffer;
|
|
|
20
22
|
* Convert (copy) ArrayBuffer to Buffer
|
|
21
23
|
*/
|
|
22
24
|
function toBuffer(binaryData) {
|
|
25
|
+
if (Buffer.isBuffer(binaryData)) {
|
|
26
|
+
return binaryData;
|
|
27
|
+
}
|
|
23
28
|
if (ArrayBuffer.isView(binaryData)) {
|
|
24
29
|
binaryData = binaryData.buffer;
|
|
25
30
|
}
|
|
26
31
|
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;
|
|
32
|
+
return Buffer.from(binaryData);
|
|
33
33
|
}
|
|
34
|
-
|
|
34
|
+
throw new Error('toBuffer');
|
|
35
35
|
}
|
|
36
36
|
exports.toBuffer = toBuffer;
|
package/dist/lib/node/fs.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
|
|
1
|
+
import fs from 'fs';
|
|
2
|
+
export type { Stats, WriteStream } from 'fs';
|
|
2
3
|
export declare let readdir: any;
|
|
3
4
|
/** Wrapper for Node.js fs method */
|
|
4
5
|
export declare let stat: any;
|
|
@@ -13,11 +14,12 @@ export declare let writeFileSync: any;
|
|
|
13
14
|
/** Wrapper for Node.js fs method */
|
|
14
15
|
export declare let open: any;
|
|
15
16
|
/** Wrapper for Node.js fs method */
|
|
16
|
-
export declare let close:
|
|
17
|
+
export declare let close: (fd: number) => Promise<void>;
|
|
17
18
|
/** Wrapper for Node.js fs method */
|
|
18
19
|
export declare let read: any;
|
|
19
20
|
/** Wrapper for Node.js fs method */
|
|
20
21
|
export declare let fstat: any;
|
|
22
|
+
export declare let createWriteStream: typeof fs.createWriteStream;
|
|
21
23
|
export declare let isSupported: boolean;
|
|
22
24
|
export declare function _readToArrayBuffer(fd: number, start: number, length: number): Promise<any>;
|
|
23
25
|
//# sourceMappingURL=fs.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fs.d.ts","sourceRoot":"","sources":["../../../src/lib/node/fs.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"fs.d.ts","sourceRoot":"","sources":["../../../src/lib/node/fs.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,IAAI,CAAC;AAIpB,YAAY,EAAC,KAAK,EAAE,WAAW,EAAC,MAAM,IAAI,CAAC;AAE3C,eAAO,IAAI,OAAO,KAAA,CAAC;AACnB,oCAAoC;AACpC,eAAO,IAAI,IAAI,KAAA,CAAC;AAEhB,oCAAoC;AACpC,eAAO,IAAI,QAAQ,KAAA,CAAC;AACpB,oCAAoC;AACpC,eAAO,IAAI,YAAY,KAAA,CAAC;AACxB,oCAAoC;AACpC,eAAO,IAAI,SAAS,KAAA,CAAC;AACrB,oCAAoC;AACpC,eAAO,IAAI,aAAa,KAAA,CAAC;AAIzB,oCAAoC;AACpC,eAAO,IAAI,IAAI,KAAA,CAAC;AAChB,oCAAoC;AACpC,eAAO,IAAI,KAAK,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AAChD,oCAAoC;AACpC,eAAO,IAAI,IAAI,KAAA,CAAC;AAChB,oCAAoC;AACpC,eAAO,IAAI,KAAK,KAAA,CAAC;AAEjB,eAAO,IAAI,iBAAiB,EAAE,OAAO,EAAE,CAAC,iBAAiB,CAAC;AAE1D,eAAO,IAAI,WAAW,SAAc,CAAC;AAsCrC,wBAAsB,kBAAkB,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,gBAOjF"}
|
package/dist/lib/node/fs.js
CHANGED
|
@@ -3,35 +3,36 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports._readToArrayBuffer = exports.isSupported = exports.fstat = exports.read = exports.close = exports.open = exports.writeFileSync = exports.writeFile = exports.readFileSync = exports.readFile = exports.stat = exports.readdir = void 0;
|
|
6
|
+
exports._readToArrayBuffer = exports.isSupported = exports.createWriteStream = exports.fstat = exports.read = exports.close = exports.open = exports.writeFileSync = exports.writeFile = exports.readFileSync = exports.readFile = exports.stat = exports.readdir = void 0;
|
|
7
7
|
// fs wrapper (promisified fs + avoids bundling fs in browsers)
|
|
8
8
|
const fs_1 = __importDefault(require("fs"));
|
|
9
9
|
const buffer_1 = require("./buffer");
|
|
10
|
-
const
|
|
10
|
+
const promisify_1 = require("./promisify");
|
|
11
11
|
exports.isSupported = Boolean(fs_1.default);
|
|
12
12
|
// paths
|
|
13
13
|
try {
|
|
14
14
|
/** Wrapper for Node.js fs method */
|
|
15
|
-
exports.readdir = (0,
|
|
15
|
+
exports.readdir = (0, promisify_1.promisify2)(fs_1.default.readdir);
|
|
16
16
|
/** Wrapper for Node.js fs method */
|
|
17
|
-
exports.stat = (0,
|
|
17
|
+
exports.stat = (0, promisify_1.promisify2)(fs_1.default.stat);
|
|
18
18
|
/** Wrapper for Node.js fs method */
|
|
19
|
-
exports.readFile =
|
|
19
|
+
exports.readFile = fs_1.default.readFile;
|
|
20
20
|
/** Wrapper for Node.js fs method */
|
|
21
21
|
exports.readFileSync = fs_1.default.readFileSync;
|
|
22
22
|
/** Wrapper for Node.js fs method */
|
|
23
|
-
exports.writeFile = (0,
|
|
23
|
+
exports.writeFile = (0, promisify_1.promisify3)(fs_1.default.writeFile);
|
|
24
24
|
/** Wrapper for Node.js fs method */
|
|
25
25
|
exports.writeFileSync = fs_1.default.writeFileSync;
|
|
26
26
|
// file descriptors
|
|
27
27
|
/** Wrapper for Node.js fs method */
|
|
28
|
-
exports.open =
|
|
28
|
+
exports.open = fs_1.default.open;
|
|
29
29
|
/** Wrapper for Node.js fs method */
|
|
30
|
-
exports.close = (
|
|
30
|
+
exports.close = (fd) => new Promise((resolve, reject) => fs_1.default.close(fd, (err) => (err ? reject(err) : resolve())));
|
|
31
31
|
/** Wrapper for Node.js fs method */
|
|
32
|
-
exports.read =
|
|
32
|
+
exports.read = fs_1.default.read;
|
|
33
33
|
/** Wrapper for Node.js fs method */
|
|
34
|
-
exports.fstat =
|
|
34
|
+
exports.fstat = fs_1.default.fstat;
|
|
35
|
+
exports.createWriteStream = fs_1.default.createWriteStream;
|
|
35
36
|
exports.isSupported = Boolean(fs_1.default);
|
|
36
37
|
}
|
|
37
38
|
catch {
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/** Wrapper for Node.js promisify */
|
|
2
|
+
type Callback<A> = (error: unknown, args: A) => void;
|
|
3
|
+
/**
|
|
4
|
+
* Typesafe promisify implementation
|
|
5
|
+
* @link https://dev.to/_gdelgado/implement-a-type-safe-version-of-node-s-promisify-in-7-lines-of-code-in-typescript-2j34
|
|
6
|
+
* @param fn
|
|
7
|
+
* @returns
|
|
8
|
+
*/
|
|
9
|
+
export declare function promisify1<T, A>(fn: (args: T, cb: Callback<A>) => void): (args: T) => Promise<A>;
|
|
10
|
+
export declare function promisify2<T1, T2, A>(fn: (arg1: T1, arg2: T2, cb: Callback<A>) => void): (arg1: T1, arg2: T2) => Promise<A>;
|
|
11
|
+
export declare function promisify3<T1, T2, T3, A>(fn: (arg1: T1, arg2: T2, arg3: T3, cb: Callback<A>) => void): (arg1: T1, arg2: T2, arg3: T3) => Promise<A>;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=promisify.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"promisify.d.ts","sourceRoot":"","sources":["../../../src/lib/node/promisify.ts"],"names":[],"mappings":"AAqCA,oCAAoC;AACpC,KAAK,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC;AAErD;;;;;GAKG;AACH,wBAAgB,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,IAAI,GAAG,CAAC,IAAI,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,CAKhG;AAED,wBAAgB,UAAU,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,EAClC,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,IAAI,GAChD,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,KAAK,OAAO,CAAC,CAAC,CAAC,CAKpC;AAED,wBAAgB,UAAU,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EACtC,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,IAAI,GAC1D,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,KAAK,OAAO,CAAC,CAAC,CAAC,CAK9C"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// @loaders.gl, MIT license
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.promisify3 = exports.promisify2 = exports.promisify1 = void 0;
|
|
5
|
+
/**
|
|
6
|
+
* Typesafe promisify implementation
|
|
7
|
+
* @link https://dev.to/_gdelgado/implement-a-type-safe-version-of-node-s-promisify-in-7-lines-of-code-in-typescript-2j34
|
|
8
|
+
* @param fn
|
|
9
|
+
* @returns
|
|
10
|
+
*/
|
|
11
|
+
function promisify1(fn) {
|
|
12
|
+
return (args) => new Promise((resolve, reject) => fn(args, (error, callbackArgs) => (error ? reject(error) : resolve(callbackArgs))));
|
|
13
|
+
}
|
|
14
|
+
exports.promisify1 = promisify1;
|
|
15
|
+
function promisify2(fn) {
|
|
16
|
+
return (arg1, arg2) => new Promise((resolve, reject) => fn(arg1, arg2, (error, callbackArgs) => (error ? reject(error) : resolve(callbackArgs))));
|
|
17
|
+
}
|
|
18
|
+
exports.promisify2 = promisify2;
|
|
19
|
+
function promisify3(fn) {
|
|
20
|
+
return (arg1, arg2, arg3) => new Promise((resolve, reject) => fn(arg1, arg2, arg3, (error, callbackArgs) => (error ? reject(error) : resolve(callbackArgs))));
|
|
21
|
+
}
|
|
22
|
+
exports.promisify3 = promisify3;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream.d.ts","sourceRoot":"","sources":["../../../src/lib/node/stream.ts"],"names":[],"mappings":"AAIA,YAAY,EAAC,QAAQ,EAAC,MAAM,QAAQ,CAAC;AAErC,eAAO,IAAI,SAAS,KAAA,CAAC;AAErB,eAAO,MAAM,WAAW,SAAkB,CAAC"}
|