@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,129 +1,129 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getReadableStream = exports.getAsyncIterableFromData = exports.getArrayBufferOrStringFromData = exports.getArrayBufferOrStringFromDataSync = void 0;
4
- const loader_utils_1 = require("@loaders.gl/loader-utils");
5
- const is_type_1 = require("../../javascript-utils/is-type");
6
- const make_iterator_1 = require("../../iterators/make-iterator/make-iterator");
7
- const response_utils_1 = require("../utils/response-utils");
1
+ import { concatenateArrayBuffersAsync } from '@loaders.gl/loader-utils';
2
+ import { isResponse, isReadableStream, isAsyncIterable, isIterable, isIterator, isBlob, isBuffer } from '../../javascript-utils/is-type';
3
+ import { makeIterator } from '../../iterators/make-iterator/make-iterator';
4
+ import { checkResponse, makeResponse } from '../utils/response-utils';
8
5
  const ERR_DATA = 'Cannot convert supplied data type';
9
- // eslint-disable-next-line complexity
10
- function getArrayBufferOrStringFromDataSync(data, loader, options) {
11
- if (loader.text && typeof data === 'string') {
12
- return data;
13
- }
14
- if ((0, is_type_1.isBuffer)(data)) {
15
- // @ts-ignore
16
- data = data.buffer;
17
- }
18
- if (data instanceof ArrayBuffer) {
19
- const arrayBuffer = data;
20
- if (loader.text && !loader.binary) {
21
- const textDecoder = new TextDecoder('utf8');
22
- return textDecoder.decode(arrayBuffer);
23
- }
24
- return arrayBuffer;
25
- }
26
- // We may need to handle offsets
27
- if (ArrayBuffer.isView(data)) {
28
- // TextDecoder is invoked on typed arrays and will handle offsets
29
- if (loader.text && !loader.binary) {
30
- const textDecoder = new TextDecoder('utf8');
31
- return textDecoder.decode(data);
32
- }
33
- let arrayBuffer = data.buffer;
34
- // Since we are returning the underlying arrayBuffer, we must create a new copy
35
- // if this typed array / Buffer is a partial view into the ArryayBuffer
36
- // TODO - this is a potentially unnecessary copy
37
- const byteLength = data.byteLength || data.length;
38
- if (data.byteOffset !== 0 || byteLength !== arrayBuffer.byteLength) {
39
- // console.warn(`loaders.gl copying arraybuffer of length ${byteLength}`);
40
- arrayBuffer = arrayBuffer.slice(data.byteOffset, data.byteOffset + byteLength);
41
- }
42
- return arrayBuffer;
43
- }
44
- throw new Error(ERR_DATA);
6
+ export function getArrayBufferOrStringFromDataSync(data, loader, options) {
7
+ if (loader.text && typeof data === 'string') {
8
+ return data;
9
+ }
10
+
11
+ if (isBuffer(data)) {
12
+ data = data.buffer;
13
+ }
14
+
15
+ if (data instanceof ArrayBuffer) {
16
+ const arrayBuffer = data;
17
+
18
+ if (loader.text && !loader.binary) {
19
+ const textDecoder = new TextDecoder('utf8');
20
+ return textDecoder.decode(arrayBuffer);
21
+ }
22
+
23
+ return arrayBuffer;
24
+ }
25
+
26
+ if (ArrayBuffer.isView(data)) {
27
+ if (loader.text && !loader.binary) {
28
+ const textDecoder = new TextDecoder('utf8');
29
+ return textDecoder.decode(data);
30
+ }
31
+
32
+ let arrayBuffer = data.buffer;
33
+ const byteLength = data.byteLength || data.length;
34
+
35
+ if (data.byteOffset !== 0 || byteLength !== arrayBuffer.byteLength) {
36
+ arrayBuffer = arrayBuffer.slice(data.byteOffset, data.byteOffset + byteLength);
37
+ }
38
+
39
+ return arrayBuffer;
40
+ }
41
+
42
+ throw new Error(ERR_DATA);
45
43
  }
46
- exports.getArrayBufferOrStringFromDataSync = getArrayBufferOrStringFromDataSync;
47
- // Convert async iterator to a promise
48
- async function getArrayBufferOrStringFromData(data, loader, options) {
49
- const isArrayBuffer = data instanceof ArrayBuffer || ArrayBuffer.isView(data);
50
- if (typeof data === 'string' || isArrayBuffer) {
51
- return getArrayBufferOrStringFromDataSync(data, loader, options);
52
- }
53
- // Blobs and files are FileReader compatible
54
- if ((0, is_type_1.isBlob)(data)) {
55
- data = await (0, response_utils_1.makeResponse)(data);
56
- }
57
- if ((0, is_type_1.isResponse)(data)) {
58
- const response = data;
59
- await (0, response_utils_1.checkResponse)(response);
60
- return loader.binary ? await response.arrayBuffer() : await response.text();
61
- }
62
- if ((0, is_type_1.isReadableStream)(data)) {
63
- // @ts-expect-error TS2559 options type
64
- data = (0, make_iterator_1.makeIterator)(data, options);
65
- }
66
- if ((0, is_type_1.isIterable)(data) || (0, is_type_1.isAsyncIterable)(data)) {
67
- // Assume arrayBuffer iterator - attempt to concatenate
68
- return (0, loader_utils_1.concatenateArrayBuffersAsync)(data);
69
- }
70
- throw new Error(ERR_DATA);
44
+ export async function getArrayBufferOrStringFromData(data, loader, options) {
45
+ const isArrayBuffer = data instanceof ArrayBuffer || ArrayBuffer.isView(data);
46
+
47
+ if (typeof data === 'string' || isArrayBuffer) {
48
+ return getArrayBufferOrStringFromDataSync(data, loader, options);
49
+ }
50
+
51
+ if (isBlob(data)) {
52
+ data = await makeResponse(data);
53
+ }
54
+
55
+ if (isResponse(data)) {
56
+ const response = data;
57
+ await checkResponse(response);
58
+ return loader.binary ? await response.arrayBuffer() : await response.text();
59
+ }
60
+
61
+ if (isReadableStream(data)) {
62
+ data = makeIterator(data, options);
63
+ }
64
+
65
+ if (isIterable(data) || isAsyncIterable(data)) {
66
+ return concatenateArrayBuffersAsync(data);
67
+ }
68
+
69
+ throw new Error(ERR_DATA);
71
70
  }
72
- exports.getArrayBufferOrStringFromData = getArrayBufferOrStringFromData;
73
- async function getAsyncIterableFromData(data, options) {
74
- if ((0, is_type_1.isIterator)(data)) {
75
- return data;
76
- }
77
- if ((0, is_type_1.isResponse)(data)) {
78
- const response = data;
79
- // Note Since this function is not async, we currently can't load error message, just status
80
- await (0, response_utils_1.checkResponse)(response);
81
- // TODO - bug in polyfill, body can be a Promise under Node.js
82
- // eslint-disable-next-line @typescript-eslint/await-thenable
83
- const body = await response.body;
84
- // TODO - body can be null?
85
- return (0, make_iterator_1.makeIterator)(body, options);
86
- }
87
- if ((0, is_type_1.isBlob)(data) || (0, is_type_1.isReadableStream)(data)) {
88
- return (0, make_iterator_1.makeIterator)(data, options);
89
- }
90
- if ((0, is_type_1.isAsyncIterable)(data)) {
91
- return data[Symbol.asyncIterator]();
92
- }
93
- return getIterableFromData(data);
71
+ export async function getAsyncIterableFromData(data, options) {
72
+ if (isIterator(data)) {
73
+ return data;
74
+ }
75
+
76
+ if (isResponse(data)) {
77
+ const response = data;
78
+ await checkResponse(response);
79
+ const body = await response.body;
80
+ return makeIterator(body, options);
81
+ }
82
+
83
+ if (isBlob(data) || isReadableStream(data)) {
84
+ return makeIterator(data, options);
85
+ }
86
+
87
+ if (isAsyncIterable(data)) {
88
+ return data[Symbol.asyncIterator]();
89
+ }
90
+
91
+ return getIterableFromData(data);
94
92
  }
95
- exports.getAsyncIterableFromData = getAsyncIterableFromData;
96
- async function getReadableStream(data) {
97
- if ((0, is_type_1.isReadableStream)(data)) {
98
- return data;
99
- }
100
- if ((0, is_type_1.isResponse)(data)) {
101
- // @ts-ignore
102
- return data.body;
103
- }
104
- const response = await (0, response_utils_1.makeResponse)(data);
105
- // @ts-ignore
106
- return response.body;
93
+ export async function getReadableStream(data) {
94
+ if (isReadableStream(data)) {
95
+ return data;
96
+ }
97
+
98
+ if (isResponse(data)) {
99
+ return data.body;
100
+ }
101
+
102
+ const response = await makeResponse(data);
103
+ return response.body;
107
104
  }
108
- exports.getReadableStream = getReadableStream;
109
- // HELPERS
105
+
110
106
  function getIterableFromData(data) {
111
- // generate an iterator that emits a single chunk
112
- if (ArrayBuffer.isView(data)) {
113
- return (function* oneChunk() {
114
- yield data.buffer;
115
- })();
116
- }
117
- if (data instanceof ArrayBuffer) {
118
- return (function* oneChunk() {
119
- yield data;
120
- })();
121
- }
122
- if ((0, is_type_1.isIterator)(data)) {
123
- return data;
124
- }
125
- if ((0, is_type_1.isIterable)(data)) {
126
- return data[Symbol.iterator]();
127
- }
128
- throw new Error(ERR_DATA);
107
+ if (ArrayBuffer.isView(data)) {
108
+ return function* oneChunk() {
109
+ yield data.buffer;
110
+ }();
111
+ }
112
+
113
+ if (data instanceof ArrayBuffer) {
114
+ return function* oneChunk() {
115
+ yield data;
116
+ }();
117
+ }
118
+
119
+ if (isIterator(data)) {
120
+ return data;
121
+ }
122
+
123
+ if (isIterable(data)) {
124
+ return data[Symbol.iterator]();
125
+ }
126
+
127
+ throw new Error(ERR_DATA);
129
128
  }
129
+ //# sourceMappingURL=get-data.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/loader-utils/get-data.ts"],"names":["concatenateArrayBuffersAsync","isResponse","isReadableStream","isAsyncIterable","isIterable","isIterator","isBlob","isBuffer","makeIterator","checkResponse","makeResponse","ERR_DATA","getArrayBufferOrStringFromDataSync","data","loader","options","text","buffer","ArrayBuffer","arrayBuffer","binary","textDecoder","TextDecoder","decode","isView","byteLength","length","byteOffset","slice","Error","getArrayBufferOrStringFromData","isArrayBuffer","response","getAsyncIterableFromData","body","Symbol","asyncIterator","getIterableFromData","getReadableStream","oneChunk","iterator"],"mappings":"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","sourcesContent":["import type {\n DataType,\n SyncDataType,\n BatchableDataType,\n Loader,\n LoaderOptions\n} from '@loaders.gl/loader-utils';\nimport {concatenateArrayBuffersAsync} from '@loaders.gl/loader-utils';\nimport {\n isResponse,\n isReadableStream,\n isAsyncIterable,\n isIterable,\n isIterator,\n isBlob,\n isBuffer\n} from '../../javascript-utils/is-type';\nimport {makeIterator} from '../../iterators/make-iterator/make-iterator';\nimport {checkResponse, makeResponse} from '../utils/response-utils';\n\nconst ERR_DATA = 'Cannot convert supplied data type';\n\n// eslint-disable-next-line complexity\nexport function getArrayBufferOrStringFromDataSync(\n data: SyncDataType,\n loader: Loader,\n options: LoaderOptions\n): ArrayBuffer | string {\n if (loader.text && typeof data === 'string') {\n return data;\n }\n\n if (isBuffer(data)) {\n // @ts-ignore\n data = data.buffer;\n }\n\n if (data instanceof ArrayBuffer) {\n const arrayBuffer = data;\n if (loader.text && !loader.binary) {\n const textDecoder = new TextDecoder('utf8');\n return textDecoder.decode(arrayBuffer);\n }\n return arrayBuffer;\n }\n\n // We may need to handle offsets\n if (ArrayBuffer.isView(data)) {\n // TextDecoder is invoked on typed arrays and will handle offsets\n if (loader.text && !loader.binary) {\n const textDecoder = new TextDecoder('utf8');\n return textDecoder.decode(data);\n }\n\n let arrayBuffer = data.buffer;\n\n // Since we are returning the underlying arrayBuffer, we must create a new copy\n // if this typed array / Buffer is a partial view into the ArryayBuffer\n // TODO - this is a potentially unnecessary copy\n const byteLength = data.byteLength || data.length;\n if (data.byteOffset !== 0 || byteLength !== arrayBuffer.byteLength) {\n // console.warn(`loaders.gl copying arraybuffer of length ${byteLength}`);\n arrayBuffer = arrayBuffer.slice(data.byteOffset, data.byteOffset + byteLength);\n }\n return arrayBuffer;\n }\n\n throw new Error(ERR_DATA);\n}\n\n// Convert async iterator to a promise\nexport async function getArrayBufferOrStringFromData(\n data: DataType,\n loader: Loader,\n options: LoaderOptions\n): Promise<ArrayBuffer | string> {\n const isArrayBuffer = data instanceof ArrayBuffer || ArrayBuffer.isView(data);\n if (typeof data === 'string' || isArrayBuffer) {\n return getArrayBufferOrStringFromDataSync(data as string | ArrayBuffer, loader, options);\n }\n\n // Blobs and files are FileReader compatible\n if (isBlob(data)) {\n data = await makeResponse(data);\n }\n\n if (isResponse(data)) {\n const response = data as Response;\n await checkResponse(response);\n return loader.binary ? await response.arrayBuffer() : await response.text();\n }\n\n if (isReadableStream(data)) {\n // @ts-expect-error TS2559 options type\n data = makeIterator(data as ReadableStream, options);\n }\n\n if (isIterable(data) || isAsyncIterable(data)) {\n // Assume arrayBuffer iterator - attempt to concatenate\n return concatenateArrayBuffersAsync(data as AsyncIterable<ArrayBuffer>);\n }\n\n throw new Error(ERR_DATA);\n}\n\nexport async function getAsyncIterableFromData(\n data: BatchableDataType,\n options: LoaderOptions\n): Promise<AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>> {\n if (isIterator(data)) {\n return data as AsyncIterable<ArrayBuffer>;\n }\n\n if (isResponse(data)) {\n const response = data as Response;\n // Note Since this function is not async, we currently can't load error message, just status\n await checkResponse(response);\n // TODO - bug in polyfill, body can be a Promise under Node.js\n // eslint-disable-next-line @typescript-eslint/await-thenable\n const body = await response.body;\n // TODO - body can be null?\n return makeIterator(body as ReadableStream<Uint8Array>, options as any);\n }\n\n if (isBlob(data) || isReadableStream(data)) {\n return makeIterator(data as Blob | ReadableStream, options as any);\n }\n\n if (isAsyncIterable(data)) {\n return data[Symbol.asyncIterator]();\n }\n\n return getIterableFromData(data);\n}\n\nexport async function getReadableStream(data: BatchableDataType): Promise<ReadableStream> {\n if (isReadableStream(data)) {\n return data as ReadableStream;\n }\n if (isResponse(data)) {\n // @ts-ignore\n return data.body;\n }\n const response = await makeResponse(data);\n // @ts-ignore\n return response.body;\n}\n\n// HELPERS\n\nfunction getIterableFromData(data) {\n // generate an iterator that emits a single chunk\n if (ArrayBuffer.isView(data)) {\n return (function* oneChunk() {\n yield data.buffer;\n })();\n }\n\n if (data instanceof ArrayBuffer) {\n return (function* oneChunk() {\n yield data;\n })();\n }\n\n if (isIterator(data)) {\n return data;\n }\n\n if (isIterable(data)) {\n return data[Symbol.iterator]();\n }\n\n throw new Error(ERR_DATA);\n}\n"],"file":"get-data.js"}
@@ -1,49 +1,36 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getLoadersFromContext = exports.getLoaderContext = void 0;
4
- const option_utils_1 = require("./option-utils");
5
- /**
6
- * "sub" loaders invoked by other loaders get a "context" injected on `this`
7
- * The context will inject core methods like `parse` and contain information
8
- * about loaders and options passed in to the top-level `parse` call.
9
- *
10
- * @param context
11
- * @param options
12
- * @param previousContext
13
- */
14
- function getLoaderContext(context, options, previousContext = null) {
15
- // For recursive calls, we already have a context
16
- // TODO - add any additional loaders to context?
17
- if (previousContext) {
18
- return previousContext;
19
- }
20
- const resolvedContext = {
21
- fetch: (0, option_utils_1.getFetchFunction)(options, context),
22
- ...context
23
- };
24
- // Recursive loading does not use single loader
25
- if (!Array.isArray(resolvedContext.loaders)) {
26
- resolvedContext.loaders = null;
27
- }
28
- return resolvedContext;
1
+ import { getFetchFunction } from './option-utils';
2
+ export function getLoaderContext(context, options, previousContext = null) {
3
+ if (previousContext) {
4
+ return previousContext;
5
+ }
6
+
7
+ const resolvedContext = {
8
+ fetch: getFetchFunction(options, context),
9
+ ...context
10
+ };
11
+
12
+ if (!Array.isArray(resolvedContext.loaders)) {
13
+ resolvedContext.loaders = null;
14
+ }
15
+
16
+ return resolvedContext;
29
17
  }
30
- exports.getLoaderContext = getLoaderContext;
31
- // eslint-disable-next-line complexity
32
- function getLoadersFromContext(loaders, context) {
33
- // A single non-array loader is force selected, but only on top-level (context === null)
34
- if (!context && loaders && !Array.isArray(loaders)) {
35
- return loaders;
36
- }
37
- // Create a merged list
38
- let candidateLoaders;
39
- if (loaders) {
40
- candidateLoaders = Array.isArray(loaders) ? loaders : [loaders];
41
- }
42
- if (context && context.loaders) {
43
- const contextLoaders = Array.isArray(context.loaders) ? context.loaders : [context.loaders];
44
- candidateLoaders = candidateLoaders ? [...candidateLoaders, ...contextLoaders] : contextLoaders;
45
- }
46
- // If no loaders, return null to look in globally registered loaders
47
- return candidateLoaders && candidateLoaders.length ? candidateLoaders : null;
18
+ export function getLoadersFromContext(loaders, context) {
19
+ if (!context && loaders && !Array.isArray(loaders)) {
20
+ return loaders;
21
+ }
22
+
23
+ let candidateLoaders;
24
+
25
+ if (loaders) {
26
+ candidateLoaders = Array.isArray(loaders) ? loaders : [loaders];
27
+ }
28
+
29
+ if (context && context.loaders) {
30
+ const contextLoaders = Array.isArray(context.loaders) ? context.loaders : [context.loaders];
31
+ candidateLoaders = candidateLoaders ? [...candidateLoaders, ...contextLoaders] : contextLoaders;
32
+ }
33
+
34
+ return candidateLoaders && candidateLoaders.length ? candidateLoaders : null;
48
35
  }
49
- exports.getLoadersFromContext = getLoadersFromContext;
36
+ //# sourceMappingURL=loader-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/loader-utils/loader-context.ts"],"names":["getFetchFunction","getLoaderContext","context","options","previousContext","resolvedContext","fetch","Array","isArray","loaders","getLoadersFromContext","candidateLoaders","contextLoaders","length"],"mappings":"AACA,SAAQA,gBAAR,QAA+B,gBAA/B;AAWA,OAAO,SAASC,gBAAT,CACLC,OADK,EAELC,OAFK,EAGLC,eAAqC,GAAG,IAHnC,EAIU;AAGf,MAAIA,eAAJ,EAAqB;AACnB,WAAOA,eAAP;AACD;;AAED,QAAMC,eAA8B,GAAG;AACrCC,IAAAA,KAAK,EAAEN,gBAAgB,CAACG,OAAD,EAAUD,OAAV,CADc;AAErC,OAAGA;AAFkC,GAAvC;;AAMA,MAAI,CAACK,KAAK,CAACC,OAAN,CAAcH,eAAe,CAACI,OAA9B,CAAL,EAA6C;AAC3CJ,IAAAA,eAAe,CAACI,OAAhB,GAA0B,IAA1B;AACD;;AAED,SAAOJ,eAAP;AACD;AAGD,OAAO,SAASK,qBAAT,CACLD,OADK,EAELP,OAFK,EAGL;AAEA,MAAI,CAACA,OAAD,IAAYO,OAAZ,IAAuB,CAACF,KAAK,CAACC,OAAN,CAAcC,OAAd,CAA5B,EAAoD;AAClD,WAAOA,OAAP;AACD;;AAGD,MAAIE,gBAAJ;;AACA,MAAIF,OAAJ,EAAa;AACXE,IAAAA,gBAAgB,GAAGJ,KAAK,CAACC,OAAN,CAAcC,OAAd,IAAyBA,OAAzB,GAAmC,CAACA,OAAD,CAAtD;AACD;;AACD,MAAIP,OAAO,IAAIA,OAAO,CAACO,OAAvB,EAAgC;AAC9B,UAAMG,cAAc,GAAGL,KAAK,CAACC,OAAN,CAAcN,OAAO,CAACO,OAAtB,IAAiCP,OAAO,CAACO,OAAzC,GAAmD,CAACP,OAAO,CAACO,OAAT,CAA1E;AACAE,IAAAA,gBAAgB,GAAGA,gBAAgB,GAAG,CAAC,GAAGA,gBAAJ,EAAsB,GAAGC,cAAzB,CAAH,GAA8CA,cAAjF;AACD;;AAED,SAAOD,gBAAgB,IAAIA,gBAAgB,CAACE,MAArC,GAA8CF,gBAA9C,GAAiE,IAAxE;AACD","sourcesContent":["import type {Loader, LoaderOptions, LoaderContext} from '@loaders.gl/loader-utils';\nimport {getFetchFunction} from './option-utils';\n\n/**\n * \"sub\" loaders invoked by other loaders get a \"context\" injected on `this`\n * The context will inject core methods like `parse` and contain information\n * about loaders and options passed in to the top-level `parse` call.\n *\n * @param context\n * @param options\n * @param previousContext\n */\nexport function getLoaderContext(\n context: Omit<LoaderContext, 'fetch'> & Partial<Pick<LoaderContext, 'fetch'>>,\n options?: LoaderOptions,\n previousContext: LoaderContext | null = null\n): LoaderContext {\n // For recursive calls, we already have a context\n // TODO - add any additional loaders to context?\n if (previousContext) {\n return previousContext;\n }\n\n const resolvedContext: LoaderContext = {\n fetch: getFetchFunction(options, context),\n ...context\n };\n\n // Recursive loading does not use single loader\n if (!Array.isArray(resolvedContext.loaders)) {\n resolvedContext.loaders = null;\n }\n\n return resolvedContext;\n}\n\n// eslint-disable-next-line complexity\nexport function getLoadersFromContext(\n loaders: Loader[] | Loader | undefined,\n context?: LoaderContext\n) {\n // A single non-array loader is force selected, but only on top-level (context === null)\n if (!context && loaders && !Array.isArray(loaders)) {\n return loaders;\n }\n\n // Create a merged list\n let candidateLoaders;\n if (loaders) {\n candidateLoaders = Array.isArray(loaders) ? loaders : [loaders];\n }\n if (context && context.loaders) {\n const contextLoaders = Array.isArray(context.loaders) ? context.loaders : [context.loaders];\n candidateLoaders = candidateLoaders ? [...candidateLoaders, ...contextLoaders] : contextLoaders;\n }\n // If no loaders, return null to look in globally registered loaders\n return candidateLoaders && candidateLoaders.length ? candidateLoaders : null;\n}\n"],"file":"loader-context.js"}
@@ -1,41 +1,48 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ConsoleLog = exports.NullLog = exports.probeLog = void 0;
4
- // probe.gl Log compatible loggers
5
- const probe_gl_1 = require("probe.gl");
6
- exports.probeLog = new probe_gl_1.Log({ id: 'loaders.gl' });
7
- // Logs nothing
8
- class NullLog {
9
- log() {
10
- return () => { };
11
- }
12
- info() {
13
- return () => { };
14
- }
15
- warn() {
16
- return () => { };
17
- }
18
- error() {
19
- return () => { };
20
- }
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
+ import { Log } from 'probe.gl';
3
+ export const probeLog = new Log({
4
+ id: 'loaders.gl'
5
+ });
6
+ export class NullLog {
7
+ log() {
8
+ return () => {};
9
+ }
10
+
11
+ info() {
12
+ return () => {};
13
+ }
14
+
15
+ warn() {
16
+ return () => {};
17
+ }
18
+
19
+ error() {
20
+ return () => {};
21
+ }
22
+
21
23
  }
22
- exports.NullLog = NullLog;
23
- // Logs to console
24
- class ConsoleLog {
25
- constructor() {
26
- this.console = console; // eslint-disable-line
27
- }
28
- log(...args) {
29
- return this.console.log.bind(this.console, ...args);
30
- }
31
- info(...args) {
32
- return this.console.info.bind(this.console, ...args);
33
- }
34
- warn(...args) {
35
- return this.console.warn.bind(this.console, ...args);
36
- }
37
- error(...args) {
38
- return this.console.error.bind(this.console, ...args);
39
- }
24
+ export class ConsoleLog {
25
+ constructor() {
26
+ _defineProperty(this, "console", void 0);
27
+
28
+ this.console = console;
29
+ }
30
+
31
+ log(...args) {
32
+ return this.console.log.bind(this.console, ...args);
33
+ }
34
+
35
+ info(...args) {
36
+ return this.console.info.bind(this.console, ...args);
37
+ }
38
+
39
+ warn(...args) {
40
+ return this.console.warn.bind(this.console, ...args);
41
+ }
42
+
43
+ error(...args) {
44
+ return this.console.error.bind(this.console, ...args);
45
+ }
46
+
40
47
  }
41
- exports.ConsoleLog = ConsoleLog;
48
+ //# sourceMappingURL=loggers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/loader-utils/loggers.ts"],"names":["Log","probeLog","id","NullLog","log","info","warn","error","ConsoleLog","constructor","console","args","bind"],"mappings":";AACA,SAAQA,GAAR,QAAkB,UAAlB;AAEA,OAAO,MAAMC,QAAQ,GAAG,IAAID,GAAJ,CAAQ;AAACE,EAAAA,EAAE,EAAE;AAAL,CAAR,CAAjB;AAGP,OAAO,MAAMC,OAAN,CAAc;AACnBC,EAAAA,GAAG,GAAG;AACJ,WAAO,MAAM,CAAE,CAAf;AACD;;AACDC,EAAAA,IAAI,GAAG;AACL,WAAO,MAAM,CAAE,CAAf;AACD;;AACDC,EAAAA,IAAI,GAAG;AACL,WAAO,MAAM,CAAE,CAAf;AACD;;AACDC,EAAAA,KAAK,GAAG;AACN,WAAO,MAAM,CAAE,CAAf;AACD;;AAZkB;AAgBrB,OAAO,MAAMC,UAAN,CAAiB;AAGtBC,EAAAA,WAAW,GAAG;AAAA;;AACZ,SAAKC,OAAL,GAAeA,OAAf;AACD;;AACDN,EAAAA,GAAG,CAAC,GAAGO,IAAJ,EAAU;AACX,WAAO,KAAKD,OAAL,CAAaN,GAAb,CAAiBQ,IAAjB,CAAsB,KAAKF,OAA3B,EAAoC,GAAGC,IAAvC,CAAP;AACD;;AACDN,EAAAA,IAAI,CAAC,GAAGM,IAAJ,EAAU;AACZ,WAAO,KAAKD,OAAL,CAAaL,IAAb,CAAkBO,IAAlB,CAAuB,KAAKF,OAA5B,EAAqC,GAAGC,IAAxC,CAAP;AACD;;AACDL,EAAAA,IAAI,CAAC,GAAGK,IAAJ,EAAU;AACZ,WAAO,KAAKD,OAAL,CAAaJ,IAAb,CAAkBM,IAAlB,CAAuB,KAAKF,OAA5B,EAAqC,GAAGC,IAAxC,CAAP;AACD;;AACDJ,EAAAA,KAAK,CAAC,GAAGI,IAAJ,EAAU;AACb,WAAO,KAAKD,OAAL,CAAaH,KAAb,CAAmBK,IAAnB,CAAwB,KAAKF,OAA7B,EAAsC,GAAGC,IAAzC,CAAP;AACD;;AAjBqB","sourcesContent":["// probe.gl Log compatible loggers\nimport {Log} from 'probe.gl';\n\nexport const probeLog = new Log({id: 'loaders.gl'});\n\n// Logs nothing\nexport class NullLog {\n log() {\n return () => {};\n }\n info() {\n return () => {};\n }\n warn() {\n return () => {};\n }\n error() {\n return () => {};\n }\n}\n\n// Logs to console\nexport class ConsoleLog {\n console;\n\n constructor() {\n this.console = console; // eslint-disable-line\n }\n log(...args) {\n return this.console.log.bind(this.console, ...args);\n }\n info(...args) {\n return this.console.info.bind(this.console, ...args);\n }\n warn(...args) {\n return this.console.warn.bind(this.console, ...args);\n }\n error(...args) {\n return this.console.error.bind(this.console, ...args);\n }\n}\n"],"file":"loggers.js"}
@@ -1,52 +1,43 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.normalizeLoader = exports.isLoaderObject = void 0;
4
- const loader_utils_1 = require("@loaders.gl/loader-utils");
5
- function isLoaderObject(loader) {
6
- if (!loader) {
7
- return false;
8
- }
9
- if (Array.isArray(loader)) {
10
- loader = loader[0];
11
- }
12
- const hasExtensions = Array.isArray(loader?.extensions);
13
- /* Now handled by types and worker loaders do not have these
14
- let hasParser =
15
- loader.parseTextSync ||
16
- loader.parseSync ||
17
- loader.parse ||
18
- loader.parseStream || // TODO Remove, Replace with parseInBatches
19
- loader.parseInBatches;
20
- */
21
- return hasExtensions;
1
+ import { assert } from '@loaders.gl/loader-utils';
2
+ export function isLoaderObject(loader) {
3
+ var _loader;
4
+
5
+ if (!loader) {
6
+ return false;
7
+ }
8
+
9
+ if (Array.isArray(loader)) {
10
+ loader = loader[0];
11
+ }
12
+
13
+ const hasExtensions = Array.isArray((_loader = loader) === null || _loader === void 0 ? void 0 : _loader.extensions);
14
+ return hasExtensions;
22
15
  }
23
- exports.isLoaderObject = isLoaderObject;
24
- function normalizeLoader(loader) {
25
- // This error is fairly easy to trigger by mixing up import statements etc
26
- // So we make an exception and add a developer error message for this case
27
- // To help new users from getting stuck here
28
- (0, loader_utils_1.assert)(loader, 'null loader');
29
- (0, loader_utils_1.assert)(isLoaderObject(loader), 'invalid loader');
30
- // NORMALIZE [LOADER, OPTIONS] => LOADER
31
- // If [loader, options], create a new loaders object with options merged in
32
- let options;
33
- if (Array.isArray(loader)) {
34
- options = loader[1];
35
- loader = loader[0];
36
- loader = {
37
- ...loader,
38
- options: { ...loader.options, ...options }
39
- };
40
- }
41
- // NORMALIZE text and binary flags
42
- // Ensure at least one of text/binary flags are properly set
43
- // @ts-expect-error
44
- if (loader?.parseTextSync || loader?.parseText) {
45
- loader.text = true;
46
- }
47
- if (!loader.text) {
48
- loader.binary = true;
49
- }
50
- return loader;
16
+ export function normalizeLoader(loader) {
17
+ var _loader2, _loader3;
18
+
19
+ assert(loader, 'null loader');
20
+ assert(isLoaderObject(loader), 'invalid loader');
21
+ let options;
22
+
23
+ if (Array.isArray(loader)) {
24
+ options = loader[1];
25
+ loader = loader[0];
26
+ loader = { ...loader,
27
+ options: { ...loader.options,
28
+ ...options
29
+ }
30
+ };
31
+ }
32
+
33
+ if ((_loader2 = loader) !== null && _loader2 !== void 0 && _loader2.parseTextSync || (_loader3 = loader) !== null && _loader3 !== void 0 && _loader3.parseText) {
34
+ loader.text = true;
35
+ }
36
+
37
+ if (!loader.text) {
38
+ loader.binary = true;
39
+ }
40
+
41
+ return loader;
51
42
  }
52
- exports.normalizeLoader = normalizeLoader;
43
+ //# sourceMappingURL=normalize-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/loader-utils/normalize-loader.ts"],"names":["assert","isLoaderObject","loader","Array","isArray","hasExtensions","extensions","normalizeLoader","options","parseTextSync","parseText","text","binary"],"mappings":"AACA,SAAQA,MAAR,QAAqB,0BAArB;AAEA,OAAO,SAASC,cAAT,CAAwBC,MAAxB,EAA+C;AAAA;;AACpD,MAAI,CAACA,MAAL,EAAa;AACX,WAAO,KAAP;AACD;;AAED,MAAIC,KAAK,CAACC,OAAN,CAAcF,MAAd,CAAJ,EAA2B;AACzBA,IAAAA,MAAM,GAAGA,MAAM,CAAC,CAAD,CAAf;AACD;;AAED,QAAMG,aAAa,GAAGF,KAAK,CAACC,OAAN,YAAcF,MAAd,4CAAc,QAAQI,UAAtB,CAAtB;AAWA,SAAOD,aAAP;AACD;AAED,OAAO,SAASE,eAAT,CAAyBL,MAAzB,EAAiD;AAAA;;AAItDF,EAAAA,MAAM,CAACE,MAAD,EAAS,aAAT,CAAN;AACAF,EAAAA,MAAM,CAACC,cAAc,CAACC,MAAD,CAAf,EAAyB,gBAAzB,CAAN;AAKA,MAAIM,OAAJ;;AACA,MAAIL,KAAK,CAACC,OAAN,CAAcF,MAAd,CAAJ,EAA2B;AACzBM,IAAAA,OAAO,GAAGN,MAAM,CAAC,CAAD,CAAhB;AACAA,IAAAA,MAAM,GAAGA,MAAM,CAAC,CAAD,CAAf;AACAA,IAAAA,MAAM,GAAG,EACP,GAAGA,MADI;AAEPM,MAAAA,OAAO,EAAE,EAAC,GAAGN,MAAM,CAACM,OAAX;AAAoB,WAAGA;AAAvB;AAFF,KAAT;AAID;;AAMD,MAAI,YAAAN,MAAM,UAAN,oCAAQO,aAAR,gBAAyBP,MAAzB,qCAAyB,SAAQQ,SAArC,EAAgD;AAC9CR,IAAAA,MAAM,CAACS,IAAP,GAAc,IAAd;AACD;;AAED,MAAI,CAACT,MAAM,CAACS,IAAZ,EAAkB;AAChBT,IAAAA,MAAM,CAACU,MAAP,GAAgB,IAAhB;AACD;;AAED,SAAOV,MAAP;AACD","sourcesContent":["import type {Loader} from '@loaders.gl/loader-utils';\nimport {assert} from '@loaders.gl/loader-utils';\n\nexport function isLoaderObject(loader?: any): boolean {\n if (!loader) {\n return false;\n }\n\n if (Array.isArray(loader)) {\n loader = loader[0];\n }\n\n const hasExtensions = Array.isArray(loader?.extensions);\n\n /* Now handled by types and worker loaders do not have these\n let hasParser =\n loader.parseTextSync ||\n loader.parseSync ||\n loader.parse ||\n loader.parseStream || // TODO Remove, Replace with parseInBatches\n loader.parseInBatches;\n */\n\n return hasExtensions;\n}\n\nexport function normalizeLoader(loader: Loader): Loader {\n // This error is fairly easy to trigger by mixing up import statements etc\n // So we make an exception and add a developer error message for this case\n // To help new users from getting stuck here\n assert(loader, 'null loader');\n assert(isLoaderObject(loader), 'invalid loader');\n\n // NORMALIZE [LOADER, OPTIONS] => LOADER\n\n // If [loader, options], create a new loaders object with options merged in\n let options;\n if (Array.isArray(loader)) {\n options = loader[1];\n loader = loader[0];\n loader = {\n ...loader,\n options: {...loader.options, ...options}\n };\n }\n\n // NORMALIZE text and binary flags\n // Ensure at least one of text/binary flags are properly set\n\n // @ts-expect-error\n if (loader?.parseTextSync || loader?.parseText) {\n loader.text = true;\n }\n\n if (!loader.text) {\n loader.binary = true;\n }\n\n return loader;\n}\n"],"file":"normalize-loader.js"}