@loaders.gl/loader-utils 3.1.0-alpha.3 → 3.1.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (193) hide show
  1. package/dist/es5/index.js +323 -0
  2. package/dist/es5/index.js.map +1 -0
  3. package/dist/es5/json-loader.js +29 -0
  4. package/dist/es5/json-loader.js.map +1 -0
  5. package/dist/es5/lib/binary-utils/array-buffer-utils.js +102 -0
  6. package/dist/es5/lib/binary-utils/array-buffer-utils.js.map +1 -0
  7. package/dist/es5/lib/binary-utils/binary-copy-utils.js +35 -0
  8. package/dist/es5/lib/binary-utils/binary-copy-utils.js.map +1 -0
  9. package/dist/es5/lib/binary-utils/buffer-utils.js +32 -0
  10. package/dist/es5/lib/binary-utils/buffer-utils.js.map +1 -0
  11. package/dist/es5/lib/binary-utils/encode-utils.js +42 -0
  12. package/dist/es5/lib/binary-utils/encode-utils.js.map +1 -0
  13. package/dist/es5/lib/binary-utils/get-first-characters.js +36 -0
  14. package/dist/es5/lib/binary-utils/get-first-characters.js.map +1 -0
  15. package/dist/es5/lib/binary-utils/memory-copy-utils.js +39 -0
  16. package/dist/es5/lib/binary-utils/memory-copy-utils.js.map +1 -0
  17. package/dist/es5/lib/env-utils/assert.js +13 -0
  18. package/dist/es5/lib/env-utils/assert.js.map +1 -0
  19. package/dist/es5/lib/env-utils/globals.js +28 -0
  20. package/dist/es5/lib/env-utils/globals.js.map +1 -0
  21. package/dist/es5/lib/filesystems/node-filesystem.js +74 -0
  22. package/dist/es5/lib/filesystems/node-filesystem.js.map +1 -0
  23. package/dist/es5/lib/iterators/async-iteration.js +51 -0
  24. package/dist/es5/lib/iterators/async-iteration.js.map +1 -0
  25. package/dist/es5/lib/iterators/text-iterators.js +59 -0
  26. package/dist/es5/lib/iterators/text-iterators.js.map +1 -0
  27. package/dist/es5/lib/node/buffer.js +38 -0
  28. package/dist/es5/lib/node/buffer.js.map +1 -0
  29. package/dist/es5/lib/node/fs.js +52 -0
  30. package/dist/es5/lib/node/fs.js.map +1 -0
  31. package/dist/es5/lib/node/util.js +16 -0
  32. package/dist/es5/lib/node/util.js.map +1 -0
  33. package/dist/es5/lib/parser-utils/parse-json.js +17 -0
  34. package/dist/es5/lib/parser-utils/parse-json.js.map +1 -0
  35. package/dist/es5/lib/path-utils/file-aliases.js +39 -0
  36. package/dist/es5/lib/path-utils/file-aliases.js.map +1 -0
  37. package/dist/es5/lib/path-utils/path.js +35 -0
  38. package/dist/es5/lib/path-utils/path.js.map +1 -0
  39. package/dist/es5/lib/request-utils/request-scheduler.js +154 -0
  40. package/dist/es5/lib/request-utils/request-scheduler.js.map +1 -0
  41. package/dist/es5/lib/worker-loader-utils/create-loader-worker.js +117 -0
  42. package/dist/es5/lib/worker-loader-utils/create-loader-worker.js.map +1 -0
  43. package/dist/es5/lib/worker-loader-utils/parse-with-worker.js +76 -0
  44. package/dist/es5/lib/worker-loader-utils/parse-with-worker.js.map +1 -0
  45. package/dist/es5/types.js +2 -0
  46. package/dist/{types.js.map → es5/types.js.map} +0 -0
  47. package/dist/es5/workers/json-worker.js +8 -0
  48. package/dist/es5/workers/json-worker.js.map +1 -0
  49. package/dist/esm/index.js +26 -0
  50. package/dist/esm/index.js.map +1 -0
  51. package/dist/esm/json-loader.js +21 -0
  52. package/dist/esm/json-loader.js.map +1 -0
  53. package/dist/esm/lib/binary-utils/array-buffer-utils.js +86 -0
  54. package/dist/esm/lib/binary-utils/array-buffer-utils.js.map +1 -0
  55. package/dist/esm/lib/binary-utils/binary-copy-utils.js +25 -0
  56. package/dist/esm/lib/binary-utils/binary-copy-utils.js.map +1 -0
  57. package/dist/esm/lib/binary-utils/buffer-utils.js +16 -0
  58. package/dist/esm/lib/binary-utils/buffer-utils.js.map +1 -0
  59. package/dist/esm/lib/binary-utils/encode-utils.js +31 -0
  60. package/dist/esm/lib/binary-utils/encode-utils.js.map +1 -0
  61. package/dist/esm/lib/binary-utils/get-first-characters.js +27 -0
  62. package/dist/esm/lib/binary-utils/get-first-characters.js.map +1 -0
  63. package/dist/esm/lib/binary-utils/memory-copy-utils.js +27 -0
  64. package/dist/esm/lib/binary-utils/memory-copy-utils.js.map +1 -0
  65. package/dist/esm/lib/env-utils/assert.js +6 -0
  66. package/dist/esm/lib/env-utils/assert.js.map +1 -0
  67. package/dist/esm/lib/env-utils/globals.js +16 -0
  68. package/dist/esm/lib/env-utils/globals.js.map +1 -0
  69. package/dist/esm/lib/filesystems/node-filesystem.js +60 -0
  70. package/dist/esm/lib/filesystems/node-filesystem.js.map +1 -0
  71. package/dist/esm/lib/iterators/async-iteration.js +39 -0
  72. package/dist/esm/lib/iterators/async-iteration.js.map +1 -0
  73. package/dist/esm/lib/iterators/text-iterators.js +46 -0
  74. package/dist/esm/lib/iterators/text-iterators.js.map +1 -0
  75. package/dist/esm/lib/node/buffer.js +28 -0
  76. package/dist/esm/lib/node/buffer.js.map +1 -0
  77. package/dist/esm/lib/node/fs.js +27 -0
  78. package/dist/esm/lib/node/fs.js.map +1 -0
  79. package/dist/esm/lib/node/util.js +3 -0
  80. package/dist/esm/lib/node/util.js.map +1 -0
  81. package/dist/esm/lib/parser-utils/parse-json.js +9 -0
  82. package/dist/esm/lib/parser-utils/parse-json.js.map +1 -0
  83. package/dist/esm/lib/path-utils/file-aliases.js +26 -0
  84. package/dist/esm/lib/path-utils/file-aliases.js.map +1 -0
  85. package/dist/esm/lib/path-utils/path.js +24 -0
  86. package/dist/esm/lib/path-utils/path.js.map +1 -0
  87. package/dist/esm/lib/request-utils/request-scheduler.js +146 -0
  88. package/dist/esm/lib/request-utils/request-scheduler.js.map +1 -0
  89. package/dist/esm/lib/worker-loader-utils/create-loader-worker.js +102 -0
  90. package/dist/esm/lib/worker-loader-utils/create-loader-worker.js.map +1 -0
  91. package/dist/esm/lib/worker-loader-utils/parse-with-worker.js +64 -0
  92. package/dist/esm/lib/worker-loader-utils/parse-with-worker.js.map +1 -0
  93. package/dist/esm/types.js +2 -0
  94. package/dist/esm/types.js.map +1 -0
  95. package/dist/esm/workers/json-worker.js +4 -0
  96. package/dist/esm/workers/json-worker.js.map +1 -0
  97. package/dist/index.d.ts +27 -0
  98. package/dist/index.d.ts.map +1 -0
  99. package/dist/index.js +111 -26
  100. package/dist/json-loader.d.ts +22 -0
  101. package/dist/json-loader.d.ts.map +1 -0
  102. package/dist/json-loader.js +25 -18
  103. package/dist/lib/binary-utils/array-buffer-utils.d.ts +31 -0
  104. package/dist/lib/binary-utils/array-buffer-utils.d.ts.map +1 -0
  105. package/dist/lib/binary-utils/array-buffer-utils.js +108 -79
  106. package/dist/lib/binary-utils/binary-copy-utils.d.ts +24 -0
  107. package/dist/lib/binary-utils/binary-copy-utils.d.ts.map +1 -0
  108. package/dist/lib/binary-utils/binary-copy-utils.js +48 -22
  109. package/dist/lib/binary-utils/buffer-utils.d.ts +16 -0
  110. package/dist/lib/binary-utils/buffer-utils.d.ts.map +1 -0
  111. package/dist/lib/binary-utils/buffer-utils.js +47 -13
  112. package/dist/lib/binary-utils/encode-utils.d.ts +4 -0
  113. package/dist/lib/binary-utils/encode-utils.d.ts.map +1 -0
  114. package/dist/lib/binary-utils/encode-utils.js +30 -26
  115. package/dist/lib/binary-utils/get-first-characters.d.ts +3 -0
  116. package/dist/lib/binary-utils/get-first-characters.d.ts.map +1 -0
  117. package/dist/lib/binary-utils/get-first-characters.js +28 -25
  118. package/dist/lib/binary-utils/memory-copy-utils.d.ts +25 -0
  119. package/dist/lib/binary-utils/memory-copy-utils.d.ts.map +1 -0
  120. package/dist/lib/binary-utils/memory-copy-utils.js +58 -24
  121. package/dist/lib/env-utils/assert.d.ts +6 -0
  122. package/dist/lib/env-utils/assert.d.ts.map +1 -0
  123. package/dist/lib/env-utils/assert.js +12 -5
  124. package/dist/lib/env-utils/globals.d.ts +15 -0
  125. package/dist/lib/env-utils/globals.d.ts.map +1 -0
  126. package/dist/lib/env-utils/globals.js +23 -9
  127. package/dist/lib/filesystems/node-filesystem.d.ts +38 -0
  128. package/dist/lib/filesystems/node-filesystem.d.ts.map +1 -0
  129. package/dist/lib/filesystems/node-filesystem.js +68 -59
  130. package/dist/lib/iterators/async-iteration.d.ts +20 -0
  131. package/dist/lib/iterators/async-iteration.d.ts.map +1 -0
  132. package/dist/lib/iterators/async-iteration.js +49 -35
  133. package/dist/lib/iterators/text-iterators.d.ts +19 -0
  134. package/dist/lib/iterators/text-iterators.d.ts.map +1 -0
  135. package/dist/lib/iterators/text-iterators.js +56 -41
  136. package/dist/lib/node/buffer.d.ts +10 -0
  137. package/dist/lib/node/buffer.d.ts.map +1 -0
  138. package/dist/lib/node/buffer.js +33 -25
  139. package/dist/lib/node/fs.d.ts +26 -0
  140. package/dist/lib/node/fs.d.ts.map +1 -0
  141. package/dist/lib/node/fs.js +41 -26
  142. package/dist/lib/node/util.d.ts +5 -0
  143. package/dist/lib/node/util.d.ts.map +1 -0
  144. package/dist/lib/node/util.js +25 -3
  145. package/dist/lib/parser-utils/parse-json.d.ts +5 -0
  146. package/dist/lib/parser-utils/parse-json.d.ts.map +1 -0
  147. package/dist/lib/parser-utils/parse-json.js +15 -8
  148. package/dist/lib/path-utils/file-aliases.d.ts +17 -0
  149. package/dist/lib/path-utils/file-aliases.d.ts.map +1 -0
  150. package/dist/lib/path-utils/file-aliases.js +40 -19
  151. package/dist/lib/path-utils/path.d.ts +16 -0
  152. package/dist/lib/path-utils/path.d.ts.map +1 -0
  153. package/dist/lib/path-utils/path.js +37 -21
  154. package/dist/lib/request-utils/request-scheduler.d.ts +62 -0
  155. package/dist/lib/request-utils/request-scheduler.d.ts.map +1 -0
  156. package/dist/lib/request-utils/request-scheduler.js +127 -131
  157. package/dist/lib/worker-loader-utils/create-loader-worker.d.ts +7 -0
  158. package/dist/lib/worker-loader-utils/create-loader-worker.d.ts.map +1 -0
  159. package/dist/lib/worker-loader-utils/create-loader-worker.js +91 -96
  160. package/dist/lib/worker-loader-utils/parse-with-worker.d.ts +15 -0
  161. package/dist/lib/worker-loader-utils/parse-with-worker.d.ts.map +1 -0
  162. package/dist/lib/worker-loader-utils/parse-with-worker.js +69 -60
  163. package/dist/types.d.ts +207 -0
  164. package/dist/types.d.ts.map +1 -0
  165. package/dist/types.js +3 -2
  166. package/dist/workers/json-worker.d.ts +2 -0
  167. package/dist/workers/json-worker.d.ts.map +1 -0
  168. package/dist/workers/json-worker.js +5 -4
  169. package/package.json +7 -10
  170. package/src/lib/worker-loader-utils/parse-with-worker.ts +6 -5
  171. package/dist/index.js.map +0 -1
  172. package/dist/json-loader.js.map +0 -1
  173. package/dist/lib/binary-utils/array-buffer-utils.js.map +0 -1
  174. package/dist/lib/binary-utils/binary-copy-utils.js.map +0 -1
  175. package/dist/lib/binary-utils/buffer-utils.js.map +0 -1
  176. package/dist/lib/binary-utils/encode-utils.js.map +0 -1
  177. package/dist/lib/binary-utils/get-first-characters.js.map +0 -1
  178. package/dist/lib/binary-utils/memory-copy-utils.js.map +0 -1
  179. package/dist/lib/env-utils/assert.js.map +0 -1
  180. package/dist/lib/env-utils/globals.js.map +0 -1
  181. package/dist/lib/filesystems/node-filesystem.js.map +0 -1
  182. package/dist/lib/iterators/async-iteration.js.map +0 -1
  183. package/dist/lib/iterators/text-iterators.js.map +0 -1
  184. package/dist/lib/node/buffer.js.map +0 -1
  185. package/dist/lib/node/fs.js.map +0 -1
  186. package/dist/lib/node/util.js.map +0 -1
  187. package/dist/lib/parser-utils/parse-json.js.map +0 -1
  188. package/dist/lib/path-utils/file-aliases.js.map +0 -1
  189. package/dist/lib/path-utils/path.js.map +0 -1
  190. package/dist/lib/request-utils/request-scheduler.js.map +0 -1
  191. package/dist/lib/worker-loader-utils/create-loader-worker.js.map +0 -1
  192. package/dist/lib/worker-loader-utils/parse-with-worker.js.map +0 -1
  193. package/dist/workers/json-worker.js.map +0 -1
