@atlaspack/workers 2.14.5-canary.39 → 2.14.5-canary.390

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 (68) hide show
  1. package/CHANGELOG.md +439 -0
  2. package/dist/Handle.js +33 -0
  3. package/dist/Worker.js +180 -0
  4. package/dist/WorkerFarm.js +539 -0
  5. package/dist/backend.js +34 -0
  6. package/dist/bus.js +24 -0
  7. package/dist/child.js +290 -0
  8. package/dist/childState.js +11 -0
  9. package/dist/cpuCount.js +72 -0
  10. package/dist/index.js +44 -0
  11. package/dist/process/ProcessChild.js +48 -0
  12. package/dist/process/ProcessWorker.js +68 -0
  13. package/dist/threads/ThreadsChild.js +31 -0
  14. package/dist/threads/ThreadsWorker.js +47 -0
  15. package/dist/types.js +2 -0
  16. package/dist/web/WebChild.js +34 -0
  17. package/dist/web/WebWorker.js +70 -0
  18. package/index.d.ts +96 -3
  19. package/lib/Handle.js +0 -3
  20. package/lib/Worker.js +7 -1
  21. package/lib/WorkerFarm.js +12 -7
  22. package/lib/backend.js +5 -1
  23. package/lib/bus.js +1 -1
  24. package/lib/child.js +11 -4
  25. package/lib/cpuCount.js +6 -2
  26. package/lib/process/ProcessChild.js +6 -1
  27. package/lib/process/ProcessWorker.js +9 -2
  28. package/lib/threads/ThreadsChild.js +3 -0
  29. package/lib/threads/ThreadsWorker.js +10 -2
  30. package/lib/types/Handle.d.ts +19 -0
  31. package/lib/types/Worker.d.ts +40 -0
  32. package/lib/types/WorkerFarm.d.ts +93 -0
  33. package/lib/types/backend.d.ts +4 -0
  34. package/lib/types/bus.d.ts +6 -0
  35. package/lib/types/child.d.ts +43 -0
  36. package/lib/types/childState.d.ts +3 -0
  37. package/lib/types/cpuCount.d.ts +2 -0
  38. package/lib/types/index.d.ts +6 -0
  39. package/lib/types/process/ProcessChild.d.ts +9 -0
  40. package/lib/types/process/ProcessWorker.d.ts +16 -0
  41. package/lib/types/threads/ThreadsChild.d.ts +8 -0
  42. package/lib/types/threads/ThreadsWorker.d.ts +15 -0
  43. package/lib/types/types.d.ts +52 -0
  44. package/lib/types/web/WebChild.d.ts +8 -0
  45. package/lib/types/web/WebWorker.d.ts +15 -0
  46. package/lib/web/WebChild.js +6 -1
  47. package/lib/web/WebWorker.js +19 -4
  48. package/package.json +15 -19
  49. package/src/{Handle.js → Handle.ts} +11 -11
  50. package/src/{Worker.js → Worker.ts} +66 -54
  51. package/src/{WorkerFarm.js → WorkerFarm.ts} +195 -142
  52. package/src/{backend.js → backend.ts} +6 -3
  53. package/src/{bus.js → bus.ts} +2 -3
  54. package/src/{child.js → child.ts} +55 -43
  55. package/src/{childState.js → childState.ts} +1 -2
  56. package/src/{cpuCount.js → cpuCount.ts} +10 -7
  57. package/src/{index.js → index.ts} +0 -1
  58. package/src/process/{ProcessChild.js → ProcessChild.ts} +5 -3
  59. package/src/process/{ProcessWorker.js → ProcessWorker.ts} +10 -7
  60. package/src/threads/{ThreadsChild.js → ThreadsChild.ts} +2 -2
  61. package/src/threads/{ThreadsWorker.js → ThreadsWorker.ts} +14 -8
  62. package/src/{types.js → types.ts} +34 -35
  63. package/src/web/{WebChild.js → WebChild.ts} +6 -2
  64. package/src/web/{WebWorker.js → WebWorker.ts} +19 -7
  65. package/test/{cpuCount.test.js → cpuCount.test.ts} +0 -1
  66. package/test/{workerfarm.test.cjs → workerfarm.test.js} +9 -2
  67. package/tsconfig.json +27 -0
  68. package/tsconfig.tsbuildinfo +1 -0
