@loaders.gl/core 4.0.0-alpha.8 → 4.0.0-beta.1

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 (344) hide show
  1. package/dist/dist.min.js +172 -175
  2. package/dist/es5/index.js +10 -5
  3. package/dist/es5/index.js.map +1 -1
  4. package/dist/es5/iterators/batch-iterators/timed-batch-iterator.js.map +1 -1
  5. package/dist/es5/iterators/make-stream/make-dom-stream.js.map +1 -1
  6. package/dist/es5/iterators/make-stream/make-node-stream.js.map +1 -1
  7. package/dist/es5/javascript-utils/is-type.js +1 -1
  8. package/dist/es5/javascript-utils/is-type.js.map +1 -1
  9. package/dist/es5/lib/api/encode-table.js +6 -4
  10. package/dist/es5/lib/api/encode-table.js.map +1 -1
  11. package/dist/es5/lib/api/encode.js +14 -4
  12. package/dist/es5/lib/api/encode.js.map +1 -1
  13. package/dist/es5/lib/api/load-in-batches.js +40 -11
  14. package/dist/es5/lib/api/load-in-batches.js.map +1 -1
  15. package/dist/es5/lib/api/load.js.map +1 -1
  16. package/dist/es5/lib/api/parse-in-batches.js +12 -14
  17. package/dist/es5/lib/api/parse-in-batches.js.map +1 -1
  18. package/dist/es5/lib/api/parse-sync.js +2 -6
  19. package/dist/es5/lib/api/parse-sync.js.map +1 -1
  20. package/dist/es5/lib/api/parse.js +38 -39
  21. package/dist/es5/lib/api/parse.js.map +1 -1
  22. package/dist/es5/lib/api/save.js.map +1 -1
  23. package/dist/es5/lib/api/select-loader.js +5 -3
  24. package/dist/es5/lib/api/select-loader.js.map +1 -1
  25. package/dist/es5/lib/fetch/fetch-file.js +26 -8
  26. package/dist/es5/lib/fetch/fetch-file.js.map +1 -1
  27. package/dist/es5/lib/fetch/fetch-file.node.js +86 -0
  28. package/dist/es5/lib/fetch/fetch-file.node.js.map +1 -0
  29. package/dist/es5/lib/filesystems/browser-filesystem.js +2 -2
  30. package/dist/es5/lib/filesystems/browser-filesystem.js.map +1 -1
  31. package/dist/es5/lib/filesystems/read-array-buffer.js.map +1 -1
  32. package/dist/es5/lib/init.js +1 -1
  33. package/dist/es5/lib/init.js.map +1 -1
  34. package/dist/es5/lib/loader-utils/check-errors.js +1 -1
  35. package/dist/es5/lib/loader-utils/check-errors.js.map +1 -1
  36. package/dist/es5/lib/loader-utils/get-data.js +1 -1
  37. package/dist/es5/lib/loader-utils/get-data.js.map +1 -1
  38. package/dist/es5/lib/loader-utils/get-fetch-function.js +5 -5
  39. package/dist/es5/lib/loader-utils/get-fetch-function.js.map +1 -1
  40. package/dist/es5/lib/loader-utils/loader-context.js +2 -2
  41. package/dist/es5/lib/loader-utils/loader-context.js.map +1 -1
  42. package/dist/es5/lib/loader-utils/loggers.js.map +1 -1
  43. package/dist/es5/lib/loader-utils/option-defaults.js +1 -0
  44. package/dist/es5/lib/loader-utils/option-defaults.js.map +1 -1
  45. package/dist/es5/lib/loader-utils/option-utils.js +3 -4
  46. package/dist/es5/lib/loader-utils/option-utils.js.map +1 -1
  47. package/dist/es5/lib/progress/fetch-progress.js +1 -1
  48. package/dist/es5/lib/progress/fetch-progress.js.map +1 -1
  49. package/dist/es5/null-loader.js +6 -14
  50. package/dist/es5/null-loader.js.map +1 -1
  51. package/dist/esm/index.js +4 -3
  52. package/dist/esm/index.js.map +1 -1
  53. package/dist/esm/iterators/batch-iterators/timed-batch-iterator.js.map +1 -1
  54. package/dist/esm/iterators/make-stream/make-dom-stream.js.map +1 -1
  55. package/dist/esm/iterators/make-stream/make-node-stream.js.map +1 -1
  56. package/dist/esm/javascript-utils/is-type.js +1 -1
  57. package/dist/esm/javascript-utils/is-type.js.map +1 -1
  58. package/dist/esm/lib/api/encode-table.js +2 -2
  59. package/dist/esm/lib/api/encode-table.js.map +1 -1
  60. package/dist/esm/lib/api/encode.js +12 -2
  61. package/dist/esm/lib/api/encode.js.map +1 -1
  62. package/dist/esm/lib/api/load-in-batches.js +8 -5
  63. package/dist/esm/lib/api/load-in-batches.js.map +1 -1
  64. package/dist/esm/lib/api/load.js.map +1 -1
  65. package/dist/esm/lib/api/parse-in-batches.js +4 -5
  66. package/dist/esm/lib/api/parse-in-batches.js.map +1 -1
  67. package/dist/esm/lib/api/parse-sync.js +2 -4
  68. package/dist/esm/lib/api/parse-sync.js.map +1 -1
  69. package/dist/esm/lib/api/parse.js +12 -11
  70. package/dist/esm/lib/api/parse.js.map +1 -1
  71. package/dist/esm/lib/api/save.js.map +1 -1
  72. package/dist/esm/lib/api/select-loader.js +5 -3
  73. package/dist/esm/lib/api/select-loader.js.map +1 -1
  74. package/dist/esm/lib/fetch/fetch-file.js +16 -7
  75. package/dist/esm/lib/fetch/fetch-file.js.map +1 -1
  76. package/dist/esm/lib/fetch/fetch-file.node.js +54 -0
  77. package/dist/esm/lib/fetch/fetch-file.node.js.map +1 -0
  78. package/dist/esm/lib/filesystems/browser-filesystem.js +1 -1
  79. package/dist/esm/lib/filesystems/browser-filesystem.js.map +1 -1
  80. package/dist/esm/lib/filesystems/read-array-buffer.js.map +1 -1
  81. package/dist/esm/lib/init.js +1 -1
  82. package/dist/esm/lib/init.js.map +1 -1
  83. package/dist/esm/lib/loader-utils/check-errors.js +1 -1
  84. package/dist/esm/lib/loader-utils/check-errors.js.map +1 -1
  85. package/dist/esm/lib/loader-utils/get-data.js +1 -1
  86. package/dist/esm/lib/loader-utils/get-data.js.map +1 -1
  87. package/dist/esm/lib/loader-utils/get-fetch-function.js +5 -5
  88. package/dist/esm/lib/loader-utils/get-fetch-function.js.map +1 -1
  89. package/dist/esm/lib/loader-utils/loader-context.js +2 -2
  90. package/dist/esm/lib/loader-utils/loader-context.js.map +1 -1
  91. package/dist/esm/lib/loader-utils/loggers.js.map +1 -1
  92. package/dist/esm/lib/loader-utils/option-defaults.js +1 -0
  93. package/dist/esm/lib/loader-utils/option-defaults.js.map +1 -1
  94. package/dist/esm/lib/loader-utils/option-utils.js +2 -2
  95. package/dist/esm/lib/loader-utils/option-utils.js.map +1 -1
  96. package/dist/esm/lib/progress/fetch-progress.js +1 -1
  97. package/dist/esm/lib/progress/fetch-progress.js.map +1 -1
  98. package/dist/esm/null-loader.js +6 -14
  99. package/dist/esm/null-loader.js.map +1 -1
  100. package/dist/null-worker-node.js +14 -14
  101. package/dist/null-worker.js +14 -14
  102. package/dist/src/bundle.d.ts.map +1 -0
  103. package/dist/src/core-addons/write-file-browser.d.ts.map +1 -0
  104. package/dist/{index.d.ts → src/index.d.ts} +5 -4
  105. package/dist/src/index.d.ts.map +1 -0
  106. package/dist/src/iterators/batch-iterators/timed-batch-iterator.d.ts +5 -0
  107. package/dist/src/iterators/batch-iterators/timed-batch-iterator.d.ts.map +1 -0
  108. package/dist/src/iterators/make-iterator/make-array-buffer-iterator.d.ts.map +1 -0
  109. package/dist/src/iterators/make-iterator/make-blob-iterator.d.ts.map +1 -0
  110. package/dist/src/iterators/make-iterator/make-iterator.d.ts.map +1 -0
  111. package/dist/src/iterators/make-iterator/make-stream-iterator.d.ts.map +1 -0
  112. package/dist/src/iterators/make-iterator/make-string-iterator.d.ts.map +1 -0
  113. package/dist/src/iterators/make-stream/make-dom-stream.d.ts.map +1 -0
  114. package/dist/src/iterators/make-stream/make-node-stream.d.ts.map +1 -0
  115. package/dist/{javascript-utils → src/javascript-utils}/is-type.d.ts +5 -5
  116. package/dist/src/javascript-utils/is-type.d.ts.map +1 -0
  117. package/dist/src/lib/api/encode-table.d.ts.map +1 -0
  118. package/dist/src/lib/api/encode.d.ts +33 -0
  119. package/dist/src/lib/api/encode.d.ts.map +1 -0
  120. package/dist/{lib → src/lib}/api/load-in-batches.d.ts +7 -2
  121. package/dist/src/lib/api/load-in-batches.d.ts.map +1 -0
  122. package/dist/src/lib/api/load.d.ts +16 -0
  123. package/dist/src/lib/api/load.d.ts.map +1 -0
  124. package/dist/src/lib/api/loader-options.d.ts.map +1 -0
  125. package/dist/src/lib/api/parse-in-batches.d.ts +16 -0
  126. package/dist/src/lib/api/parse-in-batches.d.ts.map +1 -0
  127. package/dist/src/lib/api/parse-sync.d.ts +16 -0
  128. package/dist/src/lib/api/parse-sync.d.ts.map +1 -0
  129. package/dist/{lib → src/lib}/api/parse.d.ts +13 -3
  130. package/dist/src/lib/api/parse.d.ts.map +1 -0
  131. package/dist/src/lib/api/register-loaders.d.ts.map +1 -0
  132. package/dist/src/lib/api/save.d.ts +4 -0
  133. package/dist/src/lib/api/save.d.ts.map +1 -0
  134. package/dist/src/lib/api/select-loader.d.ts.map +1 -0
  135. package/dist/src/lib/common.d.ts.map +1 -0
  136. package/dist/src/lib/fetch/fetch-error-message.d.ts.map +1 -0
  137. package/dist/src/lib/fetch/fetch-file.d.ts +10 -0
  138. package/dist/src/lib/fetch/fetch-file.d.ts.map +1 -0
  139. package/dist/src/lib/fetch/fetch-file.node.d.ts +8 -0
  140. package/dist/src/lib/fetch/fetch-file.node.d.ts.map +1 -0
  141. package/dist/src/lib/fetch/read-array-buffer.d.ts.map +1 -0
  142. package/dist/{lib → src/lib}/fetch/read-file.d.ts +1 -1
  143. package/dist/src/lib/fetch/read-file.d.ts.map +1 -0
  144. package/dist/src/lib/fetch/write-file.d.ts.map +1 -0
  145. package/dist/{lib → src/lib}/filesystems/browser-filesystem.d.ts +4 -4
  146. package/dist/src/lib/filesystems/browser-filesystem.d.ts.map +1 -0
  147. package/dist/src/lib/filesystems/read-array-buffer.d.ts +8 -0
  148. package/dist/src/lib/filesystems/read-array-buffer.d.ts.map +1 -0
  149. package/dist/{lib → src/lib}/init.d.ts.map +1 -1
  150. package/dist/src/lib/loader-utils/check-errors.d.ts +12 -0
  151. package/dist/src/lib/loader-utils/check-errors.d.ts.map +1 -0
  152. package/dist/src/lib/loader-utils/get-data.d.ts.map +1 -0
  153. package/dist/src/lib/loader-utils/get-fetch-function.d.ts +8 -0
  154. package/dist/src/lib/loader-utils/get-fetch-function.d.ts.map +1 -0
  155. package/dist/{lib → src/lib}/loader-utils/loader-context.d.ts +5 -2
  156. package/dist/src/lib/loader-utils/loader-context.d.ts.map +1 -0
  157. package/dist/src/lib/loader-utils/loggers.d.ts +19 -0
  158. package/dist/src/lib/loader-utils/loggers.d.ts.map +1 -0
  159. package/dist/src/lib/loader-utils/normalize-loader.d.ts.map +1 -0
  160. package/dist/src/lib/loader-utils/option-defaults.d.ts.map +1 -0
  161. package/dist/{lib → src/lib}/loader-utils/option-utils.d.ts +1 -1
  162. package/dist/src/lib/loader-utils/option-utils.d.ts.map +1 -0
  163. package/dist/{lib → src/lib}/progress/fetch-progress.d.ts +1 -1
  164. package/dist/src/lib/progress/fetch-progress.d.ts.map +1 -0
  165. package/dist/src/lib/utils/log.d.ts.map +1 -0
  166. package/dist/src/lib/utils/mime-type-utils.d.ts.map +1 -0
  167. package/dist/src/lib/utils/resource-utils.d.ts.map +1 -0
  168. package/dist/src/lib/utils/response-utils.d.ts.map +1 -0
  169. package/dist/src/lib/utils/url-utils.d.ts.map +1 -0
  170. package/dist/src/null-loader.d.ts +13 -0
  171. package/dist/src/null-loader.d.ts.map +1 -0
  172. package/dist/src/workers/null-worker.d.ts.map +1 -0
  173. package/dist/tsconfig.tsbuildinfo +1 -0
  174. package/package.json +7 -6
  175. package/src/index.ts +6 -5
  176. package/src/iterators/batch-iterators/timed-batch-iterator.ts +4 -1
  177. package/src/iterators/make-stream/make-dom-stream.ts +2 -1
  178. package/src/iterators/make-stream/make-node-stream.ts +5 -2
  179. package/src/javascript-utils/is-type.ts +12 -8
  180. package/src/lib/api/encode-table.ts +3 -3
  181. package/src/lib/api/encode.ts +31 -12
  182. package/src/lib/api/load-in-batches.ts +54 -11
  183. package/src/lib/api/load.ts +22 -14
  184. package/src/lib/api/parse-in-batches.ts +45 -17
  185. package/src/lib/api/parse-sync.ts +38 -17
  186. package/src/lib/api/parse.ts +41 -17
  187. package/src/lib/api/save.ts +2 -2
  188. package/src/lib/api/select-loader.ts +24 -13
  189. package/src/lib/fetch/fetch-file.node.ts +61 -0
  190. package/src/lib/fetch/fetch-file.ts +28 -16
  191. package/src/lib/filesystems/browser-filesystem.ts +5 -5
  192. package/src/lib/filesystems/read-array-buffer.ts +6 -18
  193. package/src/lib/init.ts +1 -0
  194. package/src/lib/loader-utils/check-errors.ts +21 -4
  195. package/src/lib/loader-utils/get-data.ts +1 -1
  196. package/src/lib/loader-utils/get-fetch-function.ts +7 -7
  197. package/src/lib/loader-utils/loader-context.ts +8 -5
  198. package/src/lib/loader-utils/loggers.ts +10 -8
  199. package/src/lib/loader-utils/option-defaults.ts +1 -0
  200. package/src/lib/loader-utils/option-utils.ts +23 -14
  201. package/src/lib/progress/fetch-progress.ts +10 -2
  202. package/src/null-loader.ts +23 -17
  203. package/dist/bundle.d.ts.map +0 -1
  204. package/dist/bundle.js +0 -5
  205. package/dist/core-addons/write-file-browser.d.ts.map +0 -1
  206. package/dist/core-addons/write-file-browser.js +0 -60
  207. package/dist/es5/lib/filesystems/filesystem.js +0 -2
  208. package/dist/es5/lib/filesystems/filesystem.js.map +0 -1
  209. package/dist/esm/lib/filesystems/filesystem.js +0 -2
  210. package/dist/esm/lib/filesystems/filesystem.js.map +0 -1
  211. package/dist/index.d.ts.map +0 -1
  212. package/dist/index.js +0 -108
  213. package/dist/iterators/batch-iterators/timed-batch-iterator.d.ts +0 -5
  214. package/dist/iterators/batch-iterators/timed-batch-iterator.d.ts.map +0 -1
  215. package/dist/iterators/batch-iterators/timed-batch-iterator.js +0 -22
  216. package/dist/iterators/make-iterator/make-array-buffer-iterator.d.ts.map +0 -1
  217. package/dist/iterators/make-iterator/make-array-buffer-iterator.js +0 -27
  218. package/dist/iterators/make-iterator/make-blob-iterator.d.ts.map +0 -1
  219. package/dist/iterators/make-iterator/make-blob-iterator.js +0 -21
  220. package/dist/iterators/make-iterator/make-iterator.d.ts.map +0 -1
  221. package/dist/iterators/make-iterator/make-iterator.js +0 -37
  222. package/dist/iterators/make-iterator/make-stream-iterator.d.ts.map +0 -1
  223. package/dist/iterators/make-iterator/make-stream-iterator.js +0 -96
  224. package/dist/iterators/make-iterator/make-string-iterator.d.ts.map +0 -1
  225. package/dist/iterators/make-iterator/make-string-iterator.js +0 -24
  226. package/dist/iterators/make-stream/make-dom-stream.d.ts.map +0 -1
  227. package/dist/iterators/make-stream/make-dom-stream.js +0 -46
  228. package/dist/iterators/make-stream/make-node-stream.d.ts.map +0 -1
  229. package/dist/iterators/make-stream/make-node-stream.js +0 -82
  230. package/dist/javascript-utils/is-type.d.ts.map +0 -1
  231. package/dist/javascript-utils/is-type.js +0 -41
  232. package/dist/lib/api/encode-table.d.ts.map +0 -1
  233. package/dist/lib/api/encode-table.js +0 -54
  234. package/dist/lib/api/encode.d.ts +0 -26
  235. package/dist/lib/api/encode.d.ts.map +0 -1
  236. package/dist/lib/api/encode.js +0 -121
  237. package/dist/lib/api/load-in-batches.d.ts.map +0 -1
  238. package/dist/lib/api/load-in-batches.js +0 -33
  239. package/dist/lib/api/load.d.ts +0 -15
  240. package/dist/lib/api/load.d.ts.map +0 -1
  241. package/dist/lib/api/load.js +0 -43
  242. package/dist/lib/api/loader-options.d.ts.map +0 -1
  243. package/dist/lib/api/loader-options.js +0 -7
  244. package/dist/lib/api/parse-in-batches.d.ts +0 -10
  245. package/dist/lib/api/parse-in-batches.d.ts.map +0 -1
  246. package/dist/lib/api/parse-in-batches.js +0 -117
  247. package/dist/lib/api/parse-sync.d.ts +0 -10
  248. package/dist/lib/api/parse-sync.d.ts.map +0 -1
  249. package/dist/lib/api/parse-sync.js +0 -59
  250. package/dist/lib/api/parse.d.ts.map +0 -1
  251. package/dist/lib/api/parse.js +0 -84
  252. package/dist/lib/api/register-loaders.d.ts.map +0 -1
  253. package/dist/lib/api/register-loaders.js +0 -35
  254. package/dist/lib/api/save.d.ts +0 -4
  255. package/dist/lib/api/save.d.ts.map +0 -1
  256. package/dist/lib/api/save.js +0 -15
  257. package/dist/lib/api/select-loader.d.ts.map +0 -1
  258. package/dist/lib/api/select-loader.js +0 -253
  259. package/dist/lib/common.d.ts.map +0 -1
  260. package/dist/lib/common.js +0 -2
  261. package/dist/lib/fetch/fetch-error-message.d.ts.map +0 -1
  262. package/dist/lib/fetch/fetch-error-message.js +0 -25
  263. package/dist/lib/fetch/fetch-file.d.ts +0 -13
  264. package/dist/lib/fetch/fetch-file.d.ts.map +0 -1
  265. package/dist/lib/fetch/fetch-file.js +0 -27
  266. package/dist/lib/fetch/read-array-buffer.d.ts.map +0 -1
  267. package/dist/lib/fetch/read-array-buffer.js +0 -41
  268. package/dist/lib/fetch/read-file.d.ts.map +0 -1
  269. package/dist/lib/fetch/read-file.js +0 -29
  270. package/dist/lib/fetch/write-file.d.ts.map +0 -1
  271. package/dist/lib/fetch/write-file.js +0 -22
  272. package/dist/lib/filesystems/browser-filesystem.d.ts.map +0 -1
  273. package/dist/lib/filesystems/browser-filesystem.js +0 -126
  274. package/dist/lib/filesystems/filesystem.d.ts +0 -46
  275. package/dist/lib/filesystems/filesystem.d.ts.map +0 -1
  276. package/dist/lib/filesystems/filesystem.js +0 -2
  277. package/dist/lib/filesystems/read-array-buffer.d.ts +0 -19
  278. package/dist/lib/filesystems/read-array-buffer.d.ts.map +0 -1
  279. package/dist/lib/filesystems/read-array-buffer.js +0 -29
  280. package/dist/lib/init.js +0 -16
  281. package/dist/lib/loader-utils/check-errors.d.ts +0 -3
  282. package/dist/lib/loader-utils/check-errors.d.ts.map +0 -1
  283. package/dist/lib/loader-utils/check-errors.js +0 -30
  284. package/dist/lib/loader-utils/get-data.d.ts.map +0 -1
  285. package/dist/lib/loader-utils/get-data.js +0 -129
  286. package/dist/lib/loader-utils/get-fetch-function.d.ts +0 -9
  287. package/dist/lib/loader-utils/get-fetch-function.d.ts.map +0 -1
  288. package/dist/lib/loader-utils/get-fetch-function.js +0 -31
  289. package/dist/lib/loader-utils/loader-context.d.ts.map +0 -1
  290. package/dist/lib/loader-utils/loader-context.js +0 -59
  291. package/dist/lib/loader-utils/loggers.d.ts +0 -17
  292. package/dist/lib/loader-utils/loggers.d.ts.map +0 -1
  293. package/dist/lib/loader-utils/loggers.js +0 -41
  294. package/dist/lib/loader-utils/normalize-loader.d.ts.map +0 -1
  295. package/dist/lib/loader-utils/normalize-loader.js +0 -52
  296. package/dist/lib/loader-utils/option-defaults.d.ts.map +0 -1
  297. package/dist/lib/loader-utils/option-defaults.js +0 -43
  298. package/dist/lib/loader-utils/option-utils.d.ts.map +0 -1
  299. package/dist/lib/loader-utils/option-utils.js +0 -160
  300. package/dist/lib/progress/fetch-progress.d.ts.map +0 -1
  301. package/dist/lib/progress/fetch-progress.js +0 -59
  302. package/dist/lib/utils/log.d.ts.map +0 -1
  303. package/dist/lib/utils/log.js +0 -6
  304. package/dist/lib/utils/mime-type-utils.d.ts.map +0 -1
  305. package/dist/lib/utils/mime-type-utils.js +0 -42
  306. package/dist/lib/utils/resource-utils.d.ts.map +0 -1
  307. package/dist/lib/utils/resource-utils.js +0 -90
  308. package/dist/lib/utils/response-utils.d.ts.map +0 -1
  309. package/dist/lib/utils/response-utils.js +0 -115
  310. package/dist/lib/utils/url-utils.d.ts.map +0 -1
  311. package/dist/lib/utils/url-utils.js +0 -14
  312. package/dist/null-loader.d.ts +0 -10
  313. package/dist/null-loader.d.ts.map +0 -1
  314. package/dist/null-loader.js +0 -56
  315. package/dist/workers/null-worker.d.ts.map +0 -1
  316. package/dist/workers/null-worker.js +0 -5
  317. package/src/lib/filesystems/filesystem.ts +0 -49
  318. /package/dist/{bundle.d.ts → src/bundle.d.ts} +0 -0
  319. /package/dist/{core-addons → src/core-addons}/write-file-browser.d.ts +0 -0
  320. /package/dist/{iterators → src/iterators}/make-iterator/make-array-buffer-iterator.d.ts +0 -0
  321. /package/dist/{iterators → src/iterators}/make-iterator/make-blob-iterator.d.ts +0 -0
  322. /package/dist/{iterators → src/iterators}/make-iterator/make-iterator.d.ts +0 -0
  323. /package/dist/{iterators → src/iterators}/make-iterator/make-stream-iterator.d.ts +0 -0
  324. /package/dist/{iterators → src/iterators}/make-iterator/make-string-iterator.d.ts +0 -0
  325. /package/dist/{iterators → src/iterators}/make-stream/make-dom-stream.d.ts +0 -0
  326. /package/dist/{iterators → src/iterators}/make-stream/make-node-stream.d.ts +0 -0
  327. /package/dist/{lib → src/lib}/api/encode-table.d.ts +0 -0
  328. /package/dist/{lib → src/lib}/api/loader-options.d.ts +0 -0
  329. /package/dist/{lib → src/lib}/api/register-loaders.d.ts +0 -0
  330. /package/dist/{lib → src/lib}/api/select-loader.d.ts +0 -0
  331. /package/dist/{lib → src/lib}/common.d.ts +0 -0
  332. /package/dist/{lib → src/lib}/fetch/fetch-error-message.d.ts +0 -0
  333. /package/dist/{lib → src/lib}/fetch/read-array-buffer.d.ts +0 -0
  334. /package/dist/{lib → src/lib}/fetch/write-file.d.ts +0 -0
  335. /package/dist/{lib → src/lib}/init.d.ts +0 -0
  336. /package/dist/{lib → src/lib}/loader-utils/get-data.d.ts +0 -0
  337. /package/dist/{lib → src/lib}/loader-utils/normalize-loader.d.ts +0 -0
  338. /package/dist/{lib → src/lib}/loader-utils/option-defaults.d.ts +0 -0
  339. /package/dist/{lib → src/lib}/utils/log.d.ts +0 -0
  340. /package/dist/{lib → src/lib}/utils/mime-type-utils.d.ts +0 -0
  341. /package/dist/{lib → src/lib}/utils/resource-utils.d.ts +0 -0
  342. /package/dist/{lib → src/lib}/utils/response-utils.d.ts +0 -0
  343. /package/dist/{lib → src/lib}/utils/url-utils.d.ts +0 -0
  344. /package/dist/{workers → src/workers}/null-worker.d.ts +0 -0
