@ls-stack/utils 3.65.0 → 3.66.0

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 (336) hide show
  1. package/dist/{arrayUtils.d.cts → arrayUtils.d.mts} +24 -23
  2. package/dist/arrayUtils.mjs +249 -0
  3. package/dist/assertions-qMxfVhSu.mjs +207 -0
  4. package/dist/{assertions.d.ts → assertions.d.mts} +4 -3
  5. package/dist/assertions.mjs +3 -0
  6. package/dist/asyncQueue.d.mts +497 -0
  7. package/dist/asyncQueue.mjs +757 -0
  8. package/dist/{awaitDebounce.d.cts → awaitDebounce.d.mts} +11 -6
  9. package/dist/awaitDebounce.mjs +54 -0
  10. package/dist/{cache.d.ts → cache.d.mts} +76 -68
  11. package/dist/cache.mjs +355 -0
  12. package/dist/castValues-DfICShCc.mjs +19 -0
  13. package/dist/{castValues.d.cts → castValues.d.mts} +3 -2
  14. package/dist/castValues.mjs +3 -0
  15. package/dist/{concurrentCalls.d.ts → concurrentCalls.d.mts} +74 -65
  16. package/dist/concurrentCalls.mjs +295 -0
  17. package/dist/consoleFmt.d.mts +55 -0
  18. package/dist/consoleFmt.mjs +63 -0
  19. package/dist/conversions-DTmwEMIu.mjs +12 -0
  20. package/dist/conversions.d.mts +4 -0
  21. package/dist/conversions.mjs +3 -0
  22. package/dist/createThrottleController.d.mts +18 -0
  23. package/dist/createThrottleController.mjs +40 -0
  24. package/dist/debounce.d.mts +47 -0
  25. package/dist/debounce.mjs +117 -0
  26. package/dist/dedent.d.mts +74 -0
  27. package/dist/dedent.mjs +80 -0
  28. package/dist/deepEqual-C7EZEixx.mjs +78 -0
  29. package/dist/{deepEqual.d.cts → deepEqual.d.mts} +3 -2
  30. package/dist/deepEqual.mjs +3 -0
  31. package/dist/{deepReplaceValues.d.cts → deepReplaceValues.d.mts} +4 -3
  32. package/dist/deepReplaceValues.mjs +61 -0
  33. package/dist/diffParser.d.mts +63 -0
  34. package/dist/diffParser.mjs +410 -0
  35. package/dist/enhancedMap.d.mts +21 -0
  36. package/dist/enhancedMap.mjs +69 -0
  37. package/dist/exhaustiveMatch.d.mts +10 -0
  38. package/dist/exhaustiveMatch.mjs +48 -0
  39. package/dist/{filterObjectOrArrayKeys.d.cts → filterObjectOrArrayKeys.d.mts} +15 -8
  40. package/dist/filterObjectOrArrayKeys.mjs +497 -0
  41. package/dist/{getAutoIncrementId.d.cts → getAutoIncrementId.d.mts} +9 -5
  42. package/dist/getAutoIncrementId.mjs +53 -0
  43. package/dist/{getCompositeKey.d.cts → getCompositeKey.d.mts} +3 -2
  44. package/dist/getCompositeKey.mjs +50 -0
  45. package/dist/{getValueStableKey.d.cts → getValueStableKey.d.mts} +5 -3
  46. package/dist/getValueStableKey.mjs +17 -0
  47. package/dist/{hash.d.cts → hash.d.mts} +3 -2
  48. package/dist/hash.mjs +28 -0
  49. package/dist/interpolate.d.mts +17 -0
  50. package/dist/interpolate.mjs +28 -0
  51. package/dist/{iteratorUtils.d.cts → iteratorUtils.d.mts} +5 -4
  52. package/dist/iteratorUtils.mjs +39 -0
  53. package/dist/keepPrevIfUnchanged.d.mts +12 -0
  54. package/dist/keepPrevIfUnchanged.mjs +9 -0
  55. package/dist/keyedMap.d.mts +76 -0
  56. package/dist/keyedMap.mjs +139 -0
  57. package/dist/keyedSet.d.mts +77 -0
  58. package/dist/keyedSet.mjs +129 -0
  59. package/dist/{levenshtein.d.cts → levenshtein.d.mts} +3 -2
  60. package/dist/levenshtein.mjs +121 -0
  61. package/dist/main.d.mts +4 -0
  62. package/dist/main.mjs +7 -0
  63. package/dist/matchPath.d.mts +50 -0
  64. package/dist/matchPath.mjs +81 -0
  65. package/dist/mathUtils-BDP1lM_z.mjs +81 -0
  66. package/dist/{mathUtils.d.cts → mathUtils.d.mts} +3 -2
  67. package/dist/mathUtils.mjs +3 -0
  68. package/dist/{mutationUtils.d.cts → mutationUtils.d.mts} +6 -5
  69. package/dist/mutationUtils.mjs +44 -0
  70. package/dist/{objUtils.d.ts → objUtils.d.mts} +8 -6
  71. package/dist/objUtils.mjs +115 -0
  72. package/dist/parallelAsyncCalls.d.mts +83 -0
  73. package/dist/parallelAsyncCalls.mjs +121 -0
  74. package/dist/partialEqual.d.mts +139 -0
  75. package/dist/partialEqual.mjs +1055 -0
  76. package/dist/promiseUtils.d.mts +9 -0
  77. package/dist/promiseUtils.mjs +17 -0
  78. package/dist/regexUtils.d.mts +18 -0
  79. package/dist/regexUtils.mjs +34 -0
  80. package/dist/{retryOnError.d.cts → retryOnError.d.mts} +38 -37
  81. package/dist/retryOnError.mjs +91 -0
  82. package/dist/{runShellCmd.d.ts → runShellCmd.d.mts} +24 -15
  83. package/dist/runShellCmd.mjs +151 -0
  84. package/dist/{safeJson.d.cts → safeJson.d.mts} +3 -2
  85. package/dist/safeJson.mjs +30 -0
  86. package/dist/{saferTyping.d.cts → saferTyping.d.mts} +4 -3
  87. package/dist/saferTyping.mjs +45 -0
  88. package/dist/serializeXML.d.mts +23 -0
  89. package/dist/serializeXML.mjs +74 -0
  90. package/dist/{shallowEqual.d.cts → shallowEqual.d.mts} +3 -2
  91. package/dist/shallowEqual.mjs +54 -0
  92. package/dist/sleep.d.mts +4 -0
  93. package/dist/sleep.mjs +7 -0
  94. package/dist/stringUtils-DjhWOiYn.mjs +113 -0
  95. package/dist/{stringUtils.d.cts → stringUtils.d.mts} +3 -2
  96. package/dist/stringUtils.mjs +3 -0
  97. package/dist/{testUtils.d.ts → testUtils.d.mts} +83 -52
  98. package/dist/testUtils.mjs +310 -0
  99. package/dist/{throttle.d.ts → throttle.d.mts} +18 -17
  100. package/dist/throttle.mjs +102 -0
  101. package/dist/time-sr2lhQRw.mjs +67 -0
  102. package/dist/{time.d.ts → time.d.mts} +8 -7
  103. package/dist/time.mjs +3 -0
  104. package/dist/{timers.d.cts → timers.d.mts} +22 -13
  105. package/dist/timers.mjs +220 -0
  106. package/dist/{tsResult.d.cts → tsResult.d.mts} +52 -48
  107. package/dist/tsResult.mjs +142 -0
  108. package/dist/typeGuards-B1mzA-Rz.mjs +128 -0
  109. package/dist/{typeGuards.d.cts → typeGuards.d.mts} +3 -2
  110. package/dist/typeGuards.mjs +3 -0
  111. package/dist/{typeUtils.d.ts → typeUtils.d.mts} +13 -34
  112. package/dist/typeUtils.mjs +1 -0
  113. package/dist/{typedStrings.d.cts → typedStrings.d.mts} +5 -4
  114. package/dist/typedStrings.mjs +131 -0
  115. package/dist/typingFnUtils-Bb8drgKF.mjs +101 -0
  116. package/dist/{typingFnUtils.d.cts → typingFnUtils.d.mts} +13 -22
  117. package/dist/typingFnUtils.mjs +3 -0
  118. package/dist/{typingTestUtils.d.cts → typingTestUtils.d.mts} +11 -15
  119. package/dist/typingTestUtils.mjs +80 -0
  120. package/dist/typingUtils.d.mts +20 -0
  121. package/dist/typingUtils.mjs +1 -0
  122. package/dist/yamlStringify.d.mts +17 -0
  123. package/dist/yamlStringify.mjs +189 -0
  124. package/package.json +65 -242
  125. package/dist/arrayUtils.cjs +0 -229
  126. package/dist/arrayUtils.d.ts +0 -171
  127. package/dist/arrayUtils.js +0 -42
  128. package/dist/assertions.cjs +0 -107
  129. package/dist/assertions.d.cts +0 -192
  130. package/dist/assertions.js +0 -25
  131. package/dist/asyncQueue.cjs +0 -672
  132. package/dist/asyncQueue.d.cts +0 -488
  133. package/dist/asyncQueue.d.ts +0 -488
  134. package/dist/asyncQueue.js +0 -631
  135. package/dist/awaitDebounce.cjs +0 -106
  136. package/dist/awaitDebounce.d.ts +0 -41
  137. package/dist/awaitDebounce.js +0 -28
  138. package/dist/cache.cjs +0 -367
  139. package/dist/cache.d.cts +0 -228
  140. package/dist/cache.js +0 -19
  141. package/dist/castValues.cjs +0 -50
  142. package/dist/castValues.d.ts +0 -4
  143. package/dist/castValues.js +0 -8
  144. package/dist/chunk-5DZT3Z5Z.js +0 -8
  145. package/dist/chunk-6FBIEPWU.js +0 -96
  146. package/dist/chunk-6FIBVC2P.js +0 -56
  147. package/dist/chunk-7CQPOM5I.js +0 -100
  148. package/dist/chunk-B6DNOZCP.js +0 -369
  149. package/dist/chunk-BM4PYVOX.js +0 -109
  150. package/dist/chunk-C2SVCIWE.js +0 -57
  151. package/dist/chunk-CCUPDGSZ.js +0 -132
  152. package/dist/chunk-DBOWTYR4.js +0 -49
  153. package/dist/chunk-DFXNVEH6.js +0 -14
  154. package/dist/chunk-DX2524CZ.js +0 -314
  155. package/dist/chunk-GMJTLFM6.js +0 -60
  156. package/dist/chunk-IATIXMCE.js +0 -20
  157. package/dist/chunk-II4R3VVX.js +0 -25
  158. package/dist/chunk-JF2MDHOJ.js +0 -40
  159. package/dist/chunk-JQFUKJU5.js +0 -71
  160. package/dist/chunk-MI4UE2PQ.js +0 -561
  161. package/dist/chunk-PUKVXYYL.js +0 -52
  162. package/dist/chunk-QQS7I7ZL.js +0 -16
  163. package/dist/chunk-VAAMRG4K.js +0 -20
  164. package/dist/chunk-WFQJUJTC.js +0 -182
  165. package/dist/chunk-ZXIKIA5B.js +0 -178
  166. package/dist/concurrentCalls.cjs +0 -406
  167. package/dist/concurrentCalls.d.cts +0 -116
  168. package/dist/concurrentCalls.js +0 -346
  169. package/dist/consoleFmt.cjs +0 -85
  170. package/dist/consoleFmt.d.cts +0 -54
  171. package/dist/consoleFmt.d.ts +0 -54
  172. package/dist/consoleFmt.js +0 -60
  173. package/dist/conversions.cjs +0 -44
  174. package/dist/conversions.d.cts +0 -3
  175. package/dist/conversions.d.ts +0 -3
  176. package/dist/conversions.js +0 -6
  177. package/dist/createThrottleController.cjs +0 -193
  178. package/dist/createThrottleController.d.cts +0 -13
  179. package/dist/createThrottleController.d.ts +0 -13
  180. package/dist/createThrottleController.js +0 -61
  181. package/dist/debounce.cjs +0 -157
  182. package/dist/debounce.d.cts +0 -46
  183. package/dist/debounce.d.ts +0 -46
  184. package/dist/debounce.js +0 -8
  185. package/dist/dedent.cjs +0 -104
  186. package/dist/dedent.d.cts +0 -73
  187. package/dist/dedent.d.ts +0 -73
  188. package/dist/dedent.js +0 -79
  189. package/dist/deepEqual.cjs +0 -96
  190. package/dist/deepEqual.d.ts +0 -21
  191. package/dist/deepEqual.js +0 -8
  192. package/dist/deepReplaceValues.cjs +0 -87
  193. package/dist/deepReplaceValues.d.ts +0 -27
  194. package/dist/deepReplaceValues.js +0 -7
  195. package/dist/enhancedMap.cjs +0 -131
  196. package/dist/enhancedMap.d.cts +0 -20
  197. package/dist/enhancedMap.d.ts +0 -20
  198. package/dist/enhancedMap.js +0 -10
  199. package/dist/exhaustiveMatch.cjs +0 -66
  200. package/dist/exhaustiveMatch.d.cts +0 -9
  201. package/dist/exhaustiveMatch.d.ts +0 -9
  202. package/dist/exhaustiveMatch.js +0 -40
  203. package/dist/filterObjectOrArrayKeys.cjs +0 -619
  204. package/dist/filterObjectOrArrayKeys.d.ts +0 -88
  205. package/dist/filterObjectOrArrayKeys.js +0 -9
  206. package/dist/getAutoIncrementId.cjs +0 -44
  207. package/dist/getAutoIncrementId.d.ts +0 -46
  208. package/dist/getAutoIncrementId.js +0 -18
  209. package/dist/getCompositeKey.cjs +0 -86
  210. package/dist/getCompositeKey.d.ts +0 -11
  211. package/dist/getCompositeKey.js +0 -8
  212. package/dist/getValueStableKey.cjs +0 -89
  213. package/dist/getValueStableKey.d.ts +0 -15
  214. package/dist/getValueStableKey.js +0 -11
  215. package/dist/hash.cjs +0 -57
  216. package/dist/hash.d.ts +0 -7
  217. package/dist/hash.js +0 -32
  218. package/dist/interpolate.cjs +0 -88
  219. package/dist/interpolate.d.cts +0 -11
  220. package/dist/interpolate.d.ts +0 -11
  221. package/dist/interpolate.js +0 -46
  222. package/dist/iteratorUtils.cjs +0 -73
  223. package/dist/iteratorUtils.d.ts +0 -10
  224. package/dist/iteratorUtils.js +0 -44
  225. package/dist/keepPrevIfUnchanged.cjs +0 -102
  226. package/dist/keepPrevIfUnchanged.d.cts +0 -7
  227. package/dist/keepPrevIfUnchanged.d.ts +0 -7
  228. package/dist/keepPrevIfUnchanged.js +0 -7
  229. package/dist/keyedMap.cjs +0 -224
  230. package/dist/keyedMap.d.cts +0 -75
  231. package/dist/keyedMap.d.ts +0 -75
  232. package/dist/keyedMap.js +0 -145
  233. package/dist/keyedSet.cjs +0 -205
  234. package/dist/keyedSet.d.cts +0 -76
  235. package/dist/keyedSet.d.ts +0 -76
  236. package/dist/keyedSet.js +0 -126
  237. package/dist/levenshtein.cjs +0 -180
  238. package/dist/levenshtein.d.ts +0 -5
  239. package/dist/levenshtein.js +0 -153
  240. package/dist/main.cjs +0 -32
  241. package/dist/main.d.cts +0 -3
  242. package/dist/main.d.ts +0 -3
  243. package/dist/main.js +0 -7
  244. package/dist/matchPath.cjs +0 -155
  245. package/dist/matchPath.d.cts +0 -53
  246. package/dist/matchPath.d.ts +0 -53
  247. package/dist/matchPath.js +0 -108
  248. package/dist/mathUtils.cjs +0 -81
  249. package/dist/mathUtils.d.ts +0 -54
  250. package/dist/mathUtils.js +0 -22
  251. package/dist/mutationUtils.cjs +0 -153
  252. package/dist/mutationUtils.d.ts +0 -15
  253. package/dist/mutationUtils.js +0 -55
  254. package/dist/objUtils.cjs +0 -242
  255. package/dist/objUtils.d.cts +0 -28
  256. package/dist/objUtils.js +0 -38
  257. package/dist/parallelAsyncCalls.cjs +0 -162
  258. package/dist/parallelAsyncCalls.d.cts +0 -82
  259. package/dist/parallelAsyncCalls.d.ts +0 -82
  260. package/dist/parallelAsyncCalls.js +0 -126
  261. package/dist/partialEqual.cjs +0 -1196
  262. package/dist/partialEqual.d.cts +0 -141
  263. package/dist/partialEqual.d.ts +0 -141
  264. package/dist/partialEqual.js +0 -1168
  265. package/dist/promiseUtils.cjs +0 -38
  266. package/dist/promiseUtils.d.cts +0 -8
  267. package/dist/promiseUtils.d.ts +0 -8
  268. package/dist/promiseUtils.js +0 -6
  269. package/dist/regexUtils.cjs +0 -60
  270. package/dist/regexUtils.d.cts +0 -17
  271. package/dist/regexUtils.d.ts +0 -17
  272. package/dist/regexUtils.js +0 -33
  273. package/dist/retryOnError.cjs +0 -130
  274. package/dist/retryOnError.d.ts +0 -83
  275. package/dist/retryOnError.js +0 -101
  276. package/dist/runShellCmd.cjs +0 -127
  277. package/dist/runShellCmd.d.cts +0 -90
  278. package/dist/runShellCmd.js +0 -98
  279. package/dist/safeJson.cjs +0 -45
  280. package/dist/safeJson.d.ts +0 -16
  281. package/dist/safeJson.js +0 -8
  282. package/dist/saferTyping.cjs +0 -52
  283. package/dist/saferTyping.d.ts +0 -47
  284. package/dist/saferTyping.js +0 -23
  285. package/dist/serializeXML.cjs +0 -154
  286. package/dist/serializeXML.d.cts +0 -22
  287. package/dist/serializeXML.d.ts +0 -22
  288. package/dist/serializeXML.js +0 -116
  289. package/dist/shallowEqual.cjs +0 -88
  290. package/dist/shallowEqual.d.ts +0 -4
  291. package/dist/shallowEqual.js +0 -63
  292. package/dist/sleep.cjs +0 -32
  293. package/dist/sleep.d.cts +0 -3
  294. package/dist/sleep.d.ts +0 -3
  295. package/dist/sleep.js +0 -6
  296. package/dist/stringUtils.cjs +0 -155
  297. package/dist/stringUtils.d.ts +0 -55
  298. package/dist/stringUtils.js +0 -50
  299. package/dist/testUtils.cjs +0 -1490
  300. package/dist/testUtils.d.cts +0 -133
  301. package/dist/testUtils.js +0 -359
  302. package/dist/throttle.cjs +0 -282
  303. package/dist/throttle.d.cts +0 -98
  304. package/dist/throttle.js +0 -38
  305. package/dist/time.cjs +0 -152
  306. package/dist/time.d.cts +0 -25
  307. package/dist/time.js +0 -38
  308. package/dist/timers.cjs +0 -194
  309. package/dist/timers.d.ts +0 -121
  310. package/dist/timers.js +0 -156
  311. package/dist/tsResult.cjs +0 -226
  312. package/dist/tsResult.d.ts +0 -114
  313. package/dist/tsResult.js +0 -180
  314. package/dist/typeGuards.cjs +0 -70
  315. package/dist/typeGuards.d.ts +0 -111
  316. package/dist/typeGuards.js +0 -18
  317. package/dist/typeUtils.cjs +0 -18
  318. package/dist/typeUtils.d.cts +0 -61
  319. package/dist/typeUtils.js +0 -0
  320. package/dist/typedStrings.cjs +0 -90
  321. package/dist/typedStrings.d.ts +0 -163
  322. package/dist/typedStrings.js +0 -57
  323. package/dist/typingFnUtils.cjs +0 -96
  324. package/dist/typingFnUtils.d.ts +0 -100
  325. package/dist/typingFnUtils.js +0 -30
  326. package/dist/typingTestUtils.cjs +0 -52
  327. package/dist/typingTestUtils.d.ts +0 -79
  328. package/dist/typingTestUtils.js +0 -27
  329. package/dist/typingUtils.cjs +0 -18
  330. package/dist/typingUtils.d.cts +0 -35
  331. package/dist/typingUtils.d.ts +0 -35
  332. package/dist/typingUtils.js +0 -0
  333. package/dist/yamlStringify.cjs +0 -423
  334. package/dist/yamlStringify.d.cts +0 -10
  335. package/dist/yamlStringify.d.ts +0 -10
  336. package/dist/yamlStringify.js +0 -9
