effect 2.0.0-next.56 → 2.0.0-next.57

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 (887) hide show
  1. package/dist/cjs/BigDecimal.js +9 -9
  2. package/dist/cjs/BigDecimal.js.map +1 -1
  3. package/dist/cjs/BigInt.js.map +1 -1
  4. package/dist/cjs/Boolean.js.map +1 -1
  5. package/dist/cjs/Brand.js.map +1 -1
  6. package/dist/cjs/Cache.js.map +1 -1
  7. package/dist/cjs/Cause.js.map +1 -1
  8. package/dist/cjs/Channel.js.map +1 -1
  9. package/dist/cjs/Chunk.js +38 -29
  10. package/dist/cjs/Chunk.js.map +1 -1
  11. package/dist/cjs/Config.js +3 -3
  12. package/dist/cjs/Config.js.map +1 -1
  13. package/dist/cjs/Context.js.map +1 -1
  14. package/dist/cjs/Data.js.map +1 -1
  15. package/dist/cjs/Deferred.js.map +1 -1
  16. package/dist/cjs/Differ.js.map +1 -1
  17. package/dist/cjs/Duration.js +45 -2
  18. package/dist/cjs/Duration.js.map +1 -1
  19. package/dist/cjs/Effect.js +6 -11
  20. package/dist/cjs/Effect.js.map +1 -1
  21. package/dist/cjs/Either.js +36 -7
  22. package/dist/cjs/Either.js.map +1 -1
  23. package/dist/cjs/Equal.js.map +1 -1
  24. package/dist/cjs/Equivalence.js +1 -1
  25. package/dist/cjs/Equivalence.js.map +1 -1
  26. package/dist/cjs/Fiber.js.map +1 -1
  27. package/dist/cjs/FiberRef.js +6 -1
  28. package/dist/cjs/FiberRef.js.map +1 -1
  29. package/dist/cjs/Function.js.map +1 -1
  30. package/dist/cjs/GlobalValue.js.map +1 -1
  31. package/dist/cjs/GroupBy.js.map +1 -1
  32. package/dist/cjs/Hash.js.map +1 -1
  33. package/dist/cjs/Inspectable.js +4 -6
  34. package/dist/cjs/Inspectable.js.map +1 -1
  35. package/dist/cjs/KeyedPool.js.map +1 -1
  36. package/dist/cjs/Layer.js +9 -29
  37. package/dist/cjs/Layer.js.map +1 -1
  38. package/dist/cjs/List.js +25 -22
  39. package/dist/cjs/List.js.map +1 -1
  40. package/dist/cjs/LogLevel.js.map +1 -1
  41. package/dist/cjs/Logger.js.map +1 -1
  42. package/dist/cjs/Match.js.map +1 -1
  43. package/dist/cjs/MergeDecision.js.map +1 -1
  44. package/dist/cjs/Metric.js.map +1 -1
  45. package/dist/cjs/MetricHook.js.map +1 -1
  46. package/dist/cjs/MetricKey.js.map +1 -1
  47. package/dist/cjs/MetricKeyType.js.map +1 -1
  48. package/dist/cjs/MetricPair.js.map +1 -1
  49. package/dist/cjs/MetricState.js.map +1 -1
  50. package/dist/cjs/MutableHashMap.js +1 -1
  51. package/dist/cjs/MutableHashMap.js.map +1 -1
  52. package/dist/cjs/MutableHashSet.js +1 -1
  53. package/dist/cjs/MutableHashSet.js.map +1 -1
  54. package/dist/cjs/MutableList.js +1 -1
  55. package/dist/cjs/MutableList.js.map +1 -1
  56. package/dist/cjs/MutableQueue.js +1 -1
  57. package/dist/cjs/MutableQueue.js.map +1 -1
  58. package/dist/cjs/MutableRef.js +1 -1
  59. package/dist/cjs/MutableRef.js.map +1 -1
  60. package/dist/cjs/NonEmptyIterable.js.map +1 -1
  61. package/dist/cjs/Number.js.map +1 -1
  62. package/dist/cjs/Option.js +19 -12
  63. package/dist/cjs/Option.js.map +1 -1
  64. package/dist/cjs/Order.js +1 -1
  65. package/dist/cjs/Order.js.map +1 -1
  66. package/dist/cjs/Ordering.js.map +1 -1
  67. package/dist/cjs/Pipeable.js.map +1 -1
  68. package/dist/cjs/Pool.js +15 -17
  69. package/dist/cjs/Pool.js.map +1 -1
  70. package/dist/cjs/Predicate.js.map +1 -1
  71. package/dist/cjs/PrimaryKey.js +7 -1
  72. package/dist/cjs/PrimaryKey.js.map +1 -1
  73. package/dist/cjs/Queue.js.map +1 -1
  74. package/dist/cjs/ReadonlyArray.js +200 -187
  75. package/dist/cjs/ReadonlyArray.js.map +1 -1
  76. package/dist/cjs/ReadonlyRecord.js +59 -6
  77. package/dist/cjs/ReadonlyRecord.js.map +1 -1
  78. package/dist/cjs/RedBlackTree.js.map +1 -1
  79. package/dist/cjs/Ref.js.map +1 -1
  80. package/dist/cjs/Reloadable.js.map +1 -1
  81. package/dist/cjs/Request.js +8 -1
  82. package/dist/cjs/Request.js.map +1 -1
  83. package/dist/cjs/RequestBlock.js +5 -24
  84. package/dist/cjs/RequestBlock.js.map +1 -1
  85. package/dist/cjs/RequestResolver.js.map +1 -1
  86. package/dist/cjs/Resource.js.map +1 -1
  87. package/dist/cjs/STM.js.map +1 -1
  88. package/dist/cjs/Schedule.js.map +1 -1
  89. package/dist/cjs/Scheduler.js.map +1 -1
  90. package/dist/cjs/ScopedCache.js.map +1 -1
  91. package/dist/cjs/ScopedRef.js.map +1 -1
  92. package/dist/cjs/Sink.js.map +1 -1
  93. package/dist/cjs/SortedMap.js +1 -1
  94. package/dist/cjs/SortedMap.js.map +1 -1
  95. package/dist/cjs/SortedSet.js +1 -1
  96. package/dist/cjs/SortedSet.js.map +1 -1
  97. package/dist/cjs/Stream.js.map +1 -1
  98. package/dist/cjs/Streamable.js +3 -0
  99. package/dist/cjs/Streamable.js.map +1 -1
  100. package/dist/cjs/String.js.map +1 -1
  101. package/dist/cjs/Struct.js.map +1 -1
  102. package/dist/cjs/SubscriptionRef.js.map +1 -1
  103. package/dist/cjs/Supervisor.js.map +1 -1
  104. package/dist/cjs/SynchronizedRef.js.map +1 -1
  105. package/dist/cjs/TArray.js.map +1 -1
  106. package/dist/cjs/TDeferred.js.map +1 -1
  107. package/dist/cjs/TMap.js.map +1 -1
  108. package/dist/cjs/TPriorityQueue.js.map +1 -1
  109. package/dist/cjs/TPubSub.js.map +1 -1
  110. package/dist/cjs/TQueue.js.map +1 -1
  111. package/dist/cjs/TRef.js.map +1 -1
  112. package/dist/cjs/TSet.js.map +1 -1
  113. package/dist/cjs/Take.js.map +1 -1
  114. package/dist/cjs/TestAnnotation.js.map +1 -1
  115. package/dist/cjs/TestAnnotationMap.js.map +1 -1
  116. package/dist/cjs/TestAnnotations.js.map +1 -1
  117. package/dist/cjs/TestClock.js.map +1 -1
  118. package/dist/cjs/TestContext.js +2 -2
  119. package/dist/cjs/TestContext.js.map +1 -1
  120. package/dist/cjs/UpstreamPullRequest.js.map +1 -1
  121. package/dist/cjs/UpstreamPullStrategy.js.map +1 -1
  122. package/dist/cjs/Utils.js.map +1 -1
  123. package/dist/cjs/internal/Iterable.js.map +1 -1
  124. package/dist/cjs/internal/blockedRequests.js +3 -2
  125. package/dist/cjs/internal/blockedRequests.js.map +1 -1
  126. package/dist/cjs/internal/cache.js +3 -0
  127. package/dist/cjs/internal/cache.js.map +1 -1
  128. package/dist/cjs/internal/cause.js +1 -1
  129. package/dist/cjs/internal/cause.js.map +1 -1
  130. package/dist/cjs/internal/channel/channelExecutor.js.map +1 -1
  131. package/dist/cjs/internal/channel/channelState.js +2 -1
  132. package/dist/cjs/internal/channel/channelState.js.map +1 -1
  133. package/dist/cjs/internal/channel/childExecutorDecision.js.map +1 -1
  134. package/dist/cjs/internal/channel/continuation.js +9 -1
  135. package/dist/cjs/internal/channel/continuation.js.map +1 -1
  136. package/dist/cjs/internal/channel/mergeDecision.js.map +1 -1
  137. package/dist/cjs/internal/channel/mergeState.js.map +1 -1
  138. package/dist/cjs/internal/channel/mergeStrategy.js.map +1 -1
  139. package/dist/cjs/internal/channel/singleProducerAsyncInput.js.map +1 -1
  140. package/dist/cjs/internal/channel/subexecutor.js.map +1 -1
  141. package/dist/cjs/internal/channel/upstreamPullRequest.js +1 -1
  142. package/dist/cjs/internal/channel/upstreamPullRequest.js.map +1 -1
  143. package/dist/cjs/internal/channel/upstreamPullStrategy.js +1 -1
  144. package/dist/cjs/internal/channel/upstreamPullStrategy.js.map +1 -1
  145. package/dist/cjs/internal/channel.js.map +1 -1
  146. package/dist/cjs/internal/clock.js.map +1 -1
  147. package/dist/cjs/internal/concurrency.js.map +1 -1
  148. package/dist/cjs/internal/config.js +16 -24
  149. package/dist/cjs/internal/config.js.map +1 -1
  150. package/dist/cjs/internal/configError.js +2 -2
  151. package/dist/cjs/internal/configError.js.map +1 -1
  152. package/dist/cjs/internal/configProvider/pathPatch.js.map +1 -1
  153. package/dist/cjs/internal/configProvider.js +5 -3
  154. package/dist/cjs/internal/configProvider.js.map +1 -1
  155. package/dist/cjs/internal/configSecret.js.map +1 -1
  156. package/dist/cjs/internal/context.js +5 -5
  157. package/dist/cjs/internal/context.js.map +1 -1
  158. package/dist/cjs/internal/core-effect.js +13 -9
  159. package/dist/cjs/internal/core-effect.js.map +1 -1
  160. package/dist/cjs/internal/core-stream.js +7 -1
  161. package/dist/cjs/internal/core-stream.js.map +1 -1
  162. package/dist/cjs/internal/core.js +47 -77
  163. package/dist/cjs/internal/core.js.map +1 -1
  164. package/dist/cjs/internal/data.js.map +1 -1
  165. package/dist/cjs/internal/dataSource.js.map +1 -1
  166. package/dist/cjs/internal/deferred.js +2 -0
  167. package/dist/cjs/internal/deferred.js.map +1 -1
  168. package/dist/cjs/internal/differ/chunkPatch.js.map +1 -1
  169. package/dist/cjs/internal/differ/contextPatch.js.map +1 -1
  170. package/dist/cjs/internal/differ/hashMapPatch.js.map +1 -1
  171. package/dist/cjs/internal/differ/hashSetPatch.js.map +1 -1
  172. package/dist/cjs/internal/differ/orPatch.js.map +1 -1
  173. package/dist/cjs/internal/differ.js.map +1 -1
  174. package/dist/cjs/internal/effect/circular.js +1 -0
  175. package/dist/cjs/internal/effect/circular.js.map +1 -1
  176. package/dist/cjs/internal/effectable.js +18 -5
  177. package/dist/cjs/internal/effectable.js.map +1 -1
  178. package/dist/cjs/internal/either.js +1 -1
  179. package/dist/cjs/internal/either.js.map +1 -1
  180. package/dist/cjs/internal/encoding/base64.js.map +1 -1
  181. package/dist/cjs/internal/encoding/base64Url.js.map +1 -1
  182. package/dist/cjs/internal/encoding/common.js.map +1 -1
  183. package/dist/cjs/internal/encoding/hex.js.map +1 -1
  184. package/dist/cjs/internal/executionStrategy.js.map +1 -1
  185. package/dist/cjs/internal/fiber.js +2 -0
  186. package/dist/cjs/internal/fiber.js.map +1 -1
  187. package/dist/cjs/internal/fiberId.js +3 -3
  188. package/dist/cjs/internal/fiberId.js.map +1 -1
  189. package/dist/cjs/internal/fiberRefs/patch.js.map +1 -1
  190. package/dist/cjs/internal/fiberRefs.js.map +1 -1
  191. package/dist/cjs/internal/fiberRuntime.js +172 -208
  192. package/dist/cjs/internal/fiberRuntime.js.map +1 -1
  193. package/dist/cjs/internal/groupBy.js +4 -1
  194. package/dist/cjs/internal/groupBy.js.map +1 -1
  195. package/dist/cjs/internal/hashMap/array.js.map +1 -1
  196. package/dist/cjs/internal/hashMap/node.js.map +1 -1
  197. package/dist/cjs/internal/hashMap.js +1 -1
  198. package/dist/cjs/internal/hashMap.js.map +1 -1
  199. package/dist/cjs/internal/hashSet.js +1 -1
  200. package/dist/cjs/internal/hashSet.js.map +1 -1
  201. package/dist/cjs/internal/keyedPool.js +3 -0
  202. package/dist/cjs/internal/keyedPool.js.map +1 -1
  203. package/dist/cjs/internal/layer.js +23 -53
  204. package/dist/cjs/internal/layer.js.map +1 -1
  205. package/dist/cjs/internal/logger.js +2 -1
  206. package/dist/cjs/internal/logger.js.map +1 -1
  207. package/dist/cjs/internal/matcher.js.map +1 -1
  208. package/dist/cjs/internal/metric/hook.js +2 -1
  209. package/dist/cjs/internal/metric/hook.js.map +1 -1
  210. package/dist/cjs/internal/metric/key.js +1 -1
  211. package/dist/cjs/internal/metric/key.js.map +1 -1
  212. package/dist/cjs/internal/metric/keyType.js +2 -1
  213. package/dist/cjs/internal/metric/keyType.js.map +1 -1
  214. package/dist/cjs/internal/metric/pair.js +1 -1
  215. package/dist/cjs/internal/metric/pair.js.map +1 -1
  216. package/dist/cjs/internal/metric/polling.js.map +1 -1
  217. package/dist/cjs/internal/metric/registry.js.map +1 -1
  218. package/dist/cjs/internal/metric/state.js +1 -1
  219. package/dist/cjs/internal/metric/state.js.map +1 -1
  220. package/dist/cjs/internal/metric.js +7 -5
  221. package/dist/cjs/internal/metric.js.map +1 -1
  222. package/dist/cjs/internal/opCodes/layer.js +4 -4
  223. package/dist/cjs/internal/opCodes/layer.js.map +1 -1
  224. package/dist/cjs/internal/option.js +1 -1
  225. package/dist/cjs/internal/option.js.map +1 -1
  226. package/dist/cjs/internal/pool.js +2 -0
  227. package/dist/cjs/internal/pool.js.map +1 -1
  228. package/dist/cjs/internal/pubsub.js +1 -1
  229. package/dist/cjs/internal/pubsub.js.map +1 -1
  230. package/dist/cjs/internal/query.js +1 -1
  231. package/dist/cjs/internal/query.js.map +1 -1
  232. package/dist/cjs/internal/queue.js +6 -4
  233. package/dist/cjs/internal/queue.js.map +1 -1
  234. package/dist/cjs/internal/random.js.map +1 -1
  235. package/dist/cjs/internal/redBlackTree/iterator.js.map +1 -1
  236. package/dist/cjs/internal/redBlackTree.js +3 -1
  237. package/dist/cjs/internal/redBlackTree.js.map +1 -1
  238. package/dist/cjs/internal/ref.js +1 -0
  239. package/dist/cjs/internal/ref.js.map +1 -1
  240. package/dist/cjs/internal/reloadable.js +1 -1
  241. package/dist/cjs/internal/reloadable.js.map +1 -1
  242. package/dist/cjs/internal/request.js +5 -2
  243. package/dist/cjs/internal/request.js.map +1 -1
  244. package/dist/cjs/internal/resource.js +2 -1
  245. package/dist/cjs/internal/resource.js.map +1 -1
  246. package/dist/cjs/internal/ringBuffer.js.map +1 -1
  247. package/dist/cjs/internal/runtime.js +1 -1
  248. package/dist/cjs/internal/runtime.js.map +1 -1
  249. package/dist/cjs/internal/runtimeFlags.js.map +1 -1
  250. package/dist/cjs/internal/schedule/interval.js.map +1 -1
  251. package/dist/cjs/internal/schedule/intervals.js.map +1 -1
  252. package/dist/cjs/internal/schedule.js +6 -1
  253. package/dist/cjs/internal/schedule.js.map +1 -1
  254. package/dist/cjs/internal/scopedCache.js +5 -2
  255. package/dist/cjs/internal/scopedCache.js.map +1 -1
  256. package/dist/cjs/internal/scopedRef.js +1 -0
  257. package/dist/cjs/internal/scopedRef.js.map +1 -1
  258. package/dist/cjs/internal/sink.js +5 -1
  259. package/dist/cjs/internal/sink.js.map +1 -1
  260. package/dist/cjs/internal/stm/core.js +3 -1
  261. package/dist/cjs/internal/stm/core.js.map +1 -1
  262. package/dist/cjs/internal/stm/stm/journal.js.map +1 -1
  263. package/dist/cjs/internal/stm/stm/stmState.js.map +1 -1
  264. package/dist/cjs/internal/stm/stm/tExit.js +2 -1
  265. package/dist/cjs/internal/stm/stm/tExit.js.map +1 -1
  266. package/dist/cjs/internal/stm/stm.js.map +1 -1
  267. package/dist/cjs/internal/stm/tArray.js +1 -1
  268. package/dist/cjs/internal/stm/tArray.js.map +1 -1
  269. package/dist/cjs/internal/stm/tMap.js +2 -1
  270. package/dist/cjs/internal/stm/tMap.js.map +1 -1
  271. package/dist/cjs/internal/stm/tPriorityQueue.js +1 -1
  272. package/dist/cjs/internal/stm/tPriorityQueue.js.map +1 -1
  273. package/dist/cjs/internal/stm/tPubSub.js.map +1 -1
  274. package/dist/cjs/internal/stm/tQueue.js +2 -0
  275. package/dist/cjs/internal/stm/tQueue.js.map +1 -1
  276. package/dist/cjs/internal/stm/tRandom.js.map +1 -1
  277. package/dist/cjs/internal/stm/tReentrantLock.js.map +1 -1
  278. package/dist/cjs/internal/stm/tRef.js +1 -1
  279. package/dist/cjs/internal/stm/tRef.js.map +1 -1
  280. package/dist/cjs/internal/stm/tSemaphore.js.map +1 -1
  281. package/dist/cjs/internal/stm/tSet.js +1 -1
  282. package/dist/cjs/internal/stm/tSet.js.map +1 -1
  283. package/dist/cjs/internal/stream/haltStrategy.js.map +1 -1
  284. package/dist/cjs/internal/stream/handoff.js +1 -1
  285. package/dist/cjs/internal/stream/handoff.js.map +1 -1
  286. package/dist/cjs/internal/stream.js +1 -1
  287. package/dist/cjs/internal/stream.js.map +1 -1
  288. package/dist/cjs/internal/string-utils.js.map +1 -1
  289. package/dist/cjs/internal/subscriptionRef.js +1 -1
  290. package/dist/cjs/internal/subscriptionRef.js.map +1 -1
  291. package/dist/cjs/internal/supervisor/patch.js.map +1 -1
  292. package/dist/cjs/internal/supervisor.js +1 -0
  293. package/dist/cjs/internal/supervisor.js.map +1 -1
  294. package/dist/cjs/internal/synchronizedRef.js.map +1 -1
  295. package/dist/cjs/internal/take.js +2 -1
  296. package/dist/cjs/internal/take.js.map +1 -1
  297. package/dist/cjs/internal/version.js +1 -1
  298. package/dist/dts/BigDecimal.d.ts +5 -5
  299. package/dist/dts/BigDecimal.d.ts.map +1 -1
  300. package/dist/dts/Cache.d.ts +4 -3
  301. package/dist/dts/Cache.d.ts.map +1 -1
  302. package/dist/dts/Cause.d.ts +2 -1
  303. package/dist/dts/Cause.d.ts.map +1 -1
  304. package/dist/dts/Channel.d.ts +8 -7
  305. package/dist/dts/Channel.d.ts.map +1 -1
  306. package/dist/dts/Chunk.d.ts +55 -45
  307. package/dist/dts/Chunk.d.ts.map +1 -1
  308. package/dist/dts/Config.d.ts +16 -15
  309. package/dist/dts/Config.d.ts.map +1 -1
  310. package/dist/dts/Context.d.ts +4 -3
  311. package/dist/dts/Context.d.ts.map +1 -1
  312. package/dist/dts/Data.d.ts +4 -4
  313. package/dist/dts/Data.d.ts.map +1 -1
  314. package/dist/dts/Deferred.d.ts +3 -2
  315. package/dist/dts/Deferred.d.ts.map +1 -1
  316. package/dist/dts/Differ.d.ts +15 -14
  317. package/dist/dts/Differ.d.ts.map +1 -1
  318. package/dist/dts/Duration.d.ts +11 -0
  319. package/dist/dts/Duration.d.ts.map +1 -1
  320. package/dist/dts/Effect.d.ts +30 -27
  321. package/dist/dts/Effect.d.ts.map +1 -1
  322. package/dist/dts/Either.d.ts +46 -10
  323. package/dist/dts/Either.d.ts.map +1 -1
  324. package/dist/dts/Equivalence.d.ts +1 -1
  325. package/dist/dts/Fiber.d.ts +5 -4
  326. package/dist/dts/Fiber.d.ts.map +1 -1
  327. package/dist/dts/FiberRef.d.ts +7 -1
  328. package/dist/dts/FiberRef.d.ts.map +1 -1
  329. package/dist/dts/GroupBy.d.ts +5 -4
  330. package/dist/dts/GroupBy.d.ts.map +1 -1
  331. package/dist/dts/HKT.d.ts +5 -4
  332. package/dist/dts/HKT.d.ts.map +1 -1
  333. package/dist/dts/Inspectable.d.ts +0 -4
  334. package/dist/dts/Inspectable.d.ts.map +1 -1
  335. package/dist/dts/KeyedPool.d.ts +4 -3
  336. package/dist/dts/KeyedPool.d.ts.map +1 -1
  337. package/dist/dts/Layer.d.ts +14 -39
  338. package/dist/dts/Layer.d.ts.map +1 -1
  339. package/dist/dts/List.d.ts +32 -33
  340. package/dist/dts/List.d.ts.map +1 -1
  341. package/dist/dts/Logger.d.ts +3 -2
  342. package/dist/dts/Logger.d.ts.map +1 -1
  343. package/dist/dts/Match.d.ts +20 -8
  344. package/dist/dts/Match.d.ts.map +1 -1
  345. package/dist/dts/MergeDecision.d.ts +6 -5
  346. package/dist/dts/MergeDecision.d.ts.map +1 -1
  347. package/dist/dts/Metric.d.ts +6 -5
  348. package/dist/dts/Metric.d.ts.map +1 -1
  349. package/dist/dts/MetricHook.d.ts +3 -2
  350. package/dist/dts/MetricHook.d.ts.map +1 -1
  351. package/dist/dts/MetricKey.d.ts +2 -1
  352. package/dist/dts/MetricKey.d.ts.map +1 -1
  353. package/dist/dts/MetricKeyType.d.ts +3 -2
  354. package/dist/dts/MetricKeyType.d.ts.map +1 -1
  355. package/dist/dts/MetricPair.d.ts +2 -1
  356. package/dist/dts/MetricPair.d.ts.map +1 -1
  357. package/dist/dts/MetricState.d.ts +2 -1
  358. package/dist/dts/MetricState.d.ts.map +1 -1
  359. package/dist/dts/MutableHashMap.d.ts.map +1 -1
  360. package/dist/dts/MutableHashSet.d.ts.map +1 -1
  361. package/dist/dts/MutableQueue.d.ts.map +1 -1
  362. package/dist/dts/MutableRef.d.ts.map +1 -1
  363. package/dist/dts/Option.d.ts +26 -13
  364. package/dist/dts/Option.d.ts.map +1 -1
  365. package/dist/dts/Order.d.ts +1 -1
  366. package/dist/dts/Pool.d.ts +18 -19
  367. package/dist/dts/Pool.d.ts.map +1 -1
  368. package/dist/dts/PrimaryKey.d.ts +5 -0
  369. package/dist/dts/PrimaryKey.d.ts.map +1 -1
  370. package/dist/dts/Queue.d.ts +5 -4
  371. package/dist/dts/Queue.d.ts.map +1 -1
  372. package/dist/dts/ReadonlyArray.d.ts +134 -170
  373. package/dist/dts/ReadonlyArray.d.ts.map +1 -1
  374. package/dist/dts/ReadonlyRecord.d.ts +38 -5
  375. package/dist/dts/ReadonlyRecord.d.ts.map +1 -1
  376. package/dist/dts/RedBlackTree.d.ts +3 -2
  377. package/dist/dts/RedBlackTree.d.ts.map +1 -1
  378. package/dist/dts/Ref.d.ts +2 -1
  379. package/dist/dts/Ref.d.ts.map +1 -1
  380. package/dist/dts/Reloadable.d.ts +2 -1
  381. package/dist/dts/Reloadable.d.ts.map +1 -1
  382. package/dist/dts/Request.d.ts +14 -3
  383. package/dist/dts/Request.d.ts.map +1 -1
  384. package/dist/dts/RequestBlock.d.ts +17 -36
  385. package/dist/dts/RequestBlock.d.ts.map +1 -1
  386. package/dist/dts/RequestResolver.d.ts +3 -2
  387. package/dist/dts/RequestResolver.d.ts.map +1 -1
  388. package/dist/dts/Resource.d.ts +3 -2
  389. package/dist/dts/Resource.d.ts.map +1 -1
  390. package/dist/dts/STM.d.ts +4 -3
  391. package/dist/dts/STM.d.ts.map +1 -1
  392. package/dist/dts/Schedule.d.ts +7 -6
  393. package/dist/dts/Schedule.d.ts.map +1 -1
  394. package/dist/dts/ScopedCache.d.ts +4 -3
  395. package/dist/dts/ScopedCache.d.ts.map +1 -1
  396. package/dist/dts/ScopedRef.d.ts +2 -1
  397. package/dist/dts/ScopedRef.d.ts.map +1 -1
  398. package/dist/dts/Sink.d.ts +6 -5
  399. package/dist/dts/Sink.d.ts.map +1 -1
  400. package/dist/dts/SortedMap.d.ts +3 -2
  401. package/dist/dts/SortedMap.d.ts.map +1 -1
  402. package/dist/dts/SortedSet.d.ts +2 -1
  403. package/dist/dts/SortedSet.d.ts.map +1 -1
  404. package/dist/dts/Stream.d.ts +5 -4
  405. package/dist/dts/Stream.d.ts.map +1 -1
  406. package/dist/dts/Streamable.d.ts.map +1 -1
  407. package/dist/dts/SubscriptionRef.d.ts +2 -1
  408. package/dist/dts/SubscriptionRef.d.ts.map +1 -1
  409. package/dist/dts/Supervisor.d.ts +2 -1
  410. package/dist/dts/Supervisor.d.ts.map +1 -1
  411. package/dist/dts/SynchronizedRef.d.ts +2 -1
  412. package/dist/dts/SynchronizedRef.d.ts.map +1 -1
  413. package/dist/dts/TArray.d.ts +2 -1
  414. package/dist/dts/TArray.d.ts.map +1 -1
  415. package/dist/dts/TDeferred.d.ts +3 -2
  416. package/dist/dts/TDeferred.d.ts.map +1 -1
  417. package/dist/dts/TMap.d.ts +3 -2
  418. package/dist/dts/TMap.d.ts.map +1 -1
  419. package/dist/dts/TPriorityQueue.d.ts +2 -1
  420. package/dist/dts/TPriorityQueue.d.ts.map +1 -1
  421. package/dist/dts/TPubSub.d.ts +2 -1
  422. package/dist/dts/TPubSub.d.ts.map +1 -1
  423. package/dist/dts/TQueue.d.ts +3 -2
  424. package/dist/dts/TQueue.d.ts.map +1 -1
  425. package/dist/dts/TRef.d.ts +2 -1
  426. package/dist/dts/TRef.d.ts.map +1 -1
  427. package/dist/dts/TSet.d.ts +2 -1
  428. package/dist/dts/TSet.d.ts.map +1 -1
  429. package/dist/dts/Take.d.ts +3 -2
  430. package/dist/dts/Take.d.ts.map +1 -1
  431. package/dist/dts/TestAnnotation.d.ts +2 -1
  432. package/dist/dts/TestAnnotation.d.ts.map +1 -1
  433. package/dist/dts/TestContext.d.ts.map +1 -1
  434. package/dist/dts/Types.d.ts +21 -0
  435. package/dist/dts/Types.d.ts.map +1 -1
  436. package/dist/dts/UpstreamPullRequest.d.ts +2 -1
  437. package/dist/dts/UpstreamPullRequest.d.ts.map +1 -1
  438. package/dist/dts/UpstreamPullStrategy.d.ts +2 -1
  439. package/dist/dts/UpstreamPullStrategy.d.ts.map +1 -1
  440. package/dist/dts/Utils.d.ts +6 -5
  441. package/dist/dts/Utils.d.ts.map +1 -1
  442. package/dist/dts/internal/config.d.ts +1 -2
  443. package/dist/dts/internal/config.d.ts.map +1 -1
  444. package/dist/dts/internal/core-stream.d.ts.map +1 -1
  445. package/dist/dts/internal/logger.d.ts.map +1 -1
  446. package/dist/dts/internal/metric/keyType.d.ts.map +1 -1
  447. package/dist/dts/internal/version.d.ts +1 -1
  448. package/dist/esm/BigDecimal.js +7 -7
  449. package/dist/esm/BigDecimal.js.map +1 -1
  450. package/dist/esm/BigInt.js.map +1 -1
  451. package/dist/esm/Boolean.js.map +1 -1
  452. package/dist/esm/Brand.js.map +1 -1
  453. package/dist/esm/Cache.js.map +1 -1
  454. package/dist/esm/Cause.js.map +1 -1
  455. package/dist/esm/Channel.js.map +1 -1
  456. package/dist/esm/Chunk.js +38 -29
  457. package/dist/esm/Chunk.js.map +1 -1
  458. package/dist/esm/Config.js +3 -3
  459. package/dist/esm/Config.js.map +1 -1
  460. package/dist/esm/Context.js.map +1 -1
  461. package/dist/esm/Data.js.map +1 -1
  462. package/dist/esm/Deferred.js.map +1 -1
  463. package/dist/esm/Differ.js.map +1 -1
  464. package/dist/esm/Duration.js +44 -2
  465. package/dist/esm/Duration.js.map +1 -1
  466. package/dist/esm/Effect.js +2 -7
  467. package/dist/esm/Effect.js.map +1 -1
  468. package/dist/esm/Either.js +35 -6
  469. package/dist/esm/Either.js.map +1 -1
  470. package/dist/esm/Equal.js.map +1 -1
  471. package/dist/esm/Equivalence.js +1 -1
  472. package/dist/esm/Equivalence.js.map +1 -1
  473. package/dist/esm/Fiber.js.map +1 -1
  474. package/dist/esm/FiberRef.js +5 -0
  475. package/dist/esm/FiberRef.js.map +1 -1
  476. package/dist/esm/Function.js.map +1 -1
  477. package/dist/esm/GlobalValue.js.map +1 -1
  478. package/dist/esm/GroupBy.js.map +1 -1
  479. package/dist/esm/HKT.js +0 -3
  480. package/dist/esm/HKT.js.map +1 -1
  481. package/dist/esm/Hash.js.map +1 -1
  482. package/dist/esm/Inspectable.js +2 -4
  483. package/dist/esm/Inspectable.js.map +1 -1
  484. package/dist/esm/KeyedPool.js.map +1 -1
  485. package/dist/esm/Layer.js +8 -28
  486. package/dist/esm/Layer.js.map +1 -1
  487. package/dist/esm/List.js +25 -22
  488. package/dist/esm/List.js.map +1 -1
  489. package/dist/esm/LogLevel.js.map +1 -1
  490. package/dist/esm/Logger.js.map +1 -1
  491. package/dist/esm/Match.js.map +1 -1
  492. package/dist/esm/MergeDecision.js.map +1 -1
  493. package/dist/esm/Metric.js.map +1 -1
  494. package/dist/esm/MetricHook.js.map +1 -1
  495. package/dist/esm/MetricKey.js.map +1 -1
  496. package/dist/esm/MetricKeyType.js.map +1 -1
  497. package/dist/esm/MetricPair.js.map +1 -1
  498. package/dist/esm/MetricState.js.map +1 -1
  499. package/dist/esm/MutableHashMap.js +2 -2
  500. package/dist/esm/MutableHashMap.js.map +1 -1
  501. package/dist/esm/MutableHashSet.js +2 -2
  502. package/dist/esm/MutableHashSet.js.map +1 -1
  503. package/dist/esm/MutableList.js +2 -2
  504. package/dist/esm/MutableList.js.map +1 -1
  505. package/dist/esm/MutableQueue.js +2 -2
  506. package/dist/esm/MutableQueue.js.map +1 -1
  507. package/dist/esm/MutableRef.js +2 -2
  508. package/dist/esm/MutableRef.js.map +1 -1
  509. package/dist/esm/NonEmptyIterable.js.map +1 -1
  510. package/dist/esm/Number.js.map +1 -1
  511. package/dist/esm/Option.js +19 -12
  512. package/dist/esm/Option.js.map +1 -1
  513. package/dist/esm/Order.js +1 -1
  514. package/dist/esm/Order.js.map +1 -1
  515. package/dist/esm/Ordering.js.map +1 -1
  516. package/dist/esm/Pipeable.js.map +1 -1
  517. package/dist/esm/Pool.js +15 -17
  518. package/dist/esm/Pool.js.map +1 -1
  519. package/dist/esm/Predicate.js.map +1 -1
  520. package/dist/esm/PrimaryKey.js +5 -0
  521. package/dist/esm/PrimaryKey.js.map +1 -1
  522. package/dist/esm/Queue.js.map +1 -1
  523. package/dist/esm/ReadonlyArray.js +193 -177
  524. package/dist/esm/ReadonlyArray.js.map +1 -1
  525. package/dist/esm/ReadonlyRecord.js +56 -5
  526. package/dist/esm/ReadonlyRecord.js.map +1 -1
  527. package/dist/esm/RedBlackTree.js.map +1 -1
  528. package/dist/esm/Ref.js.map +1 -1
  529. package/dist/esm/Reloadable.js.map +1 -1
  530. package/dist/esm/Request.js +7 -0
  531. package/dist/esm/Request.js.map +1 -1
  532. package/dist/esm/RequestBlock.js +3 -22
  533. package/dist/esm/RequestBlock.js.map +1 -1
  534. package/dist/esm/RequestResolver.js.map +1 -1
  535. package/dist/esm/Resource.js.map +1 -1
  536. package/dist/esm/STM.js.map +1 -1
  537. package/dist/esm/Schedule.js.map +1 -1
  538. package/dist/esm/Scheduler.js.map +1 -1
  539. package/dist/esm/ScopedCache.js.map +1 -1
  540. package/dist/esm/ScopedRef.js.map +1 -1
  541. package/dist/esm/Sink.js.map +1 -1
  542. package/dist/esm/SortedMap.js +2 -2
  543. package/dist/esm/SortedMap.js.map +1 -1
  544. package/dist/esm/SortedSet.js +2 -2
  545. package/dist/esm/SortedSet.js.map +1 -1
  546. package/dist/esm/Stream.js.map +1 -1
  547. package/dist/esm/Streamable.js +3 -0
  548. package/dist/esm/Streamable.js.map +1 -1
  549. package/dist/esm/String.js.map +1 -1
  550. package/dist/esm/Struct.js.map +1 -1
  551. package/dist/esm/SubscriptionRef.js.map +1 -1
  552. package/dist/esm/Supervisor.js.map +1 -1
  553. package/dist/esm/SynchronizedRef.js.map +1 -1
  554. package/dist/esm/TArray.js.map +1 -1
  555. package/dist/esm/TDeferred.js.map +1 -1
  556. package/dist/esm/TMap.js.map +1 -1
  557. package/dist/esm/TPriorityQueue.js.map +1 -1
  558. package/dist/esm/TPubSub.js.map +1 -1
  559. package/dist/esm/TQueue.js.map +1 -1
  560. package/dist/esm/TRef.js.map +1 -1
  561. package/dist/esm/TSet.js.map +1 -1
  562. package/dist/esm/Take.js.map +1 -1
  563. package/dist/esm/TestAnnotation.js.map +1 -1
  564. package/dist/esm/TestAnnotationMap.js.map +1 -1
  565. package/dist/esm/TestAnnotations.js.map +1 -1
  566. package/dist/esm/TestClock.js.map +1 -1
  567. package/dist/esm/TestContext.js +2 -2
  568. package/dist/esm/TestContext.js.map +1 -1
  569. package/dist/esm/UpstreamPullRequest.js.map +1 -1
  570. package/dist/esm/UpstreamPullStrategy.js.map +1 -1
  571. package/dist/esm/Utils.js.map +1 -1
  572. package/dist/esm/internal/Iterable.js.map +1 -1
  573. package/dist/esm/internal/blockedRequests.js +3 -2
  574. package/dist/esm/internal/blockedRequests.js.map +1 -1
  575. package/dist/esm/internal/cache.js +3 -0
  576. package/dist/esm/internal/cache.js.map +1 -1
  577. package/dist/esm/internal/cause.js +1 -1
  578. package/dist/esm/internal/cause.js.map +1 -1
  579. package/dist/esm/internal/channel/channelExecutor.js.map +1 -1
  580. package/dist/esm/internal/channel/channelState.js +2 -1
  581. package/dist/esm/internal/channel/channelState.js.map +1 -1
  582. package/dist/esm/internal/channel/childExecutorDecision.js.map +1 -1
  583. package/dist/esm/internal/channel/continuation.js +9 -1
  584. package/dist/esm/internal/channel/continuation.js.map +1 -1
  585. package/dist/esm/internal/channel/mergeDecision.js.map +1 -1
  586. package/dist/esm/internal/channel/mergeState.js.map +1 -1
  587. package/dist/esm/internal/channel/mergeStrategy.js.map +1 -1
  588. package/dist/esm/internal/channel/singleProducerAsyncInput.js.map +1 -1
  589. package/dist/esm/internal/channel/subexecutor.js.map +1 -1
  590. package/dist/esm/internal/channel/upstreamPullRequest.js +1 -1
  591. package/dist/esm/internal/channel/upstreamPullRequest.js.map +1 -1
  592. package/dist/esm/internal/channel/upstreamPullStrategy.js +1 -1
  593. package/dist/esm/internal/channel/upstreamPullStrategy.js.map +1 -1
  594. package/dist/esm/internal/channel.js.map +1 -1
  595. package/dist/esm/internal/clock.js.map +1 -1
  596. package/dist/esm/internal/concurrency.js.map +1 -1
  597. package/dist/esm/internal/config.js +15 -22
  598. package/dist/esm/internal/config.js.map +1 -1
  599. package/dist/esm/internal/configError.js +2 -2
  600. package/dist/esm/internal/configError.js.map +1 -1
  601. package/dist/esm/internal/configProvider/pathPatch.js.map +1 -1
  602. package/dist/esm/internal/configProvider.js +5 -3
  603. package/dist/esm/internal/configProvider.js.map +1 -1
  604. package/dist/esm/internal/configSecret.js.map +1 -1
  605. package/dist/esm/internal/context.js +6 -6
  606. package/dist/esm/internal/context.js.map +1 -1
  607. package/dist/esm/internal/core-effect.js +13 -9
  608. package/dist/esm/internal/core-effect.js.map +1 -1
  609. package/dist/esm/internal/core-stream.js +7 -1
  610. package/dist/esm/internal/core-stream.js.map +1 -1
  611. package/dist/esm/internal/core.js +46 -75
  612. package/dist/esm/internal/core.js.map +1 -1
  613. package/dist/esm/internal/data.js.map +1 -1
  614. package/dist/esm/internal/dataSource.js.map +1 -1
  615. package/dist/esm/internal/deferred.js +2 -0
  616. package/dist/esm/internal/deferred.js.map +1 -1
  617. package/dist/esm/internal/differ/chunkPatch.js.map +1 -1
  618. package/dist/esm/internal/differ/contextPatch.js.map +1 -1
  619. package/dist/esm/internal/differ/hashMapPatch.js.map +1 -1
  620. package/dist/esm/internal/differ/hashSetPatch.js.map +1 -1
  621. package/dist/esm/internal/differ/orPatch.js.map +1 -1
  622. package/dist/esm/internal/differ.js.map +1 -1
  623. package/dist/esm/internal/effect/circular.js +1 -0
  624. package/dist/esm/internal/effect/circular.js.map +1 -1
  625. package/dist/esm/internal/effectable.js +17 -4
  626. package/dist/esm/internal/effectable.js.map +1 -1
  627. package/dist/esm/internal/either.js +2 -2
  628. package/dist/esm/internal/either.js.map +1 -1
  629. package/dist/esm/internal/encoding/base64.js.map +1 -1
  630. package/dist/esm/internal/encoding/base64Url.js.map +1 -1
  631. package/dist/esm/internal/encoding/common.js.map +1 -1
  632. package/dist/esm/internal/encoding/hex.js.map +1 -1
  633. package/dist/esm/internal/executionStrategy.js.map +1 -1
  634. package/dist/esm/internal/fiber.js +2 -0
  635. package/dist/esm/internal/fiber.js.map +1 -1
  636. package/dist/esm/internal/fiberId.js +4 -4
  637. package/dist/esm/internal/fiberId.js.map +1 -1
  638. package/dist/esm/internal/fiberRefs/patch.js.map +1 -1
  639. package/dist/esm/internal/fiberRefs.js.map +1 -1
  640. package/dist/esm/internal/fiberRuntime.js +169 -205
  641. package/dist/esm/internal/fiberRuntime.js.map +1 -1
  642. package/dist/esm/internal/groupBy.js +4 -1
  643. package/dist/esm/internal/groupBy.js.map +1 -1
  644. package/dist/esm/internal/hashMap/array.js.map +1 -1
  645. package/dist/esm/internal/hashMap/node.js.map +1 -1
  646. package/dist/esm/internal/hashMap.js +2 -2
  647. package/dist/esm/internal/hashMap.js.map +1 -1
  648. package/dist/esm/internal/hashSet.js +2 -2
  649. package/dist/esm/internal/hashSet.js.map +1 -1
  650. package/dist/esm/internal/keyedPool.js +3 -0
  651. package/dist/esm/internal/keyedPool.js.map +1 -1
  652. package/dist/esm/internal/layer.js +22 -52
  653. package/dist/esm/internal/layer.js.map +1 -1
  654. package/dist/esm/internal/logger.js +2 -1
  655. package/dist/esm/internal/logger.js.map +1 -1
  656. package/dist/esm/internal/matcher.js.map +1 -1
  657. package/dist/esm/internal/metric/hook.js +2 -1
  658. package/dist/esm/internal/metric/hook.js.map +1 -1
  659. package/dist/esm/internal/metric/key.js +1 -1
  660. package/dist/esm/internal/metric/key.js.map +1 -1
  661. package/dist/esm/internal/metric/keyType.js +2 -1
  662. package/dist/esm/internal/metric/keyType.js.map +1 -1
  663. package/dist/esm/internal/metric/pair.js +1 -1
  664. package/dist/esm/internal/metric/pair.js.map +1 -1
  665. package/dist/esm/internal/metric/polling.js.map +1 -1
  666. package/dist/esm/internal/metric/registry.js.map +1 -1
  667. package/dist/esm/internal/metric/state.js +1 -1
  668. package/dist/esm/internal/metric/state.js.map +1 -1
  669. package/dist/esm/internal/metric.js +7 -5
  670. package/dist/esm/internal/metric.js.map +1 -1
  671. package/dist/esm/internal/opCodes/layer.js +3 -3
  672. package/dist/esm/internal/opCodes/layer.js.map +1 -1
  673. package/dist/esm/internal/option.js +2 -2
  674. package/dist/esm/internal/option.js.map +1 -1
  675. package/dist/esm/internal/pool.js +2 -0
  676. package/dist/esm/internal/pool.js.map +1 -1
  677. package/dist/esm/internal/pubsub.js +1 -1
  678. package/dist/esm/internal/pubsub.js.map +1 -1
  679. package/dist/esm/internal/query.js +1 -1
  680. package/dist/esm/internal/query.js.map +1 -1
  681. package/dist/esm/internal/queue.js +6 -4
  682. package/dist/esm/internal/queue.js.map +1 -1
  683. package/dist/esm/internal/random.js.map +1 -1
  684. package/dist/esm/internal/redBlackTree/iterator.js.map +1 -1
  685. package/dist/esm/internal/redBlackTree.js +4 -2
  686. package/dist/esm/internal/redBlackTree.js.map +1 -1
  687. package/dist/esm/internal/ref.js +1 -0
  688. package/dist/esm/internal/ref.js.map +1 -1
  689. package/dist/esm/internal/reloadable.js +1 -1
  690. package/dist/esm/internal/reloadable.js.map +1 -1
  691. package/dist/esm/internal/request.js +4 -1
  692. package/dist/esm/internal/request.js.map +1 -1
  693. package/dist/esm/internal/resource.js +2 -1
  694. package/dist/esm/internal/resource.js.map +1 -1
  695. package/dist/esm/internal/ringBuffer.js.map +1 -1
  696. package/dist/esm/internal/runtime.js +2 -2
  697. package/dist/esm/internal/runtime.js.map +1 -1
  698. package/dist/esm/internal/runtimeFlags.js.map +1 -1
  699. package/dist/esm/internal/schedule/interval.js.map +1 -1
  700. package/dist/esm/internal/schedule/intervals.js.map +1 -1
  701. package/dist/esm/internal/schedule.js +6 -1
  702. package/dist/esm/internal/schedule.js.map +1 -1
  703. package/dist/esm/internal/scopedCache.js +5 -2
  704. package/dist/esm/internal/scopedCache.js.map +1 -1
  705. package/dist/esm/internal/scopedRef.js +1 -0
  706. package/dist/esm/internal/scopedRef.js.map +1 -1
  707. package/dist/esm/internal/sink.js +5 -1
  708. package/dist/esm/internal/sink.js.map +1 -1
  709. package/dist/esm/internal/stm/core.js +3 -1
  710. package/dist/esm/internal/stm/core.js.map +1 -1
  711. package/dist/esm/internal/stm/stm/journal.js.map +1 -1
  712. package/dist/esm/internal/stm/stm/stmState.js.map +1 -1
  713. package/dist/esm/internal/stm/stm/tExit.js +2 -1
  714. package/dist/esm/internal/stm/stm/tExit.js.map +1 -1
  715. package/dist/esm/internal/stm/stm.js.map +1 -1
  716. package/dist/esm/internal/stm/tArray.js +1 -1
  717. package/dist/esm/internal/stm/tArray.js.map +1 -1
  718. package/dist/esm/internal/stm/tMap.js +2 -1
  719. package/dist/esm/internal/stm/tMap.js.map +1 -1
  720. package/dist/esm/internal/stm/tPriorityQueue.js +1 -1
  721. package/dist/esm/internal/stm/tPriorityQueue.js.map +1 -1
  722. package/dist/esm/internal/stm/tPubSub.js.map +1 -1
  723. package/dist/esm/internal/stm/tQueue.js +2 -0
  724. package/dist/esm/internal/stm/tQueue.js.map +1 -1
  725. package/dist/esm/internal/stm/tRandom.js.map +1 -1
  726. package/dist/esm/internal/stm/tReentrantLock.js.map +1 -1
  727. package/dist/esm/internal/stm/tRef.js +1 -1
  728. package/dist/esm/internal/stm/tRef.js.map +1 -1
  729. package/dist/esm/internal/stm/tSemaphore.js.map +1 -1
  730. package/dist/esm/internal/stm/tSet.js +1 -1
  731. package/dist/esm/internal/stm/tSet.js.map +1 -1
  732. package/dist/esm/internal/stream/haltStrategy.js.map +1 -1
  733. package/dist/esm/internal/stream/handoff.js +1 -1
  734. package/dist/esm/internal/stream/handoff.js.map +1 -1
  735. package/dist/esm/internal/stream.js +1 -1
  736. package/dist/esm/internal/stream.js.map +1 -1
  737. package/dist/esm/internal/string-utils.js.map +1 -1
  738. package/dist/esm/internal/subscriptionRef.js +1 -1
  739. package/dist/esm/internal/subscriptionRef.js.map +1 -1
  740. package/dist/esm/internal/supervisor/patch.js.map +1 -1
  741. package/dist/esm/internal/supervisor.js +1 -0
  742. package/dist/esm/internal/supervisor.js.map +1 -1
  743. package/dist/esm/internal/synchronizedRef.js.map +1 -1
  744. package/dist/esm/internal/take.js +2 -1
  745. package/dist/esm/internal/take.js.map +1 -1
  746. package/dist/esm/internal/version.js +1 -1
  747. package/package.json +1 -1
  748. package/src/BigDecimal.ts +7 -7
  749. package/src/Cache.ts +4 -3
  750. package/src/Cause.ts +2 -1
  751. package/src/Channel.ts +8 -7
  752. package/src/Chunk.ts +66 -57
  753. package/src/Config.ts +16 -16
  754. package/src/Context.ts +4 -3
  755. package/src/Data.ts +4 -4
  756. package/src/Deferred.ts +3 -2
  757. package/src/Differ.ts +15 -14
  758. package/src/Duration.ts +54 -2
  759. package/src/Effect.ts +18 -29
  760. package/src/Either.ts +65 -10
  761. package/src/Equivalence.ts +1 -1
  762. package/src/Fiber.ts +5 -4
  763. package/src/FiberRef.ts +8 -1
  764. package/src/GroupBy.ts +5 -4
  765. package/src/HKT.ts +5 -4
  766. package/src/Inspectable.ts +2 -4
  767. package/src/KeyedPool.ts +4 -3
  768. package/src/Layer.ts +19 -56
  769. package/src/List.ts +44 -43
  770. package/src/Logger.ts +3 -2
  771. package/src/Match.ts +50 -38
  772. package/src/MergeDecision.ts +6 -5
  773. package/src/Metric.ts +8 -5
  774. package/src/MetricHook.ts +3 -2
  775. package/src/MetricKey.ts +2 -1
  776. package/src/MetricKeyType.ts +3 -2
  777. package/src/MetricPair.ts +2 -1
  778. package/src/MetricState.ts +2 -1
  779. package/src/MutableHashMap.ts +2 -2
  780. package/src/MutableHashSet.ts +2 -2
  781. package/src/MutableList.ts +2 -2
  782. package/src/MutableQueue.ts +2 -2
  783. package/src/MutableRef.ts +2 -2
  784. package/src/Option.ts +32 -14
  785. package/src/Order.ts +1 -1
  786. package/src/Pool.ts +18 -19
  787. package/src/PrimaryKey.ts +6 -0
  788. package/src/Queue.ts +5 -4
  789. package/src/ReadonlyArray.ts +300 -324
  790. package/src/ReadonlyRecord.ts +60 -5
  791. package/src/RedBlackTree.ts +3 -2
  792. package/src/Ref.ts +2 -1
  793. package/src/Reloadable.ts +2 -1
  794. package/src/Request.ts +15 -3
  795. package/src/RequestBlock.ts +22 -61
  796. package/src/RequestResolver.ts +3 -2
  797. package/src/Resource.ts +3 -2
  798. package/src/STM.ts +4 -3
  799. package/src/Schedule.ts +7 -6
  800. package/src/ScopedCache.ts +4 -3
  801. package/src/ScopedRef.ts +2 -1
  802. package/src/Sink.ts +6 -5
  803. package/src/SortedMap.ts +5 -4
  804. package/src/SortedSet.ts +4 -3
  805. package/src/Stream.ts +5 -4
  806. package/src/Streamable.ts +3 -0
  807. package/src/SubscriptionRef.ts +2 -1
  808. package/src/Supervisor.ts +2 -1
  809. package/src/SynchronizedRef.ts +2 -1
  810. package/src/TArray.ts +2 -1
  811. package/src/TDeferred.ts +3 -2
  812. package/src/TMap.ts +3 -2
  813. package/src/TPriorityQueue.ts +2 -1
  814. package/src/TPubSub.ts +2 -1
  815. package/src/TQueue.ts +3 -2
  816. package/src/TRef.ts +2 -1
  817. package/src/TSet.ts +2 -1
  818. package/src/Take.ts +3 -2
  819. package/src/TestAnnotation.ts +2 -2
  820. package/src/TestContext.ts +5 -4
  821. package/src/Types.ts +24 -0
  822. package/src/UpstreamPullRequest.ts +2 -1
  823. package/src/UpstreamPullStrategy.ts +2 -1
  824. package/src/Utils.ts +6 -5
  825. package/src/internal/blockedRequests.ts +78 -81
  826. package/src/internal/cache.ts +3 -0
  827. package/src/internal/cause.ts +1 -1
  828. package/src/internal/channel/channelState.ts +5 -3
  829. package/src/internal/channel/continuation.ts +19 -10
  830. package/src/internal/channel/upstreamPullRequest.ts +1 -1
  831. package/src/internal/channel/upstreamPullStrategy.ts +1 -1
  832. package/src/internal/config.ts +15 -23
  833. package/src/internal/configError.ts +2 -2
  834. package/src/internal/configProvider.ts +6 -4
  835. package/src/internal/context.ts +6 -6
  836. package/src/internal/core-effect.ts +27 -30
  837. package/src/internal/core-stream.ts +7 -1
  838. package/src/internal/core.ts +78 -118
  839. package/src/internal/deferred.ts +2 -0
  840. package/src/internal/effect/circular.ts +1 -0
  841. package/src/internal/effectable.ts +18 -4
  842. package/src/internal/either.ts +2 -2
  843. package/src/internal/fiber.ts +2 -0
  844. package/src/internal/fiberId.ts +4 -4
  845. package/src/internal/fiberRuntime.ts +228 -269
  846. package/src/internal/groupBy.ts +4 -1
  847. package/src/internal/hashMap.ts +2 -2
  848. package/src/internal/hashSet.ts +2 -2
  849. package/src/internal/keyedPool.ts +3 -0
  850. package/src/internal/layer.ts +29 -77
  851. package/src/internal/logger.ts +2 -1
  852. package/src/internal/metric/hook.ts +2 -1
  853. package/src/internal/metric/key.ts +1 -1
  854. package/src/internal/metric/keyType.ts +2 -1
  855. package/src/internal/metric/pair.ts +1 -1
  856. package/src/internal/metric/state.ts +1 -1
  857. package/src/internal/metric.ts +8 -5
  858. package/src/internal/opCodes/layer.ts +6 -6
  859. package/src/internal/option.ts +2 -2
  860. package/src/internal/pool.ts +2 -0
  861. package/src/internal/pubsub.ts +2 -1
  862. package/src/internal/query.ts +1 -1
  863. package/src/internal/queue.ts +18 -10
  864. package/src/internal/redBlackTree.ts +4 -2
  865. package/src/internal/ref.ts +1 -0
  866. package/src/internal/reloadable.ts +1 -1
  867. package/src/internal/request.ts +14 -1
  868. package/src/internal/resource.ts +2 -1
  869. package/src/internal/runtime.ts +2 -2
  870. package/src/internal/schedule.ts +6 -1
  871. package/src/internal/scopedCache.ts +7 -2
  872. package/src/internal/scopedRef.ts +1 -0
  873. package/src/internal/sink.ts +5 -1
  874. package/src/internal/stm/core.ts +3 -1
  875. package/src/internal/stm/stm/tExit.ts +5 -3
  876. package/src/internal/stm/tArray.ts +1 -1
  877. package/src/internal/stm/tMap.ts +2 -1
  878. package/src/internal/stm/tPriorityQueue.ts +1 -1
  879. package/src/internal/stm/tQueue.ts +2 -0
  880. package/src/internal/stm/tRef.ts +1 -1
  881. package/src/internal/stm/tSet.ts +1 -1
  882. package/src/internal/stream/handoff.ts +1 -1
  883. package/src/internal/stream.ts +2 -2
  884. package/src/internal/subscriptionRef.ts +1 -1
  885. package/src/internal/supervisor.ts +1 -0
  886. package/src/internal/take.ts +2 -1
  887. package/src/internal/version.ts +1 -1
