@loaders.gl/core 3.1.3 → 4.0.0-alpha.5

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 (272) hide show
  1. package/dist/bundle.js +2 -2
  2. package/dist/bundle.js.map +1 -0
  3. package/dist/{es5/core-addons → core-addons}/README.md +0 -0
  4. package/dist/core-addons/write-file-browser.js +1 -59
  5. package/dist/{es5/core-addons → core-addons}/write-file-browser.js.map +0 -0
  6. package/dist/dist.min.js +18 -18
  7. package/dist/index.js +29 -102
  8. package/dist/index.js.map +1 -0
  9. package/dist/iterators/batch-iterators/timed-batch-iterator.js +17 -20
  10. package/dist/iterators/batch-iterators/timed-batch-iterator.js.map +1 -0
  11. package/dist/iterators/make-iterator/make-array-buffer-iterator.js +16 -25
  12. package/dist/iterators/make-iterator/make-array-buffer-iterator.js.map +1 -0
  13. package/dist/iterators/make-iterator/make-blob-iterator.js +12 -20
  14. package/dist/iterators/make-iterator/make-blob-iterator.js.map +1 -0
  15. package/dist/iterators/make-iterator/make-iterator.js +29 -36
  16. package/dist/iterators/make-iterator/make-iterator.js.map +1 -0
  17. package/dist/iterators/make-iterator/make-stream-iterator.js +32 -89
  18. package/dist/iterators/make-iterator/make-stream-iterator.js.map +1 -0
  19. package/dist/iterators/make-iterator/make-string-iterator.js +12 -22
  20. package/dist/iterators/make-iterator/make-string-iterator.js.map +1 -0
  21. package/dist/iterators/make-stream/make-dom-stream.js +32 -44
  22. package/dist/iterators/make-stream/make-dom-stream.js.map +1 -0
  23. package/dist/iterators/make-stream/make-node-stream.js +68 -50
  24. package/dist/iterators/make-stream/make-node-stream.js.map +1 -0
  25. package/dist/javascript-utils/is-type.js +21 -41
  26. package/dist/javascript-utils/is-type.js.map +1 -0
  27. package/dist/lib/api/encode.js +81 -101
  28. package/dist/lib/api/encode.js.map +1 -0
  29. package/dist/lib/api/load-in-batches.js +27 -30
  30. package/dist/lib/api/load-in-batches.js.map +1 -0
  31. package/dist/lib/api/load.js +24 -40
  32. package/dist/lib/api/load.js.map +1 -0
  33. package/dist/lib/api/parse-in-batches.js +92 -113
  34. package/dist/lib/api/parse-in-batches.js.map +1 -0
  35. package/dist/lib/api/parse-sync.js +54 -56
  36. package/dist/lib/api/parse-sync.js.map +1 -0
  37. package/dist/lib/api/parse.js +61 -71
  38. package/dist/lib/api/parse.js.map +1 -0
  39. package/dist/lib/api/register-loaders.js +23 -29
  40. package/dist/lib/api/register-loaders.js.map +1 -0
  41. package/dist/lib/api/save.js +9 -13
  42. package/dist/lib/api/save.js.map +1 -0
  43. package/dist/lib/api/select-loader.js +194 -205
  44. package/dist/lib/api/select-loader.js.map +1 -0
  45. package/dist/lib/api/set-loader-options.js +4 -11
  46. package/dist/lib/api/set-loader-options.js.map +1 -0
  47. package/dist/lib/common.js +2 -2
  48. package/dist/{es5/lib → lib}/common.js.map +0 -0
  49. package/dist/lib/fetch/fetch-error-message.js +17 -21
  50. package/dist/lib/fetch/fetch-error-message.js.map +1 -0
  51. package/dist/lib/fetch/fetch-file.js +15 -25
  52. package/dist/lib/fetch/fetch-file.js.map +1 -0
  53. package/dist/lib/fetch/read-array-buffer.js +27 -39
  54. package/dist/lib/fetch/read-array-buffer.js.map +1 -0
  55. package/dist/lib/fetch/read-file.js +16 -28
  56. package/dist/lib/fetch/read-file.js.map +1 -0
  57. package/dist/lib/fetch/write-file.js +23 -20
  58. package/dist/lib/fetch/write-file.js.map +1 -0
  59. package/dist/lib/filesystems/browser-filesystem.js +107 -118
  60. package/dist/lib/filesystems/browser-filesystem.js.map +1 -0
  61. package/dist/lib/filesystems/filesystem.js +2 -2
  62. package/dist/{es5/lib → lib}/filesystems/filesystem.js.map +0 -0
  63. package/dist/lib/filesystems/read-array-buffer.js +8 -28
  64. package/dist/lib/filesystems/read-array-buffer.js.map +1 -0
  65. package/dist/lib/init.js +4 -8
  66. package/dist/lib/init.js.map +1 -0
  67. package/dist/lib/loader-utils/check-errors.js +22 -26
  68. package/dist/lib/loader-utils/check-errors.js.map +1 -0
  69. package/dist/lib/loader-utils/get-data.js +122 -122
  70. package/dist/lib/loader-utils/get-data.js.map +1 -0
  71. package/dist/lib/loader-utils/loader-context.js +34 -47
  72. package/dist/lib/loader-utils/loader-context.js.map +1 -0
  73. package/dist/lib/loader-utils/loggers.js +46 -39
  74. package/dist/lib/loader-utils/loggers.js.map +1 -0
  75. package/dist/lib/loader-utils/normalize-loader.js +41 -50
  76. package/dist/lib/loader-utils/normalize-loader.js.map +1 -0
  77. package/dist/lib/loader-utils/option-defaults.js +35 -39
  78. package/dist/lib/loader-utils/option-defaults.js.map +1 -0
  79. package/dist/lib/loader-utils/option-utils.js +119 -156
  80. package/dist/lib/loader-utils/option-utils.js.map +1 -0
  81. package/dist/lib/progress/fetch-progress.js +56 -54
  82. package/dist/lib/progress/fetch-progress.js.map +1 -0
  83. package/dist/lib/utils/mime-type-utils.js +17 -38
  84. package/dist/lib/utils/mime-type-utils.js.map +1 -0
  85. package/dist/lib/utils/resource-utils.js +52 -70
  86. package/dist/lib/utils/resource-utils.js.map +1 -0
  87. package/dist/lib/utils/response-utils.js +105 -104
  88. package/dist/lib/utils/response-utils.js.map +1 -0
  89. package/dist/null-loader.js +31 -41
  90. package/dist/null-loader.js.map +1 -0
  91. package/dist/null-worker.js +1 -1
  92. package/dist/workers/null-worker.js +4 -5
  93. package/dist/workers/null-worker.js.map +1 -0
  94. package/package.json +9 -7
  95. package/dist/es5/bundle.js +0 -7
  96. package/dist/es5/bundle.js.map +0 -1
  97. package/dist/es5/core-addons/write-file-browser.js +0 -2
  98. package/dist/es5/index.js +0 -374
  99. package/dist/es5/index.js.map +0 -1
  100. package/dist/es5/iterators/batch-iterators/timed-batch-iterator.js +0 -131
  101. package/dist/es5/iterators/batch-iterators/timed-batch-iterator.js.map +0 -1
  102. package/dist/es5/iterators/make-iterator/make-array-buffer-iterator.js +0 -61
  103. package/dist/es5/iterators/make-iterator/make-array-buffer-iterator.js.map +0 -1
  104. package/dist/es5/iterators/make-iterator/make-blob-iterator.js +0 -61
  105. package/dist/es5/iterators/make-iterator/make-blob-iterator.js.map +0 -1
  106. package/dist/es5/iterators/make-iterator/make-iterator.js +0 -42
  107. package/dist/es5/iterators/make-iterator/make-iterator.js.map +0 -1
  108. package/dist/es5/iterators/make-iterator/make-stream-iterator.js +0 -184
  109. package/dist/es5/iterators/make-iterator/make-stream-iterator.js.map +0 -1
  110. package/dist/es5/iterators/make-iterator/make-string-iterator.js +0 -49
  111. package/dist/es5/iterators/make-iterator/make-string-iterator.js.map +0 -1
  112. package/dist/es5/iterators/make-stream/make-dom-stream.js +0 -86
  113. package/dist/es5/iterators/make-stream/make-dom-stream.js.map +0 -1
  114. package/dist/es5/iterators/make-stream/make-node-stream.js +0 -217
  115. package/dist/es5/iterators/make-stream/make-node-stream.js.map +0 -1
  116. package/dist/es5/javascript-utils/is-type.js +0 -115
  117. package/dist/es5/javascript-utils/is-type.js.map +0 -1
  118. package/dist/es5/lib/api/encode.js +0 -304
  119. package/dist/es5/lib/api/encode.js.map +0 -1
  120. package/dist/es5/lib/api/load-in-batches.js +0 -83
  121. package/dist/es5/lib/api/load-in-batches.js.map +0 -1
  122. package/dist/es5/lib/api/load.js +0 -81
  123. package/dist/es5/lib/api/load.js.map +0 -1
  124. package/dist/es5/lib/api/parse-in-batches.js +0 -366
  125. package/dist/es5/lib/api/parse-in-batches.js.map +0 -1
  126. package/dist/es5/lib/api/parse-sync.js +0 -75
  127. package/dist/es5/lib/api/parse-sync.js.map +0 -1
  128. package/dist/es5/lib/api/parse.js +0 -171
  129. package/dist/es5/lib/api/parse.js.map +0 -1
  130. package/dist/es5/lib/api/register-loaders.js +0 -63
  131. package/dist/es5/lib/api/register-loaders.js.map +0 -1
  132. package/dist/es5/lib/api/save.js +0 -55
  133. package/dist/es5/lib/api/save.js.map +0 -1
  134. package/dist/es5/lib/api/select-loader.js +0 -378
  135. package/dist/es5/lib/api/select-loader.js.map +0 -1
  136. package/dist/es5/lib/api/set-loader-options.js +0 -13
  137. package/dist/es5/lib/api/set-loader-options.js.map +0 -1
  138. package/dist/es5/lib/common.js +0 -2
  139. package/dist/es5/lib/fetch/fetch-error-message.js +0 -72
  140. package/dist/es5/lib/fetch/fetch-error-message.js.map +0 -1
  141. package/dist/es5/lib/fetch/fetch-file.js +0 -63
  142. package/dist/es5/lib/fetch/fetch-file.js.map +0 -1
  143. package/dist/es5/lib/fetch/read-array-buffer.js +0 -100
  144. package/dist/es5/lib/fetch/read-array-buffer.js.map +0 -1
  145. package/dist/es5/lib/fetch/read-file.js +0 -26
  146. package/dist/es5/lib/fetch/read-file.js.map +0 -1
  147. package/dist/es5/lib/fetch/write-file.js +0 -63
  148. package/dist/es5/lib/fetch/write-file.js.map +0 -1
  149. package/dist/es5/lib/filesystems/browser-filesystem.js +0 -312
  150. package/dist/es5/lib/filesystems/browser-filesystem.js.map +0 -1
  151. package/dist/es5/lib/filesystems/filesystem.js +0 -2
  152. package/dist/es5/lib/filesystems/read-array-buffer.js +0 -53
  153. package/dist/es5/lib/filesystems/read-array-buffer.js.map +0 -1
  154. package/dist/es5/lib/init.js +0 -13
  155. package/dist/es5/lib/init.js.map +0 -1
  156. package/dist/es5/lib/loader-utils/check-errors.js +0 -73
  157. package/dist/es5/lib/loader-utils/check-errors.js.map +0 -1
  158. package/dist/es5/lib/loader-utils/get-data.js +0 -314
  159. package/dist/es5/lib/loader-utils/get-data.js.map +0 -1
  160. package/dist/es5/lib/loader-utils/loader-context.js +0 -57
  161. package/dist/es5/lib/loader-utils/loader-context.js.map +0 -1
  162. package/dist/es5/lib/loader-utils/loggers.js +0 -110
  163. package/dist/es5/lib/loader-utils/loggers.js.map +0 -1
  164. package/dist/es5/lib/loader-utils/normalize-loader.js +0 -59
  165. package/dist/es5/lib/loader-utils/normalize-loader.js.map +0 -1
  166. package/dist/es5/lib/loader-utils/option-defaults.js +0 -47
  167. package/dist/es5/lib/loader-utils/option-defaults.js.map +0 -1
  168. package/dist/es5/lib/loader-utils/option-utils.js +0 -191
  169. package/dist/es5/lib/loader-utils/option-utils.js.map +0 -1
  170. package/dist/es5/lib/progress/fetch-progress.js +0 -169
  171. package/dist/es5/lib/progress/fetch-progress.js.map +0 -1
  172. package/dist/es5/lib/utils/mime-type-utils.js +0 -30
  173. package/dist/es5/lib/utils/mime-type-utils.js.map +0 -1
  174. package/dist/es5/lib/utils/resource-utils.js +0 -72
  175. package/dist/es5/lib/utils/resource-utils.js.map +0 -1
  176. package/dist/es5/lib/utils/response-utils.js +0 -255
  177. package/dist/es5/lib/utils/response-utils.js.map +0 -1
  178. package/dist/es5/null-loader.js +0 -169
  179. package/dist/es5/null-loader.js.map +0 -1
  180. package/dist/es5/workers/null-worker.js +0 -8
  181. package/dist/es5/workers/null-worker.js.map +0 -1
  182. package/dist/esm/bundle.js +0 -5
  183. package/dist/esm/bundle.js.map +0 -1
  184. package/dist/esm/core-addons/README.md +0 -1
  185. package/dist/esm/core-addons/write-file-browser.js +0 -2
  186. package/dist/esm/core-addons/write-file-browser.js.map +0 -1
  187. package/dist/esm/index.js +0 -29
  188. package/dist/esm/index.js.map +0 -1
  189. package/dist/esm/iterators/batch-iterators/timed-batch-iterator.js +0 -19
  190. package/dist/esm/iterators/batch-iterators/timed-batch-iterator.js.map +0 -1
  191. package/dist/esm/iterators/make-iterator/make-array-buffer-iterator.js +0 -18
  192. package/dist/esm/iterators/make-iterator/make-array-buffer-iterator.js.map +0 -1
  193. package/dist/esm/iterators/make-iterator/make-blob-iterator.js +0 -13
  194. package/dist/esm/iterators/make-iterator/make-blob-iterator.js.map +0 -1
  195. package/dist/esm/iterators/make-iterator/make-iterator.js +0 -30
  196. package/dist/esm/iterators/make-iterator/make-iterator.js.map +0 -1
  197. package/dist/esm/iterators/make-iterator/make-stream-iterator.js +0 -39
  198. package/dist/esm/iterators/make-iterator/make-stream-iterator.js.map +0 -1
  199. package/dist/esm/iterators/make-iterator/make-string-iterator.js +0 -14
  200. package/dist/esm/iterators/make-iterator/make-string-iterator.js.map +0 -1
  201. package/dist/esm/iterators/make-stream/make-dom-stream.js +0 -34
  202. package/dist/esm/iterators/make-stream/make-dom-stream.js.map +0 -1
  203. package/dist/esm/iterators/make-stream/make-node-stream.js +0 -74
  204. package/dist/esm/iterators/make-stream/make-node-stream.js.map +0 -1
  205. package/dist/esm/javascript-utils/is-type.js +0 -21
  206. package/dist/esm/javascript-utils/is-type.js.map +0 -1
  207. package/dist/esm/lib/api/encode.js +0 -91
  208. package/dist/esm/lib/api/encode.js.map +0 -1
  209. package/dist/esm/lib/api/load-in-batches.js +0 -30
  210. package/dist/esm/lib/api/load-in-batches.js.map +0 -1
  211. package/dist/esm/lib/api/load.js +0 -25
  212. package/dist/esm/lib/api/load.js.map +0 -1
  213. package/dist/esm/lib/api/parse-in-batches.js +0 -99
  214. package/dist/esm/lib/api/parse-in-batches.js.map +0 -1
  215. package/dist/esm/lib/api/parse-sync.js +0 -57
  216. package/dist/esm/lib/api/parse-sync.js.map +0 -1
  217. package/dist/esm/lib/api/parse.js +0 -64
  218. package/dist/esm/lib/api/parse.js.map +0 -1
  219. package/dist/esm/lib/api/register-loaders.js +0 -29
  220. package/dist/esm/lib/api/register-loaders.js.map +0 -1
  221. package/dist/esm/lib/api/save.js +0 -11
  222. package/dist/esm/lib/api/save.js.map +0 -1
  223. package/dist/esm/lib/api/select-loader.js +0 -228
  224. package/dist/esm/lib/api/select-loader.js.map +0 -1
  225. package/dist/esm/lib/api/set-loader-options.js +0 -5
  226. package/dist/esm/lib/api/set-loader-options.js.map +0 -1
  227. package/dist/esm/lib/common.js +0 -2
  228. package/dist/esm/lib/common.js.map +0 -1
  229. package/dist/esm/lib/fetch/fetch-error-message.js +0 -21
  230. package/dist/esm/lib/fetch/fetch-error-message.js.map +0 -1
  231. package/dist/esm/lib/fetch/fetch-file.js +0 -17
  232. package/dist/esm/lib/fetch/fetch-file.js.map +0 -1
  233. package/dist/esm/lib/fetch/read-array-buffer.js +0 -29
  234. package/dist/esm/lib/fetch/read-array-buffer.js.map +0 -1
  235. package/dist/esm/lib/fetch/read-file.js +0 -17
  236. package/dist/esm/lib/fetch/read-file.js.map +0 -1
  237. package/dist/esm/lib/fetch/write-file.js +0 -25
  238. package/dist/esm/lib/fetch/write-file.js.map +0 -1
  239. package/dist/esm/lib/filesystems/browser-filesystem.js +0 -115
  240. package/dist/esm/lib/filesystems/browser-filesystem.js.map +0 -1
  241. package/dist/esm/lib/filesystems/filesystem.js +0 -2
  242. package/dist/esm/lib/filesystems/filesystem.js.map +0 -1
  243. package/dist/esm/lib/filesystems/read-array-buffer.js +0 -9
  244. package/dist/esm/lib/filesystems/read-array-buffer.js.map +0 -1
  245. package/dist/esm/lib/init.js +0 -6
  246. package/dist/esm/lib/init.js.map +0 -1
  247. package/dist/esm/lib/loader-utils/check-errors.js +0 -26
  248. package/dist/esm/lib/loader-utils/check-errors.js.map +0 -1
  249. package/dist/esm/lib/loader-utils/get-data.js +0 -129
  250. package/dist/esm/lib/loader-utils/get-data.js.map +0 -1
  251. package/dist/esm/lib/loader-utils/loader-context.js +0 -36
  252. package/dist/esm/lib/loader-utils/loader-context.js.map +0 -1
  253. package/dist/esm/lib/loader-utils/loggers.js +0 -48
  254. package/dist/esm/lib/loader-utils/loggers.js.map +0 -1
  255. package/dist/esm/lib/loader-utils/normalize-loader.js +0 -43
  256. package/dist/esm/lib/loader-utils/normalize-loader.js.map +0 -1
  257. package/dist/esm/lib/loader-utils/option-defaults.js +0 -37
  258. package/dist/esm/lib/loader-utils/option-defaults.js.map +0 -1
  259. package/dist/esm/lib/loader-utils/option-utils.js +0 -140
  260. package/dist/esm/lib/loader-utils/option-utils.js.map +0 -1
  261. package/dist/esm/lib/progress/fetch-progress.js +0 -61
  262. package/dist/esm/lib/progress/fetch-progress.js.map +0 -1
  263. package/dist/esm/lib/utils/mime-type-utils.js +0 -21
  264. package/dist/esm/lib/utils/mime-type-utils.js.map +0 -1
  265. package/dist/esm/lib/utils/resource-utils.js +0 -60
  266. package/dist/esm/lib/utils/resource-utils.js.map +0 -1
  267. package/dist/esm/lib/utils/response-utils.js +0 -115
  268. package/dist/esm/lib/utils/response-utils.js.map +0 -1
  269. package/dist/esm/null-loader.js +0 -34
  270. package/dist/esm/null-loader.js.map +0 -1
  271. package/dist/esm/workers/null-worker.js +0 -4
  272. package/dist/esm/workers/null-worker.js.map +0 -1
