@loaders.gl/loader-utils 4.0.0-alpha.9 → 4.0.0-beta.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.
Files changed (214) hide show
  1. package/dist/es5/index.js +63 -2
  2. package/dist/es5/index.js.map +1 -1
  3. package/dist/es5/json-loader.js +1 -1
  4. package/dist/es5/json-loader.js.map +1 -1
  5. package/dist/es5/lib/file-provider/data-view-file.js +146 -0
  6. package/dist/es5/lib/file-provider/data-view-file.js.map +1 -0
  7. package/dist/es5/lib/file-provider/file-handle-file.js +236 -0
  8. package/dist/es5/lib/file-provider/file-handle-file.js.map +1 -0
  9. package/dist/es5/lib/file-provider/file-handle.js +98 -0
  10. package/dist/es5/lib/file-provider/file-handle.js.map +1 -0
  11. package/dist/es5/lib/file-provider/file-provider.js +11 -0
  12. package/dist/es5/lib/file-provider/file-provider.js.map +1 -0
  13. package/dist/es5/lib/filesystems/filesystem.js +2 -0
  14. package/dist/es5/lib/filesystems/filesystem.js.map +1 -0
  15. package/dist/es5/lib/filesystems/node-filesystem.js +28 -62
  16. package/dist/es5/lib/filesystems/node-filesystem.js.map +1 -1
  17. package/dist/es5/lib/node/fs.browser.js +9 -0
  18. package/dist/es5/lib/node/fs.browser.js.map +1 -0
  19. package/dist/es5/lib/node/fs.js +28 -34
  20. package/dist/es5/lib/node/fs.js.map +1 -1
  21. package/dist/es5/lib/node/stream.browser.js +9 -0
  22. package/dist/es5/lib/node/stream.browser.js.map +1 -0
  23. package/dist/es5/lib/node/stream.js +6 -7
  24. package/dist/es5/lib/node/stream.js.map +1 -1
  25. package/dist/es5/lib/option-utils/merge-loader-options.js +1 -1
  26. package/dist/es5/lib/option-utils/merge-loader-options.js.map +1 -1
  27. package/dist/es5/lib/sources/data-source.js +67 -0
  28. package/dist/es5/lib/sources/data-source.js.map +1 -0
  29. package/dist/es5/lib/sources/image-source.js +31 -0
  30. package/dist/es5/lib/sources/image-source.js.map +1 -0
  31. package/dist/es5/lib/sources/image-tile-source.js +2 -0
  32. package/dist/es5/lib/sources/image-tile-source.js.map +1 -0
  33. package/dist/es5/lib/sources/tile-source.js +2 -0
  34. package/dist/es5/lib/sources/tile-source.js.map +1 -0
  35. package/dist/es5/lib/sources/utils/image-type.js +2 -0
  36. package/dist/es5/lib/sources/utils/image-type.js.map +1 -0
  37. package/dist/es5/lib/sources/utils/utils.js +36 -0
  38. package/dist/es5/lib/sources/utils/utils.js.map +1 -0
  39. package/dist/es5/lib/sources/vector-tile-source.js +2 -0
  40. package/dist/es5/lib/sources/vector-tile-source.js.map +1 -0
  41. package/dist/es5/lib/worker-loader-utils/create-loader-worker.js +2 -2
  42. package/dist/es5/lib/worker-loader-utils/create-loader-worker.js.map +1 -1
  43. package/dist/es5/lib/worker-loader-utils/encode-with-worker.js.map +1 -1
  44. package/dist/es5/lib/worker-loader-utils/parse-with-worker.js.map +1 -1
  45. package/dist/es5/loader-types.js +58 -0
  46. package/dist/es5/loader-types.js.map +1 -0
  47. package/dist/es5/service-types.js +2 -0
  48. package/dist/es5/service-types.js.map +1 -0
  49. package/dist/es5/types.js.map +1 -1
  50. package/dist/es5/writer-types.js +2 -0
  51. package/dist/es5/writer-types.js.map +1 -0
  52. package/dist/esm/index.js +8 -1
  53. package/dist/esm/index.js.map +1 -1
  54. package/dist/esm/json-loader.js +1 -1
  55. package/dist/esm/json-loader.js.map +1 -1
  56. package/dist/esm/lib/file-provider/data-view-file.js +33 -0
  57. package/dist/esm/lib/file-provider/data-view-file.js.map +1 -0
  58. package/dist/esm/lib/file-provider/file-handle-file.js +59 -0
  59. package/dist/esm/lib/file-provider/file-handle-file.js.map +1 -0
  60. package/dist/esm/lib/file-provider/file-handle.js +33 -0
  61. package/dist/esm/lib/file-provider/file-handle.js.map +1 -0
  62. package/dist/esm/lib/file-provider/file-provider.js +4 -0
  63. package/dist/esm/lib/file-provider/file-provider.js.map +1 -0
  64. package/dist/esm/lib/filesystems/filesystem.js +2 -0
  65. package/dist/esm/lib/filesystems/filesystem.js.map +1 -0
  66. package/dist/esm/lib/filesystems/node-filesystem.js +18 -25
  67. package/dist/esm/lib/filesystems/node-filesystem.js.map +1 -1
  68. package/dist/esm/lib/node/fs.browser.js +2 -0
  69. package/dist/esm/lib/node/fs.browser.js.map +1 -0
  70. package/dist/esm/lib/node/fs.js +16 -27
  71. package/dist/esm/lib/node/fs.js.map +1 -1
  72. package/dist/esm/lib/node/stream.browser.js +2 -0
  73. package/dist/esm/lib/node/stream.browser.js.map +1 -0
  74. package/dist/esm/lib/node/stream.js +2 -5
  75. package/dist/esm/lib/node/stream.js.map +1 -1
  76. package/dist/esm/lib/option-utils/merge-loader-options.js +1 -1
  77. package/dist/esm/lib/option-utils/merge-loader-options.js.map +1 -1
  78. package/dist/esm/lib/sources/data-source.js +43 -0
  79. package/dist/esm/lib/sources/data-source.js.map +1 -0
  80. package/dist/esm/lib/sources/image-source.js +6 -0
  81. package/dist/esm/lib/sources/image-source.js.map +1 -0
  82. package/dist/esm/lib/sources/image-tile-source.js +2 -0
  83. package/dist/esm/lib/sources/image-tile-source.js.map +1 -0
  84. package/dist/esm/lib/sources/tile-source.js +2 -0
  85. package/dist/esm/lib/sources/tile-source.js.map +1 -0
  86. package/dist/esm/lib/sources/utils/image-type.js +2 -0
  87. package/dist/esm/lib/sources/utils/image-type.js.map +1 -0
  88. package/dist/esm/lib/sources/utils/utils.js +21 -0
  89. package/dist/esm/lib/sources/utils/utils.js.map +1 -0
  90. package/dist/esm/lib/sources/vector-tile-source.js +2 -0
  91. package/dist/esm/lib/sources/vector-tile-source.js.map +1 -0
  92. package/dist/esm/lib/worker-loader-utils/create-loader-worker.js +2 -2
  93. package/dist/esm/lib/worker-loader-utils/create-loader-worker.js.map +1 -1
  94. package/dist/esm/lib/worker-loader-utils/encode-with-worker.js.map +1 -1
  95. package/dist/esm/lib/worker-loader-utils/parse-with-worker.js.map +1 -1
  96. package/dist/esm/loader-types.js +16 -0
  97. package/dist/esm/loader-types.js.map +1 -0
  98. package/dist/esm/service-types.js +2 -0
  99. package/dist/esm/service-types.js.map +1 -0
  100. package/dist/esm/types.js.map +1 -1
  101. package/dist/esm/writer-types.js +2 -0
  102. package/dist/esm/writer-types.js.map +1 -0
  103. package/dist/index.d.ts +22 -2
  104. package/dist/index.d.ts.map +1 -1
  105. package/dist/json-loader.d.ts +1 -1
  106. package/dist/json-loader.d.ts.map +1 -1
  107. package/dist/lib/file-provider/data-view-file.d.ts +37 -0
  108. package/dist/lib/file-provider/data-view-file.d.ts.map +1 -0
  109. package/dist/lib/file-provider/file-handle-file.d.ts +53 -0
  110. package/dist/lib/file-provider/file-handle-file.d.ts.map +1 -0
  111. package/dist/lib/file-provider/file-handle.d.ts +40 -0
  112. package/dist/lib/file-provider/file-handle.d.ts.map +1 -0
  113. package/dist/lib/file-provider/file-provider.d.ts +45 -0
  114. package/dist/lib/file-provider/file-provider.d.ts.map +1 -0
  115. package/dist/lib/filesystems/filesystem.d.ts +80 -0
  116. package/dist/lib/filesystems/filesystem.d.ts.map +1 -0
  117. package/dist/lib/filesystems/node-filesystem.d.ts +4 -4
  118. package/dist/lib/filesystems/node-filesystem.d.ts.map +1 -1
  119. package/dist/lib/node/fs.browser.d.ts +2 -0
  120. package/dist/lib/node/fs.browser.d.ts.map +1 -0
  121. package/dist/lib/node/fs.d.ts +19 -14
  122. package/dist/lib/node/fs.d.ts.map +1 -1
  123. package/dist/lib/node/stream.browser.d.ts +2 -0
  124. package/dist/lib/node/stream.browser.d.ts.map +1 -0
  125. package/dist/lib/node/stream.d.ts +4 -1
  126. package/dist/lib/node/stream.d.ts.map +1 -1
  127. package/dist/lib/option-utils/merge-loader-options.d.ts +1 -1
  128. package/dist/lib/option-utils/merge-loader-options.d.ts.map +1 -1
  129. package/dist/lib/sources/data-source.d.ts +33 -0
  130. package/dist/lib/sources/data-source.d.ts.map +1 -0
  131. package/dist/lib/sources/image-source.d.ts +81 -0
  132. package/dist/lib/sources/image-source.d.ts.map +1 -0
  133. package/dist/lib/sources/image-tile-source.d.ts +11 -0
  134. package/dist/lib/sources/image-tile-source.d.ts.map +1 -0
  135. package/dist/lib/sources/tile-source.d.ts +105 -0
  136. package/dist/lib/sources/tile-source.d.ts.map +1 -0
  137. package/dist/lib/sources/utils/image-type.d.ts +10 -0
  138. package/dist/lib/sources/utils/image-type.d.ts.map +1 -0
  139. package/dist/lib/sources/utils/utils.d.ts +13 -0
  140. package/dist/lib/sources/utils/utils.d.ts.map +1 -0
  141. package/dist/lib/sources/vector-tile-source.d.ts +10 -0
  142. package/dist/lib/sources/vector-tile-source.d.ts.map +1 -0
  143. package/dist/lib/worker-loader-utils/create-loader-worker.d.ts +1 -1
  144. package/dist/lib/worker-loader-utils/create-loader-worker.d.ts.map +1 -1
  145. package/dist/lib/worker-loader-utils/encode-with-worker.d.ts +1 -1
  146. package/dist/lib/worker-loader-utils/encode-with-worker.d.ts.map +1 -1
  147. package/dist/lib/worker-loader-utils/parse-with-worker.d.ts +2 -2
  148. package/dist/lib/worker-loader-utils/parse-with-worker.d.ts.map +1 -1
  149. package/dist/loader-types.d.ts +209 -0
  150. package/dist/loader-types.d.ts.map +1 -0
  151. package/dist/service-types.d.ts +10 -0
  152. package/dist/service-types.d.ts.map +1 -0
  153. package/dist/types.d.ts +1 -240
  154. package/dist/types.d.ts.map +1 -1
  155. package/dist/writer-types.d.ts +34 -0
  156. package/dist/writer-types.d.ts.map +1 -0
  157. package/package.json +9 -5
  158. package/src/index.ts +57 -17
  159. package/src/json-loader.ts +1 -1
  160. package/src/lib/file-provider/data-view-file.ts +72 -0
  161. package/src/lib/file-provider/file-handle-file.ts +116 -0
  162. package/src/lib/file-provider/file-handle.ts +79 -0
  163. package/src/lib/file-provider/file-provider.ts +56 -0
  164. package/src/lib/filesystems/filesystem.ts +87 -0
  165. package/src/lib/filesystems/node-filesystem.ts +19 -31
  166. package/src/lib/node/fs.browser.ts +1 -0
  167. package/src/lib/node/fs.ts +20 -50
  168. package/src/lib/node/stream.browser.ts +1 -0
  169. package/src/lib/node/stream.ts +3 -11
  170. package/src/lib/option-utils/merge-loader-options.ts +2 -2
  171. package/src/lib/sources/data-source.ts +74 -0
  172. package/src/lib/sources/image-source.ts +95 -0
  173. package/src/lib/sources/image-tile-source.ts +14 -0
  174. package/src/lib/sources/tile-source.ts +101 -0
  175. package/src/lib/sources/utils/image-type.ts +10 -0
  176. package/src/lib/sources/utils/utils.ts +42 -0
  177. package/src/lib/sources/vector-tile-source.ts +13 -0
  178. package/src/lib/worker-loader-utils/create-loader-worker.ts +20 -4
  179. package/src/lib/worker-loader-utils/encode-with-worker.ts +1 -1
  180. package/src/lib/worker-loader-utils/parse-with-worker.ts +2 -2
  181. package/src/loader-types.ts +367 -0
  182. package/src/service-types.ts +12 -0
  183. package/src/types.ts +2 -351
  184. package/src/writer-types.ts +56 -0
  185. package/dist/index.js +0 -122
  186. package/dist/json-loader.js +0 -27
  187. package/dist/lib/binary-utils/array-buffer-utils.js +0 -84
  188. package/dist/lib/binary-utils/dataview-copy-utils.js +0 -97
  189. package/dist/lib/binary-utils/get-first-characters.js +0 -45
  190. package/dist/lib/binary-utils/memory-conversion-utils.js +0 -73
  191. package/dist/lib/binary-utils/memory-copy-utils.js +0 -61
  192. package/dist/lib/env-utils/assert.js +0 -13
  193. package/dist/lib/env-utils/globals.js +0 -30
  194. package/dist/lib/filesystems/node-filesystem.js +0 -73
  195. package/dist/lib/filesystems/readable-file.js +0 -25
  196. package/dist/lib/filesystems/writable-file.js +0 -48
  197. package/dist/lib/iterators/async-iteration.js +0 -53
  198. package/dist/lib/iterators/text-iterators.js +0 -61
  199. package/dist/lib/node/buffer.browser.js +0 -22
  200. package/dist/lib/node/buffer.js +0 -36
  201. package/dist/lib/node/fs.js +0 -49
  202. package/dist/lib/node/promisify.js +0 -22
  203. package/dist/lib/node/stream.js +0 -17
  204. package/dist/lib/option-utils/merge-loader-options.js +0 -27
  205. package/dist/lib/parser-utils/parse-json.js +0 -16
  206. package/dist/lib/path-utils/file-aliases.js +0 -47
  207. package/dist/lib/path-utils/get-cwd.js +0 -12
  208. package/dist/lib/path-utils/path.js +0 -178
  209. package/dist/lib/request-utils/request-scheduler.js +0 -142
  210. package/dist/lib/worker-loader-utils/create-loader-worker.js +0 -98
  211. package/dist/lib/worker-loader-utils/encode-with-worker.js +0 -21
  212. package/dist/lib/worker-loader-utils/parse-with-worker.js +0 -81
  213. package/dist/types.js +0 -3
  214. package/dist/workers/json-worker.js +0 -5