@@ -1,253 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.selectLoaderSync = exports.selectLoader = void 0;
4
- const loader_utils_1 = require("@loaders.gl/loader-utils");
5
- const normalize_loader_1 = require("../loader-utils/normalize-loader");
6
- const log_1 = require("../utils/log");
7
- const resource_utils_1 = require("../utils/resource-utils");
8
- const register_loaders_1 = require("./register-loaders");
9
- const is_type_1 = require("../../javascript-utils/is-type");
10
- const url_utils_1 = require("../utils/url-utils");
11
- const EXT_PATTERN = /\.([^.]+)$/;
12
- // TODO - Need a variant that peeks at streams for parseInBatches
13
- // TODO - Detect multiple matching loaders? Use heuristics to grade matches?
14
- // TODO - Allow apps to pass context to disambiguate between multiple matches (e.g. multiple .json formats)?
15
- /**
16
- * Find a loader that matches file extension and/or initial file content
17
- * Search the loaders array argument for a loader that matches url extension or initial data
18
- * Returns: a normalized loader
19
- * @param data data to assist
20
- * @param loaders
21
- * @param options
22
- * @param context used internally, applications should not provide this parameter
23
- */
24
- async function selectLoader(data, loaders = [], options, context) {
25
- if (!validHTTPResponse(data)) {
26
- return null;
27
- }
28
- // First make a sync attempt, disabling exceptions
29
- let loader = selectLoaderSync(data, loaders, { ...options, nothrow: true }, context);
30
- if (loader) {
31
- return loader;
32
- }
33
- // For Blobs and Files, try to asynchronously read a small initial slice and test again with that
34
- // to see if we can detect by initial content
35
- if ((0, is_type_1.isBlob)(data)) {
36
- data = await data.slice(0, 10).arrayBuffer();
37
- loader = selectLoaderSync(data, loaders, options, context);
38
- }
39
- // no loader available
40
- if (!loader && !options?.nothrow) {
41
- throw new Error(getNoValidLoaderMessage(data));
42
- }
43
- return loader;
44
- }
45
- exports.selectLoader = selectLoader;
46
- /**
47
- * Find a loader that matches file extension and/or initial file content
48
- * Search the loaders array argument for a loader that matches url extension or initial data
49
- * Returns: a normalized loader
50
- * @param data data to assist
51
- * @param loaders
52
- * @param options
53
- * @param context used internally, applications should not provide this parameter
54
- */
55
- function selectLoaderSync(data, loaders = [], options, context) {
56
- if (!validHTTPResponse(data)) {
57
- return null;
58
- }
59
- // eslint-disable-next-line complexity
60
- // if only a single loader was provided (not as array), force its use
61
- // TODO - Should this behavior be kept and documented?
62
- if (loaders && !Array.isArray(loaders)) {
63
- // TODO - remove support for legacy loaders
64
- return (0, normalize_loader_1.normalizeLoader)(loaders);
65
- }
66
- // Build list of candidate loaders that will be searched in order for a match
67
- let candidateLoaders = [];
68
- // First search supplied loaders
69
- if (loaders) {
70
- candidateLoaders = candidateLoaders.concat(loaders);
71
- }
72
- // Then fall back to registered loaders
73
- if (!options?.ignoreRegisteredLoaders) {
74
- candidateLoaders.push(...(0, register_loaders_1.getRegisteredLoaders)());
75
- }
76
- // TODO - remove support for legacy loaders
77
- normalizeLoaders(candidateLoaders);
78
- const loader = selectLoaderInternal(data, candidateLoaders, options, context);
79
- // no loader available
80
- if (!loader && !options?.nothrow) {
81
- throw new Error(getNoValidLoaderMessage(data));
82
- }
83
- return loader;
84
- }
85
- exports.selectLoaderSync = selectLoaderSync;
86
- /** Implements loaders selection logic */
87
- // eslint-disable-next-line complexity
88
- function selectLoaderInternal(data, loaders, options, context) {
89
- const url = (0, resource_utils_1.getResourceUrl)(data);
90
- const type = (0, resource_utils_1.getResourceMIMEType)(data);
91
- const testUrl = (0, url_utils_1.stripQueryString)(url) || context?.url;
92
- let loader = null;
93
- let reason = '';
94
- // if options.mimeType is supplied, it takes precedence
95
- if (options?.mimeType) {
96
- loader = findLoaderByMIMEType(loaders, options?.mimeType);
97
- reason = `match forced by supplied MIME type ${options?.mimeType}`;
98
- }
99
- // Look up loader by url
100
- loader = loader || findLoaderByUrl(loaders, testUrl);
101
- reason = reason || (loader ? `matched url ${testUrl}` : '');
102
- // Look up loader by mime type
103
- loader = loader || findLoaderByMIMEType(loaders, type);
104
- reason = reason || (loader ? `matched MIME type ${type}` : '');
105
- // Look for loader via initial bytes (Note: not always accessible (e.g. Response, stream, async iterator)
106
- loader = loader || findLoaderByInitialBytes(loaders, data);
107
- reason = reason || (loader ? `matched initial data ${getFirstCharacters(data)}` : '');
108
- // Look up loader by fallback mime type
109
- loader = loader || findLoaderByMIMEType(loaders, options?.fallbackMimeType);
110
- reason = reason || (loader ? `matched fallback MIME type ${type}` : '');
111
- if (reason) {
112
- log_1.log.log(1, `selectLoader selected ${loader?.name}: ${reason}.`);
113
- }
114
- return loader;
115
- }
116
- /** Check HTTP Response */
117
- function validHTTPResponse(data) {
118
- // HANDLE HTTP status
119
- if (data instanceof Response) {
120
- // 204 - NO CONTENT. This handles cases where e.g. a tile server responds with 204 for a missing tile
121
- if (data.status === 204) {
122
- return false;
123
- }
124
- }
125
- return true;
126
- }
127
- /** Generate a helpful message to help explain why loader selection failed. */
128
- function getNoValidLoaderMessage(data) {
129
- const url = (0, resource_utils_1.getResourceUrl)(data);
130
- const type = (0, resource_utils_1.getResourceMIMEType)(data);
131
- let message = 'No valid loader found (';
132
- message += url ? `${loader_utils_1.path.filename(url)}, ` : 'no url provided, ';
133
- message += `MIME type: ${type ? `"${type}"` : 'not provided'}, `;
134
- // First characters are only accessible when called on data (string or arrayBuffer).
135
- const firstCharacters = data ? getFirstCharacters(data) : '';
136
- message += firstCharacters ? ` first bytes: "${firstCharacters}"` : 'first bytes: not available';
137
- message += ')';
138
- return message;
139
- }
140
- function normalizeLoaders(loaders) {
141
- for (const loader of loaders) {
142
- (0, normalize_loader_1.normalizeLoader)(loader);
143
- }
144
- }
145
- // TODO - Would be nice to support http://example.com/file.glb?parameter=1
146
- // E.g: x = new URL('http://example.com/file.glb?load=1'; x.pathname
147
- function findLoaderByUrl(loaders, url) {
148
- // Get extension
149
- const match = url && EXT_PATTERN.exec(url);
150
- const extension = match && match[1];
151
- return extension ? findLoaderByExtension(loaders, extension) : null;
152
- }
153
- function findLoaderByExtension(loaders, extension) {
154
- extension = extension.toLowerCase();
155
- for (const loader of loaders) {
156
- for (const loaderExtension of loader.extensions) {
157
- if (loaderExtension.toLowerCase() === extension) {
158
- return loader;
159
- }
160
- }
161
- }
162
- return null;
163
- }
164
- function findLoaderByMIMEType(loaders, mimeType) {
165
- for (const loader of loaders) {
166
- if (loader.mimeTypes && loader.mimeTypes.includes(mimeType)) {
167
- return loader;
168
- }
169
- // Support referring to loaders using the "unregistered tree"
170
- // https://en.wikipedia.org/wiki/Media_type#Unregistered_tree
171
- if (mimeType === `application/x.${loader.id}`) {
172
- return loader;
173
- }
174
- }
175
- return null;
176
- }
177
- function findLoaderByInitialBytes(loaders, data) {
178
- if (!data) {
179
- return null;
180
- }
181
- for (const loader of loaders) {
182
- if (typeof data === 'string') {
183
- if (testDataAgainstText(data, loader)) {
184
- return loader;
185
- }
186
- }
187
- else if (ArrayBuffer.isView(data)) {
188
- // Typed Arrays can have offsets into underlying buffer
189
- if (testDataAgainstBinary(data.buffer, data.byteOffset, loader)) {
190
- return loader;
191
- }
192
- }
193
- else if (data instanceof ArrayBuffer) {
194
- const byteOffset = 0;
195
- if (testDataAgainstBinary(data, byteOffset, loader)) {
196
- return loader;
197
- }
198
- }
199
- // TODO Handle streaming case (requires creating a new AsyncIterator)
200
- }
201
- return null;
202
- }
203
- function testDataAgainstText(data, loader) {
204
- if (loader.testText) {
205
- return loader.testText(data);
206
- }
207
- const tests = Array.isArray(loader.tests) ? loader.tests : [loader.tests];
208
- return tests.some((test) => data.startsWith(test));
209
- }
210
- function testDataAgainstBinary(data, byteOffset, loader) {
211
- const tests = Array.isArray(loader.tests) ? loader.tests : [loader.tests];
212
- return tests.some((test) => testBinary(data, byteOffset, loader, test));
213
- }
214
- function testBinary(data, byteOffset, loader, test) {
215
- if (test instanceof ArrayBuffer) {
216
- return (0, loader_utils_1.compareArrayBuffers)(test, data, test.byteLength);
217
- }
218
- switch (typeof test) {
219
- case 'function':
220
- return test(data, loader);
221
- case 'string':
222
- // Magic bytes check: If `test` is a string, check if binary data starts with that strings
223
- const magic = getMagicString(data, byteOffset, test.length);
224
- return test === magic;
225
- default:
226
- return false;
227
- }
228
- }
229
- function getFirstCharacters(data, length = 5) {
230
- if (typeof data === 'string') {
231
- return data.slice(0, length);
232
- }
233
- else if (ArrayBuffer.isView(data)) {
234
- // Typed Arrays can have offsets into underlying buffer
235
- return getMagicString(data.buffer, data.byteOffset, length);
236
- }
237
- else if (data instanceof ArrayBuffer) {
238
- const byteOffset = 0;
239
- return getMagicString(data, byteOffset, length);
240
- }
241
- return '';
242
- }
243
- function getMagicString(arrayBuffer, byteOffset, length) {
244
- if (arrayBuffer.byteLength < byteOffset + length) {
245
- return '';
246
- }
247
- const dataView = new DataView(arrayBuffer);
248
- let magic = '';
249
- for (let i = 0; i < length; i++) {
250
- magic += String.fromCharCode(dataView.getUint8(byteOffset + i));
251
- }
252
- return magic;
253
- }
@@ -1 +0,0 @@
1
- {"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../src/lib/common.ts"],"names":[],"mappings":"AAAA,YAAY,EAAC,gBAAgB,EAAC,MAAM,0BAA0B,CAAC"}
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1 +0,0 @@
1
- {"version":3,"file":"fetch-error-message.d.ts","sourceRoot":"","sources":["../../../src/lib/fetch/fetch-error-message.ts"],"names":[],"mappings":"AAAA,wBAAgB,+BAA+B,CAAC,QAAQ,EAAE,QAAQ,GAAG,MAAM,CAE1E;AAED,wBAAsB,2BAA2B,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,CAcrF"}
@@ -1,25 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getErrorMessageFromResponse = exports.getErrorMessageFromResponseSync = void 0;
4
- function getErrorMessageFromResponseSync(response) {
5
- return `Failed to fetch resource ${response.url}(${response.status}): ${response.statusText} `;
6
- }
7
- exports.getErrorMessageFromResponseSync = getErrorMessageFromResponseSync;
8
- async function getErrorMessageFromResponse(response) {
9
- let message = `Failed to fetch resource ${response.url} (${response.status}): `;
10
- try {
11
- const contentType = response.headers.get('Content-Type') || '';
12
- if (contentType.includes('application/json')) {
13
- message += await response.text();
14
- }
15
- else {
16
- message += response.statusText;
17
- }
18
- }
19
- catch (error) {
20
- // eslint forbids return in finally statement
21
- return message;
22
- }
23
- return message;
24
- }
25
- exports.getErrorMessageFromResponse = getErrorMessageFromResponse;
@@ -1,13 +0,0 @@
1
- /**
2
- * fetch compatible function
3
- * Reads file data from:
4
- * - http/http urls
5
- * - data urls
6
- * - File/Blob objects
7
- * Leverages `@loaders.gl/polyfills` for Node.js support
8
- * Respects pathPrefix and file aliases
9
- */
10
- export declare function fetchFile(url: string | Blob, options?: RequestInit & {
11
- fetch?: RequestInit | Function;
12
- }): Promise<Response>;
13
- //# sourceMappingURL=fetch-file.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fetch-file.d.ts","sourceRoot":"","sources":["../../../src/lib/fetch/fetch-file.ts"],"names":[],"mappings":"AAIA;;;;;;;;GAQG;AACH,wBAAsB,SAAS,CAC7B,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,OAAO,CAAC,EAAE,WAAW,GAAG;IAAC,KAAK,CAAC,EAAE,WAAW,GAAG,QAAQ,CAAA;CAAC,GACvD,OAAO,CAAC,QAAQ,CAAC,CAanB"}
@@ -1,27 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.fetchFile = void 0;
4
- const loader_utils_1 = require("@loaders.gl/loader-utils");
5
- const response_utils_1 = require("../utils/response-utils");
6
- // import {getErrorMessageFromResponse} from './fetch-error-message';
7
- /**
8
- * fetch compatible function
9
- * Reads file data from:
10
- * - http/http urls
11
- * - data urls
12
- * - File/Blob objects
13
- * Leverages `@loaders.gl/polyfills` for Node.js support
14
- * Respects pathPrefix and file aliases
15
- */
16
- async function fetchFile(url, options) {
17
- if (typeof url === 'string') {
18
- url = (0, loader_utils_1.resolvePath)(url);
19
- let fetchOptions = options;
20
- if (options?.fetch && typeof options?.fetch !== 'function') {
21
- fetchOptions = options.fetch;
22
- }
23
- return await fetch(url, fetchOptions);
24
- }
25
- return await (0, response_utils_1.makeResponse)(url);
26
- }
27
- exports.fetchFile = fetchFile;
@@ -1 +0,0 @@
1
- {"version":3,"file":"read-array-buffer.d.ts","sourceRoot":"","sources":["../../../src/lib/fetch/read-array-buffer.ts"],"names":[],"mappings":"AAGA;;;;;;GAMG;AACH,wBAAsB,eAAe,CACnC,IAAI,EAAE,IAAI,GAAG,WAAW,GAAG,MAAM,GAAG,MAAM,EAC1C,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,CAAC,CAUtB;AAED;;;;;;GAMG;AACH,wBAAsB,QAAQ,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,WAAW,CAAC,CAS/D"}
@@ -1,41 +0,0 @@
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);
23
- }
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
- });
40
- }
41
- exports.readBlob = readBlob;
@@ -1 +0,0 @@
1
- {"version":3,"file":"read-file.d.ts","sourceRoot":"","sources":["../../../src/lib/fetch/read-file.ts"],"names":[],"mappings":"AAOA;;GAEG;AACH,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,GAAE,MAAW,+BAoB7D"}
@@ -1,29 +0,0 @@
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;
28
- }
29
- exports.readFileSync = readFileSync;
@@ -1 +0,0 @@
1
- {"version":3,"file":"write-file.d.ts","sourceRoot":"","sources":["../../../src/lib/fetch/write-file.ts"],"names":[],"mappings":"AAIA,wBAAsB,SAAS,CAC7B,QAAQ,EAAE,MAAM,EAChB,mBAAmB,EAAE,WAAW,GAAG,MAAM,EACzC,OAAO,CAAC,KAAA,GACP,OAAO,CAAC,IAAI,CAAC,CAMf;AAED,wBAAgB,aAAa,CAC3B,QAAQ,EAAE,MAAM,EAChB,mBAAmB,EAAE,WAAW,GAAG,MAAM,EACzC,OAAO,CAAC,KAAA,GACP,IAAI,CAMN"}
@@ -1,22 +0,0 @@
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);
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);
21
- }
22
- exports.writeFileSync = writeFileSync;
@@ -1 +0,0 @@
1
- {"version":3,"file":"browser-filesystem.d.ts","sourceRoot":"","sources":["../../../src/lib/filesystems/browser-filesystem.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,cAAc,CAAC;AAE7C,KAAK,wBAAwB,GAAG;IAC9B,KAAK,CAAC,EAAE,OAAO,KAAK,CAAC;CACtB,CAAC;AAEF;;;GAGG;AACH,MAAM,CAAC,OAAO,OAAO,iBAAkB,YAAW,UAAU;IAC1D,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,KAAK,CAAkC;IAC/C,OAAO,CAAC,cAAc,CAAkC;IACxD,OAAO,CAAC,SAAS,CAAqC;IAEtD;;;;OAIG;gBACS,KAAK,EAAE,QAAQ,GAAG,IAAI,EAAE,EAAE,OAAO,CAAC,EAAE,wBAAwB;IAexE;;;OAGG;IACG,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,QAAQ,CAAC;IAkCnE;;;;OAIG;IACG,OAAO,CAAC,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IASlD;;OAEG;IACG,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAC,CAAC;IAQnE;;OAEG;IACG,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IASnC,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,KAAA,EAAE,IAAI,CAAC,KAAA,GAAG,OAAO,CAAC,GAAG,CAAC;IAIxD;;;;;;;OAOG;IACG,IAAI,CACR,EAAE,EAAE,GAAG,EACP,MAAM,EAAE,WAAW,EACnB,MAAM,GAAE,MAAU,EAClB,MAAM,GAAE,MAA0B,EAClC,QAAQ,GAAE,MAAM,GAAG,IAAW,GAC7B,OAAO,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,WAAW,CAAA;KAAC,CAAC;IAQ9C,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAStC,QAAQ,CAAC,IAAI,KAAA,EAAE,IAAI,KAAA;CAQpB"}
@@ -1,126 +0,0 @@
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);
25
- }
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;
59
- }
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;
72
- }
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 };
82
- }
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;
90
- }
91
- // implements IRandomAccessFileSystem
92
- // RANDOM ACCESS
93
- async open(pathname, flags, mode) {
94
- return this.files[pathname];
95
- }
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;
124
- }
125
- }
126
- exports.default = BrowserFileSystem;
@@ -1,46 +0,0 @@
1
- export type ReadOptions = {};
2
- export type Stat = {
3
- size: number;
4
- isDirectory: () => boolean;
5
- };
6
- /**
7
- * A FileSystem interface can encapsulate various file sources,
8
- * a FileList, a ZipFile, a GoogleDrive etc.
9
- */
10
- export interface FileSystem {
11
- /**
12
- * Return a list of file names
13
- * @param dirname directory name. file system root directory if omitted
14
- */
15
- readdir(dirname?: string, options?: {
16
- recursive?: boolean;
17
- }): Promise<string[]>;
18
- /**
19
- * Gets information from a local file from the filesystem
20
- * @param filename file name to stat
21
- * @param options currently unused
22
- * @throws if filename is not in local filesystem
23
- */
24
- stat(filename: string, options?: object): Promise<{
25
- size: number;
26
- }>;
27
- /**
28
- * Fetches a local file from the filesystem (or a URL)
29
- * @param filename
30
- * @param options
31
- */
32
- fetch(filename: RequestInfo, options?: RequestInit): Promise<Response>;
33
- }
34
- /**
35
- * A random access file system
36
- */
37
- export interface RandomAccessReadFileSystem extends FileSystem {
38
- open(path: string, flags: any, mode?: any): Promise<any>;
39
- close(fd: any): Promise<void>;
40
- fstat(fd: any): Promise<Stat>;
41
- read(fd: any, buffer: ArrayBuffer | ArrayBufferView, offset?: number, length?: number, position?: number): Promise<{
42
- bytesRead: number;
43
- buffer: ArrayBuffer;
44
- }>;
45
- }
46
- //# sourceMappingURL=filesystem.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"filesystem.d.ts","sourceRoot":"","sources":["../../../src/lib/filesystems/filesystem.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG,EAAE,CAAC;AAE7B,MAAM,MAAM,IAAI,GAAG;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,OAAO,CAAC;CAC5B,CAAC;AAEF;;;GAGG;AACH,MAAM,WAAW,UAAU;IACzB;;;OAGG;IACH,OAAO,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE;QAAC,SAAS,CAAC,EAAE,OAAO,CAAA;KAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAE9E;;;;;OAKG;IACH,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAC,CAAC,CAAC;IAElE;;;;OAIG;IACH,KAAK,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;CACxE;AAED;;GAEG;AACH,MAAM,WAAW,0BAA2B,SAAQ,UAAU;IAC5D,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,KAAA,EAAE,IAAI,CAAC,KAAA,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;IAC/C,KAAK,CAAC,EAAE,EAAE,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9B,KAAK,CAAC,EAAE,EAAE,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9B,IAAI,CACF,EAAE,EAAE,GAAG,EACP,MAAM,EAAE,WAAW,GAAG,eAAe,EACrC,MAAM,CAAC,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,MAAM,EACf,QAAQ,CAAC,EAAE,MAAM,GAChB,OAAO,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,WAAW,CAAA;KAAC,CAAC,CAAC;CACtD"}
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,19 +0,0 @@
1
- export declare function readArrayBuffer(file: Blob | ArrayBuffer | any, start: number, length: number): Promise<ArrayBuffer>;
2
- /**
3
- * Read a slice of a Blob or File, without loading the entire file into memory
4
- * The trick when reading File objects is to read successive "slices" of the File
5
- * Per spec https://w3c.github.io/FileAPI/, slicing a File only updates the start and end fields
6
- * Actually reading from file happens in `readAsArrayBuffer`
7
- * @param blob to read
8
- export async function readBlob(blob: Blob): Promise<ArrayBuffer> {
9
- return await new Promise((resolve, reject) => {
10
- const fileReader = new FileReader();
11
- fileReader.onload = (event: ProgressEvent<FileReader>) =>
12
- resolve(event?.target?.result as ArrayBuffer);
13
- // TODO - reject with a proper Error
14
- fileReader.onerror = (error: ProgressEvent<FileReader>) => reject(error);
15
- fileReader.readAsArrayBuffer(blob);
16
- });
17
- }
18
- */
19
- //# sourceMappingURL=read-array-buffer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"read-array-buffer.d.ts","sourceRoot":"","sources":["../../../src/lib/filesystems/read-array-buffer.ts"],"names":[],"mappings":"AAEA,wBAAsB,eAAe,CACnC,IAAI,EAAE,IAAI,GAAG,WAAW,GAAG,GAAG,EAC9B,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,CAAC,CAMtB;AAED;;;;;;;;;;;;;;;;EAgBE"}