@@ -1,146 +1,142 @@
1
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
- import { Stats } from '@probe.gl/stats';
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const stats_1 = require("@probe.gl/stats");
3
4
  const STAT_QUEUED_REQUESTS = 'Queued Requests';
4
5
  const STAT_ACTIVE_REQUESTS = 'Active Requests';
5
6
  const STAT_CANCELLED_REQUESTS = 'Cancelled Requests';
6
7
  const STAT_QUEUED_REQUESTS_EVER = 'Queued Requests Ever';
7
8
  const STAT_ACTIVE_REQUESTS_EVER = 'Active Requests Ever';
8
9
  const DEFAULT_PROPS = {
9
- id: 'request-scheduler',
10
- throttleRequests: true,
11
- maxRequests: 6
10
+ id: 'request-scheduler',
11
+ // Specifies if the request scheduler should throttle incoming requests, mainly for comparative testing
12
+ throttleRequests: true,
13
+ // The maximum number of simultaneous active requests. Un-throttled requests do not observe this limit.
14
+ maxRequests: 6
12
15
  };
13
- export default class RequestScheduler {
14
- constructor(props = {}) {
15
- _defineProperty(this, "props", void 0);
16
-
17
- _defineProperty(this, "stats", void 0);
18
-
19
- _defineProperty(this, "activeRequestCount", 0);
20
-
21
- _defineProperty(this, "requestQueue", []);
22
-
23
- _defineProperty(this, "requestMap", new Map());
24
-
25
- _defineProperty(this, "deferredUpdate", null);
26
-
27
- this.props = { ...DEFAULT_PROPS,
28
- ...props
29
- };
30
- this.stats = new Stats({
31
- id: this.props.id
32
- });
33
- this.stats.get(STAT_QUEUED_REQUESTS);
34
- this.stats.get(STAT_ACTIVE_REQUESTS);
35
- this.stats.get(STAT_CANCELLED_REQUESTS);
36
- this.stats.get(STAT_QUEUED_REQUESTS_EVER);
37
- this.stats.get(STAT_ACTIVE_REQUESTS_EVER);
38
- }
39
-
40
- scheduleRequest(handle, getPriority = () => 0) {
41
- if (!this.props.throttleRequests) {
42
- return Promise.resolve({
43
- done: () => {}
44
- });
16
+ /**
17
+ * Used to issue a request, without having them "deeply queued" by the browser.
18
+ * @todo - Track requests globally, across multiple servers
19
+ */
20
+ class RequestScheduler {
21
+ constructor(props = {}) {
22
+ this.activeRequestCount = 0;
23
+ /** Tracks the number of active requests and prioritizes/cancels queued requests. */
24
+ this.requestQueue = [];
25
+ this.requestMap = new Map();
26
+ this.deferredUpdate = null;
27
+ this.props = { ...DEFAULT_PROPS, ...props };
28
+ // Returns the statistics used by the request scheduler.
29
+ this.stats = new stats_1.Stats({ id: this.props.id });
30
+ this.stats.get(STAT_QUEUED_REQUESTS);
31
+ this.stats.get(STAT_ACTIVE_REQUESTS);
32
+ this.stats.get(STAT_CANCELLED_REQUESTS);
33
+ this.stats.get(STAT_QUEUED_REQUESTS_EVER);
34
+ this.stats.get(STAT_ACTIVE_REQUESTS_EVER);
45
35
  }
46
-
47
- if (this.requestMap.has(handle)) {
48
- return this.requestMap.get(handle);
49
- }
50
-
51
- const request = {
52
- handle,
53
- priority: 0,
54
- getPriority
55
- };
56
- const promise = new Promise(resolve => {
57
- request.resolve = resolve;
58
- return request;
59
- });
60
- this.requestQueue.push(request);
61
- this.requestMap.set(handle, promise);
62
-
63
- this._issueNewRequests();
64
-
65
- return promise;
66
- }
67
-
68
- _issueRequest(request) {
69
- const {
70
- handle,
71
- resolve
72
- } = request;
73
- let isDone = false;
74
-
75
- const done = () => {
76
- if (!isDone) {
77
- isDone = true;
78
- this.requestMap.delete(handle);
79
- this.activeRequestCount--;
80
-
36
+ /**
37
+ * Called by an application that wants to issue a request, without having it deeply queued by the browser
38
+ *
39
+ * When the returned promise resolved, it is OK for the application to issue a request.
40
+ * The promise resolves to an object that contains a `done` method.
41
+ * When the application's request has completed (or failed), the application must call the `done` function
42
+ *
43
+ * @param handle
44
+ * @param getPriority will be called when request "slots" open up,
45
+ * allowing the caller to update priority or cancel the request
46
+ * Highest priority executes first, priority < 0 cancels the request
47
+ * @returns a promise
48
+ * - resolves to a object (with a `done` field) when the request can be issued without queueing,
49
+ * - resolves to `null` if the request has been cancelled (by the callback return < 0).
50
+ * In this case the application should not issue the request
51
+ */
52
+ scheduleRequest(handle, getPriority = () => 0) {
53
+ // Allows throttling to be disabled
54
+ if (!this.props.throttleRequests) {
55
+ return Promise.resolve({ done: () => { } });
56
+ }
57
+ // dedupe
58
+ if (this.requestMap.has(handle)) {
59
+ return this.requestMap.get(handle);
60
+ }
61
+ const request = { handle, priority: 0, getPriority };
62
+ const promise = new Promise((resolve) => {
63
+ // @ts-ignore
64
+ request.resolve = resolve;
65
+ return request;
66
+ });
67
+ this.requestQueue.push(request);
68
+ this.requestMap.set(handle, promise);
81
69
  this._issueNewRequests();
82
- }
83
- };
84
-
85
- this.activeRequestCount++;
86
- return resolve ? resolve({
87
- done
88
- }) : Promise.resolve({
89
- done
90
- });
91
- }
92
-
93
- _issueNewRequests() {
94
- if (!this.deferredUpdate) {
95
- this.deferredUpdate = setTimeout(() => this._issueNewRequestsAsync(), 0);
70
+ return promise;
71
+ }
72
+ // PRIVATE
73
+ _issueRequest(request) {
74
+ const { handle, resolve } = request;
75
+ let isDone = false;
76
+ const done = () => {
77
+ // can only be called once
78
+ if (!isDone) {
79
+ isDone = true;
80
+ // Stop tracking a request - it has completed, failed, cancelled etc
81
+ this.requestMap.delete(handle);
82
+ this.activeRequestCount--;
83
+ // A slot just freed up, see if any queued requests are waiting
84
+ this._issueNewRequests();
85
+ }
86
+ };
87
+ // Track this request
88
+ this.activeRequestCount++;
89
+ return resolve ? resolve({ done }) : Promise.resolve({ done });
96
90
  }
97
- }
98
-
99
- _issueNewRequestsAsync() {
100
- this.deferredUpdate = null;
101
- const freeSlots = Math.max(this.props.maxRequests - this.activeRequestCount, 0);
102
-
103
- if (freeSlots === 0) {
104
- return;
91
+ /** We check requests asynchronously, to prevent multiple updates */
92
+ _issueNewRequests() {
93
+ if (!this.deferredUpdate) {
94
+ this.deferredUpdate = setTimeout(() => this._issueNewRequestsAsync(), 0);
95
+ }
105
96
  }
106
-
107
- this._updateAllRequests();
108
-
109
- for (let i = 0; i < freeSlots; ++i) {
110
- const request = this.requestQueue.shift();
111
-
112
- if (request) {
113
- this._issueRequest(request);
114
- }
97
+ /** Refresh all requests */
98
+ _issueNewRequestsAsync() {
99
+ // TODO - shouldn't we clear the timeout?
100
+ this.deferredUpdate = null;
101
+ const freeSlots = Math.max(this.props.maxRequests - this.activeRequestCount, 0);
102
+ if (freeSlots === 0) {
103
+ return;
104
+ }
105
+ this._updateAllRequests();
106
+ // Resolve pending promises for the top-priority requests
107
+ for (let i = 0; i < freeSlots; ++i) {
108
+ const request = this.requestQueue.shift();
109
+ if (request) {
110
+ this._issueRequest(request); // eslint-disable-line @typescript-eslint/no-floating-promises
111
+ }
112
+ }
113
+ // Uncomment to debug
114
+ // console.log(`${freeSlots} free slots, ${this.requestQueue.length} queued requests`);
115
115
  }
116
- }
117
-
118
- _updateAllRequests() {
119
- const requestQueue = this.requestQueue;
120
-
121
- for (let i = 0; i < requestQueue.length; ++i) {
122
- const request = requestQueue[i];
123
-
124
- if (!this._updateRequest(request)) {
125
- requestQueue.splice(i, 1);
126
- this.requestMap.delete(request.handle);
127
- i--;
128
- }
116
+ /** Ensure all requests have updated priorities, and that no longer valid requests are cancelled */
117
+ _updateAllRequests() {
118
+ const requestQueue = this.requestQueue;
119
+ for (let i = 0; i < requestQueue.length; ++i) {
120
+ const request = requestQueue[i];
121
+ if (!this._updateRequest(request)) {
122
+ // Remove the element and make sure to adjust the counter to account for shortened array
123
+ requestQueue.splice(i, 1);
124
+ this.requestMap.delete(request.handle);
125
+ i--;
126
+ }
127
+ }
128
+ // Sort the remaining requests based on priority
129
+ requestQueue.sort((a, b) => a.priority - b.priority);
129
130
  }
130
-
131
- requestQueue.sort((a, b) => a.priority - b.priority);
132
- }
133
-
134
- _updateRequest(request) {
135
- request.priority = request.getPriority(request.handle);
136
-
137
- if (request.priority < 0) {
138
- request.resolve(null);
139
- return false;
131
+ /** Update a single request by calling the callback */
132
+ _updateRequest(request) {
133
+ request.priority = request.getPriority(request.handle); // eslint-disable-line callback-return
134
+ // by returning a negative priority, the callback cancels the request
135
+ if (request.priority < 0) {
136
+ request.resolve(null);
137
+ return false;
138
+ }
139
+ return true;
140
140
  }
141
-
142
- return true;
143
- }
144
-
145
141
  }
146
- //# sourceMappingURL=request-scheduler.js.map
142
+ exports.default = RequestScheduler;
@@ -0,0 +1,7 @@
1
+ import type { LoaderWithParser } from '../../types';
2
+ /**
3
+ * Set up a WebWorkerGlobalScope to talk with the main thread
4
+ * @param loader
5
+ */
6
+ export declare function createLoaderWorker(loader: LoaderWithParser): void;
7
+ //# sourceMappingURL=create-loader-worker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-loader-worker.d.ts","sourceRoot":"","sources":["../../../src/lib/worker-loader-utils/create-loader-worker.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAC,gBAAgB,EAAC,MAAM,aAAa,CAAC;AAMlD;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,gBAAgB,QA+B1D"}
@@ -1,102 +1,97 @@
1
- import { WorkerBody } from '@loaders.gl/worker-utils';
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createLoaderWorker = void 0;
4
+ const worker_utils_1 = require("@loaders.gl/worker-utils");
5
+ // import {validateLoaderVersion} from './validate-loader-version.js';
2
6
  let requestId = 0;
3
- export function createLoaderWorker(loader) {
4
- if (typeof self === 'undefined') {
5
- return;
6
- }
7
-
8
- WorkerBody.onmessage = async (type, payload) => {
9
- switch (type) {
10
- case 'process':
11
- try {
12
- const {
13
- input,
14
- options = {}
15
- } = payload;
16
- const result = await parseData({
17
- loader,
18
- arrayBuffer: input,
19
- options,
20
- context: {
21
- parse: parseOnMainThread
22
- }
23
- });
24
- WorkerBody.postMessage('done', {
25
- result
26
- });
27
- } catch (error) {
28
- const message = error instanceof Error ? error.message : '';
29
- WorkerBody.postMessage('error', {
30
- error: message
31
- });
32
- }
33
-
34
- break;
35
-
36
- default:
7
+ /**
8
+ * Set up a WebWorkerGlobalScope to talk with the main thread
9
+ * @param loader
10
+ */
11
+ function createLoaderWorker(loader) {
12
+ // Check that we are actually in a worker thread
13
+ if (typeof self === 'undefined') {
14
+ return;
37
15
  }
38
- };
16
+ worker_utils_1.WorkerBody.onmessage = async (type, payload) => {
17
+ switch (type) {
18
+ case 'process':
19
+ try {
20
+ // validateLoaderVersion(loader, data.source.split('@')[1]);
21
+ const { input, options = {} } = payload;
22
+ const result = await parseData({
23
+ loader,
24
+ arrayBuffer: input,
25
+ options,
26
+ context: {
27
+ parse: parseOnMainThread
28
+ }
29
+ });
30
+ worker_utils_1.WorkerBody.postMessage('done', { result });
31
+ }
32
+ catch (error) {
33
+ const message = error instanceof Error ? error.message : '';
34
+ worker_utils_1.WorkerBody.postMessage('error', { error: message });
35
+ }
36
+ break;
37
+ default:
38
+ }
39
+ };
39
40
  }
40
-
41
+ exports.createLoaderWorker = createLoaderWorker;
41
42
  function parseOnMainThread(arrayBuffer, options) {
42
- return new Promise((resolve, reject) => {
43
- const id = requestId++;
44
-
45
- const onMessage = (type, payload) => {
46
- if (payload.id !== id) {
47
- return;
48
- }
49
-
50
- switch (type) {
51
- case 'done':
52
- WorkerBody.removeEventListener(onMessage);
53
- resolve(payload.result);
54
- break;
55
-
56
- case 'error':
57
- WorkerBody.removeEventListener(onMessage);
58
- reject(payload.error);
59
- break;
60
-
61
- default:
62
- }
63
- };
64
-
65
- WorkerBody.addEventListener(onMessage);
66
- const payload = {
67
- id,
68
- input: arrayBuffer,
69
- options
70
- };
71
- WorkerBody.postMessage('process', payload);
72
- });
43
+ return new Promise((resolve, reject) => {
44
+ const id = requestId++;
45
+ /**
46
+ */
47
+ const onMessage = (type, payload) => {
48
+ if (payload.id !== id) {
49
+ // not ours
50
+ return;
51
+ }
52
+ switch (type) {
53
+ case 'done':
54
+ worker_utils_1.WorkerBody.removeEventListener(onMessage);
55
+ resolve(payload.result);
56
+ break;
57
+ case 'error':
58
+ worker_utils_1.WorkerBody.removeEventListener(onMessage);
59
+ reject(payload.error);
60
+ break;
61
+ default:
62
+ // ignore
63
+ }
64
+ };
65
+ worker_utils_1.WorkerBody.addEventListener(onMessage);
66
+ // Ask the main thread to decode data
67
+ const payload = { id, input: arrayBuffer, options };
68
+ worker_utils_1.WorkerBody.postMessage('process', payload);
69
+ });
73
70
  }
74
-
75
- async function parseData({
76
- loader,
77
- arrayBuffer,
78
- options,
79
- context
80
- }) {
81
- let data;
82
- let parser;
83
-
84
- if (loader.parseSync || loader.parse) {
85
- data = arrayBuffer;
86
- parser = loader.parseSync || loader.parse;
87
- } else if (loader.parseTextSync) {
88
- const textDecoder = new TextDecoder();
89
- data = textDecoder.decode(arrayBuffer);
90
- parser = loader.parseTextSync;
91
- } else {
92
- throw new Error(`Could not load data with ${loader.name} loader`);
93
- }
94
-
95
- options = { ...options,
96
- modules: loader && loader.options && loader.options.modules || {},
97
- worker: false
98
- };
99
- return await parser(data, { ...options
100
- }, context, loader);
71
+ // TODO - Support byteOffset and byteLength (enabling parsing of embedded binaries without copies)
72
+ // TODO - Why not support async loader.parse* funcs here?
73
+ // TODO - Why not reuse a common function instead of reimplementing loader.parse* selection logic? Keeping loader small?
74
+ // TODO - Lack of appropriate parser functions can be detected when we create worker, no need to wait until parse
75
+ async function parseData({ loader, arrayBuffer, options, context }) {
76
+ let data;
77
+ let parser;
78
+ if (loader.parseSync || loader.parse) {
79
+ data = arrayBuffer;
80
+ parser = loader.parseSync || loader.parse;
81
+ }
82
+ else if (loader.parseTextSync) {
83
+ const textDecoder = new TextDecoder();
84
+ data = textDecoder.decode(arrayBuffer);
85
+ parser = loader.parseTextSync;
86
+ }
87
+ else {
88
+ throw new Error(`Could not load data with ${loader.name} loader`);
89
+ }
90
+ // TODO - proper merge in of loader options...
91
+ options = {
92
+ ...options,
93
+ modules: (loader && loader.options && loader.options.modules) || {},
94
+ worker: false
95
+ };
96
+ return await parser(data, { ...options }, context, loader);
101
97
  }
102
- //# sourceMappingURL=create-loader-worker.js.map
@@ -0,0 +1,15 @@
1
+ import type { Loader, LoaderOptions, LoaderContext } from '../../types';
2
+ /**
3
+ * Determines if a loader can parse with worker
4
+ * @param loader
5
+ * @param options
6
+ */
7
+ export declare function canParseWithWorker(loader: Loader, options?: LoaderOptions): boolean | "" | undefined;
8
+ /**
9
+ * this function expects that the worker function sends certain messages,
10
+ * this can be automated if the worker is wrapper by a call to createLoaderWorker in @loaders.gl/loader-utils.
11
+ */
12
+ export declare function parseWithWorker(loader: Loader, data: any, options?: LoaderOptions, context?: LoaderContext, parseOnMainThread?: (arrayBuffer: ArrayBuffer, options: {
13
+ [key: string]: any;
14
+ }) => Promise<void>): Promise<any>;
15
+ //# sourceMappingURL=parse-with-worker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-with-worker.d.ts","sourceRoot":"","sources":["../../../src/lib/worker-loader-utils/parse-with-worker.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAC,MAAM,EAAE,aAAa,EAAE,aAAa,EAAC,MAAM,aAAa,CAAC;AAGtE;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,aAAa,4BAMzE;AAED;;;GAGG;AACH,wBAAsB,eAAe,CACnC,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,GAAG,EACT,OAAO,CAAC,EAAE,aAAa,EACvB,OAAO,CAAC,EAAE,aAAa,EACvB,iBAAiB,CAAC,EAAE,CAAC,WAAW,EAAE,WAAW,EAAE,OAAO,EAAE;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,gBA2B/F"}
@@ -1,64 +1,73 @@
1
- import { WorkerFarm, getWorkerURL } from '@loaders.gl/worker-utils';
2
- export function canParseWithWorker(loader, options) {
3
- if (!WorkerFarm.isSupported()) {
4
- return false;
5
- }
6
-
7
- return loader.worker && (options === null || options === void 0 ? void 0 : options.worker);
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.parseWithWorker = exports.canParseWithWorker = void 0;
4
+ const worker_utils_1 = require("@loaders.gl/worker-utils");
5
+ /**
6
+ * Determines if a loader can parse with worker
7
+ * @param loader
8
+ * @param options
9
+ */
10
+ function canParseWithWorker(loader, options) {
11
+ if (!worker_utils_1.WorkerFarm.isSupported()) {
12
+ return false;
13
+ }
14
+ return loader.worker && options?.worker;
8
15
  }
9
- export async function parseWithWorker(loader, data, options, context, parseOnMainThread) {
10
- const name = loader.id;
11
- const url = getWorkerURL(loader, options);
12
- const workerFarm = WorkerFarm.getWorkerFarm(options);
13
- const workerPool = workerFarm.getWorkerPool({
14
- name,
15
- url
16
- });
17
- options = JSON.parse(JSON.stringify(options));
18
- const job = await workerPool.startJob('process-on-worker', onMessage.bind(null, parseOnMainThread));
19
- job.postMessage('process', {
20
- input: data,
21
- options
22
- });
23
- const result = await job.result;
24
- return await result.result;
16
+ exports.canParseWithWorker = canParseWithWorker;
17
+ /**
18
+ * this function expects that the worker function sends certain messages,
19
+ * this can be automated if the worker is wrapper by a call to createLoaderWorker in @loaders.gl/loader-utils.
20
+ */
21
+ async function parseWithWorker(loader, data, options, context, parseOnMainThread) {
22
+ const name = loader.id; // TODO
23
+ const url = (0, worker_utils_1.getWorkerURL)(loader, options);
24
+ const workerFarm = worker_utils_1.WorkerFarm.getWorkerFarm(options);
25
+ const workerPool = workerFarm.getWorkerPool({ name, url });
26
+ // options.log object contains functions which cannot be transferred
27
+ // TODO - decide how to handle logging on workers
28
+ options = JSON.parse(JSON.stringify(options));
29
+ const job = await workerPool.startJob('process-on-worker',
30
+ // @ts-expect-error
31
+ onMessage.bind(null, parseOnMainThread) // eslint-disable-line @typescript-eslint/no-misused-promises
32
+ );
33
+ job.postMessage('process', {
34
+ // @ts-ignore
35
+ input: data,
36
+ options
37
+ });
38
+ const result = await job.result;
39
+ // TODO - what is going on here?
40
+ return await result.result;
25
41
  }
26
-
42
+ exports.parseWithWorker = parseWithWorker;
43
+ /**
44
+ * Handle worker's responses to the main thread
45
+ * @param job
46
+ * @param type
47
+ * @param payload
48
+ */
27
49
  async function onMessage(parseOnMainThread, job, type, payload) {
28
- switch (type) {
29
- case 'done':
30
- job.done(payload);
31
- break;
32
-
33
- case 'error':
34
- job.error(payload.error);
35
- break;
36
-
37
- case 'process':
38
- const {
39
- id,
40
- input,
41
- options
42
- } = payload;
43
-
44
- try {
45
- const result = await parseOnMainThread(input, options);
46
- job.postMessage('done', {
47
- id,
48
- result
49
- });
50
- } catch (error) {
51
- const message = error instanceof Error ? error.message : 'unknown error';
52
- job.postMessage('error', {
53
- id,
54
- error: message
55
- });
56
- }
57
-
58
- break;
59
-
60
- default:
61
- console.warn(`parse-with-worker unknown message ${type}`);
62
- }
50
+ switch (type) {
51
+ case 'done':
52
+ job.done(payload);
53
+ break;
54
+ case 'error':
55
+ job.error(new Error(payload.error));
56
+ break;
57
+ case 'process':
58
+ // Worker is asking for main thread to parseO
59
+ const { id, input, options } = payload;
60
+ try {
61
+ const result = await parseOnMainThread(input, options);
62
+ job.postMessage('done', { id, result });
63
+ }
64
+ catch (error) {
65
+ const message = error instanceof Error ? error.message : 'unknown error';
66
+ job.postMessage('error', { id, error: message });
67
+ }
68
+ break;
69
+ default:
70
+ // eslint-disable-next-line
71
+ console.warn(`parse-with-worker unknown message ${type}`);
72
+ }
63
73
  }
64
- //# sourceMappingURL=parse-with-worker.js.map