package/CHANGELOG.md CHANGED
@@ -1,5 +1,444 @@
1
1
  # @atlaspack/workers
2
2
 
3
+ ## 2.14.51
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies []:
8
+ - @atlaspack/logger@2.14.43
9
+ - @atlaspack/utils@3.3.3
10
+ - @atlaspack/profiler@2.15.12
11
+ - @atlaspack/types-internal@2.22.8
12
+
13
+ ## 2.14.50
14
+
15
+ ### Patch Changes
16
+
17
+ - Updated dependencies []:
18
+ - @atlaspack/logger@2.14.42
19
+ - @atlaspack/utils@3.3.2
20
+ - @atlaspack/build-cache@2.13.9
21
+ - @atlaspack/types-internal@2.22.7
22
+ - @atlaspack/profiler@2.15.11
23
+
24
+ ## 2.14.49
25
+
26
+ ### Patch Changes
27
+
28
+ - Updated dependencies []:
29
+ - @atlaspack/logger@2.14.41
30
+ - @atlaspack/utils@3.3.1
31
+ - @atlaspack/build-cache@2.13.8
32
+ - @atlaspack/types-internal@2.22.6
33
+ - @atlaspack/profiler@2.15.10
34
+
35
+ ## 2.14.48
36
+
37
+ ### Patch Changes
38
+
39
+ - Updated dependencies [[`47aa84e`](https://github.com/atlassian-labs/atlaspack/commit/47aa84e44c61066072a5bf3d57678565b9d2c5a3), [`565bab3`](https://github.com/atlassian-labs/atlaspack/commit/565bab3771cc334659d873cabff4cdfac0860cc7)]:
40
+ - @atlaspack/utils@3.3.0
41
+ - @atlaspack/build-cache@2.13.7
42
+ - @atlaspack/profiler@2.15.9
43
+ - @atlaspack/logger@2.14.40
44
+ - @atlaspack/types-internal@2.22.5
45
+
46
+ ## 2.14.47
47
+
48
+ ### Patch Changes
49
+
50
+ - Updated dependencies []:
51
+ - @atlaspack/logger@2.14.39
52
+ - @atlaspack/utils@3.2.8
53
+ - @atlaspack/profiler@2.15.8
54
+ - @atlaspack/types-internal@2.22.4
55
+
56
+ ## 2.14.46
57
+
58
+ ### Patch Changes
59
+
60
+ - Updated dependencies [[`02cc8b3`](https://github.com/atlassian-labs/atlaspack/commit/02cc8b32c06ca6b51806b33f6f707ca06e55e957)]:
61
+ - @atlaspack/types-internal@2.22.3
62
+ - @atlaspack/logger@2.14.38
63
+ - @atlaspack/utils@3.2.7
64
+ - @atlaspack/profiler@2.15.7
65
+
66
+ ## 2.14.45
67
+
68
+ ### Patch Changes
69
+
70
+ - Updated dependencies []:
71
+ - @atlaspack/types-internal@2.22.2
72
+ - @atlaspack/utils@3.2.6
73
+ - @atlaspack/logger@2.14.37
74
+ - @atlaspack/profiler@2.15.6
75
+
76
+ ## 2.14.44
77
+
78
+ ### Patch Changes
79
+
80
+ - Updated dependencies []:
81
+ - @atlaspack/logger@2.14.36
82
+ - @atlaspack/utils@3.2.5
83
+ - @atlaspack/types-internal@2.22.1
84
+ - @atlaspack/profiler@2.15.5
85
+
86
+ ## 2.14.43
87
+
88
+ ### Patch Changes
89
+
90
+ - Updated dependencies [[`00fa643`](https://github.com/atlassian-labs/atlaspack/commit/00fa6433202bfd3311479f6314c9ec878a789f2c)]:
91
+ - @atlaspack/types-internal@2.22.0
92
+ - @atlaspack/logger@2.14.35
93
+ - @atlaspack/profiler@2.15.4
94
+ - @atlaspack/utils@3.2.4
95
+
96
+ ## 2.14.42
97
+
98
+ ### Patch Changes
99
+
100
+ - Updated dependencies []:
101
+ - @atlaspack/logger@2.14.34
102
+ - @atlaspack/utils@3.2.3
103
+ - @atlaspack/types-internal@2.21.3
104
+ - @atlaspack/profiler@2.15.3
105
+
106
+ ## 2.14.41
107
+
108
+ ### Patch Changes
109
+
110
+ - Updated dependencies []:
111
+ - @atlaspack/logger@2.14.33
112
+ - @atlaspack/utils@3.2.2
113
+ - @atlaspack/types-internal@2.21.2
114
+ - @atlaspack/profiler@2.15.2
115
+
116
+ ## 2.14.40
117
+
118
+ ### Patch Changes
119
+
120
+ - Updated dependencies []:
121
+ - @atlaspack/logger@2.14.32
122
+ - @atlaspack/utils@3.2.1
123
+ - @atlaspack/types-internal@2.21.1
124
+ - @atlaspack/profiler@2.15.1
125
+
126
+ ## 2.14.39
127
+
128
+ ### Patch Changes
129
+
130
+ - Updated dependencies [[`8eb84ee`](https://github.com/atlassian-labs/atlaspack/commit/8eb84ee61a42bfe87c58079b610802b07a6a13e4), [`73168c2`](https://github.com/atlassian-labs/atlaspack/commit/73168c275a5d9abff9907bcf536b340bca1ed5f0), [`617a318`](https://github.com/atlassian-labs/atlaspack/commit/617a318ddc9419b38360257353fec50b9051ee13)]:
131
+ - @atlaspack/types-internal@2.21.0
132
+ - @atlaspack/utils@3.2.0
133
+ - @atlaspack/profiler@2.15.0
134
+ - @atlaspack/logger@2.14.31
135
+
136
+ ## 2.14.38
137
+
138
+ ### Patch Changes
139
+
140
+ - Updated dependencies [[`7d7a55d`](https://github.com/atlassian-labs/atlaspack/commit/7d7a55dd6395ec391a2e4c33b3dec0d1ea477d4c)]:
141
+ - @atlaspack/utils@3.1.2
142
+ - @atlaspack/types-internal@2.20.8
143
+ - @atlaspack/logger@2.14.30
144
+ - @atlaspack/profiler@2.14.35
145
+
146
+ ## 2.14.37
147
+
148
+ ### Patch Changes
149
+
150
+ - Updated dependencies []:
151
+ - @atlaspack/logger@2.14.29
152
+ - @atlaspack/utils@3.1.1
153
+ - @atlaspack/types-internal@2.20.7
154
+ - @atlaspack/profiler@2.14.34
155
+
156
+ ## 2.14.36
157
+
158
+ ### Patch Changes
159
+
160
+ - Updated dependencies [[`5776be2`](https://github.com/atlassian-labs/atlaspack/commit/5776be21f70a3f2b9471ba33da3ba1a883f21f1a)]:
161
+ - @atlaspack/utils@3.1.0
162
+ - @atlaspack/logger@2.14.28
163
+ - @atlaspack/types-internal@2.20.6
164
+ - @atlaspack/profiler@2.14.33
165
+
166
+ ## 2.14.35
167
+
168
+ ### Patch Changes
169
+
170
+ - Updated dependencies [[`c372f3f`](https://github.com/atlassian-labs/atlaspack/commit/c372f3fd6fce8200d5cf47f41bc7895c6cbb5558), [`17dfea9`](https://github.com/atlassian-labs/atlaspack/commit/17dfea9e9f3169807808520df9c09ebf70dc8b10)]:
171
+ - @atlaspack/types-internal@2.20.5
172
+ - @atlaspack/utils@3.0.3
173
+ - @atlaspack/logger@2.14.27
174
+ - @atlaspack/profiler@2.14.32
175
+
176
+ ## 2.14.34
177
+
178
+ ### Patch Changes
179
+
180
+ - [#782](https://github.com/atlassian-labs/atlaspack/pull/782) [`25cbee6`](https://github.com/atlassian-labs/atlaspack/commit/25cbee625fb47ac20423fe34ff37bc818a807245) Thanks [@yamadapc](https://github.com/yamadapc)! - Initial atlaspack-inspector release
181
+
182
+ - Updated dependencies []:
183
+ - @atlaspack/types-internal@2.20.4
184
+ - @atlaspack/utils@3.0.2
185
+ - @atlaspack/logger@2.14.26
186
+ - @atlaspack/profiler@2.14.31
187
+
188
+ ## 2.14.33
189
+
190
+ ### Patch Changes
191
+
192
+ - Updated dependencies [[`236e546`](https://github.com/atlassian-labs/atlaspack/commit/236e5465863dca6044a7191e05260a5b924c342e)]:
193
+ - @atlaspack/utils@3.0.1
194
+ - @atlaspack/types-internal@2.20.3
195
+ - @atlaspack/logger@2.14.25
196
+ - @atlaspack/profiler@2.14.30
197
+
198
+ ## 2.14.32
199
+
200
+ ### Patch Changes
201
+
202
+ - Updated dependencies [[`1180103`](https://github.com/atlassian-labs/atlaspack/commit/118010351ed444f8178988afb3f77807154dd933)]:
203
+ - @atlaspack/utils@3.0.0
204
+ - @atlaspack/types-internal@2.20.2
205
+ - @atlaspack/logger@2.14.24
206
+ - @atlaspack/profiler@2.14.29
207
+
208
+ ## 2.14.31
209
+
210
+ ### Patch Changes
211
+
212
+ - [#785](https://github.com/atlassian-labs/atlaspack/pull/785) [`0e7dd5e`](https://github.com/atlassian-labs/atlaspack/commit/0e7dd5ec6fbe05aa9e0bb5775a9d0975f206a922) Thanks [@matt-koko](https://github.com/matt-koko)! - We need to re-publish every package in Atlaspack with the corrected types field.
213
+
214
+ - Updated dependencies [[`0e7dd5e`](https://github.com/atlassian-labs/atlaspack/commit/0e7dd5ec6fbe05aa9e0bb5775a9d0975f206a922)]:
215
+ - @atlaspack/build-cache@2.13.6
216
+ - @atlaspack/diagnostic@2.14.4
217
+ - @atlaspack/logger@2.14.23
218
+ - @atlaspack/profiler@2.14.28
219
+ - @atlaspack/types-internal@2.20.1
220
+ - @atlaspack/utils@2.19.3
221
+
222
+ ## 2.14.30
223
+
224
+ ### Patch Changes
225
+
226
+ - Updated dependencies [[`eedcbc4`](https://github.com/atlassian-labs/atlaspack/commit/eedcbc408fc1e86a2a8e25f1a41c57146d8529e1), [`f6532d7`](https://github.com/atlassian-labs/atlaspack/commit/f6532d7a4f7f007bd4e5e36af04dd466f0b9f572)]:
227
+ - @atlaspack/types-internal@2.20.0
228
+ - @atlaspack/utils@2.19.2
229
+ - @atlaspack/logger@2.14.22
230
+ - @atlaspack/profiler@2.14.27
231
+
232
+ ## 2.14.29
233
+
234
+ ### Patch Changes
235
+
236
+ - Updated dependencies []:
237
+ - @atlaspack/types-internal@2.19.5
238
+ - @atlaspack/utils@2.19.1
239
+ - @atlaspack/logger@2.14.21
240
+ - @atlaspack/profiler@2.14.26
241
+
242
+ ## 2.14.28
243
+
244
+ ### Patch Changes
245
+
246
+ - Updated dependencies [[`f0349a6`](https://github.com/atlassian-labs/atlaspack/commit/f0349a6b9b04755088f121095ca6301a2ada3767)]:
247
+ - @atlaspack/utils@2.19.0
248
+ - @atlaspack/types-internal@2.19.4
249
+ - @atlaspack/logger@2.14.20
250
+ - @atlaspack/profiler@2.14.25
251
+
252
+ ## 2.14.27
253
+
254
+ ### Patch Changes
255
+
256
+ - Updated dependencies []:
257
+ - @atlaspack/types-internal@2.19.3
258
+ - @atlaspack/utils@2.18.4
259
+ - @atlaspack/logger@2.14.19
260
+ - @atlaspack/profiler@2.14.24
261
+
262
+ ## 2.14.26
263
+
264
+ ### Patch Changes
265
+
266
+ - [#742](https://github.com/atlassian-labs/atlaspack/pull/742) [`ee040bb`](https://github.com/atlassian-labs/atlaspack/commit/ee040bb6428f29b57d892ddd8107e29077d08ffd) Thanks [@yamadapc](https://github.com/yamadapc)! - Internal changes and bug fixes to environmentDeduplication flag
267
+
268
+ - Updated dependencies [[`ee040bb`](https://github.com/atlassian-labs/atlaspack/commit/ee040bb6428f29b57d892ddd8107e29077d08ffd), [`889c65c`](https://github.com/atlassian-labs/atlaspack/commit/889c65cd25b811045e26a117e7404f694dde77a2)]:
269
+ - @atlaspack/types-internal@2.19.2
270
+ - @atlaspack/build-cache@2.13.5
271
+ - @atlaspack/diagnostic@2.14.3
272
+ - @atlaspack/profiler@2.14.23
273
+ - @atlaspack/logger@2.14.18
274
+ - @atlaspack/utils@2.18.3
275
+
276
+ ## 2.14.25
277
+
278
+ ### Patch Changes
279
+
280
+ - Updated dependencies []:
281
+ - @atlaspack/types-internal@2.19.1
282
+ - @atlaspack/utils@2.18.2
283
+ - @atlaspack/logger@2.14.17
284
+ - @atlaspack/profiler@2.14.22
285
+
286
+ ## 2.14.24
287
+
288
+ ### Patch Changes
289
+
290
+ - Updated dependencies [[`7f5841c`](https://github.com/atlassian-labs/atlaspack/commit/7f5841c39df049f9546cccbeea2a7337e0337b45)]:
291
+ - @atlaspack/types-internal@2.19.0
292
+ - @atlaspack/logger@2.14.16
293
+ - @atlaspack/utils@2.18.1
294
+ - @atlaspack/profiler@2.14.21
295
+
296
+ ## 2.14.23
297
+
298
+ ### Patch Changes
299
+
300
+ - Updated dependencies [[`23d561e`](https://github.com/atlassian-labs/atlaspack/commit/23d561e51e68b0c38fd1ff4e4fb173e5e7b01cf2)]:
301
+ - @atlaspack/utils@2.18.0
302
+ - @atlaspack/types-internal@2.18.0
303
+ - @atlaspack/logger@2.14.15
304
+ - @atlaspack/profiler@2.14.20
305
+
306
+ ## 2.14.22
307
+
308
+ ### Patch Changes
309
+
310
+ - [#720](https://github.com/atlassian-labs/atlaspack/pull/720) [`d2fd849`](https://github.com/atlassian-labs/atlaspack/commit/d2fd849770fe6305e9c694bd97b1bd905abd9d94) Thanks [@alshdavid](https://github.com/alshdavid)! - Migrate to TypeScript
311
+
312
+ - Updated dependencies [[`d2fd849`](https://github.com/atlassian-labs/atlaspack/commit/d2fd849770fe6305e9c694bd97b1bd905abd9d94), [`43fdd22`](https://github.com/atlassian-labs/atlaspack/commit/43fdd223860fbc97af17d68c65419b97412cb888)]:
313
+ - @atlaspack/types-internal@2.17.0
314
+ - @atlaspack/build-cache@2.13.4
315
+ - @atlaspack/diagnostic@2.14.2
316
+ - @atlaspack/profiler@2.14.19
317
+ - @atlaspack/logger@2.14.14
318
+ - @atlaspack/utils@2.17.4
319
+
320
+ ## 2.14.21
321
+
322
+ ### Patch Changes
323
+
324
+ - Updated dependencies [[`069de47`](https://github.com/atlassian-labs/atlaspack/commit/069de478e64fb5889f6f2ce023eb510782767fbd)]:
325
+ - @atlaspack/types-internal@2.16.0
326
+ - @atlaspack/profiler@2.14.18
327
+ - @atlaspack/utils@2.17.3
328
+
329
+ ## 2.14.20
330
+
331
+ ### Patch Changes
332
+
333
+ - Updated dependencies []:
334
+ - @atlaspack/types-internal@2.15.2
335
+ - @atlaspack/utils@2.17.2
336
+ - @atlaspack/profiler@2.14.17
337
+
338
+ ## 2.14.19
339
+
340
+ ### Patch Changes
341
+
342
+ - Updated dependencies []:
343
+ - @atlaspack/types-internal@2.15.1
344
+ - @atlaspack/utils@2.17.1
345
+ - @atlaspack/profiler@2.14.16
346
+
347
+ ## 2.14.18
348
+
349
+ ### Patch Changes
350
+
351
+ - Updated dependencies [[`dbb4072`](https://github.com/atlassian-labs/atlaspack/commit/dbb40721ebeb45990a14ba04e6b44e7f836fb32d), [`de23e0c`](https://github.com/atlassian-labs/atlaspack/commit/de23e0ce49d5504fe3947ac26640a3d951087da3), [`18a57cf`](https://github.com/atlassian-labs/atlaspack/commit/18a57cf8a4789b2de5ad8e2676f317a26cc91417), [`a5ed1b4`](https://github.com/atlassian-labs/atlaspack/commit/a5ed1b414498560f393ff491af4da25b6e8dde56)]:
352
+ - @atlaspack/utils@2.17.0
353
+ - @atlaspack/types-internal@2.15.0
354
+ - @atlaspack/logger@2.14.13
355
+ - @atlaspack/profiler@2.14.15
356
+
357
+ ## 2.14.17
358
+
359
+ ### Patch Changes
360
+
361
+ - Updated dependencies []:
362
+ - @atlaspack/logger@2.14.12
363
+ - @atlaspack/utils@2.16.1
364
+
365
+ ## 2.14.16
366
+
367
+ ### Patch Changes
368
+
369
+ - Updated dependencies [[`30ee2cf`](https://github.com/atlassian-labs/atlaspack/commit/30ee2cfcd34cf2646ded0eda13fdb80a2a5de529)]:
370
+ - @atlaspack/utils@2.16.0
371
+ - @atlaspack/types-internal@2.14.14
372
+ - @atlaspack/profiler@2.14.14
373
+
374
+ ## 2.14.15
375
+
376
+ ### Patch Changes
377
+
378
+ - Updated dependencies []:
379
+ - @atlaspack/types-internal@2.14.13
380
+ - @atlaspack/utils@2.15.3
381
+ - @atlaspack/profiler@2.14.13
382
+
383
+ ## 2.14.14
384
+
385
+ ### Patch Changes
386
+
387
+ - Updated dependencies []:
388
+ - @atlaspack/types-internal@2.14.12
389
+ - @atlaspack/utils@2.15.2
390
+ - @atlaspack/profiler@2.14.12
391
+
392
+ ## 2.14.13
393
+
394
+ ### Patch Changes
395
+
396
+ - [#650](https://github.com/atlassian-labs/atlaspack/pull/650) [`ef3d622`](https://github.com/atlassian-labs/atlaspack/commit/ef3d6228f4e006702198a19c61e051d194d325cb) Thanks [@alshdavid](https://github.com/alshdavid)! - Remove package.json#exports
397
+
398
+ - Updated dependencies [[`ef3d622`](https://github.com/atlassian-labs/atlaspack/commit/ef3d6228f4e006702198a19c61e051d194d325cb)]:
399
+ - @atlaspack/logger@2.14.11
400
+ - @atlaspack/utils@2.15.1
401
+ - @atlaspack/types-internal@2.14.11
402
+ - @atlaspack/profiler@2.14.11
403
+
404
+ ## 2.14.12
405
+
406
+ ### Patch Changes
407
+
408
+ - Updated dependencies [[`e39c6cf`](https://github.com/atlassian-labs/atlaspack/commit/e39c6cf05f7e95ce5420dbcea66f401b1cbd397c)]:
409
+ - @atlaspack/utils@2.15.0
410
+ - @atlaspack/types-internal@2.14.10
411
+ - @atlaspack/profiler@2.14.10
412
+
413
+ ## 2.14.11
414
+
415
+ ### Patch Changes
416
+
417
+ - Updated dependencies []:
418
+ - @atlaspack/types-internal@2.14.9
419
+ - @atlaspack/utils@2.14.11
420
+ - @atlaspack/profiler@2.14.9
421
+
422
+ ## 2.14.10
423
+
424
+ ### Patch Changes
425
+
426
+ - Updated dependencies [[`51aba5f`](https://github.com/atlassian-labs/atlaspack/commit/51aba5fc0e49235ee06bbc3c376f48c3e7da5c4b)]:
427
+ - @atlaspack/types-internal@2.14.8
428
+ - @atlaspack/profiler@2.14.8
429
+ - @atlaspack/logger@2.14.10
430
+ - @atlaspack/utils@2.14.10
431
+
432
+ ## 2.14.9
433
+
434
+ ### Patch Changes
435
+
436
+ - Updated dependencies []:
437
+ - @atlaspack/logger@2.14.9
438
+ - @atlaspack/utils@2.14.9
439
+ - @atlaspack/types-internal@2.14.7
440
+ - @atlaspack/profiler@2.14.7
441
+
3
442
  ## 2.14.8
4
443
 
5
444
  ### Patch Changes
package/dist/Handle.js ADDED
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const build_cache_1 = require("@atlaspack/build-cache");
7
+ const package_json_1 = __importDefault(require("../package.json"));
8
+ let HANDLE_ID = 0;
9
+ const handleById = new Map();
10
+ class Handle {
11
+ constructor(opts) {
12
+ this.id = opts.id ?? ++HANDLE_ID;
13
+ this.fn = opts.fn;
14
+ this.childId = opts.childId;
15
+ handleById.set(this.id, this);
16
+ }
17
+ dispose() {
18
+ handleById.delete(this.id);
19
+ }
20
+ serialize() {
21
+ return {
22
+ id: this.id,
23
+ childId: this.childId,
24
+ };
25
+ }
26
+ static deserialize(opts) {
27
+ return new Handle(opts);
28
+ }
29
+ }
30
+ exports.default = Handle;
31
+ // Register the Handle as a serializable class so that it will properly be deserialized
32
+ // by anything that uses WorkerFarm.
33
+ (0, build_cache_1.registerSerializableClass)(`${package_json_1.default.version}:Handle`, Handle);
package/dist/Worker.js ADDED
@@ -0,0 +1,180 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const nullthrows_1 = __importDefault(require("nullthrows"));
7
+ const events_1 = __importDefault(require("events"));
8
+ const diagnostic_1 = __importDefault(require("@atlaspack/diagnostic"));
9
+ const backend_1 = require("./backend");
10
+ let WORKER_ID = 0;
11
+ class Worker extends events_1.default {
12
+ constructor(options) {
13
+ super();
14
+ this.id = WORKER_ID++;
15
+ this.sentSharedReferences = new Set();
16
+ this.calls = new Map();
17
+ this.exitCode = null;
18
+ this.callId = 0;
19
+ this.ready = false;
20
+ this.stopped = false;
21
+ this.isStopping = false;
22
+ this.options = options;
23
+ }
24
+ async fork(forkModule) {
25
+ let filteredArgs = [];
26
+ if (process.execArgv) {
27
+ filteredArgs = process.execArgv.filter((v) => !/^--(debug|inspect|no-opt|max-old-space-size=|max-semi-space-size=|expose-gc)/.test(v));
28
+ for (let i = 0; i < filteredArgs.length; i++) {
29
+ let arg = filteredArgs[i];
30
+ let isArgWithParam = ((arg === '-r' || arg === '--require') &&
31
+ filteredArgs[i + 1] === '@atlaspack/register') ||
32
+ arg === '--title';
33
+ if (isArgWithParam) {
34
+ filteredArgs.splice(i, 2);
35
+ i--;
36
+ }
37
+ }
38
+ }
39
+ // Workaround for https://github.com/nodejs/node/issues/29117
40
+ if (process.env.NODE_OPTIONS) {
41
+ // arg parsing logic adapted from https://stackoverflow.com/a/46946420/2352201
42
+ let opts = [''];
43
+ let quote = false;
44
+ for (let c of (0, nullthrows_1.default)(process.env.NODE_OPTIONS.match(/.|^$/g))) {
45
+ if (c === '"') {
46
+ quote = !quote;
47
+ }
48
+ else if (!quote && c === ' ') {
49
+ opts.push('');
50
+ }
51
+ else {
52
+ opts[opts.length - 1] += c.replace(/\\(.)/, '$1');
53
+ }
54
+ }
55
+ for (let i = 0; i < opts.length; i++) {
56
+ let opt = opts[i];
57
+ if (opt === '-r' || opt === '--require') {
58
+ filteredArgs.push(opt, opts[i + 1]);
59
+ i++;
60
+ }
61
+ }
62
+ }
63
+ let onMessage = (data) => this.receive(data);
64
+ let onExit = (code) => {
65
+ this.exitCode = code;
66
+ this.emit('exit', code);
67
+ };
68
+ let onError = (err) => {
69
+ this.emit('error', err);
70
+ };
71
+ let WorkerBackend = (0, backend_1.getWorkerBackend)(this.options.backend);
72
+ this.worker = new WorkerBackend(filteredArgs, onMessage, onError, onExit);
73
+ await this.worker.start();
74
+ await new Promise((resolve, reject) => {
75
+ this.call({
76
+ method: 'childInit',
77
+ args: [
78
+ forkModule,
79
+ {
80
+ shouldPatchConsole: !!this.options.shouldPatchConsole,
81
+ shouldTrace: !!this.options.shouldTrace,
82
+ },
83
+ ],
84
+ retries: 0,
85
+ skipReadyCheck: true,
86
+ resolve,
87
+ reject,
88
+ });
89
+ });
90
+ let sharedRefs = this.options.sharedReferences;
91
+ let refsShared = new Set();
92
+ // in case more refs are created while initial refs are sending
93
+ while (refsShared.size < sharedRefs.size) {
94
+ await Promise.all([...sharedRefs]
95
+ // @ts-expect-error TS2769
96
+ .filter(([ref]) => !refsShared.has(ref))
97
+ .map(async ([ref, value]) => {
98
+ await this.sendSharedReference(ref, value);
99
+ refsShared.add(ref);
100
+ }));
101
+ }
102
+ this.ready = true;
103
+ this.emit('ready');
104
+ }
105
+ sendSharedReference(ref, value) {
106
+ this.sentSharedReferences.add(ref);
107
+ return new Promise((resolve, reject) => {
108
+ this.call({
109
+ method: 'createSharedReference',
110
+ args: [ref, value],
111
+ resolve,
112
+ reject,
113
+ retries: 0,
114
+ skipReadyCheck: true,
115
+ });
116
+ });
117
+ }
118
+ send(data) {
119
+ this.worker.send(data);
120
+ }
121
+ call(call) {
122
+ if (this.stopped || this.isStopping) {
123
+ return;
124
+ }
125
+ let idx = this.callId++;
126
+ this.calls.set(idx, call);
127
+ let msg = {
128
+ type: 'request',
129
+ idx: idx,
130
+ child: this.id,
131
+ handle: call.handle,
132
+ method: call.method,
133
+ args: call.args,
134
+ };
135
+ if (this.ready || call.skipReadyCheck === true) {
136
+ // @ts-expect-error TS2345
137
+ this.send(msg);
138
+ }
139
+ else {
140
+ // @ts-expect-error TS2345
141
+ this.once('ready', () => this.send(msg));
142
+ }
143
+ }
144
+ receive(message) {
145
+ if (this.stopped || this.isStopping) {
146
+ return;
147
+ }
148
+ if (message.type === 'request') {
149
+ this.emit('request', message);
150
+ }
151
+ else if (message.type === 'response') {
152
+ let idx = message.idx;
153
+ if (idx == null) {
154
+ return;
155
+ }
156
+ let call = this.calls.get(idx);
157
+ if (!call) {
158
+ // Return for unknown calls, these might accur if a third party process uses workers
159
+ return;
160
+ }
161
+ if (message.contentType === 'error') {
162
+ call.reject(new diagnostic_1.default({ diagnostic: message.content }));
163
+ }
164
+ else {
165
+ call.resolve(message.content);
166
+ }
167
+ this.calls.delete(idx);
168
+ this.emit('response', message);
169
+ }
170
+ }
171
+ async stop() {
172
+ if (!this.stopped) {
173
+ this.stopped = true;
174
+ if (this.worker) {
175
+ await this.worker.stop();
176
+ }
177
+ }
178
+ }
179
+ }
180
+ exports.default = Worker;