@@ -1,41 +1,29 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.readBlob = exports.readArrayBuffer = void 0;
4
- //
5
- const loader_utils_1 = require("@loaders.gl/loader-utils");
6
- /**
7
- * Reads a chunk from a random access file
8
- * @param file
9
- * @param start
10
- * @param length
11
- * @returns
12
- */
13
- async function readArrayBuffer(file, start, length) {
14
- if (typeof file === 'number') {
15
- return await loader_utils_1.fs._readToArrayBuffer(file, start, length);
16
- }
17
- // TODO - we can do better for ArrayBuffer and string
18
- if (!(file instanceof Blob)) {
19
- file = new Blob([file]);
20
- }
21
- const slice = file.slice(start, start + length);
22
- return await readBlob(slice);
1
+ import { fs } from '@loaders.gl/loader-utils';
2
+ export async function readArrayBuffer(file, start, length) {
3
+ if (typeof file === 'number') {
4
+ return await fs._readToArrayBuffer(file, start, length);
5
+ }
6
+
7
+ if (!(file instanceof Blob)) {
8
+ file = new Blob([file]);
9
+ }
10
+
11
+ const slice = file.slice(start, start + length);
12
+ return await readBlob(slice);
23
13
  }
24
- exports.readArrayBuffer = readArrayBuffer;
25
- /**
26
- * Read a slice of a Blob or File, without loading the entire file into memory
27
- * The trick when reading File objects is to read successive "slices" of the File
28
- * Per spec https://w3c.github.io/FileAPI/, slicing a File only updates the start and end fields
29
- * Actually reading from file happens in `readAsArrayBuffer`
30
- * @param blob to read
31
- */
32
- async function readBlob(blob) {
33
- return await new Promise((resolve, reject) => {
34
- const fileReader = new FileReader();
35
- fileReader.onload = (event) => resolve(event?.target?.result);
36
- // TODO - reject with a proper Error
37
- fileReader.onerror = (error) => reject(error);
38
- fileReader.readAsArrayBuffer(blob);
39
- });
14
+ export async function readBlob(blob) {
15
+ return await new Promise((resolve, reject) => {
16
+ const fileReader = new FileReader();
17
+
18
+ fileReader.onload = event => {
19
+ var _event$target;
20
+
21
+ return resolve(event === null || event === void 0 ? void 0 : (_event$target = event.target) === null || _event$target === void 0 ? void 0 : _event$target.result);
22
+ };
23
+
24
+ fileReader.onerror = error => reject(error);
25
+
26
+ fileReader.readAsArrayBuffer(blob);
27
+ });
40
28
  }
41
- exports.readBlob = readBlob;
29
+ //# sourceMappingURL=read-array-buffer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/fetch/read-array-buffer.ts"],"names":["fs","readArrayBuffer","file","start","length","_readToArrayBuffer","Blob","slice","readBlob","blob","Promise","resolve","reject","fileReader","FileReader","onload","event","target","result","onerror","error","readAsArrayBuffer"],"mappings":"AACA,SAAQA,EAAR,QAAiB,0BAAjB;AASA,OAAO,eAAeC,eAAf,CACLC,IADK,EAELC,KAFK,EAGLC,MAHK,EAIiB;AACtB,MAAI,OAAOF,IAAP,KAAgB,QAApB,EAA8B;AAC5B,WAAO,MAAMF,EAAE,CAACK,kBAAH,CAAsBH,IAAtB,EAA4BC,KAA5B,EAAmCC,MAAnC,CAAb;AACD;;AAED,MAAI,EAAEF,IAAI,YAAYI,IAAlB,CAAJ,EAA6B;AAC3BJ,IAAAA,IAAI,GAAG,IAAII,IAAJ,CAAS,CAACJ,IAAD,CAAT,CAAP;AACD;;AACD,QAAMK,KAAK,GAAGL,IAAI,CAACK,KAAL,CAAWJ,KAAX,EAAkBA,KAAK,GAAGC,MAA1B,CAAd;AACA,SAAO,MAAMI,QAAQ,CAACD,KAAD,CAArB;AACD;AASD,OAAO,eAAeC,QAAf,CAAwBC,IAAxB,EAA0D;AAC/D,SAAO,MAAM,IAAIC,OAAJ,CAAY,CAACC,OAAD,EAAUC,MAAV,KAAqB;AAC5C,UAAMC,UAAU,GAAG,IAAIC,UAAJ,EAAnB;;AACAD,IAAAA,UAAU,CAACE,MAAX,GAAqBC,KAAD;AAAA;;AAAA,aAClBL,OAAO,CAACK,KAAD,aAACA,KAAD,wCAACA,KAAK,CAAEC,MAAR,kDAAC,cAAeC,MAAhB,CADW;AAAA,KAApB;;AAGAL,IAAAA,UAAU,CAACM,OAAX,GAAsBC,KAAD,IAAsCR,MAAM,CAACQ,KAAD,CAAjE;;AACAP,IAAAA,UAAU,CAACQ,iBAAX,CAA6BZ,IAA7B;AACD,GAPY,CAAb;AAQD","sourcesContent":["//\nimport {fs} from '@loaders.gl/loader-utils';\n\n/**\n * Reads a chunk from a random access file\n * @param file\n * @param start\n * @param length\n * @returns\n */\nexport async function readArrayBuffer(\n file: Blob | ArrayBuffer | string | number,\n start: number,\n length: number\n): Promise<ArrayBuffer> {\n if (typeof file === 'number') {\n return await fs._readToArrayBuffer(file, start, length);\n }\n // TODO - we can do better for ArrayBuffer and string\n if (!(file instanceof Blob)) {\n file = new Blob([file]);\n }\n const slice = file.slice(start, start + length);\n return await readBlob(slice);\n}\n\n/**\n * Read a slice of a Blob or File, without loading the entire file into memory\n * The trick when reading File objects is to read successive \"slices\" of the File\n * Per spec https://w3c.github.io/FileAPI/, slicing a File only updates the start and end fields\n * Actually reading from file happens in `readAsArrayBuffer`\n * @param blob to read\n */\nexport async function readBlob(blob: Blob): Promise<ArrayBuffer> {\n return await new Promise((resolve, reject) => {\n const fileReader = new FileReader();\n fileReader.onload = (event: ProgressEvent<FileReader>) =>\n resolve(event?.target?.result as ArrayBuffer);\n // TODO - reject with a proper Error\n fileReader.onerror = (error: ProgressEvent<FileReader>) => reject(error);\n fileReader.readAsArrayBuffer(blob);\n });\n}\n"],"file":"read-array-buffer.js"}
@@ -1,29 +1,17 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.readFileSync = void 0;
4
- // File read
5
- const loader_utils_1 = require("@loaders.gl/loader-utils");
6
- const loader_utils_2 = require("@loaders.gl/loader-utils");
7
- // TODO - this is not tested
8
- // const isDataURL = (url) => url.startsWith('data:');
9
- /**
10
- * In a few cases (data URIs, node.js) "files" can be read synchronously
11
- */
12
- function readFileSync(url, options = {}) {
13
- url = (0, loader_utils_1.resolvePath)(url);
14
- // Only support this if we can also support sync data URL decoding in browser
15
- // if (isDataURL(url)) {
16
- // return decodeDataUri(url);
17
- // }
18
- if (!loader_utils_1.isBrowser) {
19
- const buffer = loader_utils_1.fs.readFileSync(url, options);
20
- return typeof buffer !== 'string' ? (0, loader_utils_1.toArrayBuffer)(buffer) : buffer;
21
- }
22
- // @ts-ignore
23
- if (!options.nothrow) {
24
- // throw new Error('Cant load URI synchronously');
25
- (0, loader_utils_2.assert)(false);
26
- }
27
- return null;
1
+ import { isBrowser, resolvePath, fs, toArrayBuffer } from '@loaders.gl/loader-utils';
2
+ import { assert } from '@loaders.gl/loader-utils';
3
+ export function readFileSync(url, options = {}) {
4
+ url = resolvePath(url);
5
+
6
+ if (!isBrowser) {
7
+ const buffer = fs.readFileSync(url, options);
8
+ return typeof buffer !== 'string' ? toArrayBuffer(buffer) : buffer;
9
+ }
10
+
11
+ if (!options.nothrow) {
12
+ assert(false);
13
+ }
14
+
15
+ return null;
28
16
  }
29
- exports.readFileSync = readFileSync;
17
+ //# sourceMappingURL=read-file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/fetch/read-file.ts"],"names":["isBrowser","resolvePath","fs","toArrayBuffer","assert","readFileSync","url","options","buffer","nothrow"],"mappings":"AACA,SAAQA,SAAR,EAAmBC,WAAnB,EAAgCC,EAAhC,EAAoCC,aAApC,QAAwD,0BAAxD;AACA,SAAQC,MAAR,QAAqB,0BAArB;AAQA,OAAO,SAASC,YAAT,CAAsBC,GAAtB,EAAmCC,OAAe,GAAG,EAArD,EAAyD;AAC9DD,EAAAA,GAAG,GAAGL,WAAW,CAACK,GAAD,CAAjB;;AAOA,MAAI,CAACN,SAAL,EAAgB;AACd,UAAMQ,MAAM,GAAGN,EAAE,CAACG,YAAH,CAAgBC,GAAhB,EAAqBC,OAArB,CAAf;AACA,WAAO,OAAOC,MAAP,KAAkB,QAAlB,GAA6BL,aAAa,CAACK,MAAD,CAA1C,GAAqDA,MAA5D;AACD;;AAGD,MAAI,CAACD,OAAO,CAACE,OAAb,EAAsB;AAEpBL,IAAAA,MAAM,CAAC,KAAD,CAAN;AACD;;AAED,SAAO,IAAP;AACD","sourcesContent":["// File read\nimport {isBrowser, resolvePath, fs, toArrayBuffer} from '@loaders.gl/loader-utils';\nimport {assert} from '@loaders.gl/loader-utils';\n\n// TODO - this is not tested\n// const isDataURL = (url) => url.startsWith('data:');\n\n/**\n * In a few cases (data URIs, node.js) \"files\" can be read synchronously\n */\nexport function readFileSync(url: string, options: object = {}) {\n url = resolvePath(url);\n\n // Only support this if we can also support sync data URL decoding in browser\n // if (isDataURL(url)) {\n // return decodeDataUri(url);\n // }\n\n if (!isBrowser) {\n const buffer = fs.readFileSync(url, options);\n return typeof buffer !== 'string' ? toArrayBuffer(buffer) : buffer;\n }\n\n // @ts-ignore\n if (!options.nothrow) {\n // throw new Error('Cant load URI synchronously');\n assert(false);\n }\n\n return null;\n}\n"],"file":"read-file.js"}
@@ -1,22 +1,25 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.writeFileSync = exports.writeFile = void 0;
4
- // file write
5
- const loader_utils_1 = require("@loaders.gl/loader-utils");
6
- const loader_utils_2 = require("@loaders.gl/loader-utils");
7
- async function writeFile(filePath, arrayBufferOrString, options) {
8
- filePath = (0, loader_utils_1.resolvePath)(filePath);
9
- if (!loader_utils_1.isBrowser) {
10
- await loader_utils_2.fs.writeFile(filePath, (0, loader_utils_2.toBuffer)(arrayBufferOrString), { flag: 'w' });
11
- }
12
- (0, loader_utils_1.assert)(false);
1
+ import { isBrowser, assert, resolvePath } from '@loaders.gl/loader-utils';
2
+ import { fs, toBuffer } from '@loaders.gl/loader-utils';
3
+ export async function writeFile(filePath, arrayBufferOrString, options) {
4
+ filePath = resolvePath(filePath);
5
+
6
+ if (!isBrowser) {
7
+ await fs.writeFile(filePath, toBuffer(arrayBufferOrString), {
8
+ flag: 'w'
9
+ });
10
+ }
11
+
12
+ assert(false);
13
13
  }
14
- exports.writeFile = writeFile;
15
- function writeFileSync(filePath, arrayBufferOrString, options) {
16
- filePath = (0, loader_utils_1.resolvePath)(filePath);
17
- if (!loader_utils_1.isBrowser) {
18
- loader_utils_2.fs.writeFileSync(filePath, (0, loader_utils_2.toBuffer)(arrayBufferOrString), { flag: 'w' });
19
- }
20
- (0, loader_utils_1.assert)(false);
14
+ export function writeFileSync(filePath, arrayBufferOrString, options) {
15
+ filePath = resolvePath(filePath);
16
+
17
+ if (!isBrowser) {
18
+ fs.writeFileSync(filePath, toBuffer(arrayBufferOrString), {
19
+ flag: 'w'
20
+ });
21
+ }
22
+
23
+ assert(false);
21
24
  }
22
- exports.writeFileSync = writeFileSync;
25
+ //# sourceMappingURL=write-file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/fetch/write-file.ts"],"names":["isBrowser","assert","resolvePath","fs","toBuffer","writeFile","filePath","arrayBufferOrString","options","flag","writeFileSync"],"mappings":"AACA,SAAQA,SAAR,EAAmBC,MAAnB,EAA2BC,WAA3B,QAA6C,0BAA7C;AACA,SAAQC,EAAR,EAAYC,QAAZ,QAA2B,0BAA3B;AAEA,OAAO,eAAeC,SAAf,CACLC,QADK,EAELC,mBAFK,EAGLC,OAHK,EAIU;AACfF,EAAAA,QAAQ,GAAGJ,WAAW,CAACI,QAAD,CAAtB;;AACA,MAAI,CAACN,SAAL,EAAgB;AACd,UAAMG,EAAE,CAACE,SAAH,CAAaC,QAAb,EAAuBF,QAAQ,CAACG,mBAAD,CAA/B,EAAsD;AAACE,MAAAA,IAAI,EAAE;AAAP,KAAtD,CAAN;AACD;;AACDR,EAAAA,MAAM,CAAC,KAAD,CAAN;AACD;AAED,OAAO,SAASS,aAAT,CACLJ,QADK,EAELC,mBAFK,EAGLC,OAHK,EAIC;AACNF,EAAAA,QAAQ,GAAGJ,WAAW,CAACI,QAAD,CAAtB;;AACA,MAAI,CAACN,SAAL,EAAgB;AACdG,IAAAA,EAAE,CAACO,aAAH,CAAiBJ,QAAjB,EAA2BF,QAAQ,CAACG,mBAAD,CAAnC,EAA0D;AAACE,MAAAA,IAAI,EAAE;AAAP,KAA1D;AACD;;AACDR,EAAAA,MAAM,CAAC,KAAD,CAAN;AACD","sourcesContent":["// file write\nimport {isBrowser, assert, resolvePath} from '@loaders.gl/loader-utils';\nimport {fs, toBuffer} from '@loaders.gl/loader-utils';\n\nexport async function writeFile(\n filePath: string,\n arrayBufferOrString: ArrayBuffer | string,\n options?\n): Promise<void> {\n filePath = resolvePath(filePath);\n if (!isBrowser) {\n await fs.writeFile(filePath, toBuffer(arrayBufferOrString), {flag: 'w'});\n }\n assert(false);\n}\n\nexport function writeFileSync(\n filePath: string,\n arrayBufferOrString: ArrayBuffer | string,\n options?\n): void {\n filePath = resolvePath(filePath);\n if (!isBrowser) {\n fs.writeFileSync(filePath, toBuffer(arrayBufferOrString), {flag: 'w'});\n }\n assert(false);\n}\n"],"file":"write-file.js"}
@@ -1,126 +1,115 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- /**
4
- * FileSystem adapter for a browser FileList.
5
- * Holds a list of browser 'File' objects.
6
- */
7
- class BrowserFileSystem {
8
- /**
9
- * A FileSystem API wrapper around a list of browser 'File' objects
10
- * @param files
11
- * @param options
12
- */
13
- constructor(files, options) {
14
- this.files = {};
15
- this.lowerCaseFiles = {};
16
- this.usedFiles = {};
17
- this._fetch = options?.fetch || fetch;
18
- for (let i = 0; i < files.length; ++i) {
19
- const file = files[i];
20
- this.files[file.name] = file;
21
- this.lowerCaseFiles[file.name.toLowerCase()] = file;
22
- this.usedFiles[file.name] = false;
23
- }
24
- this.fetch = this.fetch.bind(this);
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
+ export default class BrowserFileSystem {
3
+ constructor(files, options) {
4
+ _defineProperty(this, "_fetch", void 0);
5
+
6
+ _defineProperty(this, "files", {});
7
+
8
+ _defineProperty(this, "lowerCaseFiles", {});
9
+
10
+ _defineProperty(this, "usedFiles", {});
11
+
12
+ this._fetch = (options === null || options === void 0 ? void 0 : options.fetch) || fetch;
13
+
14
+ for (let i = 0; i < files.length; ++i) {
15
+ const file = files[i];
16
+ this.files[file.name] = file;
17
+ this.lowerCaseFiles[file.name.toLowerCase()] = file;
18
+ this.usedFiles[file.name] = false;
25
19
  }
26
- // implements IFileSystem
27
- /**
28
- * Implementation of fetch against this file system
29
- * Delegates to global fetch for http{s}:// or data://
30
- */
31
- async fetch(path, options) {
32
- // Fallback to handle https:/http:/data: etc fetches
33
- if (path.includes('://')) {
34
- return this._fetch(path, options);
35
- }
36
- // Local fetches are served from the list of files
37
- const file = this.files[path];
38
- if (!file) {
39
- return new Response(path, { status: 400, statusText: 'NOT FOUND' });
40
- }
41
- const headers = new Headers(options?.headers);
42
- const range = headers.get('Range');
43
- const bytes = range && /bytes=($1)-($2)/.exec(range);
44
- if (bytes) {
45
- const start = parseInt(bytes[1]);
46
- const end = parseInt(bytes[2]);
47
- // The trick when reading File objects is to read successive "slices" of the File
48
- // Per spec https://w3c.github.io/FileAPI/, slicing a File should only update the start and end fields
49
- // Actually reading from file should happen in `readAsArrayBuffer` (and as far we can tell it does)
50
- const data = await file.slice(start, end).arrayBuffer();
51
- const response = new Response(data);
52
- Object.defineProperty(response, 'url', { value: path });
53
- return response;
54
- }
55
- // return makeResponse()
56
- const response = new Response(file);
57
- Object.defineProperty(response, 'url', { value: path });
58
- return response;
20
+
21
+ this.fetch = this.fetch.bind(this);
22
+ }
23
+
24
+ async fetch(path, options) {
25
+ if (path.includes('://')) {
26
+ return this._fetch(path, options);
59
27
  }
60
- /**
61
- * List filenames in this filesystem
62
- * @param dirname
63
- * @returns
64
- */
65
- async readdir(dirname) {
66
- const files = [];
67
- for (const path in this.files) {
68
- files.push(path);
69
- }
70
- // TODO filter by dirname
71
- return files;
28
+
29
+ const file = this.files[path];
30
+
31
+ if (!file) {
32
+ return new Response(path, {
33
+ status: 400,
34
+ statusText: 'NOT FOUND'
35
+ });
72
36
  }
73
- /**
74
- * Return information (size) about files in this file system
75
- */
76
- async stat(path, options) {
77
- const file = this.files[path];
78
- if (!file) {
79
- throw new Error(path);
80
- }
81
- return { size: file.size };
37
+
38
+ const headers = new Headers(options === null || options === void 0 ? void 0 : options.headers);
39
+ const range = headers.get('Range');
40
+ const bytes = range && /bytes=($1)-($2)/.exec(range);
41
+
42
+ if (bytes) {
43
+ const start = parseInt(bytes[1]);
44
+ const end = parseInt(bytes[2]);
45
+ const data = await file.slice(start, end).arrayBuffer();
46
+ const response = new Response(data);
47
+ Object.defineProperty(response, 'url', {
48
+ value: path
49
+ });
50
+ return response;
82
51
  }
83
- /**
84
- * Just removes the file from the list
85
- */
86
- async unlink(path) {
87
- delete this.files[path];
88
- delete this.lowerCaseFiles[path];
89
- this.usedFiles[path] = true;
52
+
53
+ const response = new Response(file);
54
+ Object.defineProperty(response, 'url', {
55
+ value: path
56
+ });
57
+ return response;
58
+ }
59
+
60
+ async readdir(dirname) {
61
+ const files = [];
62
+
63
+ for (const path in this.files) {
64
+ files.push(path);
90
65
  }
91
- // implements IRandomAccessFileSystem
92
- // RANDOM ACCESS
93
- async open(pathname, flags, mode) {
94
- return this.files[pathname];
66
+
67
+ return files;
68
+ }
69
+
70
+ async stat(path, options) {
71
+ const file = this.files[path];
72
+
73
+ if (!file) {
74
+ throw new Error(path);
95
75
  }
96
- /**
97
- * Read a range into a buffer
98
- * @todo - handle position memory
99
- * @param buffer is the buffer that the data (read from the fd) will be written to.
100
- * @param offset is the offset in the buffer to start writing at.
101
- * @param length is an integer specifying the number of bytes to read.
102
- * @param position is an argument specifying where to begin reading from in the file. If position is null, data will be read from the current file position, and the file position will be updated. If position is an integer, the file position will remain unchanged.
103
- */
104
- async read(fd, buffer, offset = 0, length = buffer.byteLength, position = null) {
105
- const file = fd;
106
- const startPosition = 0; // position
107
- const arrayBuffer = await file.slice(startPosition, startPosition + length).arrayBuffer();
108
- // copy into target buffer
109
- return { bytesRead: length, buffer: arrayBuffer };
110
- }
111
- async close(fd) {
112
- // NO OP
113
- }
114
- // fstat(fd: number): Promise<object>; // Stat
115
- // PRIVATE
116
- // Supports case independent paths, and file usage tracking
117
- _getFile(path, used) {
118
- // Prefer case match, but fall back to case indepent.
119
- const file = this.files[path] || this.lowerCaseFiles[path];
120
- if (file && used) {
121
- this.usedFiles[path] = true;
122
- }
123
- return file;
76
+
77
+ return {
78
+ size: file.size
79
+ };
80
+ }
81
+
82
+ async unlink(path) {
83
+ delete this.files[path];
84
+ delete this.lowerCaseFiles[path];
85
+ this.usedFiles[path] = true;
86
+ }
87
+
88
+ async open(pathname, flags, mode) {
89
+ return this.files[pathname];
90
+ }
91
+
92
+ async read(fd, buffer, offset = 0, length = buffer.byteLength, position = null) {
93
+ const file = fd;
94
+ const startPosition = 0;
95
+ const arrayBuffer = await file.slice(startPosition, startPosition + length).arrayBuffer();
96
+ return {
97
+ bytesRead: length,
98
+ buffer: arrayBuffer
99
+ };
100
+ }
101
+
102
+ async close(fd) {}
103
+
104
+ _getFile(path, used) {
105
+ const file = this.files[path] || this.lowerCaseFiles[path];
106
+
107
+ if (file && used) {
108
+ this.usedFiles[path] = true;
124
109
  }
110
+
111
+ return file;
112
+ }
113
+
125
114
  }
126
- exports.default = BrowserFileSystem;
115
+ //# sourceMappingURL=browser-filesystem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/filesystems/browser-filesystem.ts"],"names":["BrowserFileSystem","constructor","files","options","_fetch","fetch","i","length","file","name","lowerCaseFiles","toLowerCase","usedFiles","bind","path","includes","Response","status","statusText","headers","Headers","range","get","bytes","exec","start","parseInt","end","data","slice","arrayBuffer","response","Object","defineProperty","value","readdir","dirname","push","stat","Error","size","unlink","open","pathname","flags","mode","read","fd","buffer","offset","byteLength","position","startPosition","bytesRead","close","_getFile","used"],"mappings":"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","sourcesContent":["import type {FileSystem} from './filesystem';\n\ntype BrowserFileSystemOptions = {\n fetch?: typeof fetch;\n};\n\n/**\n * FileSystem adapter for a browser FileList.\n * Holds a list of browser 'File' objects.\n */\nexport default class BrowserFileSystem implements FileSystem {\n private _fetch: typeof fetch;\n private files: {[filename: string]: File} = {};\n private lowerCaseFiles: {[filename: string]: File} = {};\n private usedFiles: {[filename: string]: boolean} = {};\n\n /**\n * A FileSystem API wrapper around a list of browser 'File' objects\n * @param files\n * @param options\n */\n constructor(files: FileList | File[], options?: BrowserFileSystemOptions) {\n this._fetch = options?.fetch || fetch;\n\n for (let i = 0; i < files.length; ++i) {\n const file = files[i];\n this.files[file.name] = file;\n this.lowerCaseFiles[file.name.toLowerCase()] = file;\n this.usedFiles[file.name] = false;\n }\n\n this.fetch = this.fetch.bind(this);\n }\n\n // implements IFileSystem\n\n /**\n * Implementation of fetch against this file system\n * Delegates to global fetch for http{s}:// or data://\n */\n async fetch(path: string, options?: RequestInit): Promise<Response> {\n // Fallback to handle https:/http:/data: etc fetches\n if (path.includes('://')) {\n return this._fetch(path, options);\n }\n\n // Local fetches are served from the list of files\n const file = this.files[path];\n if (!file) {\n return new Response(path, {status: 400, statusText: 'NOT FOUND'});\n }\n\n const headers = new Headers(options?.headers);\n const range = headers.get('Range');\n const bytes = range && /bytes=($1)-($2)/.exec(range);\n\n if (bytes) {\n const start = parseInt(bytes[1]);\n const end = parseInt(bytes[2]);\n // The trick when reading File objects is to read successive \"slices\" of the File\n // Per spec https://w3c.github.io/FileAPI/, slicing a File should only update the start and end fields\n // Actually reading from file should happen in `readAsArrayBuffer` (and as far we can tell it does)\n const data = await file.slice(start, end).arrayBuffer();\n const response = new Response(data);\n Object.defineProperty(response, 'url', {value: path});\n return response;\n }\n\n // return makeResponse()\n const response = new Response(file);\n Object.defineProperty(response, 'url', {value: path});\n return response;\n }\n\n /**\n * List filenames in this filesystem\n * @param dirname\n * @returns\n */\n async readdir(dirname?: string): Promise<string[]> {\n const files: string[] = [];\n for (const path in this.files) {\n files.push(path);\n }\n // TODO filter by dirname\n return files;\n }\n\n /**\n * Return information (size) about files in this file system\n */\n async stat(path: string, options?: object): Promise<{size: number}> {\n const file = this.files[path];\n if (!file) {\n throw new Error(path);\n }\n return {size: file.size};\n }\n\n /**\n * Just removes the file from the list\n */\n async unlink(path: string): Promise<void> {\n delete this.files[path];\n delete this.lowerCaseFiles[path];\n this.usedFiles[path] = true;\n }\n\n // implements IRandomAccessFileSystem\n\n // RANDOM ACCESS\n async open(pathname: string, flags, mode?): Promise<any> {\n return this.files[pathname];\n }\n\n /**\n * Read a range into a buffer\n * @todo - handle position memory\n * @param buffer is the buffer that the data (read from the fd) will be written to.\n * @param offset is the offset in the buffer to start writing at.\n * @param length is an integer specifying the number of bytes to read.\n * @param position is an argument specifying where to begin reading from in the file. If position is null, data will be read from the current file position, and the file position will be updated. If position is an integer, the file position will remain unchanged.\n */\n async read(\n fd: any,\n buffer: ArrayBuffer,\n offset: number = 0,\n length: number = buffer.byteLength,\n position: number | null = null\n ): Promise<{bytesRead: number; buffer: ArrayBuffer}> {\n const file = fd as File;\n const startPosition = 0; // position\n const arrayBuffer = await file.slice(startPosition, startPosition + length).arrayBuffer();\n // copy into target buffer\n return {bytesRead: length, buffer: arrayBuffer};\n }\n\n async close(fd: number): Promise<void> {\n // NO OP\n }\n\n // fstat(fd: number): Promise<object>; // Stat\n\n // PRIVATE\n\n // Supports case independent paths, and file usage tracking\n _getFile(path, used) {\n // Prefer case match, but fall back to case indepent.\n const file = this.files[path] || this.lowerCaseFiles[path];\n if (file && used) {\n this.usedFiles[path] = true;\n }\n return file;\n }\n}\n"],"file":"browser-filesystem.js"}
@@ -1,2 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ export {};
2
+ //# sourceMappingURL=filesystem.js.map
@@ -1,29 +1,9 @@
1
- "use strict";
2
- // Random-Access read
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.readArrayBuffer = void 0;
5
- async function readArrayBuffer(file, start, length) {
6
- if (file instanceof Blob) {
7
- const slice = file.slice(start, start + length);
8
- return await slice.arrayBuffer();
9
- }
10
- return await file.read(start, start + length);
1
+ export async function readArrayBuffer(file, start, length) {
2
+ if (file instanceof Blob) {
3
+ const slice = file.slice(start, start + length);
4
+ return await slice.arrayBuffer();
5
+ }
6
+
7
+ return await file.read(start, start + length);
11
8
  }
12
- exports.readArrayBuffer = readArrayBuffer;
13
- /**
14
- * Read a slice of a Blob or File, without loading the entire file into memory
15
- * The trick when reading File objects is to read successive "slices" of the File
16
- * Per spec https://w3c.github.io/FileAPI/, slicing a File only updates the start and end fields
17
- * Actually reading from file happens in `readAsArrayBuffer`
18
- * @param blob to read
19
- export async function readBlob(blob: Blob): Promise<ArrayBuffer> {
20
- return await new Promise((resolve, reject) => {
21
- const fileReader = new FileReader();
22
- fileReader.onload = (event: ProgressEvent<FileReader>) =>
23
- resolve(event?.target?.result as ArrayBuffer);
24
- // TODO - reject with a proper Error
25
- fileReader.onerror = (error: ProgressEvent<FileReader>) => reject(error);
26
- fileReader.readAsArrayBuffer(blob);
27
- });
28
- }
29
- */
9
+ //# sourceMappingURL=read-array-buffer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/filesystems/read-array-buffer.ts"],"names":["readArrayBuffer","file","start","length","Blob","slice","arrayBuffer","read"],"mappings":"AAEA,OAAO,eAAeA,eAAf,CACLC,IADK,EAELC,KAFK,EAGLC,MAHK,EAIiB;AACtB,MAAIF,IAAI,YAAYG,IAApB,EAA0B;AACxB,UAAMC,KAAK,GAAGJ,IAAI,CAACI,KAAL,CAAWH,KAAX,EAAkBA,KAAK,GAAGC,MAA1B,CAAd;AACA,WAAO,MAAME,KAAK,CAACC,WAAN,EAAb;AACD;;AACD,SAAO,MAAML,IAAI,CAACM,IAAL,CAAUL,KAAV,EAAiBA,KAAK,GAAGC,MAAzB,CAAb;AACD","sourcesContent":["// Random-Access read\n\nexport async function readArrayBuffer(\n file: Blob | ArrayBuffer | any,\n start: number,\n length: number\n): Promise<ArrayBuffer> {\n if (file instanceof Blob) {\n const slice = file.slice(start, start + length);\n return await slice.arrayBuffer();\n }\n return await file.read(start, start + length);\n}\n\n/**\n * Read a slice of a Blob or File, without loading the entire file into memory\n * The trick when reading File objects is to read successive \"slices\" of the File\n * Per spec https://w3c.github.io/FileAPI/, slicing a File only updates the start and end fields\n * Actually reading from file happens in `readAsArrayBuffer`\n * @param blob to read\n export async function readBlob(blob: Blob): Promise<ArrayBuffer> {\n return await new Promise((resolve, reject) => {\n const fileReader = new FileReader();\n fileReader.onload = (event: ProgressEvent<FileReader>) =>\n resolve(event?.target?.result as ArrayBuffer);\n // TODO - reject with a proper Error\n fileReader.onerror = (error: ProgressEvent<FileReader>) => reject(error);\n fileReader.readAsArrayBuffer(blob);\n });\n}\n*/\n"],"file":"read-array-buffer.js"}
package/dist/lib/init.js CHANGED
@@ -1,10 +1,6 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- // @ts-ignore TS2304: Cannot find name '__VERSION__'.
4
- const version = typeof __VERSION__ !== 'undefined' ? __VERSION__ : '';
5
- // @ts-ignore
1
+ const version = typeof "4.0.0-alpha.5" !== 'undefined' ? "4.0.0-alpha.5" : '';
6
2
  globalThis.loaders = Object.assign(globalThis.loaders || {}, {
7
- VERSION: version
3
+ VERSION: version
8
4
  });
9
- // @ts-ignore
10
- exports.default = globalThis.loaders;
5
+ export default globalThis.loaders;
6
+ //# sourceMappingURL=init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lib/init.ts"],"names":["version","globalThis","loaders","Object","assign","VERSION"],"mappings":"AACA,MAAMA,OAAO,GAAG,2BAAuB,WAAvB,qBAAmD,EAAnE;AAGAC,UAAU,CAACC,OAAX,GAAqBC,MAAM,CAACC,MAAP,CAAcH,UAAU,CAACC,OAAX,IAAsB,EAApC,EAAwC;AAC3DG,EAAAA,OAAO,EAAEL;AADkD,CAAxC,CAArB;AAKA,eAAeC,UAAU,CAACC,OAA1B","sourcesContent":["// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst version = typeof __VERSION__ !== 'undefined' ? __VERSION__ : '';\n\n// @ts-ignore\nglobalThis.loaders = Object.assign(globalThis.loaders || {}, {\n VERSION: version\n});\n\n// @ts-ignore\nexport default globalThis.loaders;\n"],"file":"init.js"}
@@ -1,30 +1,26 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.checkFetchResponseStatusSync = exports.checkFetchResponseStatus = void 0;
4
- async function checkFetchResponseStatus(response) {
5
- if (!response.ok) {
6
- let errorMessage = `fetch failed ${response.status} ${response.statusText}`;
7
- try {
8
- const text = await response.text();
9
- if (text) {
10
- errorMessage += `: ${getErrorText(text)}`;
11
- }
12
- }
13
- catch (error) {
14
- // ignore error
15
- }
16
- throw new Error(errorMessage);
17
- }
1
+ export async function checkFetchResponseStatus(response) {
2
+ if (!response.ok) {
3
+ let errorMessage = "fetch failed ".concat(response.status, " ").concat(response.statusText);
4
+
5
+ try {
6
+ const text = await response.text();
7
+
8
+ if (text) {
9
+ errorMessage += ": ".concat(getErrorText(text));
10
+ }
11
+ } catch (error) {}
12
+
13
+ throw new Error(errorMessage);
14
+ }
18
15
  }
19
- exports.checkFetchResponseStatus = checkFetchResponseStatus;
20
- function checkFetchResponseStatusSync(response) {
21
- if (!response.ok) {
22
- throw new Error(`fetch failed ${response.status}`);
23
- }
16
+ export function checkFetchResponseStatusSync(response) {
17
+ if (!response.ok) {
18
+ throw new Error("fetch failed ".concat(response.status));
19
+ }
24
20
  }
25
- exports.checkFetchResponseStatusSync = checkFetchResponseStatusSync;
21
+
26
22
  function getErrorText(text) {
27
- // Look for HTML error texts
28
- const matches = text.match('<pre>(.*)</pre>');
29
- return matches ? matches[1] : ` ${text.slice(0, 10)}...`;
23
+ const matches = text.match('<pre>(.*)</pre>');
24
+ return matches ? matches[1] : " ".concat(text.slice(0, 10), "...");
30
25
  }
26
+ //# sourceMappingURL=check-errors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/loader-utils/check-errors.ts"],"names":["checkFetchResponseStatus","response","ok","errorMessage","status","statusText","text","getErrorText","error","Error","checkFetchResponseStatusSync","matches","match","slice"],"mappings":"AAAA,OAAO,eAAeA,wBAAf,CAAwCC,QAAxC,EAAkD;AACvD,MAAI,CAACA,QAAQ,CAACC,EAAd,EAAkB;AAChB,QAAIC,YAAY,0BAAmBF,QAAQ,CAACG,MAA5B,cAAsCH,QAAQ,CAACI,UAA/C,CAAhB;;AACA,QAAI;AACF,YAAMC,IAAI,GAAG,MAAML,QAAQ,CAACK,IAAT,EAAnB;;AACA,UAAIA,IAAJ,EAAU;AACRH,QAAAA,YAAY,gBAASI,YAAY,CAACD,IAAD,CAArB,CAAZ;AACD;AACF,KALD,CAKE,OAAOE,KAAP,EAAc,CAEf;;AACD,UAAM,IAAIC,KAAJ,CAAUN,YAAV,CAAN;AACD;AACF;AAED,OAAO,SAASO,4BAAT,CAAsCT,QAAtC,EAAgD;AACrD,MAAI,CAACA,QAAQ,CAACC,EAAd,EAAkB;AAChB,UAAM,IAAIO,KAAJ,wBAA0BR,QAAQ,CAACG,MAAnC,EAAN;AACD;AACF;;AAED,SAASG,YAAT,CAAsBD,IAAtB,EAA4B;AAE1B,QAAMK,OAAO,GAAGL,IAAI,CAACM,KAAL,CAAW,iBAAX,CAAhB;AACA,SAAOD,OAAO,GAAGA,OAAO,CAAC,CAAD,CAAV,cAAoBL,IAAI,CAACO,KAAL,CAAW,CAAX,EAAc,EAAd,CAApB,QAAd;AACD","sourcesContent":["export async function checkFetchResponseStatus(response) {\n if (!response.ok) {\n let errorMessage = `fetch failed ${response.status} ${response.statusText}`;\n try {\n const text = await response.text();\n if (text) {\n errorMessage += `: ${getErrorText(text)}`;\n }\n } catch (error) {\n // ignore error\n }\n throw new Error(errorMessage);\n }\n}\n\nexport function checkFetchResponseStatusSync(response) {\n if (!response.ok) {\n throw new Error(`fetch failed ${response.status}`);\n }\n}\n\nfunction getErrorText(text) {\n // Look for HTML error texts\n const matches = text.match('<pre>(.*)</pre>');\n return matches ? matches[1] : ` ${text.slice(0, 10)}...`;\n}\n"],"file":"check-errors.js"}