package/src/types.ts CHANGED
@@ -39,324 +39,9 @@ export type NumberArray = number[] | TypedArray;
39
39
 
40
40
  export type NumericArray = number[] | TypedArray;
41
41
 
42
- type FetchLike = (url: string, options?: RequestInit) => Promise<Response>;
42
+ // FETCH
43
43
 
44
- // LOADERS
45
-
46
- /**
47
- * Core Loader Options
48
- */
49
- export type LoaderOptions = {
50
- /** fetch options or a custom fetch function */
51
- fetch?: typeof fetch | FetchLike | RequestInit | null;
52
- /** Do not throw on errors */
53
- nothrow?: boolean;
54
-
55
- /** loader selection, search first for supplied mimeType */
56
- mimeType?: string;
57
- /** loader selection, provide fallback mimeType is server does not provide */
58
- fallbackMimeType?: string;
59
- /** loader selection, avoid searching registered loaders */
60
- ignoreRegisteredLoaders?: boolean;
61
-
62
- // general
63
- /** Experimental: Supply a logger to the parser */
64
- log?: any;
65
-
66
- // batched parsing
67
-
68
- /** Size of each batch. `auto` matches batches to size of incoming chunks */
69
- batchSize?: number | 'auto';
70
- /** Minimal amount of time between batches */
71
- batchDebounceMs?: number;
72
- /** Stop loading after a given number of rows (compare SQL limit clause) */
73
- limit?: 0;
74
- /** Experimental: Stop loading after reaching */
75
- _limitMB?: 0;
76
- /** Generate metadata batches */
77
- metadata?: boolean;
78
- /** Transforms to run on incoming batches */
79
- transforms?: TransformBatches[];
80
-
81
- // workers
82
-
83
- /** CDN load workers from */
84
- CDN?: string | null;
85
- /** Set to `false` to disable workers */
86
- worker?: boolean;
87
- /** Number of concurrent workers (per loader) on desktop browser */
88
- maxConcurrency?: number;
89
- /** Number of concurrent workers (per loader) on mobile browsers */
90
- maxMobileConcurrency?: number;
91
- /** Set to `false` to prevent reuse workers */
92
- reuseWorkers?: boolean;
93
- /** Whether to use workers under Node.js (experimental) */
94
- _nodeWorkers?: boolean;
95
- /** set to 'test' to run local worker */
96
- _workerType?: string;
97
-
98
- /** @deprecated `options.batchType` removed, Use `options.<loader>.type` instead */
99
- batchType?: 'row' | 'columnar' | 'arrow';
100
- /** @deprecated `options.throw removed`, Use `options.nothrow` instead */
101
- throws?: boolean;
102
- /** @deprecated `options.dataType` no longer used */
103
- dataType?: never;
104
- /** @deprecated `options.uri` no longer used */
105
- uri?: never;
106
- /** @deprecated `options.method` removed. Use `options.fetch.method` */
107
- method?: never;
108
- /** @deprecated `options.headers` removed. Use `options.fetch.headers` */
109
- headers?: never;
110
- /** @deprecated `options.body` removed. Use `options.fetch.body` */
111
- body?: never;
112
- /** @deprecated `options.mode` removed. Use `options.fetch.mode` */
113
- mode?: never;
114
- /** @deprecated `options.credentials` removed. Use `options.fetch.credentials` */
115
- credentials?: never;
116
- /** @deprecated `options.cache` removed. Use `options.fetch.cache` */
117
- cache?: never;
118
- /** @deprecated `options.redirect` removed. Use `options.fetch.redirect` */
119
- redirect?: never;
120
- /** @deprecated `options.referrer` removed. Use `options.fetch.referrer` */
121
- referrer?: never;
122
- /** @deprecated `options.referrerPolicy` removed. Use `options.fetch.referrerPolicy` */
123
- referrerPolicy?: never;
124
- /** @deprecated `options.integrity` removed. Use `options.fetch.integrity` */
125
- integrity?: never;
126
- /** @deprecated `options.keepalive` removed. Use `options.fetch.keepalive` */
127
- keepalive?: never;
128
- /** @deprecated `options.signal` removed. Use `options.fetch.signal` */
129
- signal?: never;
130
-
131
- // Accept other keys (loader options objects, e.g. `options.csv`, `options.json` ...)
132
- [loaderId: string]: unknown;
133
- };
134
-
135
- type PreloadOptions = {
136
- [key: string]: unknown;
137
- };
138
-
139
- /**
140
- * A worker loader definition that can be used with `@loaders.gl/core` functions
141
- */
142
- export type Loader<DataT = any, BatchT = any, LoaderOptionsT = LoaderOptions> = {
143
- // Types
144
- dataType?: DataT;
145
- batchType?: BatchT;
146
-
147
- /** Default Options */
148
- options: LoaderOptionsT;
149
- /** Deprecated Options */
150
- deprecatedOptions?: Record<string, string | Record<string, string>>;
151
-
152
- // Worker
153
- name: string;
154
- /** id should be the same as the field used in LoaderOptions */
155
- id: string;
156
- /** module is used to generate worker threads, need to be the module directory name */
157
- module: string;
158
- /** Version should be injected by build tools */
159
- version: string;
160
- /** A boolean, or a URL */
161
- worker?: string | boolean;
162
- // end Worker
163
-
164
- /** Which category does this loader belong to */
165
- category?: string;
166
- /** What extensions does this loader generate */
167
- extensions: string[];
168
- mimeTypes: string[];
169
-
170
- binary?: boolean;
171
- text?: boolean;
172
-
173
- tests?: (((ArrayBuffer: ArrayBuffer) => boolean) | ArrayBuffer | string)[];
174
-
175
- // TODO - deprecated
176
- supported?: boolean;
177
- testText?: (string: string) => boolean;
178
- };
179
-
180
- /**
181
- * A "bundled" loader definition that can be used with `@loaders.gl/core` functions
182
- * If a worker loader is supported it will also be supported.
183
- */
184
- export type LoaderWithParser<DataT = any, BatchT = any, LoaderOptionsT = LoaderOptions> = Loader<
185
- DataT,
186
- BatchT,
187
- LoaderOptionsT
188
- > & {
189
- // TODO - deprecated
190
- testText?: (string: string) => boolean;
191
-
192
- parse: (
193
- arrayBuffer: ArrayBuffer,
194
- options?: LoaderOptionsT,
195
- context?: LoaderContext
196
- ) => Promise<DataT>;
197
- preload?: Preload;
198
- parseSync?: (
199
- arrayBuffer: ArrayBuffer,
200
- options?: LoaderOptionsT,
201
- context?: LoaderContext
202
- ) => DataT;
203
- parseText?: (text: string, options?: LoaderOptionsT) => Promise<DataT>;
204
- parseTextSync?: (text: string, options?: LoaderOptionsT) => DataT;
205
- parseInBatches?: (
206
- iterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,
207
- options?: LoaderOptionsT,
208
- context?: LoaderContext
209
- ) => AsyncIterable<BatchT>;
210
- parseFileInBatches?: (
211
- file: Blob,
212
- options?: LoaderOptionsT,
213
- context?: LoaderContext
214
- ) => AsyncIterable<BatchT>;
215
- };
216
-
217
- /**
218
- * A Loader context is provided as a third parameters to a loader object's
219
- * parse functions when that loader is called by other loaders rather then
220
- * directly by the application.
221
- *
222
- * - The context object allows the subloaders to be aware of the parameters and
223
- * options that the application provided in the top level call.
224
- * - The context also providedsaccess to parse functions so that the subloader
225
- * does not need to include the core module.
226
- * - In addition, the context's parse functions may also redirect loads from worker
227
- * threads back to main thread.
228
- */
229
- export type LoaderContext = {
230
- loaders?: Loader[] | null;
231
- /** If URL is available. */
232
- url?: string;
233
- /** the file name component of the URL (leading path and query string removed) */
234
- filename?: string;
235
- /** the directory name component of the URL (leading path excluding file name and query string) */
236
- baseUrl?: string;
237
- /** Query string (characters after `?`) */
238
- queryString?: string;
239
-
240
- /** Provides access to any application overrides of fetch() */
241
- fetch: typeof fetch | FetchLike;
242
- /** TBD */
243
- response?: Response;
244
- /** Parse function. Use instead of importing `core`. In workers, may redirect to main thread */
245
- parse: (
246
- arrayBuffer: ArrayBuffer,
247
- loaders?: Loader | Loader[] | LoaderOptions,
248
- options?: LoaderOptions,
249
- context?: LoaderContext
250
- ) => Promise<any>;
251
- /** ParseSync function. Use instead of importing `core`. In workers, may redirect to main thread */
252
- parseSync?: (
253
- arrayBuffer: ArrayBuffer,
254
- loaders?: Loader | Loader[] | LoaderOptions,
255
- options?: LoaderOptions,
256
- context?: LoaderContext
257
- ) => any;
258
- /** ParseInBatches function. Use instead of importing `core`. */
259
- parseInBatches?: (
260
- iterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,
261
- loaders?: Loader | Loader[] | LoaderOptions,
262
- options?: LoaderOptions,
263
- context?: LoaderContext
264
- ) => AsyncIterable<any> | Promise<AsyncIterable<any>>;
265
- };
266
-
267
- // type Parse = (
268
- // arrayBuffer: ArrayBuffer,
269
- // options?: LoaderOptions,
270
- // context?: LoaderContext
271
- // ) => Promise<any>;
272
- // type ParseSync = (
273
- // arrayBuffer: ArrayBuffer,
274
- // options?: LoaderOptions,
275
- // context?: LoaderContext
276
- // ) => any;
277
- // type ParseText = (text: string, options?: LoaderOptions) => Promise<any>;
278
- // type ParseTextSync = (text: string, options?: LoaderOptions) => any;
279
- // type ParseInBatches = (
280
- // iterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,
281
- // options?: LoaderOptions,
282
- // context?: LoaderContext
283
- // ) => AsyncIterable<any>;
284
- // type ParseFileInBatches = (
285
- // file: Blob,
286
- // options?: LoaderOptions,
287
- // context?: LoaderContext
288
- // ) => AsyncIterable<any>;
289
-
290
- type Preload = (url: string, options?: PreloadOptions) => any;
291
-
292
- /** Typescript helper to extract options type from a generic loader type */
293
- export type LoaderOptionsType<T = Loader> = T extends Loader<any, any, infer Options>
294
- ? Options
295
- : never;
296
- /** Typescript helper to extract data type from a generic loader type */
297
- export type LoaderReturnType<T = Loader> = T extends Loader<infer Return, any, any>
298
- ? Return
299
- : never;
300
- /** Typescript helper to extract batch type from a generic loader type */
301
- export type LoaderBatchType<T = Loader> = T extends Loader<any, infer Batch, any> ? Batch : never;
302
-
303
- // WRITERS
304
-
305
- /** Options for writers */
306
- export type WriterOptions = {
307
- /** worker source. If is set will be used instead of loading worker from the Internet */
308
- souce?: string | null;
309
- /** writer-specific options */
310
- [writerId: string]: any;
311
- };
312
-
313
- /**
314
- * A writer definition that can be used with `@loaders.gl/core` functions
315
- */
316
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
317
- export type Writer<DataT = unknown, BatchT = unknown, WriterOptionsT = WriterOptions> = {
318
- name: string;
319
-
320
- id: string;
321
- module: string;
322
- version: string;
323
- worker?: string | boolean;
324
-
325
- // TODO - are these are needed?
326
- extensions?: string[];
327
- mimeTypes?: string[];
328
- binary?: boolean;
329
- text?: boolean;
330
-
331
- options: WriterOptionsT;
332
- deprecatedOptions?: Record<string, string>;
333
-
334
- // encodeText?: EncodeText;
335
- // encode?: Encode;
336
- encodeSync?: EncodeSync;
337
- // encodeInBatches?: EncodeInBatches;
338
- encodeURLtoURL?: EncodeURLtoURL;
339
-
340
- encode?(data: DataT, options?: WriterOptionsT): Promise<ArrayBuffer>;
341
- encodeText?(table: DataT, options?: WriterOptionsT): Promise<string> | string;
342
- encodeInBatches?(data: AsyncIterable<any>, options?: WriterOptionsT): AsyncIterable<ArrayBuffer>;
343
- };
344
-
345
- // type Encode = (data: any, options?: WriterOptions) => Promise<ArrayBuffer>;
346
- type EncodeSync = (data: any, options?: WriterOptions) => ArrayBuffer;
347
- // TODO
348
- // type EncodeText = Function;
349
- // type EncodeInBatches = Function;
350
- type EncodeURLtoURL = (
351
- inputUrl: string,
352
- outputUrl: string,
353
- options?: WriterOptions
354
- ) => Promise<string>;
355
-
356
- /** Typescript helper to extract the writer options type from a generic writer type */
357
- export type WriterOptionsType<T = Writer> = T extends Writer<unknown, unknown, infer Options>
358
- ? Options
359
- : never;
44
+ export type FetchLike = (url: string, options?: RequestInit) => Promise<Response>;
360
45
 