@@ -1,488 +0,0 @@
1
- import * as evtmitter from 'evtmitter';
2
- import { ResultValidErrors, Result } from 't-result';
3
- import { DurationObj } from './time.cjs';
4
-
5
- /** Configuration for rate limiting task execution */
6
- type RateLimit = {
7
- /** Maximum number of tasks to execute within the interval */
8
- maxTasks: number;
9
- /** Time interval in milliseconds or as a duration object */
10
- interval: DurationObj | number;
11
- };
12
- /** Configuration options for AsyncQueue initialization */
13
- type AsyncQueueOptions = {
14
- /** Maximum number of tasks to run concurrently (default: 1) */
15
- concurrency?: number;
16
- /** AbortSignal to cancel the entire queue */
17
- signal?: AbortSignal;
18
- /** Default timeout for all tasks in milliseconds */
19
- timeout?: number;
20
- /** Stop processing new tasks when any task fails (default: false) */
21
- stopOnError?: boolean;
22
- /** Reject all pending tasks when stopping on error (default: false) */
23
- rejectPendingOnError?: boolean;
24
- /** Start processing tasks immediately when added (default: true) */
25
- autoStart?: boolean;
26
- /** Rate limit configuration to limit tasks per time interval */
27
- rateLimit?: RateLimit;
28
- };
29
- /** Options for adding individual tasks to the queue */
30
- type AddOptions<I, T, E extends ResultValidErrors> = {
31
- /** AbortSignal to cancel this specific task */
32
- signal?: AbortSignal;
33
- /** Timeout for this specific task in milliseconds */
34
- timeout?: number;
35
- /** Metadata to associate with this task */
36
- meta?: I;
37
- /** Callback invoked when task completes successfully */
38
- onComplete?: (value: T) => void;
39
- /** Callback invoked when task fails */
40
- onError?: (error: E | Error) => void;
41
- };
42
- /** Runtime context passed to task functions */
43
- type RunCtx<I> = {
44
- /** Combined AbortSignal from task, queue, and timeout signals */
45
- signal?: AbortSignal;
46
- /** Metadata associated with this task */
47
- meta?: I;
48
- };
49
- /**
50
- * A powerful async task queue with advanced error handling and flow control
51
- *
52
- * @example
53
- * Basic Usage
54
- * ```typescript
55
- * const queue = createAsyncQueue<string>({ concurrency: 2 });
56
- *
57
- * const processedItems: string[] = [];
58
- *
59
- * queue.resultifyAdd(async () => {
60
- * await delay(100);
61
- * return 'task completed';
62
- * }).then(result => {
63
- * if (result.ok) processedItems.push(result.value);
64
- * });
65
- *
66
- * await queue.onIdle();
67
- * console.log('Processed:', processedItems);
68
- * ```
69
- *
70
- * @example
71
- * Error Recovery
72
- * ```typescript
73
- * const queue = createAsyncQueue<string>({
74
- * stopOnError: true,
75
- * rejectPendingOnError: false
76
- * });
77
- *
78
- * // Add batch of tasks
79
- * const items = ['item1', 'item2', 'bad-item', 'item3'];
80
- * items.forEach(item => {
81
- * queue.resultifyAdd(async () => {
82
- * if (item === 'bad-item') throw new Error('Processing failed');
83
- * return item.toUpperCase();
84
- * });
85
- * });
86
- *
87
- * await queue.onIdle();
88
- *
89
- * if (queue.isStopped) {
90
- * console.log(`Stopped at ${queue.failed} failures, ${queue.size} remaining`);
91
- * // Reset and continue with remaining tasks
92
- * queue.reset();
93
- * await queue.onIdle();
94
- * }
95
- * ```
96
- *
97
- * @example
98
- * Lazy Start
99
- * ```typescript
100
- * const queue = createAsyncQueue<string>({ autoStart: false });
101
- *
102
- * // Prepare all tasks without starting
103
- * queue.resultifyAdd(() => processTask1());
104
- * queue.resultifyAdd(() => processTask2());
105
- * queue.resultifyAdd(() => processTask3());
106
- *
107
- * // Start processing when ready
108
- * queue.start();
109
- * await queue.onIdle();
110
- * ```
111
- *
112
- * @template T - The type of value returned by successful tasks
113
- * @template E - The type of errors that tasks can produce (defaults to Error)
114
- * @template I - The type of metadata associated with tasks (defaults to
115
- * unknown)
116
- */
117
- declare class AsyncQueue<T, E extends ResultValidErrors = Error, I = unknown> {
118
- #private;
119
- /**
120
- * Event emitter for tracking task lifecycle
121
- *
122
- * @example
123
- * Listening to Events
124
- * ```typescript
125
- * const queue = createAsyncQueue<string>();
126
- *
127
- * queue.events.on('start', (event) => {
128
- * console.log('Task started:', event.payload.meta);
129
- * });
130
- *
131
- * queue.events.on('complete', (event) => {
132
- * console.log('Task completed:', event.payload.value);
133
- * });
134
- *
135
- * queue.events.on('error', (event) => {
136
- * console.error('Task failed:', event.payload.error);
137
- * });
138
- * ```
139
- */
140
- events: evtmitter.Emitter<{
141
- /** Emitted when a task starts executing */
142
- start: {
143
- meta: I;
144
- };
145
- /** Emitted when a task completes successfully */
146
- complete: {
147
- meta: I;
148
- value: T;
149
- };
150
- /** Emitted when a task fails */
151
- error: {
152
- meta: I;
153
- error: E | Error;
154
- };
155
- }>;
156
- /** Array of all task failures with metadata for debugging and analysis */
157
- failures: Array<{
158
- meta: I;
159
- error: E | Error;
160
- }>;
161
- /** Array of all task completions with metadata for debugging and analysis */
162
- completions: Array<{
163
- meta: I;
164
- value: T;
165
- }>;
166
- constructor({ concurrency, signal, timeout: taskTimeout, stopOnError, rejectPendingOnError, autoStart, rateLimit, }?: AsyncQueueOptions);
167
- /**
168
- * Add a task that returns a Result to the queue
169
- *
170
- * Use this method when your task function already returns a Result type. For
171
- * functions that throw errors or return plain values, use `resultifyAdd`
172
- * instead.
173
- *
174
- * @example
175
- * ```typescript
176
- * const queue = createAsyncQueue<string>();
177
- *
178
- * const result = await queue.add(async () => {
179
- * try {
180
- * const data = await fetchData();
181
- * return Result.ok(data);
182
- * } catch (error) {
183
- * return Result.err(error);
184
- * }
185
- * });
186
- *
187
- * if (result.ok) {
188
- * console.log('Success:', result.value);
189
- * } else {
190
- * console.log('Error:', result.error);
191
- * }
192
- * ```;
193
- *
194
- * @param fn - Task function that returns a Result
195
- * @param options - Optional configuration for this task
196
- * @returns Promise that resolves with the task result
197
- */
198
- add(fn: (ctx: RunCtx<I>) => Promise<Result<T, E>> | Result<T, E>, options?: AddOptions<I, T, E>): Promise<Result<T, E | Error>>;
199
- /**
200
- * Add a task that returns a plain value or throws errors to the queue
201
- *
202
- * This is the most commonly used method. It automatically wraps your function
203
- * to handle errors and convert them to Result types.
204
- *
205
- * @example
206
- * Basic Usage
207
- * ```typescript
208
- * const queue = createAsyncQueue<string>();
209
- *
210
- * queue.resultifyAdd(async () => {
211
- * const response = await fetch('/api/data');
212
- * return response.json();
213
- * }).then(result => {
214
- * if (result.ok) {
215
- * console.log('Data:', result.value);
216
- * } else {
217
- * console.error('Failed:', result.error);
218
- * }
219
- * });
220
- * ```
221
- *
222
- * @example
223
- * With Callbacks
224
- * ```typescript
225
- * queue.resultifyAdd(
226
- * async () => processData(),
227
- * {
228
- * onComplete: (data) => console.log('Processed:', data),
229
- * onError: (error) => console.error('Failed:', error),
230
- * timeout: 5000
231
- * }
232
- * );
233
- * ```
234
- *
235
- * @param fn - Task function that returns a value or throws
236
- * @param options - Optional configuration for this task
237
- * @returns Promise that resolves with the task result wrapped in Result
238
- */
239
- resultifyAdd(fn: (ctx: RunCtx<I>) => Promise<T> | T, options?: AddOptions<I, T, E>): Promise<Result<T, E | Error>>;
240
- /**
241
- * Wait for the queue to become idle (no pending tasks, no queued tasks, and
242
- * no rate-limit timers)
243
- *
244
- * This method resolves when:
245
- *
246
- * - All tasks have completed (success or failure)
247
- * - The queue is stopped due to error (stopOnError), even with remaining tasks
248
- * - There are no queued tasks, no running tasks, and no pending rate-limit
249
- * timers
250
- *
251
- * @example
252
- * ```typescript
253
- * const queue = createAsyncQueue<string>();
254
- *
255
- * // Add multiple tasks
256
- * for (let i = 0; i < 10; i++) {
257
- * queue.resultifyAdd(async () => `task ${i}`);
258
- * }
259
- *
260
- * // Wait for all tasks to complete
261
- * await queue.onIdle();
262
- *
263
- * console.log(`Completed: ${queue.completed}, Failed: ${queue.failed}`);
264
- * ```
265
- *
266
- * @returns Promise that resolves when the queue is idle
267
- */
268
- onIdle(): Promise<void>;
269
- /**
270
- * Wait until the queued task count is below a limit
271
- *
272
- * Resolves immediately if `size < limit` at the moment of calling. This only
273
- * considers queued (not yet started) tasks; running tasks are tracked by
274
- * `pending`.
275
- *
276
- * @param limit Threshold that `size` must be below to resolve
277
- */
278
- onSizeLessThan(limit: number): Promise<void>;
279
- /**
280
- * Clear all queued tasks (does not affect currently running tasks)
281
- *
282
- * This removes all tasks waiting in the queue but allows currently executing
283
- * tasks to complete normally.
284
- *
285
- * @example
286
- * ```typescript
287
- * const queue = createAsyncQueue({ concurrency: 1 });
288
- *
289
- * // Add multiple tasks
290
- * queue.resultifyAdd(async () => longRunningTask()); // Will start immediately
291
- * queue.resultifyAdd(async () => task2()); // Queued
292
- * queue.resultifyAdd(async () => task3()); // Queued
293
- *
294
- * // Clear remaining queued tasks
295
- * queue.clear();
296
- *
297
- * // Only the first task will complete
298
- * await queue.onIdle();
299
- * ```;
300
- */
301
- clear(): void;
302
- /** Number of tasks that have completed successfully */
303
- get completed(): number;
304
- /** Number of tasks that have failed */
305
- get failed(): number;
306
- /** Number of tasks currently being processed */
307
- get pending(): number;
308
- /** Number of tasks waiting in the queue to be processed */
309
- get size(): number;
310
- /**
311
- * Manually start processing tasks (only needed if autoStart: false)
312
- *
313
- * @example
314
- * ```typescript
315
- * const queue = createAsyncQueue({ autoStart: false });
316
- *
317
- * // Add tasks without starting processing
318
- * queue.resultifyAdd(async () => 'task1');
319
- * queue.resultifyAdd(async () => 'task2');
320
- *
321
- * // Start processing when ready
322
- * queue.start();
323
- * await queue.onIdle();
324
- * ```;
325
- */
326
- start(): void;
327
- /**
328
- * Pause processing new tasks (currently running tasks continue)
329
- *
330
- * @example
331
- * ```typescript
332
- * const queue = createAsyncQueue();
333
- *
334
- * // Start some tasks
335
- * queue.resultifyAdd(async () => longRunningTask1());
336
- * queue.resultifyAdd(async () => longRunningTask2());
337
- *
338
- * // Pause before more tasks are picked up
339
- * queue.pause();
340
- *
341
- * // Later, resume processing
342
- * queue.resume();
343
- * ```;
344
- */
345
- pause(): void;
346
- /** Resume processing tasks after pause */
347
- resume(): void;
348
- /**
349
- * Reset the queue after being stopped, allowing new tasks to be processed
350
- *
351
- * This clears the stopped state and error reason, and resumes processing any
352
- * remaining queued tasks if autoStart was enabled.
353
- *
354
- * @example
355
- * ```typescript
356
- * const queue = createAsyncQueue({ stopOnError: true });
357
- *
358
- * // Add tasks that will cause the queue to stop
359
- * queue.resultifyAdd(async () => { throw new Error('fail'); });
360
- * queue.resultifyAdd(async () => 'remaining task');
361
- *
362
- * await queue.onIdle();
363
- *
364
- * if (queue.isStopped) {
365
- * console.log(`Queue stopped, ${queue.size} tasks remaining`);
366
- *
367
- * // Reset and process remaining tasks
368
- * queue.reset();
369
- * await queue.onIdle();
370
- * }
371
- * ```
372
- */
373
- reset(): void;
374
- /** Whether the queue is stopped due to an error */
375
- get isStopped(): boolean;
376
- /** Whether the queue is currently paused */
377
- get isPaused(): boolean;
378
- /** Whether the queue has been started (relevant for autoStart: false) */
379
- get isStarted(): boolean;
380
- /** The error that caused the queue to stop (if any) */
381
- get stoppedReason(): Error | undefined;
382
- }
383
- /** AddOptions variant that requires metadata to be provided */
384
- type AddOptionsWithId<I, T, E extends ResultValidErrors> = Omit<AddOptions<I, T, E>, 'meta'> & {
385
- meta: I;
386
- };
387
- /**
388
- * AsyncQueue variant that requires metadata for all tasks
389
- *
390
- * This class enforces that every task must include metadata, which is useful
391
- * when you need to track or identify tasks consistently.
392
- *
393
- * @example
394
- * ```typescript
395
- * interface TaskMeta {
396
- * id: string;
397
- * priority: number;
398
- * }
399
- *
400
- * const queue = createAsyncQueueWithMeta<string, TaskMeta>({ concurrency: 2 });
401
- *
402
- * queue.resultifyAdd(
403
- * async () => processImportantTask(),
404
- * { meta: { id: 'task-1', priority: 1 } }
405
- * );
406
- *
407
- * // Listen to events with metadata
408
- * queue.events.on('complete', (event) => {
409
- * console.log(`Task ${event.payload.meta.id} completed`);
410
- * });
411
- * ```
412
- *
413
- * @template T - The type of value returned by successful tasks
414
- * @template I - The type of metadata (required for all tasks)
415
- * @template E - The type of errors that tasks can produce
416
- */
417
- declare class AsyncQueueWithMeta<T, I, E extends ResultValidErrors = Error> extends AsyncQueue<T, E, I> {
418
- constructor(options?: AsyncQueueOptions);
419
- add(fn: (ctx: RunCtx<I>) => Promise<Result<T, E>> | Result<T, E>, options: AddOptionsWithId<I, T, E>): Promise<Result<T, E | Error>>;
420
- resultifyAdd(fn: (ctx: RunCtx<I>) => Promise<T> | T, options: AddOptionsWithId<I, T, E>): Promise<Result<T, E | Error>>;
421
- }
422
- /**
423
- * Create a new AsyncQueue instance
424
- *
425
- * @example
426
- * Basic Queue
427
- * ```typescript
428
- * const queue = createAsyncQueue<string>({ concurrency: 3 });
429
- * ```
430
- *
431
- * @example
432
- * Error Handling Queue
433
- * ```typescript
434
- * const queue = createAsyncQueue<string>({
435
- * concurrency: 2,
436
- * stopOnError: true,
437
- * rejectPendingOnError: true
438
- * });
439
- * ```
440
- *
441
- * @example
442
- * Lazy Start Queue
443
- * ```typescript
444
- * const queue = createAsyncQueue<string>({
445
- * autoStart: false,
446
- * concurrency: 1
447
- * });
448
- * ```
449
- *
450
- * @template T - The type of value returned by successful tasks
451
- * @template E - The type of errors that tasks can produce (defaults to Error)
452
- * @param options - Configuration options for the queue
453
- * @returns A new AsyncQueue instance
454
- */
455
- declare function createAsyncQueue<T, E extends ResultValidErrors = Error>(options?: AsyncQueueOptions): AsyncQueue<T, E>;
456
-
457
- /**
458
- * Create a new AsyncQueueWithMeta instance that requires metadata for all tasks
459
- *
460
- * @example
461
- * ```typescript
462
- * interface TaskInfo {
463
- * taskId: string;
464
- * userId: string;
465
- * }
466
- *
467
- * const queue = createAsyncQueueWithMeta<ProcessResult, TaskInfo>({
468
- * concurrency: 5
469
- * });
470
- *
471
- * queue.resultifyAdd(
472
- * async (ctx) => {
473
- * console.log(`Processing task ${ctx.meta.taskId} for user ${ctx.meta.userId}`);
474
- * return await processUserTask(ctx.meta.userId);
475
- * },
476
- * { meta: { taskId: '123', userId: 'user456' } }
477
- * );
478
- * ```
479
- *
480
- * @template T - The type of value returned by successful tasks
481
- * @template I - The type of metadata (required for all tasks)
482
- * @template E - The type of errors that tasks can produce (defaults to Error)
483
- * @param options - Configuration options for the queue
484
- * @returns A new AsyncQueueWithMeta instance
485
- */
486
- declare function createAsyncQueueWithMeta<T, I, E extends ResultValidErrors = Error>(options?: AsyncQueueOptions): AsyncQueueWithMeta<T, I, E>;
487
-
488
- export { AsyncQueue, AsyncQueueWithMeta, createAsyncQueue, createAsyncQueueWithMeta };