@@ -113,9 +113,10 @@ const EvaluationSignalYieldNow = "Yield" as const
113
113
  /** @internal */
114
114
  type EvaluationSignalYieldNow = typeof EvaluationSignalYieldNow
115
115
 
116
- /** @internal */
117
- export const runtimeFiberVariance = {
116
+ const runtimeFiberVariance = {
117
+ /* c8 ignore next */
118
118
  _E: (_: never) => _,
119
+ /* c8 ignore next */
119
120
  _A: (_: never) => _
120
121
  }
121
122
 
@@ -135,10 +136,10 @@ const contOpSuccess = {
135
136
  },
136
137
  ["OnStep"]: (
137
138
  _: FiberRuntime<any, any>,
138
- cont: core.OnStep,
139
+ _cont: core.OnStep,
139
140
  value: unknown
140
141
  ) => {
141
- return cont.i1(core.exitSucceed(value))
142
+ return core.exitSucceed(core.exitSucceed(value))
142
143
  },
143
144
  [OpCodes.OP_ON_SUCCESS_AND_FAILURE]: (
144
145
  _: FiberRuntime<any, any>,
@@ -214,11 +215,11 @@ const drainQueueWhileRunningTable = {
214
215
  /**
215
216
  * Executes all requests, submitting requests to each data source in parallel.
216
217
  */
217
- const runBlockedRequests = <R>(self: RequestBlock.RequestBlock<R>) =>
218
+ const runBlockedRequests = (self: RequestBlock.RequestBlock) =>
218
219
  core.forEachSequentialDiscard(
219
220
  _RequestBlock.flatten(self),
220
221
  (requestsByRequestResolver) =>
221
- forEachParUnboundedDiscard(
222
+ forEachConcurrentDiscard(
222
223
  _RequestBlock.sequentialCollectionToChunk(requestsByRequestResolver),
223
224
  ([dataSource, sequential]) => {
224
225
  const map = new Map<Request<any, any>, Entry<any>>()
@@ -233,10 +234,17 @@ const runBlockedRequests = <R>(self: RequestBlock.RequestBlock<R>) =>
233
234
  map
234
235
  )
235
236
  },
237
+ false,
236
238
  false
237
239
  )
238
240
  )
239
241
 
242
+ /** @internal */
243
+ export interface Snapshot {
244
+ refs: FiberRefs.FiberRefs
245
+ flags: RuntimeFlags.RuntimeFlags
246
+ }
247
+
240
248
  /** @internal */
241
249
  export class FiberRuntime<in out E, in out A> implements Fiber.RuntimeFiber<E, A> {
242
250
  readonly [internalFiber.FiberTypeId] = internalFiber.fiberVariance
@@ -258,7 +266,7 @@ export class FiberRuntime<in out E, in out A> implements Fiber.RuntimeFiber<E, A
258
266
  private _asyncInterruptor: ((effect: Effect.Effect<any, any, any>) => any) | null = null
259
267
  private _asyncBlockingOn: FiberId.FiberId | null = null
260
268
  private _exitValue: Exit.Exit<E, A> | null = null
261
- private _steps: Array<boolean> = [false]
269
+ private _steps: Array<Snapshot> = []
262
270
  public _supervisor: Supervisor.Supervisor<any>
263
271
  public _scheduler: Scheduler
264
272
  private _tracer: Tracer.Tracer
@@ -461,6 +469,13 @@ export class FiberRuntime<in out E, in out A> implements Fiber.RuntimeFiber<E, A
461
469
  return core.sync(() => this.tell(FiberMessage.interruptSignal(internalCause.interrupt(fiberId))))
462
470
  }
463
471
 
472
+ /**
473
+ * In the background, interrupts the fiber as if interrupted from the specified fiber.
474
+ */
475
+ unsafeInterruptAsFork(fiberId: FiberId.FiberId) {
476
+ this.tell(FiberMessage.interruptSignal(internalCause.interrupt(fiberId)))
477
+ }
478
+
464
479
  /**
465
480
  * Adds an observer to the list of observers.
466
481
  *
@@ -987,17 +1002,14 @@ export class FiberRuntime<in out E, in out A> implements Fiber.RuntimeFiber<E, A
987
1002
  pushStack(cont: core.Continuation) {
988
1003
  this._stack.push(cont)
989
1004
  if (cont._op === "OnStep") {
990
- this._steps.push(true)
991
- }
992
- if (cont._op === "RevertFlags") {
993
- this._steps.push(false)
1005
+ this._steps.push({ refs: this.getFiberRefs(), flags: this._runtimeFlags })
994
1006
  }
995
1007
  }
996
1008
 
997
1009
  popStack() {
998
1010
  const item = this._stack.pop()
999
1011
  if (item) {
1000
- if (item._op === "OnStep" || item._op === "RevertFlags") {
1012
+ if (item._op === "OnStep") {
1001
1013
  this._steps.pop()
1002
1014
  }
1003
1015
  return item
@@ -1028,14 +1040,7 @@ export class FiberRuntime<in out E, in out A> implements Fiber.RuntimeFiber<E, A
1028
1040
  [OpCodes.OP_TAG](op: core.Primitive & { _op: OpCodes.OP_SYNC }) {
1029
1041
  return core.map(
1030
1042
  core.fiberRefGet(core.currentContext),
1031
- (context) => {
1032
- try {
1033
- return Context.unsafeGet(context, op as unknown as Context.Tag<any, any>)
1034
- } catch (e) {
1035
- console.log(e)
1036
- throw e
1037
- }
1038
- }
1043
+ (context) => Context.unsafeGet(context, op as unknown as Context.Tag<any, any>)
1039
1044
  )
1040
1045
  }
1041
1046
 
@@ -1100,7 +1105,7 @@ export class FiberRuntime<in out E, in out A> implements Fiber.RuntimeFiber<E, A
1100
1105
  }
1101
1106
  case "OnStep": {
1102
1107
  if (!(_runtimeFlags.interruptible(this._runtimeFlags) && this.isInterrupted())) {
1103
- return cont.i1(core.exitFailCause(cause))
1108
+ return core.exitSucceed(core.exitFailCause(cause))
1104
1109
  } else {
1105
1110
  return core.exitFailCause(internalCause.stripFailures(cause))
1106
1111
  }
@@ -1130,54 +1135,37 @@ export class FiberRuntime<in out E, in out A> implements Fiber.RuntimeFiber<E, A
1130
1135
  }
1131
1136
 
1132
1137
  ["Blocked"](op: core.Primitive & { _op: "Blocked" }) {
1133
- if (this._steps[this._steps.length - 1]) {
1134
- const nextOp = this.popStack()
1135
- if (nextOp) {
1136
- switch (nextOp._op) {
1137
- case "OnStep": {
1138
- return nextOp.i1(op)
1139
- }
1140
- case "OnSuccess": {
1141
- return core.blocked(op.i0, core.flatMap(op.i1, nextOp.i1))
1142
- }
1143
- case "OnSuccessAndFailure": {
1144
- return core.blocked(
1145
- op.i0,
1146
- core.matchCauseEffect(op.i1, {
1147
- onFailure: nextOp.i1,
1148
- onSuccess: nextOp.i2
1149
- })
1150
- )
1151
- }
1152
- case "OnFailure": {
1153
- return core.blocked(op.i0, core.catchAllCause(op.i1, nextOp.i1))
1154
- }
1155
- case "While": {
1156
- return core.blocked(
1157
- op.i0,
1158
- core.flatMap(op.i1, (a) => {
1159
- nextOp.i2(a)
1160
- if (nextOp.i0()) {
1161
- return core.whileLoop({
1162
- while: nextOp.i0,
1163
- body: nextOp.i1,
1164
- step: nextOp.i2
1165
- })
1166
- }
1167
- return core.unit
1168
- })
1169
- )
1170
- }
1171
- case "RevertFlags": {
1172
- this.pushStack(nextOp)
1173
- break
1174
- }
1175
- }
1138
+ const refs = this.getFiberRefs()
1139
+ const flags = this._runtimeFlags
1140
+ if (this._steps.length > 0) {
1141
+ const frames: Array<core.Continuation> = []
1142
+ const snap = this._steps[this._steps.length - 1]
1143
+ let frame = this.popStack()
1144
+ while (frame && frame._op !== "OnStep") {
1145
+ frames.push(frame)
1146
+ frame = this.popStack()
1176
1147
  }
1148
+ this.setFiberRefs(snap.refs)
1149
+ this._runtimeFlags = snap.flags
1150
+ const patchRefs = FiberRefsPatch.diff(snap.refs, refs)
1151
+ const patchFlags = _runtimeFlags.diff(snap.flags, flags)
1152
+ return core.exitSucceed(core.blocked(
1153
+ op.i0,
1154
+ core.withFiberRuntime((newFiber) => {
1155
+ while (frames.length > 0) {
1156
+ newFiber.pushStack(frames.pop()!)
1157
+ }
1158
+ newFiber.setFiberRefs(
1159
+ FiberRefsPatch.patch(newFiber.id(), newFiber.getFiberRefs())(patchRefs)
1160
+ )
1161
+ newFiber._runtimeFlags = _runtimeFlags.patch(patchFlags)(newFiber._runtimeFlags)
1162
+ return op.i1
1163
+ })
1164
+ ))
1177
1165
  }
1178
1166
  return core.uninterruptibleMask((restore) =>
1179
1167
  core.flatMap(
1180
- fork(core.runRequestBlock(op.i0)),
1168
+ forkDaemon(core.runRequestBlock(op.i0)),
1181
1169
  () => restore(op.i1)
1182
1170
  )
1183
1171
  )
@@ -1285,7 +1273,6 @@ export class FiberRuntime<in out E, in out A> implements Fiber.RuntimeFiber<E, A
1285
1273
  }
1286
1274
  try {
1287
1275
  if (!("_op" in cur) || !((cur as core.Primitive)._op in this)) {
1288
- console.log(cur)
1289
1276
  // @ts-expect-error
1290
1277
  absurd(cur)
1291
1278
  }
@@ -1621,7 +1608,7 @@ export const filter = dual<
1621
1608
  (a, i) => core.map(predicate(a, i), (b) => (b ? Option.some(a) : Option.none())),
1622
1609
  options
1623
1610
  ),
1624
- RA.compact
1611
+ RA.getSomes
1625
1612
  )
1626
1613
  )
1627
1614
  }
@@ -1890,16 +1877,16 @@ export const forEach: {
1890
1877
  () =>
1891
1878
  finalizersMask(ExecutionStrategy.sequential)((restore) =>
1892
1879
  isRequestBatchingEnabled
1893
- ? forEachBatchedDiscard(self, (a, i) => restore(f(a, i)))
1880
+ ? forEachConcurrentDiscard(self, (a, i) => restore(f(a, i)), true, false, 1)
1894
1881
  : core.forEachSequentialDiscard(self, (a, i) => restore(f(a, i)))
1895
1882
  ),
1896
1883
  () =>
1897
1884
  finalizersMask(ExecutionStrategy.parallel)((restore) =>
1898
- forEachParUnboundedDiscard(self, (a, i) => restore(f(a, i)), isRequestBatchingEnabled)
1885
+ forEachConcurrentDiscard(self, (a, i) => restore(f(a, i)), isRequestBatchingEnabled, false)
1899
1886
  ),
1900
1887
  (n) =>
1901
1888
  finalizersMask(ExecutionStrategy.parallelN(n))((restore) =>
1902
- forEachParNDiscard(self, n, (a, i) => restore(f(a, i)), isRequestBatchingEnabled)
1889
+ forEachConcurrentDiscard(self, (a, i) => restore(f(a, i)), isRequestBatchingEnabled, false, n)
1903
1890
  )
1904
1891
  )
1905
1892
  }
@@ -1933,162 +1920,176 @@ export const forEachParUnbounded = <A, R, E, B>(
1933
1920
  const as = RA.fromIterable(self)
1934
1921
  const array = new Array<B>(as.length)
1935
1922
  const fn = (a: A, i: number) => core.flatMap(f(a, i), (b) => core.sync(() => array[i] = b))
1936
- return core.zipRight(forEachParUnboundedDiscard(as, fn, batching), core.succeed(array))
1923
+ return core.zipRight(forEachConcurrentDiscard(as, fn, batching, false), core.succeed(array))
1937
1924
  })
1938
1925
 
1939
- const forEachBatchedDiscard = <R, E, A, _>(
1926
+ /** @internal */
1927
+ export const forEachConcurrentDiscard = <R, E, A, _>(
1940
1928
  self: Iterable<A>,
1941
- f: (a: A, i: number) => Effect.Effect<R, E, _>
1929
+ f: (a: A, i: number) => Effect.Effect<R, E, _>,
1930
+ batching: boolean,
1931
+ processAll: boolean,
1932
+ n?: number
1942
1933
  ): Effect.Effect<R, E, void> =>
1943
- core.suspend(() => {
1944
- const as = RA.fromIterable(self)
1945
- const size = as.length
1946
- if (size === 0) {
1947
- return core.unit
1948
- } else if (size === 1) {
1949
- return core.asUnit(f(as[0], 0))
1950
- }
1951
- const effects = as.map(f)
1952
- const blocked = new Array<Effect.Blocked<R, E, void>>()
1953
- const loop = (i: number): Effect.Effect<R, E, void> =>
1954
- i === effects.length ?
1955
- core.suspend(() => {
1956
- if (blocked.length > 0) {
1957
- const requests = blocked.map((b) => b.i0).reduce(_RequestBlock.par)
1958
- return core.blocked(
1959
- requests,
1960
- forEachBatchedDiscard(blocked.map((b) => b.i1), identity)
1961
- )
1962
- }
1934
+ core.uninterruptibleMask((restore) =>
1935
+ core.transplant((graft) =>
1936
+ core.withFiberRuntime((parent) => {
1937
+ let todos = Array.from(self).reverse()
1938
+ let target = todos.length
1939
+ if (target === 0) {
1963
1940
  return core.unit
1964
- }) :
1965
- core.flatMapStep(effects[i], (s) => {
1966
- if (s._op === "Blocked") {
1967
- blocked.push(s)
1968
- return loop(i + 1)
1969
- } else if (s._op === "Failure") {
1970
- return core.suspend(() => {
1971
- if (blocked.length > 0) {
1972
- const requests = blocked.map((b) => b.i0).reduce(_RequestBlock.par)
1973
- return core.blocked(
1974
- requests,
1975
- core.flatMap(forEachBatchedDiscard(blocked.map((b) => b.i1), identity), () => s)
1976
- )
1977
- }
1978
- return core.unit
1979
- })
1980
- } else {
1981
- return loop(i + 1)
1941
+ }
1942
+ let counter = 0
1943
+ let interrupted = false
1944
+ const fibersCount = n ? Math.min(todos.length, n) : todos.length
1945
+ const fibers = new Set<FiberRuntime<never, Exit.Exit<E, _> | Effect.Blocked<E, _>>>()
1946
+ const results = new Array()
1947
+ const interruptAll = () =>
1948
+ fibers.forEach((fiber) => {
1949
+ fiber._scheduler.scheduleTask(() => {
1950
+ fiber.unsafeInterruptAsFork(parent.id())
1951
+ }, 0)
1952
+ })
1953
+ const startOrder = new Array<FiberRuntime<never, Exit.Exit<E, _> | Effect.Blocked<E, _>>>()
1954
+ const joinOrder = new Array<FiberRuntime<never, Exit.Exit<E, _> | Effect.Blocked<E, _>>>()
1955
+ const residual = new Array<core.Blocked>()
1956
+ const collectExits = () => {
1957
+ const exits: Array<Exit.Exit<E, any>> = results
1958
+ .filter(({ exit }) => exit._tag === "Failure")
1959
+ .sort((a, b) => a.index < b.index ? -1 : a.index === b.index ? 0 : 1)
1960
+ .map(({ exit }) => exit)
1961
+ if (exits.length === 0) {
1962
+ exits.push(core.exitUnit)
1982
1963
  }
1983
- })
1984
- return loop(0)
1985
- })
1986
-
1987
- /* @internal */
1988
- export const forEachParUnboundedDiscard = <R, E, A, _>(
1989
- self: Iterable<A>,
1990
- f: (a: A, i: number) => Effect.Effect<R, E, _>,
1991
- batching: boolean
1992
- ): Effect.Effect<R, E, void> =>
1993
- core.suspend(() => {
1994
- const as = RA.fromIterable(self)
1995
- const size = as.length
1996
- if (size === 0) {
1997
- return core.unit
1998
- } else if (size === 1) {
1999
- return core.asUnit(f(as[0], 0))
2000
- }
2001
- return core.uninterruptibleMask((restore) => {
2002
- const deferred = core.deferredUnsafeMake<void, Effect.Effect<any, any, any>>(FiberId.none)
2003
- let ref = 0
2004
- const residual: Array<Effect.Blocked<any, any, any>> = []
2005
- const joinOrder: Array<Fiber.RuntimeFiber<any, any>> = []
2006
- const process = core.transplant((graft) =>
2007
- core.forEachSequential(as, (a, i) =>
2008
- pipe(
2009
- graft(pipe(
2010
- core.suspend(() => restore((batching ? core.step : core.exit)(f(a, i)))),
2011
- core.flatMap(
2012
- (exit) => {
2013
- switch (exit._op) {
2014
- case "Failure": {
2015
- if (residual.length > 0) {
2016
- const requests = residual.map((blocked) => blocked.i0).reduce(_RequestBlock.par)
2017
- const _continue = forEachParUnboundedDiscard(residual, (blocked) => blocked.i1, batching)
2018
- return core.blocked(
2019
- requests,
2020
- core.matchCauseEffect(_continue, {
2021
- onFailure: (cause) =>
2022
- core.zipRight(
2023
- core.deferredFail(deferred, void 0),
2024
- core.failCause(internalCause.parallel(cause, exit.cause))
2025
- ),
2026
- onSuccess: () =>
2027
- core.zipRight(
2028
- core.deferredFail(deferred, void 0),
2029
- core.failCause(exit.cause)
2030
- )
2031
- })
2032
- )
2033
- }
2034
- return core.zipRight(
2035
- core.deferredFail(deferred, void 0),
2036
- core.failCause(exit.cause)
2037
- )
2038
- }
2039
- default: {
2040
- if (exit._op === "Blocked") {
2041
- residual.push(exit)
2042
- }
2043
- if (ref + 1 === size) {
2044
- if (residual.length > 0) {
2045
- const requests = residual.map((blocked) => blocked.i0).reduce(_RequestBlock.par)
2046
- const _continue = forEachParUnboundedDiscard(residual, (blocked) => blocked.i1, batching)
2047
- return core.deferredSucceed(deferred, core.blocked(requests, _continue))
2048
- } else {
2049
- core.deferredUnsafeDone(deferred, core.exitSucceed(core.exitUnit))
2050
- }
2051
- } else {
2052
- ref = ref + 1
2053
- }
2054
- return core.unit
1964
+ return exits
1965
+ }
1966
+ const runFiber = <R, E, A>(eff: Effect.Effect<R, E, A>) => {
1967
+ const runnable = core.uninterruptible(graft(eff))
1968
+ const fiber = unsafeForkUnstarted(
1969
+ runnable,
1970
+ parent,
1971
+ parent._runtimeFlags,
1972
+ fiberScope.globalScope
1973
+ )
1974
+ parent._scheduler.scheduleTask(() => {
1975
+ fiber.resume(runnable)
1976
+ }, 0)
1977
+ return fiber
1978
+ }
1979
+ const onInterruptSignal = () => {
1980
+ if (!processAll) {
1981
+ target -= todos.length
1982
+ todos = []
1983
+ }
1984
+ interrupted = true
1985
+ interruptAll()
1986
+ }
1987
+ const stepOrExit = batching ? core.step : core.exit
1988
+ const processingFiber = runFiber(
1989
+ core.async<any, any, any>((resume) => {
1990
+ const pushResult = <E, _>(res: Exit.Exit<E, _> | Effect.Blocked<E, _>, index: number) => {
1991
+ if (res._op === "Blocked") {
1992
+ residual.push(res as core.Blocked)
1993
+ } else {
1994
+ results.push({ index, exit: res })
1995
+ if (res._op === "Failure" && !interrupted) {
1996
+ onInterruptSignal()
1997
+ }
1998
+ }
1999
+ }
2000
+ const next = () => {
2001
+ if (todos.length > 0) {
2002
+ const a = todos.pop()!
2003
+ let index = counter++
2004
+ const returnNextElement = () => {
2005
+ const a = todos.pop()!
2006
+ index = counter++
2007
+ return core.flatMap(core.yieldNow(), () =>
2008
+ core.flatMap(
2009
+ stepOrExit(restore(f(a, index))),
2010
+ onRes
2011
+ ))
2012
+ }
2013
+ const onRes = (
2014
+ res: Exit.Exit<E, _> | Effect.Blocked<E, _>
2015
+ ): Effect.Effect<R, never, Exit.Exit<E, _> | Effect.Blocked<E, _>> => {
2016
+ if (todos.length > 0) {
2017
+ pushResult(res, index)
2018
+ if (todos.length > 0) {
2019
+ return returnNextElement()
2055
2020
  }
2056
2021
  }
2022
+ return core.succeed(res)
2057
2023
  }
2058
- )
2059
- )),
2060
- forkDaemon,
2061
- core.map((fiber) => {
2062
- fiber.addObserver(() => {
2063
- joinOrder.push(fiber)
2064
- })
2065
- return fiber
2066
- })
2067
- ))
2068
- )
2069
- return core.flatMap(process, (fibers) =>
2070
- core.matchCauseEffect(
2071
- restore(core.deferredAwait(deferred)),
2072
- {
2073
- onFailure: (cause) =>
2074
- core.flatMap(
2075
- forEachParUnbounded(fibers, core.interruptFiber, batching),
2076
- (exits) => {
2077
- const exit = core.exitCollectAll(exits, { parallel: true })
2078
- if (exit._tag === "Some" && core.exitIsFailure(exit.value)) {
2079
- return core.failCause(
2080
- internalCause.parallel(internalCause.stripFailures(cause), exit.value.i0)
2081
- )
2024
+ const todo = core.flatMap(
2025
+ stepOrExit(restore(f(a, index))),
2026
+ onRes
2027
+ )
2028
+ const fiber = runFiber(todo)
2029
+ startOrder.push(fiber)
2030
+ fibers.add(fiber)
2031
+ if (interrupted) {
2032
+ fiber._scheduler.scheduleTask(() => {
2033
+ fiber.unsafeInterruptAsFork(parent.id())
2034
+ }, 0)
2035
+ }
2036
+ fiber.addObserver((wrapped) => {
2037
+ let exit: Exit.Exit<any, any> | core.Blocked
2038
+ if (wrapped._op === "Failure") {
2039
+ exit = wrapped
2082
2040
  } else {
2083
- return core.failCause(internalCause.stripFailures(cause))
2041
+ exit = wrapped.i0 as any
2084
2042
  }
2085
- }
2086
- ),
2087
- onSuccess: (rest) => core.flatMap(rest, () => core.forEachSequentialDiscard(joinOrder, (f) => f.inheritAll))
2088
- }
2043
+ joinOrder.push(fiber)
2044
+ fibers.delete(fiber)
2045
+ pushResult(exit, index)
2046
+ if (results.length === target) {
2047
+ resume(core.succeed(Option.getOrElse(
2048
+ core.exitCollectAll(collectExits(), { parallel: true }),
2049
+ () => core.exitUnit
2050
+ )))
2051
+ } else if (residual.length + results.length === target) {
2052
+ const requests = residual.map((blocked) => blocked.i0).reduce(_RequestBlock.par)
2053
+ resume(core.succeed(core.blocked(
2054
+ requests,
2055
+ forEachConcurrentDiscard(
2056
+ [
2057
+ Option.getOrElse(
2058
+ core.exitCollectAll(collectExits(), { parallel: true }),
2059
+ () => core.exitUnit
2060
+ ),
2061
+ ...residual.map((blocked) => blocked.i1)
2062
+ ],
2063
+ (i) => i,
2064
+ batching,
2065
+ true,
2066
+ n
2067
+ )
2068
+ )))
2069
+ } else {
2070
+ next()
2071
+ }
2072
+ })
2073
+ }
2074
+ }
2075
+ for (let i = 0; i < fibersCount; i++) {
2076
+ next()
2077
+ }
2078
+ })
2079
+ )
2080
+ return core.asUnit(core.tap(
2081
+ core.flatten(core.onInterrupt(
2082
+ restore(internalFiber.join(processingFiber)),
2083
+ () => {
2084
+ onInterruptSignal()
2085
+ return internalFiber._await(processingFiber)
2086
+ }
2087
+ )),
2088
+ () => core.forEachSequential(joinOrder, (f) => f.inheritAll)
2089
2089
  ))
2090
- })
2091
- })
2090
+ })
2091
+ )
2092
+ )
2092
2093
 
2093
2094
  /* @internal */
2094
2095
  export const forEachParN = <A, R, E, B>(
@@ -2101,60 +2102,7 @@ export const forEachParN = <A, R, E, B>(
2101
2102
  const as = RA.fromIterable(self)
2102
2103
  const array = new Array<B>(as.length)
2103
2104
  const fn = (a: A, i: number) => core.map(f(a, i), (b) => array[i] = b)
2104
- return core.zipRight(forEachParNDiscard(as, n, fn, batching), core.succeed(array))
2105
- })
2106
-
2107
- /* @internal */
2108
- export const forEachParNDiscard = <A, R, E, _>(
2109
- self: Iterable<A>,
2110
- n: number,
2111
- f: (a: A, i: number) => Effect.Effect<R, E, _>,
2112
- batching: boolean
2113
- ): Effect.Effect<R, E, void> =>
2114
- core.suspend(() => {
2115
- let i = 0
2116
- const iterator = self[Symbol.iterator]()
2117
- const residual: Array<Effect.Blocked<any, any, any>> = []
2118
- const worker: Effect.Effect<R, E, void> = core.flatMap(
2119
- core.sync(() => iterator.next()),
2120
- (next) =>
2121
- next.done ?
2122
- core.unit :
2123
- core.flatMap((batching ? core.step : core.exit)(core.asUnit(f(next.value, i++))), (res) => {
2124
- switch (res._op) {
2125
- case "Blocked": {
2126
- residual.push(res)
2127
- return worker
2128
- }
2129
- case "Failure": {
2130
- return res
2131
- }
2132
- case "Success":
2133
- return worker
2134
- }
2135
- })
2136
- )
2137
- const effects: Array<Effect.Effect<R, E, void>> = []
2138
- for (let i = 0; i < n; i++) {
2139
- effects.push(worker)
2140
- }
2141
- return core.flatMap(core.exit(forEachParUnboundedDiscard(effects, identity, batching)), (exit) => {
2142
- if (residual.length === 0) {
2143
- return exit
2144
- }
2145
- const requests = residual.map((blocked) => blocked.i0).reduce(_RequestBlock.par)
2146
- const _continue = forEachParNDiscard(residual, n, (blocked) => blocked.i1, batching)
2147
- if (exit._tag === "Failure") {
2148
- return core.blocked(
2149
- requests,
2150
- core.matchCauseEffect(_continue, {
2151
- onFailure: (cause) => core.exitFailCause(internalCause.parallel(exit.cause, cause)),
2152
- onSuccess: () => exit
2153
- })
2154
- )
2155
- }
2156
- return core.blocked(requests, _continue)
2157
- })
2105
+ return core.zipRight(forEachConcurrentDiscard(as, fn, batching, false, n), core.succeed(array))
2158
2106
  })
2159
2107
 
2160
2108
  /* @internal */
@@ -2201,6 +2149,17 @@ export const unsafeFork = <R, E, A, E2, B>(
2201
2149
  return childFiber
2202
2150
  }
2203
2151
 
2152
+ /** @internal */
2153
+ export const unsafeForkUnstarted = <R, E, A, E2, B>(
2154
+ effect: Effect.Effect<R, E, A>,
2155
+ parentFiber: FiberRuntime<E2, B>,
2156
+ parentRuntimeFlags: RuntimeFlags.RuntimeFlags,
2157
+ overrideScope: fiberScope.FiberScope | null = null
2158
+ ): FiberRuntime<E, A> => {
2159
+ const childFiber = unsafeMakeChildFiber(effect, parentFiber, parentRuntimeFlags, overrideScope)
2160
+ return childFiber
2161
+ }
2162
+
2204
2163
  /** @internal */
2205
2164
  export const unsafeMakeChildFiber = <R, E, A, E2, B>(
2206
2165
  effect: Effect.Effect<R, E, A>,
@@ -3122,7 +3081,7 @@ export const fiberAll = <E, A>(fibers: Iterable<Fiber.Fiber<E, A>>): Fiber.Fiber
3122
3081
  [internalFiber.FiberTypeId]: internalFiber.fiberVariance,
3123
3082
  id: () => RA.fromIterable(fibers).reduce((id, fiber) => FiberId.combine(id, fiber.id()), FiberId.none),
3124
3083
  await: core.exit(forEachParUnbounded(fibers, (fiber) => core.flatten(fiber.await), false)),
3125
- children: core.map(forEachParUnbounded(fibers, (fiber) => fiber.children, false), RA.flatten),
3084
+ children: core.map(forEachParUnbounded(fibers, (fiber) => fiber.children, false), (children) => RA.flatten(children)),
3126
3085
  inheritAll: core.forEachSequentialDiscard(fibers, (fiber) => fiber.inheritAll),
3127
3086
  poll: core.map(
3128
3087
  core.forEachSequential(fibers, (fiber) => fiber.poll),
@@ -27,11 +27,14 @@ export const GroupByTypeId: GroupBy.GroupByTypeId = Symbol.for(
27
27
  GroupBySymbolKey
28
28
  ) as GroupBy.GroupByTypeId
29
29
 
30
- /** @internal */
31
30
  const groupByVariance = {
31
+ /* c8 ignore next */
32
32
  _R: (_: never) => _,
33
+ /* c8 ignore next */
33
34
  _E: (_: never) => _,
35
+ /* c8 ignore next */
34
36
  _K: (_: never) => _,
37
+ /* c8 ignore next */
35
38
  _V: (_: never) => _
36
39
  }
37
40