361
46
  // MISC TYPES
362
47
 
@@ -384,37 +69,3 @@ export type BatchableDataType =
384
69
  | Iterable<ArrayBuffer>
385
70
  | AsyncIterable<ArrayBuffer>
386
71
  | Promise<AsyncIterable<ArrayBuffer>>;
387
-
388
- /**
389
- * A FileSystem interface can encapsulate a FileList, a ZipFile, a GoogleDrive etc.
390
- */
391
- export interface IFileSystem {
392
- /**
393
- * Return a list of file names
394
- * @param dirname directory name. file system root directory if omitted
395
- */
396
- readdir(dirname?: string, options?: {recursive?: boolean}): Promise<string[]>;
397
-
398
- /**
399
- * Gets information from a local file from the filesystem
400
- * @param filename file name to stat
401
- * @param options currently unused
402
- * @throws if filename is not in local filesystem
403
- */
404
- stat(filename: string, options?: object): Promise<{size: number}>;
405
-
406
- /**
407
- * Fetches a local file from the filesystem (or a URL)
408
- * @param filename
409
- * @param options
410
- */
411
- fetch(filename: string, options?: object): Promise<Response>;
412
- }
413
-
414
- type ReadOptions = {buffer?: ArrayBuffer; offset?: number; length?: number; position?: number};
415
- export interface IRandomAccessReadFileSystem extends IFileSystem {
416
- open(path: string, flags: string | number, mode?: any): Promise<any>;
417
- close(fd: any): Promise<void>;
418
- fstat(fd: any): Promise<object>;
419
- read(fd: any, options?: ReadOptions): Promise<{bytesRead: number; buffer: Buffer}>;
420
- }
@@ -0,0 +1,56 @@
1
+ // loaders.gl, MIT license
2
+
3
+ // WRITERS
4
+
5
+ /** Options for writers */
6
+ export type WriterOptions = {
7
+ /** worker source. If is set will be used instead of loading worker from the Internet */
8
+ source?: string | null;
9
+ /** Force to load WASM libraries from local file system in NodeJS or from loaders.gl CDN in a web browser */
10
+ useLocalLibraries?: boolean;
11
+ /** writer-specific options */
12
+ [writerId: string]: any;
13
+ };
14
+
15
+ /**
16
+ * A writer definition that can be used with `@loaders.gl/core` functions
17
+ */
18
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
19
+ export type Writer<DataT = unknown, BatchT = unknown, WriterOptionsT = WriterOptions> = {
20
+ name: string;
21
+
22
+ id: string;
23
+ module: string;
24
+ version: string;
25
+ worker?: string | boolean;
26
+
27
+ // TODO - are these are needed?
28
+ extensions?: string[];
29
+ mimeTypes?: string[];
30
+ binary?: boolean;
31
+ text?: boolean;
32
+
33
+ options: WriterOptionsT;
34
+ deprecatedOptions?: Record<string, string>;
35
+
36
+ // encodeText?: EncodeText;
37
+ // encode?: Encode;
38
+ encode?(data: DataT, options?: WriterOptionsT): Promise<ArrayBuffer>;
39
+ encodeSync?(data: DataT, options?: WriterOptionsT): ArrayBuffer;
40
+
41
+ encodeText?(table: DataT, options?: WriterOptionsT): Promise<string>;
42
+ encodeTextSync?(table: DataT, options?: WriterOptionsT): string;
43
+
44
+ encodeInBatches?(data: AsyncIterable<any>, options?: WriterOptionsT): AsyncIterable<ArrayBuffer>;
45
+
46
+ encodeURLtoURL?: (
47
+ inputUrl: string,
48
+ outputUrl: string,
49
+ options?: WriterOptionsT
50
+ ) => Promise<string>;
51
+ };
52
+
53
+ /** Typescript helper to extract the writer options type from a generic writer type */
54
+ export type WriterOptionsType<T = Writer> = T extends Writer<unknown, unknown, infer Options>
55
+ ? Options
56
+ : never;
package/dist/index.js DELETED
@@ -1,122 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.makeWritableFile = exports.makeReadableFile = exports.stream = exports.fs = exports.path = exports.promisify2 = exports.promisify1 = exports.toArrayBuffer = exports.toBuffer = exports.isBuffer = exports.JSONLoader = exports._addAliases = exports.resolvePath = exports.getPathPrefix = exports.setPathPrefix = exports.RequestScheduler = exports.concatenateArrayBuffersAsync = exports.forEach = exports.makeNumberedLineIterator = exports.makeLineIterator = exports.makeTextDecoderIterator = exports.makeTextEncoderIterator = exports.getMagicString = exports.getFirstCharacters = exports.copyPaddedStringToDataView = exports.copyPaddedArrayBufferToDataView = exports.copyBinaryToDataView = exports.copyStringToDataView = exports.padStringToByteAlignment = exports.copyArrayBuffer = exports.copyToArray = exports.padToNBytes = exports.compareArrayBuffers = exports.concatenateTypedArrays = exports.concatenateArrayBuffers = exports.sliceArrayBuffer = exports.parseJSON = exports.canEncodeWithWorker = exports.canParseWithWorker = exports.parseWithWorker = exports.createLoaderWorker = exports.mergeLoaderOptions = exports.document = exports.global = exports.window = exports.self = exports.nodeVersion = exports.isWorker = exports.isBrowser = exports.assert = void 0;
30
- exports._NodeFileSystem = void 0;
31
- // GENERAL UTILS
32
- var assert_1 = require("./lib/env-utils/assert");
33
- Object.defineProperty(exports, "assert", { enumerable: true, get: function () { return assert_1.assert; } });
34
- var globals_1 = require("./lib/env-utils/globals");
35
- Object.defineProperty(exports, "isBrowser", { enumerable: true, get: function () { return globals_1.isBrowser; } });
36
- Object.defineProperty(exports, "isWorker", { enumerable: true, get: function () { return globals_1.isWorker; } });
37
- Object.defineProperty(exports, "nodeVersion", { enumerable: true, get: function () { return globals_1.nodeVersion; } });
38
- Object.defineProperty(exports, "self", { enumerable: true, get: function () { return globals_1.self; } });
39
- Object.defineProperty(exports, "window", { enumerable: true, get: function () { return globals_1.window; } });
40
- Object.defineProperty(exports, "global", { enumerable: true, get: function () { return globals_1.global; } });
41
- Object.defineProperty(exports, "document", { enumerable: true, get: function () { return globals_1.document; } });
42
- var merge_loader_options_1 = require("./lib/option-utils/merge-loader-options");
43
- Object.defineProperty(exports, "mergeLoaderOptions", { enumerable: true, get: function () { return merge_loader_options_1.mergeLoaderOptions; } });
44
- // LOADERS.GL-SPECIFIC WORKER UTILS
45
- var create_loader_worker_1 = require("./lib/worker-loader-utils/create-loader-worker");
46
- Object.defineProperty(exports, "createLoaderWorker", { enumerable: true, get: function () { return create_loader_worker_1.createLoaderWorker; } });
47
- var parse_with_worker_1 = require("./lib/worker-loader-utils/parse-with-worker");
48
- Object.defineProperty(exports, "parseWithWorker", { enumerable: true, get: function () { return parse_with_worker_1.parseWithWorker; } });
49
- Object.defineProperty(exports, "canParseWithWorker", { enumerable: true, get: function () { return parse_with_worker_1.canParseWithWorker; } });
50
- var encode_with_worker_1 = require("./lib/worker-loader-utils/encode-with-worker");
51
- Object.defineProperty(exports, "canEncodeWithWorker", { enumerable: true, get: function () { return encode_with_worker_1.canEncodeWithWorker; } });
52
- // PARSER UTILS
53
- var parse_json_1 = require("./lib/parser-utils/parse-json");
54
- Object.defineProperty(exports, "parseJSON", { enumerable: true, get: function () { return parse_json_1.parseJSON; } });
55
- // MEMORY COPY UTILS
56
- var array_buffer_utils_1 = require("./lib/binary-utils/array-buffer-utils");
57
- Object.defineProperty(exports, "sliceArrayBuffer", { enumerable: true, get: function () { return array_buffer_utils_1.sliceArrayBuffer; } });
58
- Object.defineProperty(exports, "concatenateArrayBuffers", { enumerable: true, get: function () { return array_buffer_utils_1.concatenateArrayBuffers; } });
59
- Object.defineProperty(exports, "concatenateTypedArrays", { enumerable: true, get: function () { return array_buffer_utils_1.concatenateTypedArrays; } });
60
- Object.defineProperty(exports, "compareArrayBuffers", { enumerable: true, get: function () { return array_buffer_utils_1.compareArrayBuffers; } });
61
- var memory_copy_utils_1 = require("./lib/binary-utils/memory-copy-utils");
62
- Object.defineProperty(exports, "padToNBytes", { enumerable: true, get: function () { return memory_copy_utils_1.padToNBytes; } });
63
- Object.defineProperty(exports, "copyToArray", { enumerable: true, get: function () { return memory_copy_utils_1.copyToArray; } });
64
- Object.defineProperty(exports, "copyArrayBuffer", { enumerable: true, get: function () { return memory_copy_utils_1.copyArrayBuffer; } });
65
- var dataview_copy_utils_1 = require("./lib/binary-utils/dataview-copy-utils");
66
- Object.defineProperty(exports, "padStringToByteAlignment", { enumerable: true, get: function () { return dataview_copy_utils_1.padStringToByteAlignment; } });
67
- Object.defineProperty(exports, "copyStringToDataView", { enumerable: true, get: function () { return dataview_copy_utils_1.copyStringToDataView; } });
68
- Object.defineProperty(exports, "copyBinaryToDataView", { enumerable: true, get: function () { return dataview_copy_utils_1.copyBinaryToDataView; } });
69
- Object.defineProperty(exports, "copyPaddedArrayBufferToDataView", { enumerable: true, get: function () { return dataview_copy_utils_1.copyPaddedArrayBufferToDataView; } });
70
- Object.defineProperty(exports, "copyPaddedStringToDataView", { enumerable: true, get: function () { return dataview_copy_utils_1.copyPaddedStringToDataView; } });
71
- var get_first_characters_1 = require("./lib/binary-utils/get-first-characters");
72
- Object.defineProperty(exports, "getFirstCharacters", { enumerable: true, get: function () { return get_first_characters_1.getFirstCharacters; } });
73
- Object.defineProperty(exports, "getMagicString", { enumerable: true, get: function () { return get_first_characters_1.getMagicString; } });
74
- // ITERATOR UTILS
75
- var text_iterators_1 = require("./lib/iterators/text-iterators");
76
- Object.defineProperty(exports, "makeTextEncoderIterator", { enumerable: true, get: function () { return text_iterators_1.makeTextEncoderIterator; } });
77
- Object.defineProperty(exports, "makeTextDecoderIterator", { enumerable: true, get: function () { return text_iterators_1.makeTextDecoderIterator; } });
78
- Object.defineProperty(exports, "makeLineIterator", { enumerable: true, get: function () { return text_iterators_1.makeLineIterator; } });
79
- Object.defineProperty(exports, "makeNumberedLineIterator", { enumerable: true, get: function () { return text_iterators_1.makeNumberedLineIterator; } });
80
- var async_iteration_1 = require("./lib/iterators/async-iteration");
81
- Object.defineProperty(exports, "forEach", { enumerable: true, get: function () { return async_iteration_1.forEach; } });
82
- Object.defineProperty(exports, "concatenateArrayBuffersAsync", { enumerable: true, get: function () { return async_iteration_1.concatenateArrayBuffersAsync; } });
83
- // REQUEST UTILS
84
- var request_scheduler_1 = require("./lib/request-utils/request-scheduler");
85
- Object.defineProperty(exports, "RequestScheduler", { enumerable: true, get: function () { return __importDefault(request_scheduler_1).default; } });
86
- // PATH HELPERS
87
- var file_aliases_1 = require("./lib/path-utils/file-aliases");
88
- Object.defineProperty(exports, "setPathPrefix", { enumerable: true, get: function () { return file_aliases_1.setPathPrefix; } });
89
- Object.defineProperty(exports, "getPathPrefix", { enumerable: true, get: function () { return file_aliases_1.getPathPrefix; } });
90
- Object.defineProperty(exports, "resolvePath", { enumerable: true, get: function () { return file_aliases_1.resolvePath; } });
91
- var file_aliases_2 = require("./lib/path-utils/file-aliases");
92
- Object.defineProperty(exports, "_addAliases", { enumerable: true, get: function () { return file_aliases_2.addAliases; } });
93
- // MICRO LOADERS
94
- var json_loader_1 = require("./json-loader");
95
- Object.defineProperty(exports, "JSONLoader", { enumerable: true, get: function () { return json_loader_1.JSONLoader; } });
96
- // NODE support
97
- // Node.js emulation (can be used in browser)
98
- // Avoid direct use of `Buffer` which pulls in 50KB polyfill
99
- var memory_conversion_utils_1 = require("./lib/binary-utils/memory-conversion-utils");
100
- Object.defineProperty(exports, "isBuffer", { enumerable: true, get: function () { return memory_conversion_utils_1.isBuffer; } });
101
- Object.defineProperty(exports, "toBuffer", { enumerable: true, get: function () { return memory_conversion_utils_1.toBuffer; } });
102
- Object.defineProperty(exports, "toArrayBuffer", { enumerable: true, get: function () { return memory_conversion_utils_1.toArrayBuffer; } });
103
- // Note.js wrappers (can be safely imported, but not used in browser)
104
- // Use instead of importing 'util' to avoid node dependencies
105
- var promisify_1 = require("./lib/node/promisify");
106
- Object.defineProperty(exports, "promisify1", { enumerable: true, get: function () { return promisify_1.promisify1; } });
107
- Object.defineProperty(exports, "promisify2", { enumerable: true, get: function () { return promisify_1.promisify2; } });
108
- // `path` replacement (avoids bundling big path polyfill)
109
- const path = __importStar(require("./lib/path-utils/path"));
110
- exports.path = path;
111
- // Use instead of importing 'fs' to avoid node dependencies`
112
- const fs = __importStar(require("./lib/node/fs"));
113
- exports.fs = fs;
114
- // Use instead of importing 'stream' to avoid node dependencies`
115
- const stream = __importStar(require("./lib/node/stream"));
116
- exports.stream = stream;
117
- var readable_file_1 = require("./lib/filesystems/readable-file");
118
- Object.defineProperty(exports, "makeReadableFile", { enumerable: true, get: function () { return readable_file_1.makeReadableFile; } });
119
- var writable_file_1 = require("./lib/filesystems/writable-file");
120
- Object.defineProperty(exports, "makeWritableFile", { enumerable: true, get: function () { return writable_file_1.makeWritableFile; } });
121
- var node_filesystem_1 = require("./lib/filesystems/node-filesystem");
122
- Object.defineProperty(exports, "_NodeFileSystem", { enumerable: true, get: function () { return __importDefault(node_filesystem_1).default; } });
@@ -1,27 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.JSONLoader = void 0;
4
- // __VERSION__ is injected by babel-plugin-version-inline
5
- // @ts-ignore TS2304: Cannot find name '__VERSION__'.
6
- const VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';
7
- /**
8
- * A JSON Micro loader (minimal bundle size)
9
- * Alternative to `@loaders.gl/json`
10
- */
11
- exports.JSONLoader = {
12
- name: 'JSON',
13
- id: 'json',
14
- module: 'json',
15
- version: VERSION,
16
- extensions: ['json', 'geojson'],
17
- mimeTypes: ['application/json'],
18
- category: 'json',
19
- text: true,
20
- parseTextSync,
21
- parse: async (arrayBuffer) => parseTextSync(new TextDecoder().decode(arrayBuffer)),
22
- options: {}
23
- };
24
- // TODO - deprecated
25
- function parseTextSync(text) {
26
- return JSON.parse(text);
27
- }
@@ -1,84 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.sliceArrayBuffer = exports.concatenateTypedArrays = exports.concatenateArrayBuffers = exports.compareArrayBuffers = void 0;
4
- /**
5
- * compare two binary arrays for equality
6
- * @param a
7
- * @param b
8
- * @param byteLength
9
- */
10
- function compareArrayBuffers(arrayBuffer1, arrayBuffer2, byteLength) {
11
- byteLength = byteLength || arrayBuffer1.byteLength;
12
- if (arrayBuffer1.byteLength < byteLength || arrayBuffer2.byteLength < byteLength) {
13
- return false;
14
- }
15
- const array1 = new Uint8Array(arrayBuffer1);
16
- const array2 = new Uint8Array(arrayBuffer2);
17
- for (let i = 0; i < array1.length; ++i) {
18
- if (array1[i] !== array2[i]) {
19
- return false;
20
- }
21
- }
22
- return true;
23
- }
24
- exports.compareArrayBuffers = compareArrayBuffers;
25
- /**
26
- * Concatenate a sequence of ArrayBuffers
27
- * @return A concatenated ArrayBuffer
28
- */
29
- function concatenateArrayBuffers(...sources) {
30
- // Make sure all inputs are wrapped in typed arrays
31
- const sourceArrays = sources.map((source2) => source2 instanceof ArrayBuffer ? new Uint8Array(source2) : source2);
32
- // Get length of all inputs
33
- const byteLength = sourceArrays.reduce((length, typedArray) => length + typedArray.byteLength, 0);
34
- // Allocate array with space for all inputs
35
- const result = new Uint8Array(byteLength);
36
- // Copy the subarrays
37
- let offset = 0;
38
- for (const sourceArray of sourceArrays) {
39
- result.set(sourceArray, offset);
40
- offset += sourceArray.byteLength;
41
- }
42
- // We work with ArrayBuffers, discard the typed array wrapper
43
- return result.buffer;
44
- }
45
- exports.concatenateArrayBuffers = concatenateArrayBuffers;
46
- /**
47
- * Concatenate arbitrary count of typed arrays
48
- * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Typed_arrays
49
- * @param - list of arrays. All arrays should be the same type
50
- * @return A concatenated TypedArray
51
- */
52
- function concatenateTypedArrays(...typedArrays) {
53
- // @ts-ignore
54
- const arrays = typedArrays;
55
- // @ts-ignore
56
- const TypedArrayConstructor = (arrays && arrays.length > 1 && arrays[0].constructor) || null;
57
- if (!TypedArrayConstructor) {
58
- throw new Error('"concatenateTypedArrays" - incorrect quantity of arguments or arguments have incompatible data types');
59
- }
60
- const sumLength = arrays.reduce((acc, value) => acc + value.length, 0);
61
- // @ts-ignore typescript does not like dynamic constructors
62
- const result = new TypedArrayConstructor(sumLength);
63
- let offset = 0;
64
- for (const array of arrays) {
65
- result.set(array, offset);
66
- offset += array.length;
67
- }
68
- return result;
69
- }
70
- exports.concatenateTypedArrays = concatenateTypedArrays;
71
- /**
72
- * Copy a view of an ArrayBuffer into new ArrayBuffer with byteOffset = 0
73
- * @param arrayBuffer
74
- * @param byteOffset
75
- * @param byteLength
76
- */
77
- function sliceArrayBuffer(arrayBuffer, byteOffset, byteLength) {
78
- const subArray = byteLength !== undefined
79
- ? new Uint8Array(arrayBuffer).subarray(byteOffset, byteOffset + byteLength)
80
- : new Uint8Array(arrayBuffer).subarray(byteOffset);
81
- const arrayCopy = new Uint8Array(subArray);
82
- return arrayCopy.buffer;
83
- }
84
- exports.sliceArrayBuffer = sliceArrayBuffer;