@fncts/io 0.0.19 → 0.0.21

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1109) hide show
  1. package/Cached/api.d.ts +2 -2
  2. package/Channel/ChildExecutorDecision/api.d.ts +2 -2
  3. package/Channel/UpstreamPullRequest/api.d.ts +2 -2
  4. package/Channel/api/interruptWhen.d.ts +5 -5
  5. package/Channel/api/mapOutIOC.d.ts +3 -3
  6. package/Channel/api/mergeAll.d.ts +2 -2
  7. package/Channel/api/mergeAllUnboundedWith.d.ts +2 -2
  8. package/Channel/api/mergeAllWith.d.ts +2 -2
  9. package/Channel/api/mergeMap.d.ts +2 -2
  10. package/Channel/api/mergeWith.d.ts +2 -2
  11. package/Channel/api/zipC.d.ts +6 -6
  12. package/Channel/api.d.ts +64 -64
  13. package/Channel/core-api.d.ts +11 -11
  14. package/Channel/definition.d.ts +35 -21
  15. package/Differ/api.d.ts +24 -0
  16. package/Differ/definition.d.ts +15 -0
  17. package/Fiber/api/evalOn.d.ts +3 -3
  18. package/Fiber/api/evalOnIO.d.ts +3 -3
  19. package/Fiber/api/interruptAs.d.ts +3 -3
  20. package/Fiber/api/interruptAsFork.d.ts +3 -3
  21. package/Fiber/api/mapFiber.d.ts +2 -2
  22. package/Fiber/api/mapIO.d.ts +5 -5
  23. package/Fiber/api/zipWith.d.ts +2 -2
  24. package/Fiber.d.ts +1 -0
  25. package/FiberRef/api/locallyScoped.d.ts +2 -2
  26. package/FiberRef/api/locallyScopedWith.d.ts +2 -2
  27. package/FiberRef/api.d.ts +18 -18
  28. package/FiberRef/unsafe.d.ts +12 -6
  29. package/FiberRefs/api.d.ts +2 -2
  30. package/FiberRefs/join.d.ts +3 -3
  31. package/Future/api.d.ts +21 -21
  32. package/Hub/constructors.d.ts +49 -0
  33. package/Hub/definition.d.ts +37 -81
  34. package/Hub/internal.d.ts +4 -11
  35. package/Hub.d.ts +1 -1
  36. package/IO/api/acquireRelease.d.ts +1 -1
  37. package/IO/api/acquireReleaseExit.d.ts +1 -1
  38. package/IO/api/bracket.d.ts +1 -1
  39. package/IO/api/bracketExit.d.ts +1 -1
  40. package/IO/api/concurrency.d.ts +2 -2
  41. package/IO/api/core-scope.d.ts +5 -5
  42. package/IO/api/ensuringChildren.d.ts +3 -3
  43. package/IO/api/environment.d.ts +11 -15
  44. package/IO/api/foreachC.d.ts +2 -2
  45. package/IO/api/foreachExec.d.ts +1 -1
  46. package/IO/api/forkIn.d.ts +3 -3
  47. package/IO/api/fulfill.d.ts +3 -3
  48. package/IO/api/interrupt.d.ts +6 -6
  49. package/IO/api/onExit.d.ts +3 -3
  50. package/IO/api/onTermination.d.ts +4 -4
  51. package/IO/api/provideLayer.d.ts +3 -3
  52. package/IO/api/provideSomeLayer.d.ts +3 -7
  53. package/IO/api/race.d.ts +2 -2
  54. package/IO/api/raceFirst.d.ts +2 -2
  55. package/IO/api/repeat.d.ts +3 -3
  56. package/IO/api/retry.d.ts +7 -7
  57. package/IO/api/schedule.d.ts +5 -5
  58. package/IO/api/scoped.d.ts +2 -2
  59. package/IO/api/supervised.d.ts +3 -3
  60. package/IO/api/timeout.d.ts +5 -5
  61. package/IO/api/withFinalizer.d.ts +3 -3
  62. package/IO/api/withFinalizerExit.d.ts +3 -3
  63. package/IO/api/withRuntimeConfig.d.ts +3 -3
  64. package/IO/api/zipC.d.ts +4 -4
  65. package/IO/api.d.ts +179 -176
  66. package/IO/definition.d.ts +15 -9
  67. package/IOEnv/services.d.ts +2 -2
  68. package/Layer/MemoMap.d.ts +4 -4
  69. package/Layer/api.d.ts +28 -28
  70. package/LogLevel.d.ts +12 -12
  71. package/LogSpan.d.ts +2 -2
  72. package/Logger/api.d.ts +5 -5
  73. package/Queue/constructors.d.ts +2 -1
  74. package/Queue/definition.d.ts +91 -82
  75. package/Queue/internal.d.ts +7 -9
  76. package/Queue.d.ts +0 -2
  77. package/Ref/Atomic.d.ts +15 -2
  78. package/Ref/Synchronized.d.ts +72 -0
  79. package/Ref/constructors.d.ts +7 -0
  80. package/Ref/definition.d.ts +60 -58
  81. package/Ref.d.ts +1 -6
  82. package/STM/api/core-api.d.ts +10 -10
  83. package/STM/api.d.ts +61 -61
  84. package/STM/internal/Journal.d.ts +4 -4
  85. package/Schedule/Decision.d.ts +2 -2
  86. package/Schedule/api.d.ts +94 -94
  87. package/Scope/ReleaseMap/api/releaseAll.d.ts +2 -2
  88. package/Scope/ReleaseMap/api.d.ts +10 -10
  89. package/Scope/api.d.ts +8 -8
  90. package/Sink/api.d.ts +68 -68
  91. package/State/api.d.ts +4 -4
  92. package/State/internal.d.ts +1 -1
  93. package/Stream/api/zipAllWith.d.ts +2 -2
  94. package/Stream/api/zipWith.d.ts +2 -2
  95. package/Stream/api/zipWithChunks.d.ts +2 -2
  96. package/Stream/api.d.ts +216 -205
  97. package/Stream/internal/DebounceState.d.ts +3 -3
  98. package/Stream/internal/Handoff.d.ts +5 -5
  99. package/Stream/internal/Pull.d.ts +2 -2
  100. package/Stream/internal/SinkEndReason.d.ts +3 -3
  101. package/Stream/internal/Take.d.ts +8 -8
  102. package/SubscriptionRef.d.ts +29 -0
  103. package/Supervisor/api.d.ts +13 -7
  104. package/Supervisor/definition.d.ts +28 -0
  105. package/SupervisorPatch.d.ts +61 -0
  106. package/TFuture/api.d.ts +7 -7
  107. package/TReentrantLock/api.d.ts +4 -4
  108. package/TRef/api.d.ts +24 -24
  109. package/TSemaphore/api.d.ts +4 -4
  110. package/TSemaphore/constructors.d.ts +6 -0
  111. package/_cjs/Cached/api.cjs +9 -9
  112. package/_cjs/Cached/api.cjs.map +1 -1
  113. package/_cjs/Channel/ChildExecutorDecision/api.cjs +19 -17
  114. package/_cjs/Channel/ChildExecutorDecision/api.cjs.map +1 -1
  115. package/_cjs/Channel/UpstreamPullRequest/api.cjs +16 -14
  116. package/_cjs/Channel/UpstreamPullRequest/api.cjs.map +1 -1
  117. package/_cjs/Channel/api/interruptWhen.cjs +14 -10
  118. package/_cjs/Channel/api/interruptWhen.cjs.map +1 -1
  119. package/_cjs/Channel/api/mapOutIOC.cjs +25 -25
  120. package/_cjs/Channel/api/mapOutIOC.cjs.map +1 -1
  121. package/_cjs/Channel/api/mergeAll.cjs +6 -4
  122. package/_cjs/Channel/api/mergeAll.cjs.map +1 -1
  123. package/_cjs/Channel/api/mergeAllUnboundedWith.cjs +6 -4
  124. package/_cjs/Channel/api/mergeAllUnboundedWith.cjs.map +1 -1
  125. package/_cjs/Channel/api/mergeAllWith.cjs +48 -52
  126. package/_cjs/Channel/api/mergeAllWith.cjs.map +1 -1
  127. package/_cjs/Channel/api/mergeMap.cjs +6 -4
  128. package/_cjs/Channel/api/mergeMap.cjs.map +1 -1
  129. package/_cjs/Channel/api/mergeWith.cjs +48 -46
  130. package/_cjs/Channel/api/mergeWith.cjs.map +1 -1
  131. package/_cjs/Channel/api/run.cjs +1 -1
  132. package/_cjs/Channel/api/run.cjs.map +1 -1
  133. package/_cjs/Channel/api/runScoped.cjs +2 -2
  134. package/_cjs/Channel/api/runScoped.cjs.map +1 -1
  135. package/_cjs/Channel/api/toPull.cjs +3 -3
  136. package/_cjs/Channel/api/toPull.cjs.map +1 -1
  137. package/_cjs/Channel/api/zipC.cjs +20 -14
  138. package/_cjs/Channel/api/zipC.cjs.map +1 -1
  139. package/_cjs/Channel/api.cjs +264 -218
  140. package/_cjs/Channel/api.cjs.map +1 -1
  141. package/_cjs/Channel/core-api.cjs +34 -24
  142. package/_cjs/Channel/core-api.cjs.map +1 -1
  143. package/_cjs/Channel/definition.cjs +1 -1
  144. package/_cjs/Channel/definition.cjs.map +1 -1
  145. package/_cjs/Channel/internal/ChannelExecutor.cjs +83 -83
  146. package/_cjs/Channel/internal/ChannelExecutor.cjs.map +1 -1
  147. package/_cjs/Channel/internal/SingleProducerAsyncInput.cjs +22 -24
  148. package/_cjs/Channel/internal/SingleProducerAsyncInput.cjs.map +1 -1
  149. package/_cjs/Differ/api.cjs +108 -0
  150. package/_cjs/Differ/api.cjs.map +1 -0
  151. package/_cjs/Differ/definition.cjs +23 -0
  152. package/_cjs/Differ/definition.cjs.map +1 -0
  153. package/_cjs/Fiber/FiberContext.cjs +48 -48
  154. package/_cjs/Fiber/FiberContext.cjs.map +1 -1
  155. package/_cjs/Fiber/api/awaitAll.cjs +1 -1
  156. package/_cjs/Fiber/api/awaitAll.cjs.map +1 -1
  157. package/_cjs/Fiber/api/collectAll.cjs +1 -1
  158. package/_cjs/Fiber/api/collectAll.cjs.map +1 -1
  159. package/_cjs/Fiber/api/evalOn.cjs +12 -10
  160. package/_cjs/Fiber/api/evalOn.cjs.map +1 -1
  161. package/_cjs/Fiber/api/evalOnIO.cjs +6 -4
  162. package/_cjs/Fiber/api/evalOnIO.cjs.map +1 -1
  163. package/_cjs/Fiber/api/fromIO.cjs +1 -1
  164. package/_cjs/Fiber/api/fromIO.cjs.map +1 -1
  165. package/_cjs/Fiber/api/interrupt.cjs +1 -1
  166. package/_cjs/Fiber/api/interrupt.cjs.map +1 -1
  167. package/_cjs/Fiber/api/interruptAll.cjs +2 -2
  168. package/_cjs/Fiber/api/interruptAll.cjs.map +1 -1
  169. package/_cjs/Fiber/api/interruptAs.cjs +6 -4
  170. package/_cjs/Fiber/api/interruptAs.cjs.map +1 -1
  171. package/_cjs/Fiber/api/interruptAsFork.cjs +6 -4
  172. package/_cjs/Fiber/api/interruptAsFork.cjs.map +1 -1
  173. package/_cjs/Fiber/api/interruptFork.cjs +1 -1
  174. package/_cjs/Fiber/api/interruptFork.cjs.map +1 -1
  175. package/_cjs/Fiber/api/join.cjs +1 -1
  176. package/_cjs/Fiber/api/join.cjs.map +1 -1
  177. package/_cjs/Fiber/api/joinAll.cjs +1 -1
  178. package/_cjs/Fiber/api/joinAll.cjs.map +1 -1
  179. package/_cjs/Fiber/api/mapFiber.cjs +6 -4
  180. package/_cjs/Fiber/api/mapFiber.cjs.map +1 -1
  181. package/_cjs/Fiber/api/mapIO.cjs +14 -10
  182. package/_cjs/Fiber/api/mapIO.cjs.map +1 -1
  183. package/_cjs/Fiber/api/zipWith.cjs +6 -4
  184. package/_cjs/Fiber/api/zipWith.cjs.map +1 -1
  185. package/_cjs/Fiber/definition.cjs.map +1 -1
  186. package/_cjs/Fiber.cjs +13 -0
  187. package/_cjs/Fiber.cjs.map +1 -1
  188. package/_cjs/FiberRef/api/locallyScoped.cjs +6 -4
  189. package/_cjs/FiberRef/api/locallyScoped.cjs.map +1 -1
  190. package/_cjs/FiberRef/api/locallyScopedWith.cjs +5 -3
  191. package/_cjs/FiberRef/api/locallyScopedWith.cjs.map +1 -1
  192. package/_cjs/FiberRef/api.cjs +64 -47
  193. package/_cjs/FiberRef/api.cjs.map +1 -1
  194. package/_cjs/FiberRef/constructors.cjs +1 -1
  195. package/_cjs/FiberRef/constructors.cjs.map +1 -1
  196. package/_cjs/FiberRef/unsafe.cjs +35 -21
  197. package/_cjs/FiberRef/unsafe.cjs.map +1 -1
  198. package/_cjs/FiberRef.cjs.map +1 -1
  199. package/_cjs/FiberRefs/api.cjs +15 -13
  200. package/_cjs/FiberRefs/api.cjs.map +1 -1
  201. package/_cjs/FiberRefs/join.cjs +37 -35
  202. package/_cjs/FiberRefs/join.cjs.map +1 -1
  203. package/_cjs/FiberState/definition.cjs.map +1 -1
  204. package/_cjs/Future/api.cjs +97 -79
  205. package/_cjs/Future/api.cjs.map +1 -1
  206. package/_cjs/Future/constructors.cjs +1 -1
  207. package/_cjs/Future/constructors.cjs.map +1 -1
  208. package/_cjs/Hub/constructors.cjs +93 -0
  209. package/_cjs/Hub/constructors.cjs.map +1 -0
  210. package/_cjs/Hub/definition.cjs +104 -13
  211. package/_cjs/Hub/definition.cjs.map +1 -1
  212. package/_cjs/Hub/internal.cjs +104 -129
  213. package/_cjs/Hub/internal.cjs.map +1 -1
  214. package/_cjs/Hub.cjs +4 -4
  215. package/_cjs/IO/api/acquireReleaseExit.cjs +1 -1
  216. package/_cjs/IO/api/acquireReleaseExit.cjs.map +1 -1
  217. package/_cjs/IO/api/acquireReleaseInterruptibleExit.cjs +1 -1
  218. package/_cjs/IO/api/acquireReleaseInterruptibleExit.cjs.map +1 -1
  219. package/_cjs/IO/api/addFinalizerExit.cjs +1 -1
  220. package/_cjs/IO/api/addFinalizerExit.cjs.map +1 -1
  221. package/_cjs/IO/api/asyncIO.cjs +4 -4
  222. package/_cjs/IO/api/asyncIO.cjs.map +1 -1
  223. package/_cjs/IO/api/bracket.cjs +3 -3
  224. package/_cjs/IO/api/bracket.cjs.map +1 -1
  225. package/_cjs/IO/api/bracketExit.cjs +3 -3
  226. package/_cjs/IO/api/bracketExit.cjs.map +1 -1
  227. package/_cjs/IO/api/clockWith.cjs +2 -2
  228. package/_cjs/IO/api/clockWith.cjs.map +1 -1
  229. package/_cjs/IO/api/concurrency.cjs +9 -7
  230. package/_cjs/IO/api/concurrency.cjs.map +1 -1
  231. package/_cjs/IO/api/concurrentFinalizers.cjs +1 -1
  232. package/_cjs/IO/api/concurrentFinalizers.cjs.map +1 -1
  233. package/_cjs/IO/api/consoleWith.cjs +2 -2
  234. package/_cjs/IO/api/consoleWith.cjs.map +1 -1
  235. package/_cjs/IO/api/core-scope.cjs +45 -41
  236. package/_cjs/IO/api/core-scope.cjs.map +1 -1
  237. package/_cjs/IO/api/ensuringChildren.cjs +5 -3
  238. package/_cjs/IO/api/ensuringChildren.cjs.map +1 -1
  239. package/_cjs/IO/api/environment.cjs +35 -35
  240. package/_cjs/IO/api/environment.cjs.map +1 -1
  241. package/_cjs/IO/api/foreachC.cjs +19 -23
  242. package/_cjs/IO/api/foreachC.cjs.map +1 -1
  243. package/_cjs/IO/api/foreachExec.cjs +3 -3
  244. package/_cjs/IO/api/foreachExec.cjs.map +1 -1
  245. package/_cjs/IO/api/forkAll.cjs +1 -1
  246. package/_cjs/IO/api/forkAll.cjs.map +1 -1
  247. package/_cjs/IO/api/forkIn.cjs +8 -6
  248. package/_cjs/IO/api/forkIn.cjs.map +1 -1
  249. package/_cjs/IO/api/forkScoped.cjs +1 -1
  250. package/_cjs/IO/api/forkScoped.cjs.map +1 -1
  251. package/_cjs/IO/api/fulfill.cjs +8 -6
  252. package/_cjs/IO/api/fulfill.cjs.map +1 -1
  253. package/_cjs/IO/api/interrupt.cjs +36 -30
  254. package/_cjs/IO/api/interrupt.cjs.map +1 -1
  255. package/_cjs/IO/api/memoize.cjs +1 -1
  256. package/_cjs/IO/api/memoize.cjs.map +1 -1
  257. package/_cjs/IO/api/onExit.cjs +6 -4
  258. package/_cjs/IO/api/onExit.cjs.map +1 -1
  259. package/_cjs/IO/api/onTermination.cjs +5 -3
  260. package/_cjs/IO/api/onTermination.cjs.map +1 -1
  261. package/_cjs/IO/api/once.cjs +3 -5
  262. package/_cjs/IO/api/once.cjs.map +1 -1
  263. package/_cjs/IO/api/provideLayer.cjs +6 -4
  264. package/_cjs/IO/api/provideLayer.cjs.map +1 -1
  265. package/_cjs/IO/api/provideSomeLayer.cjs +5 -15
  266. package/_cjs/IO/api/provideSomeLayer.cjs.map +1 -1
  267. package/_cjs/IO/api/race.cjs +6 -4
  268. package/_cjs/IO/api/race.cjs.map +1 -1
  269. package/_cjs/IO/api/raceFirst.cjs +6 -4
  270. package/_cjs/IO/api/raceFirst.cjs.map +1 -1
  271. package/_cjs/IO/api/randomWith.cjs +1 -1
  272. package/_cjs/IO/api/randomWith.cjs.map +1 -1
  273. package/_cjs/IO/api/repeat.cjs +12 -12
  274. package/_cjs/IO/api/repeat.cjs.map +1 -1
  275. package/_cjs/IO/api/retry.cjs +14 -14
  276. package/_cjs/IO/api/retry.cjs.map +1 -1
  277. package/_cjs/IO/api/schedule.cjs +15 -11
  278. package/_cjs/IO/api/schedule.cjs.map +1 -1
  279. package/_cjs/IO/api/scoped.cjs +6 -6
  280. package/_cjs/IO/api/scoped.cjs.map +1 -1
  281. package/_cjs/IO/api/sequenceT.cjs +1 -1
  282. package/_cjs/IO/api/sequenceT.cjs.map +1 -1
  283. package/_cjs/IO/api/stateful.cjs.map +1 -1
  284. package/_cjs/IO/api/supervised.cjs +6 -4
  285. package/_cjs/IO/api/supervised.cjs.map +1 -1
  286. package/_cjs/IO/api/timeout.cjs +10 -6
  287. package/_cjs/IO/api/timeout.cjs.map +1 -1
  288. package/_cjs/IO/api/withChildren.cjs +1 -1
  289. package/_cjs/IO/api/withChildren.cjs.map +1 -1
  290. package/_cjs/IO/api/withEarlyRelease.cjs +1 -1
  291. package/_cjs/IO/api/withEarlyRelease.cjs.map +1 -1
  292. package/_cjs/IO/api/withFinalizer.cjs +6 -4
  293. package/_cjs/IO/api/withFinalizer.cjs.map +1 -1
  294. package/_cjs/IO/api/withFinalizerExit.cjs +6 -4
  295. package/_cjs/IO/api/withFinalizerExit.cjs.map +1 -1
  296. package/_cjs/IO/api/withRuntimeConfig.cjs +6 -4
  297. package/_cjs/IO/api/withRuntimeConfig.cjs.map +1 -1
  298. package/_cjs/IO/api/zipC.cjs +21 -17
  299. package/_cjs/IO/api/zipC.cjs.map +1 -1
  300. package/_cjs/IO/api.cjs +634 -509
  301. package/_cjs/IO/api.cjs.map +1 -1
  302. package/_cjs/IO/definition.cjs.map +1 -1
  303. package/_cjs/IO/runtime.cjs +7 -7
  304. package/_cjs/IO/runtime.cjs.map +1 -1
  305. package/_cjs/IO.cjs.map +1 -1
  306. package/_cjs/IOEnv/definition.cjs +1 -1
  307. package/_cjs/IOEnv/definition.cjs.map +1 -1
  308. package/_cjs/IOEnv/live.cjs +1 -1
  309. package/_cjs/IOEnv/live.cjs.map +1 -1
  310. package/_cjs/IOEnv/services.cjs.map +1 -1
  311. package/_cjs/Layer/MemoMap.cjs +86 -92
  312. package/_cjs/Layer/MemoMap.cjs.map +1 -1
  313. package/_cjs/Layer/api.cjs +110 -81
  314. package/_cjs/Layer/api.cjs.map +1 -1
  315. package/_cjs/Layer/definition.cjs.map +1 -1
  316. package/_cjs/LogLevel.cjs +24 -16
  317. package/_cjs/LogLevel.cjs.map +1 -1
  318. package/_cjs/LogSpan.cjs +18 -16
  319. package/_cjs/LogSpan.cjs.map +1 -1
  320. package/_cjs/Logger/api.cjs +18 -14
  321. package/_cjs/Logger/api.cjs.map +1 -1
  322. package/_cjs/Logger/constructors.cjs +1 -1
  323. package/_cjs/Logger/constructors.cjs.map +1 -1
  324. package/_cjs/Queue/constructors.cjs +19 -5
  325. package/_cjs/Queue/constructors.cjs.map +1 -1
  326. package/_cjs/Queue/definition.cjs +191 -16
  327. package/_cjs/Queue/definition.cjs.map +1 -1
  328. package/_cjs/Queue/internal.cjs +27 -181
  329. package/_cjs/Queue/internal.cjs.map +1 -1
  330. package/_cjs/Queue/strategy.cjs +19 -19
  331. package/_cjs/Queue/strategy.cjs.map +1 -1
  332. package/_cjs/Queue.cjs +0 -26
  333. package/_cjs/Queue.cjs.map +1 -1
  334. package/_cjs/Random/live.cjs +2 -2
  335. package/_cjs/Random/live.cjs.map +1 -1
  336. package/_cjs/Ref/Atomic.cjs +47 -24
  337. package/_cjs/Ref/Atomic.cjs.map +1 -1
  338. package/_cjs/Ref/Synchronized.cjs +140 -0
  339. package/_cjs/Ref/Synchronized.cjs.map +1 -0
  340. package/_cjs/Ref/constructors.cjs +21 -2
  341. package/_cjs/Ref/constructors.cjs.map +1 -1
  342. package/_cjs/Ref/definition.cjs +105 -10
  343. package/_cjs/Ref/definition.cjs.map +1 -1
  344. package/_cjs/Ref.cjs +4 -69
  345. package/_cjs/Ref.cjs.map +1 -1
  346. package/_cjs/Reloadable/constructors.cjs +10 -10
  347. package/_cjs/Reloadable/constructors.cjs.map +1 -1
  348. package/_cjs/RuntimeConfig.cjs +2 -2
  349. package/_cjs/RuntimeConfig.cjs.map +1 -1
  350. package/_cjs/STM/api/core-api.cjs +36 -26
  351. package/_cjs/STM/api/core-api.cjs.map +1 -1
  352. package/_cjs/STM/api.cjs +217 -163
  353. package/_cjs/STM/api.cjs.map +1 -1
  354. package/_cjs/STM/driver.cjs +3 -3
  355. package/_cjs/STM/driver.cjs.map +1 -1
  356. package/_cjs/STM/internal/Entry.cjs.map +1 -1
  357. package/_cjs/STM/internal/Journal.cjs +33 -29
  358. package/_cjs/STM/internal/Journal.cjs.map +1 -1
  359. package/_cjs/STM.cjs.map +1 -1
  360. package/_cjs/Schedule/Decision.cjs +16 -14
  361. package/_cjs/Schedule/Decision.cjs.map +1 -1
  362. package/_cjs/Schedule/api/driver.cjs +16 -20
  363. package/_cjs/Schedule/api/driver.cjs.map +1 -1
  364. package/_cjs/Schedule/api.cjs +381 -290
  365. package/_cjs/Schedule/api.cjs.map +1 -1
  366. package/_cjs/Scope/ReleaseMap/api/releaseAll.cjs +14 -14
  367. package/_cjs/Scope/ReleaseMap/api/releaseAll.cjs.map +1 -1
  368. package/_cjs/Scope/ReleaseMap/api.cjs +68 -61
  369. package/_cjs/Scope/ReleaseMap/api.cjs.map +1 -1
  370. package/_cjs/Scope/api.cjs +34 -27
  371. package/_cjs/Scope/api.cjs.map +1 -1
  372. package/_cjs/ScopedRef/api.cjs +9 -13
  373. package/_cjs/ScopedRef/api.cjs.map +1 -1
  374. package/_cjs/ScopedRef/definition.cjs +1 -1
  375. package/_cjs/ScopedRef/definition.cjs.map +1 -1
  376. package/_cjs/Sink/api.cjs +307 -249
  377. package/_cjs/Sink/api.cjs.map +1 -1
  378. package/_cjs/State/api.cjs +18 -14
  379. package/_cjs/State/api.cjs.map +1 -1
  380. package/_cjs/Stream/api/zipAllWith.cjs +15 -13
  381. package/_cjs/Stream/api/zipAllWith.cjs.map +1 -1
  382. package/_cjs/Stream/api/zipWith.cjs +6 -4
  383. package/_cjs/Stream/api/zipWith.cjs.map +1 -1
  384. package/_cjs/Stream/api/zipWithChunks.cjs +13 -11
  385. package/_cjs/Stream/api/zipWithChunks.cjs.map +1 -1
  386. package/_cjs/Stream/api.cjs +992 -788
  387. package/_cjs/Stream/api.cjs.map +1 -1
  388. package/_cjs/Stream/definition.cjs.map +1 -1
  389. package/_cjs/Stream/internal/DebounceState.cjs +21 -19
  390. package/_cjs/Stream/internal/DebounceState.cjs.map +1 -1
  391. package/_cjs/Stream/internal/Handoff.cjs +35 -33
  392. package/_cjs/Stream/internal/Handoff.cjs.map +1 -1
  393. package/_cjs/Stream/internal/Pull.cjs +9 -11
  394. package/_cjs/Stream/internal/Pull.cjs.map +1 -1
  395. package/_cjs/Stream/internal/SinkEndReason.cjs +16 -14
  396. package/_cjs/Stream/internal/SinkEndReason.cjs.map +1 -1
  397. package/_cjs/Stream/internal/Take.cjs +32 -24
  398. package/_cjs/Stream/internal/Take.cjs.map +1 -1
  399. package/_cjs/Stream/internal/util.cjs +3 -3
  400. package/_cjs/Stream/internal/util.cjs.map +1 -1
  401. package/_cjs/SubscriptionRef.cjs +68 -0
  402. package/_cjs/SubscriptionRef.cjs.map +1 -0
  403. package/_cjs/Supervisor/api.cjs +49 -34
  404. package/_cjs/Supervisor/api.cjs.map +1 -1
  405. package/_cjs/Supervisor/constructors.cjs +2 -2
  406. package/_cjs/Supervisor/constructors.cjs.map +1 -1
  407. package/_cjs/Supervisor/definition.cjs +66 -1
  408. package/_cjs/Supervisor/definition.cjs.map +1 -1
  409. package/_cjs/SupervisorPatch.cjs +176 -0
  410. package/_cjs/SupervisorPatch.cjs.map +1 -0
  411. package/_cjs/TExit/definition.cjs.map +1 -1
  412. package/_cjs/TFuture/api.cjs +21 -15
  413. package/_cjs/TFuture/api.cjs.map +1 -1
  414. package/_cjs/TFuture/constructors.cjs +1 -1
  415. package/_cjs/TFuture/constructors.cjs.map +1 -1
  416. package/_cjs/TFuture/definition.cjs.map +1 -1
  417. package/_cjs/TReentrantLock/api.cjs +32 -28
  418. package/_cjs/TReentrantLock/api.cjs.map +1 -1
  419. package/_cjs/TReentrantLock/definition.cjs +4 -4
  420. package/_cjs/TReentrantLock/definition.cjs.map +1 -1
  421. package/_cjs/TRef/api.cjs +233 -209
  422. package/_cjs/TRef/api.cjs.map +1 -1
  423. package/_cjs/TRef/definition.cjs +4 -4
  424. package/_cjs/TRef/definition.cjs.map +1 -1
  425. package/_cjs/TSemaphore/api.cjs +27 -23
  426. package/_cjs/TSemaphore/api.cjs.map +1 -1
  427. package/_cjs/TSemaphore/constructors.cjs +18 -3
  428. package/_cjs/TSemaphore/constructors.cjs.map +1 -1
  429. package/_cjs/collection/immutable/Conc/dropUntilIO.cjs +21 -19
  430. package/_cjs/collection/immutable/Conc/dropUntilIO.cjs.map +1 -1
  431. package/_cjs/collection/immutable/Conc/dropWhileIO.cjs +21 -19
  432. package/_cjs/collection/immutable/Conc/dropWhileIO.cjs.map +1 -1
  433. package/_cjs/collection/immutable/Conc/filterIO.cjs +16 -14
  434. package/_cjs/collection/immutable/Conc/filterIO.cjs.map +1 -1
  435. package/_cjs/collection/immutable/Conc/findIO.cjs +19 -17
  436. package/_cjs/collection/immutable/Conc/findIO.cjs.map +1 -1
  437. package/_cjs/collection/immutable/Conc/mapIO.cjs +11 -9
  438. package/_cjs/collection/immutable/Conc/mapIO.cjs.map +1 -1
  439. package/_cjs/collection/immutable/Conc/takeWhileIO.cjs +31 -29
  440. package/_cjs/collection/immutable/Conc/takeWhileIO.cjs.map +1 -1
  441. package/_cjs/data/Exit/foreachIO.cjs +6 -4
  442. package/_cjs/data/Exit/foreachIO.cjs.map +1 -1
  443. package/_cjs/internal/Hub.cjs +13 -11
  444. package/_cjs/internal/Hub.cjs.map +1 -1
  445. package/_cjs/internal/IsFatal.cjs +18 -16
  446. package/_cjs/internal/IsFatal.cjs.map +1 -1
  447. package/_cjs/internal/MutableQueue.cjs +11 -9
  448. package/_cjs/internal/MutableQueue.cjs.map +1 -1
  449. package/_cjs/internal/StackTraceBuilder.cjs.map +1 -1
  450. package/_mjs/Cached/api.mjs +6 -6
  451. package/_mjs/Cached/api.mjs.map +1 -1
  452. package/_mjs/Channel/ChildExecutorDecision/api.mjs +18 -16
  453. package/_mjs/Channel/ChildExecutorDecision/api.mjs.map +1 -1
  454. package/_mjs/Channel/UpstreamPullRequest/api.mjs +14 -12
  455. package/_mjs/Channel/UpstreamPullRequest/api.mjs.map +1 -1
  456. package/_mjs/Channel/api/interruptWhen.mjs +11 -7
  457. package/_mjs/Channel/api/interruptWhen.mjs.map +1 -1
  458. package/_mjs/Channel/api/mapOutIOC.mjs +24 -23
  459. package/_mjs/Channel/api/mapOutIOC.mjs.map +1 -1
  460. package/_mjs/Channel/api/mergeAll.mjs +5 -3
  461. package/_mjs/Channel/api/mergeAll.mjs.map +1 -1
  462. package/_mjs/Channel/api/mergeAllUnboundedWith.mjs +5 -3
  463. package/_mjs/Channel/api/mergeAllUnboundedWith.mjs.map +1 -1
  464. package/_mjs/Channel/api/mergeAllWith.mjs +45 -46
  465. package/_mjs/Channel/api/mergeAllWith.mjs.map +1 -1
  466. package/_mjs/Channel/api/mergeMap.mjs +5 -3
  467. package/_mjs/Channel/api/mergeMap.mjs.map +1 -1
  468. package/_mjs/Channel/api/mergeWith.mjs +46 -44
  469. package/_mjs/Channel/api/mergeWith.mjs.map +1 -1
  470. package/_mjs/Channel/api/run.mjs +1 -1
  471. package/_mjs/Channel/api/run.mjs.map +1 -1
  472. package/_mjs/Channel/api/runScoped.mjs +2 -2
  473. package/_mjs/Channel/api/runScoped.mjs.map +1 -1
  474. package/_mjs/Channel/api/toPull.mjs +3 -3
  475. package/_mjs/Channel/api/toPull.mjs.map +1 -1
  476. package/_mjs/Channel/api/zipC.mjs +16 -10
  477. package/_mjs/Channel/api/zipC.mjs.map +1 -1
  478. package/_mjs/Channel/api.mjs +224 -173
  479. package/_mjs/Channel/api.mjs.map +1 -1
  480. package/_mjs/Channel/core-api.mjs +28 -18
  481. package/_mjs/Channel/core-api.mjs.map +1 -1
  482. package/_mjs/Channel/definition.mjs +1 -1
  483. package/_mjs/Channel/definition.mjs.map +1 -1
  484. package/_mjs/Channel/internal/ChannelExecutor.mjs +83 -83
  485. package/_mjs/Channel/internal/ChannelExecutor.mjs.map +1 -1
  486. package/_mjs/Channel/internal/SingleProducerAsyncInput.mjs +22 -23
  487. package/_mjs/Channel/internal/SingleProducerAsyncInput.mjs.map +1 -1
  488. package/_mjs/Differ/api.mjs +90 -0
  489. package/_mjs/Differ/api.mjs.map +1 -0
  490. package/_mjs/Differ/definition.mjs +13 -0
  491. package/_mjs/Differ/definition.mjs.map +1 -0
  492. package/_mjs/Fiber/FiberContext.mjs +48 -48
  493. package/_mjs/Fiber/FiberContext.mjs.map +1 -1
  494. package/_mjs/Fiber/api/awaitAll.mjs +1 -1
  495. package/_mjs/Fiber/api/awaitAll.mjs.map +1 -1
  496. package/_mjs/Fiber/api/collectAll.mjs +1 -1
  497. package/_mjs/Fiber/api/collectAll.mjs.map +1 -1
  498. package/_mjs/Fiber/api/evalOn.mjs +11 -9
  499. package/_mjs/Fiber/api/evalOn.mjs.map +1 -1
  500. package/_mjs/Fiber/api/evalOnIO.mjs +5 -3
  501. package/_mjs/Fiber/api/evalOnIO.mjs.map +1 -1
  502. package/_mjs/Fiber/api/fromIO.mjs +1 -1
  503. package/_mjs/Fiber/api/fromIO.mjs.map +1 -1
  504. package/_mjs/Fiber/api/interrupt.mjs +1 -1
  505. package/_mjs/Fiber/api/interrupt.mjs.map +1 -1
  506. package/_mjs/Fiber/api/interruptAll.mjs +2 -2
  507. package/_mjs/Fiber/api/interruptAll.mjs.map +1 -1
  508. package/_mjs/Fiber/api/interruptAs.mjs +6 -4
  509. package/_mjs/Fiber/api/interruptAs.mjs.map +1 -1
  510. package/_mjs/Fiber/api/interruptAsFork.mjs +6 -4
  511. package/_mjs/Fiber/api/interruptAsFork.mjs.map +1 -1
  512. package/_mjs/Fiber/api/interruptFork.mjs +1 -1
  513. package/_mjs/Fiber/api/interruptFork.mjs.map +1 -1
  514. package/_mjs/Fiber/api/join.mjs +1 -1
  515. package/_mjs/Fiber/api/join.mjs.map +1 -1
  516. package/_mjs/Fiber/api/joinAll.mjs +1 -1
  517. package/_mjs/Fiber/api/joinAll.mjs.map +1 -1
  518. package/_mjs/Fiber/api/mapFiber.mjs +5 -3
  519. package/_mjs/Fiber/api/mapFiber.mjs.map +1 -1
  520. package/_mjs/Fiber/api/mapIO.mjs +11 -7
  521. package/_mjs/Fiber/api/mapIO.mjs.map +1 -1
  522. package/_mjs/Fiber/api/zipWith.mjs +5 -3
  523. package/_mjs/Fiber/api/zipWith.mjs.map +1 -1
  524. package/_mjs/Fiber/definition.mjs.map +1 -1
  525. package/_mjs/Fiber.mjs +1 -0
  526. package/_mjs/Fiber.mjs.map +1 -1
  527. package/_mjs/FiberRef/api/locallyScoped.mjs +5 -3
  528. package/_mjs/FiberRef/api/locallyScoped.mjs.map +1 -1
  529. package/_mjs/FiberRef/api/locallyScopedWith.mjs +5 -3
  530. package/_mjs/FiberRef/api/locallyScopedWith.mjs.map +1 -1
  531. package/_mjs/FiberRef/api.mjs +52 -36
  532. package/_mjs/FiberRef/api.mjs.map +1 -1
  533. package/_mjs/FiberRef/constructors.mjs +1 -1
  534. package/_mjs/FiberRef/constructors.mjs.map +1 -1
  535. package/_mjs/FiberRef/unsafe.mjs +31 -20
  536. package/_mjs/FiberRef/unsafe.mjs.map +1 -1
  537. package/_mjs/FiberRef.mjs.map +1 -1
  538. package/_mjs/FiberRefs/api.mjs +14 -12
  539. package/_mjs/FiberRefs/api.mjs.map +1 -1
  540. package/_mjs/FiberRefs/join.mjs +35 -33
  541. package/_mjs/FiberRefs/join.mjs.map +1 -1
  542. package/_mjs/FiberState/definition.mjs.map +1 -1
  543. package/_mjs/Future/api.mjs +84 -66
  544. package/_mjs/Future/api.mjs.map +1 -1
  545. package/_mjs/Future/constructors.mjs +1 -1
  546. package/_mjs/Future/constructors.mjs.map +1 -1
  547. package/_mjs/Hub/constructors.mjs +66 -0
  548. package/_mjs/Hub/constructors.mjs.map +1 -0
  549. package/_mjs/Hub/definition.mjs +88 -9
  550. package/_mjs/Hub/definition.mjs.map +1 -1
  551. package/_mjs/Hub/internal.mjs +105 -122
  552. package/_mjs/Hub/internal.mjs.map +1 -1
  553. package/_mjs/Hub.mjs +1 -1
  554. package/_mjs/Hub.mjs.map +1 -1
  555. package/_mjs/IO/api/acquireReleaseExit.mjs +1 -1
  556. package/_mjs/IO/api/acquireReleaseExit.mjs.map +1 -1
  557. package/_mjs/IO/api/acquireReleaseInterruptibleExit.mjs +1 -1
  558. package/_mjs/IO/api/acquireReleaseInterruptibleExit.mjs.map +1 -1
  559. package/_mjs/IO/api/addFinalizerExit.mjs +1 -1
  560. package/_mjs/IO/api/addFinalizerExit.mjs.map +1 -1
  561. package/_mjs/IO/api/asyncIO.mjs +4 -4
  562. package/_mjs/IO/api/asyncIO.mjs.map +1 -1
  563. package/_mjs/IO/api/bracket.mjs +2 -2
  564. package/_mjs/IO/api/bracket.mjs.map +1 -1
  565. package/_mjs/IO/api/bracketExit.mjs +2 -2
  566. package/_mjs/IO/api/bracketExit.mjs.map +1 -1
  567. package/_mjs/IO/api/clockWith.mjs +2 -2
  568. package/_mjs/IO/api/clockWith.mjs.map +1 -1
  569. package/_mjs/IO/api/concurrency.mjs +8 -6
  570. package/_mjs/IO/api/concurrency.mjs.map +1 -1
  571. package/_mjs/IO/api/concurrentFinalizers.mjs +1 -1
  572. package/_mjs/IO/api/concurrentFinalizers.mjs.map +1 -1
  573. package/_mjs/IO/api/consoleWith.mjs +2 -2
  574. package/_mjs/IO/api/consoleWith.mjs.map +1 -1
  575. package/_mjs/IO/api/core-scope.mjs +40 -36
  576. package/_mjs/IO/api/core-scope.mjs.map +1 -1
  577. package/_mjs/IO/api/ensuringChildren.mjs +5 -3
  578. package/_mjs/IO/api/ensuringChildren.mjs.map +1 -1
  579. package/_mjs/IO/api/environment.mjs +29 -27
  580. package/_mjs/IO/api/environment.mjs.map +1 -1
  581. package/_mjs/IO/api/foreachC.mjs +17 -19
  582. package/_mjs/IO/api/foreachC.mjs.map +1 -1
  583. package/_mjs/IO/api/foreachExec.mjs +2 -2
  584. package/_mjs/IO/api/foreachExec.mjs.map +1 -1
  585. package/_mjs/IO/api/forkAll.mjs +1 -1
  586. package/_mjs/IO/api/forkAll.mjs.map +1 -1
  587. package/_mjs/IO/api/forkIn.mjs +7 -5
  588. package/_mjs/IO/api/forkIn.mjs.map +1 -1
  589. package/_mjs/IO/api/forkScoped.mjs +1 -1
  590. package/_mjs/IO/api/forkScoped.mjs.map +1 -1
  591. package/_mjs/IO/api/fulfill.mjs +7 -5
  592. package/_mjs/IO/api/fulfill.mjs.map +1 -1
  593. package/_mjs/IO/api/interrupt.mjs +34 -28
  594. package/_mjs/IO/api/interrupt.mjs.map +1 -1
  595. package/_mjs/IO/api/memoize.mjs +1 -1
  596. package/_mjs/IO/api/memoize.mjs.map +1 -1
  597. package/_mjs/IO/api/onExit.mjs +5 -3
  598. package/_mjs/IO/api/onExit.mjs.map +1 -1
  599. package/_mjs/IO/api/onTermination.mjs +5 -3
  600. package/_mjs/IO/api/onTermination.mjs.map +1 -1
  601. package/_mjs/IO/api/once.mjs +3 -4
  602. package/_mjs/IO/api/once.mjs.map +1 -1
  603. package/_mjs/IO/api/provideLayer.mjs +5 -3
  604. package/_mjs/IO/api/provideLayer.mjs.map +1 -1
  605. package/_mjs/IO/api/provideSomeLayer.mjs +5 -11
  606. package/_mjs/IO/api/provideSomeLayer.mjs.map +1 -1
  607. package/_mjs/IO/api/race.mjs +5 -3
  608. package/_mjs/IO/api/race.mjs.map +1 -1
  609. package/_mjs/IO/api/raceFirst.mjs +5 -3
  610. package/_mjs/IO/api/raceFirst.mjs.map +1 -1
  611. package/_mjs/IO/api/randomWith.mjs +1 -1
  612. package/_mjs/IO/api/randomWith.mjs.map +1 -1
  613. package/_mjs/IO/api/repeat.mjs +8 -8
  614. package/_mjs/IO/api/repeat.mjs.map +1 -1
  615. package/_mjs/IO/api/retry.mjs +12 -12
  616. package/_mjs/IO/api/retry.mjs.map +1 -1
  617. package/_mjs/IO/api/schedule.mjs +15 -11
  618. package/_mjs/IO/api/schedule.mjs.map +1 -1
  619. package/_mjs/IO/api/scoped.mjs +3 -3
  620. package/_mjs/IO/api/scoped.mjs.map +1 -1
  621. package/_mjs/IO/api/sequenceT.mjs +1 -1
  622. package/_mjs/IO/api/sequenceT.mjs.map +1 -1
  623. package/_mjs/IO/api/stateful.mjs.map +1 -1
  624. package/_mjs/IO/api/supervised.mjs +5 -3
  625. package/_mjs/IO/api/supervised.mjs.map +1 -1
  626. package/_mjs/IO/api/timeout.mjs +10 -6
  627. package/_mjs/IO/api/timeout.mjs.map +1 -1
  628. package/_mjs/IO/api/withChildren.mjs +1 -1
  629. package/_mjs/IO/api/withChildren.mjs.map +1 -1
  630. package/_mjs/IO/api/withEarlyRelease.mjs +1 -1
  631. package/_mjs/IO/api/withEarlyRelease.mjs.map +1 -1
  632. package/_mjs/IO/api/withFinalizer.mjs +5 -3
  633. package/_mjs/IO/api/withFinalizer.mjs.map +1 -1
  634. package/_mjs/IO/api/withFinalizerExit.mjs +5 -3
  635. package/_mjs/IO/api/withFinalizerExit.mjs.map +1 -1
  636. package/_mjs/IO/api/withRuntimeConfig.mjs +5 -3
  637. package/_mjs/IO/api/withRuntimeConfig.mjs.map +1 -1
  638. package/_mjs/IO/api/zipC.mjs +18 -14
  639. package/_mjs/IO/api/zipC.mjs.map +1 -1
  640. package/_mjs/IO/api.mjs +511 -387
  641. package/_mjs/IO/api.mjs.map +1 -1
  642. package/_mjs/IO/definition.mjs.map +1 -1
  643. package/_mjs/IO/runtime.mjs +7 -7
  644. package/_mjs/IO/runtime.mjs.map +1 -1
  645. package/_mjs/IO.mjs.map +1 -1
  646. package/_mjs/IOEnv/definition.mjs +1 -1
  647. package/_mjs/IOEnv/definition.mjs.map +1 -1
  648. package/_mjs/IOEnv/live.mjs +1 -1
  649. package/_mjs/IOEnv/live.mjs.map +1 -1
  650. package/_mjs/IOEnv/services.mjs.map +1 -1
  651. package/_mjs/Layer/MemoMap.mjs +86 -87
  652. package/_mjs/Layer/MemoMap.mjs.map +1 -1
  653. package/_mjs/Layer/api.mjs +91 -63
  654. package/_mjs/Layer/api.mjs.map +1 -1
  655. package/_mjs/Layer/definition.mjs.map +1 -1
  656. package/_mjs/LogLevel.mjs +24 -16
  657. package/_mjs/LogLevel.mjs.map +1 -1
  658. package/_mjs/LogSpan.mjs +16 -14
  659. package/_mjs/LogSpan.mjs.map +1 -1
  660. package/_mjs/Logger/api.mjs +16 -12
  661. package/_mjs/Logger/api.mjs.map +1 -1
  662. package/_mjs/Logger/constructors.mjs +1 -1
  663. package/_mjs/Logger/constructors.mjs.map +1 -1
  664. package/_mjs/Queue/constructors.mjs +16 -5
  665. package/_mjs/Queue/constructors.mjs.map +1 -1
  666. package/_mjs/Queue/definition.mjs +174 -12
  667. package/_mjs/Queue/definition.mjs.map +1 -1
  668. package/_mjs/Queue/internal.mjs +21 -170
  669. package/_mjs/Queue/internal.mjs.map +1 -1
  670. package/_mjs/Queue/strategy.mjs +20 -23
  671. package/_mjs/Queue/strategy.mjs.map +1 -1
  672. package/_mjs/Queue.mjs +1 -3
  673. package/_mjs/Queue.mjs.map +1 -1
  674. package/_mjs/Random/live.mjs +2 -2
  675. package/_mjs/Random/live.mjs.map +1 -1
  676. package/_mjs/Ref/Atomic.mjs +39 -3
  677. package/_mjs/Ref/Atomic.mjs.map +1 -1
  678. package/_mjs/Ref/Synchronized.mjs +123 -0
  679. package/_mjs/Ref/Synchronized.mjs.map +1 -0
  680. package/_mjs/Ref/constructors.mjs +15 -1
  681. package/_mjs/Ref/constructors.mjs.map +1 -1
  682. package/_mjs/Ref/definition.mjs +96 -4
  683. package/_mjs/Ref/definition.mjs.map +1 -1
  684. package/_mjs/Ref.mjs +1 -8
  685. package/_mjs/Ref.mjs.map +1 -1
  686. package/_mjs/Reloadable/constructors.mjs +10 -10
  687. package/_mjs/Reloadable/constructors.mjs.map +1 -1
  688. package/_mjs/RuntimeConfig.mjs +2 -2
  689. package/_mjs/RuntimeConfig.mjs.map +1 -1
  690. package/_mjs/STM/api/core-api.mjs +29 -19
  691. package/_mjs/STM/api/core-api.mjs.map +1 -1
  692. package/_mjs/STM/api.mjs +180 -127
  693. package/_mjs/STM/api.mjs.map +1 -1
  694. package/_mjs/STM/driver.mjs +3 -3
  695. package/_mjs/STM/driver.mjs.map +1 -1
  696. package/_mjs/STM/internal/Entry.mjs.map +1 -1
  697. package/_mjs/STM/internal/Journal.mjs +33 -29
  698. package/_mjs/STM/internal/Journal.mjs.map +1 -1
  699. package/_mjs/STM.mjs.map +1 -1
  700. package/_mjs/Schedule/Decision.mjs +14 -12
  701. package/_mjs/Schedule/Decision.mjs.map +1 -1
  702. package/_mjs/Schedule/api/driver.mjs +15 -17
  703. package/_mjs/Schedule/api/driver.mjs.map +1 -1
  704. package/_mjs/Schedule/api.mjs +326 -234
  705. package/_mjs/Schedule/api.mjs.map +1 -1
  706. package/_mjs/Scope/ReleaseMap/api/releaseAll.mjs +12 -11
  707. package/_mjs/Scope/ReleaseMap/api/releaseAll.mjs.map +1 -1
  708. package/_mjs/Scope/ReleaseMap/api.mjs +60 -51
  709. package/_mjs/Scope/ReleaseMap/api.mjs.map +1 -1
  710. package/_mjs/Scope/api.mjs +28 -22
  711. package/_mjs/Scope/api.mjs.map +1 -1
  712. package/_mjs/ScopedRef/api.mjs +9 -11
  713. package/_mjs/ScopedRef/api.mjs.map +1 -1
  714. package/_mjs/ScopedRef/definition.mjs +1 -1
  715. package/_mjs/ScopedRef/definition.mjs.map +1 -1
  716. package/_mjs/Sink/api.mjs +301 -240
  717. package/_mjs/Sink/api.mjs.map +1 -1
  718. package/_mjs/State/api.mjs +16 -12
  719. package/_mjs/State/api.mjs.map +1 -1
  720. package/_mjs/Stream/api/zipAllWith.mjs +14 -12
  721. package/_mjs/Stream/api/zipAllWith.mjs.map +1 -1
  722. package/_mjs/Stream/api/zipWith.mjs +5 -3
  723. package/_mjs/Stream/api/zipWith.mjs.map +1 -1
  724. package/_mjs/Stream/api/zipWithChunks.mjs +12 -10
  725. package/_mjs/Stream/api/zipWithChunks.mjs.map +1 -1
  726. package/_mjs/Stream/api.mjs +856 -653
  727. package/_mjs/Stream/api.mjs.map +1 -1
  728. package/_mjs/Stream/definition.mjs.map +1 -1
  729. package/_mjs/Stream/internal/DebounceState.mjs +18 -16
  730. package/_mjs/Stream/internal/DebounceState.mjs.map +1 -1
  731. package/_mjs/Stream/internal/Handoff.mjs +35 -32
  732. package/_mjs/Stream/internal/Handoff.mjs.map +1 -1
  733. package/_mjs/Stream/internal/Pull.mjs +9 -10
  734. package/_mjs/Stream/internal/Pull.mjs.map +1 -1
  735. package/_mjs/Stream/internal/SinkEndReason.mjs +14 -12
  736. package/_mjs/Stream/internal/SinkEndReason.mjs.map +1 -1
  737. package/_mjs/Stream/internal/Take.mjs +28 -20
  738. package/_mjs/Stream/internal/Take.mjs.map +1 -1
  739. package/_mjs/Stream/internal/util.mjs +3 -3
  740. package/_mjs/Stream/internal/util.mjs.map +1 -1
  741. package/_mjs/SubscriptionRef.mjs +45 -0
  742. package/_mjs/SubscriptionRef.mjs.map +1 -0
  743. package/_mjs/Supervisor/api.mjs +44 -33
  744. package/_mjs/Supervisor/api.mjs.map +1 -1
  745. package/_mjs/Supervisor/constructors.mjs +2 -2
  746. package/_mjs/Supervisor/constructors.mjs.map +1 -1
  747. package/_mjs/Supervisor/definition.mjs +55 -0
  748. package/_mjs/Supervisor/definition.mjs.map +1 -1
  749. package/_mjs/SupervisorPatch.mjs +135 -0
  750. package/_mjs/SupervisorPatch.mjs.map +1 -0
  751. package/_mjs/TExit/definition.mjs.map +1 -1
  752. package/_mjs/TFuture/api.mjs +17 -11
  753. package/_mjs/TFuture/api.mjs.map +1 -1
  754. package/_mjs/TFuture/constructors.mjs +1 -1
  755. package/_mjs/TFuture/constructors.mjs.map +1 -1
  756. package/_mjs/TFuture/definition.mjs.map +1 -1
  757. package/_mjs/TReentrantLock/api.mjs +32 -28
  758. package/_mjs/TReentrantLock/api.mjs.map +1 -1
  759. package/_mjs/TReentrantLock/definition.mjs +4 -4
  760. package/_mjs/TReentrantLock/definition.mjs.map +1 -1
  761. package/_mjs/TRef/api.mjs +218 -194
  762. package/_mjs/TRef/api.mjs.map +1 -1
  763. package/_mjs/TRef/definition.mjs +4 -4
  764. package/_mjs/TRef/definition.mjs.map +1 -1
  765. package/_mjs/TSemaphore/api.mjs +23 -19
  766. package/_mjs/TSemaphore/api.mjs.map +1 -1
  767. package/_mjs/TSemaphore/constructors.mjs +12 -2
  768. package/_mjs/TSemaphore/constructors.mjs.map +1 -1
  769. package/_mjs/collection/immutable/Conc/dropUntilIO.mjs +19 -17
  770. package/_mjs/collection/immutable/Conc/dropUntilIO.mjs.map +1 -1
  771. package/_mjs/collection/immutable/Conc/dropWhileIO.mjs +19 -17
  772. package/_mjs/collection/immutable/Conc/dropWhileIO.mjs.map +1 -1
  773. package/_mjs/collection/immutable/Conc/filterIO.mjs +14 -12
  774. package/_mjs/collection/immutable/Conc/filterIO.mjs.map +1 -1
  775. package/_mjs/collection/immutable/Conc/findIO.mjs +17 -15
  776. package/_mjs/collection/immutable/Conc/findIO.mjs.map +1 -1
  777. package/_mjs/collection/immutable/Conc/mapIO.mjs +10 -8
  778. package/_mjs/collection/immutable/Conc/mapIO.mjs.map +1 -1
  779. package/_mjs/collection/immutable/Conc/takeWhileIO.mjs +28 -26
  780. package/_mjs/collection/immutable/Conc/takeWhileIO.mjs.map +1 -1
  781. package/_mjs/data/Exit/foreachIO.mjs +5 -3
  782. package/_mjs/data/Exit/foreachIO.mjs.map +1 -1
  783. package/_mjs/internal/Hub.mjs +13 -11
  784. package/_mjs/internal/Hub.mjs.map +1 -1
  785. package/_mjs/internal/IsFatal.mjs +18 -16
  786. package/_mjs/internal/IsFatal.mjs.map +1 -1
  787. package/_mjs/internal/MutableQueue.mjs +10 -8
  788. package/_mjs/internal/MutableQueue.mjs.map +1 -1
  789. package/_mjs/internal/StackTraceBuilder.mjs.map +1 -1
  790. package/_src/Cached/api.ts +2 -2
  791. package/_src/Channel/ChildExecutorDecision/api.ts +14 -17
  792. package/_src/Channel/UpstreamPullRequest/api.ts +11 -13
  793. package/_src/Channel/api/interruptWhen.ts +18 -17
  794. package/_src/Channel/api/mapOutIOC.ts +58 -58
  795. package/_src/Channel/api/mergeAll.ts +15 -16
  796. package/_src/Channel/api/mergeAllUnboundedWith.ts +15 -27
  797. package/_src/Channel/api/mergeAllWith.ts +114 -126
  798. package/_src/Channel/api/mergeMap.ts +8 -18
  799. package/_src/Channel/api/mergeWith.ts +154 -158
  800. package/_src/Channel/api/toPull.ts +1 -1
  801. package/_src/Channel/api/zipC.ts +52 -88
  802. package/_src/Channel/api.ts +345 -405
  803. package/_src/Channel/core-api.ts +75 -122
  804. package/_src/Channel/definition.ts +49 -7
  805. package/_src/Channel/internal/ChannelExecutor.ts +1 -5
  806. package/_src/Channel/internal/SingleProducerAsyncInput.ts +1 -3
  807. package/_src/Differ/api.ts +72 -0
  808. package/_src/Differ/definition.ts +16 -0
  809. package/_src/Fiber/FiberContext.ts +13 -33
  810. package/_src/Fiber/api/collectAll.ts +1 -2
  811. package/_src/Fiber/api/evalOn.ts +11 -14
  812. package/_src/Fiber/api/evalOnIO.ts +10 -13
  813. package/_src/Fiber/api/interruptAll.ts +1 -2
  814. package/_src/Fiber/api/interruptAs.ts +6 -4
  815. package/_src/Fiber/api/interruptAsFork.ts +6 -4
  816. package/_src/Fiber/api/interruptFork.ts +1 -1
  817. package/_src/Fiber/api/mapFiber.ts +5 -7
  818. package/_src/Fiber/api/mapIO.ts +21 -21
  819. package/_src/Fiber/api/zipWith.ts +14 -17
  820. package/_src/Fiber/definition.ts +1 -15
  821. package/_src/Fiber.ts +1 -1
  822. package/_src/FiberRef/api/locallyScoped.ts +8 -6
  823. package/_src/FiberRef/api/locallyScopedWith.ts +5 -7
  824. package/_src/FiberRef/api.ts +50 -39
  825. package/_src/FiberRef/unsafe.ts +24 -22
  826. package/_src/FiberRef.ts +0 -1
  827. package/_src/FiberRefs/api.ts +14 -12
  828. package/_src/FiberRefs/join.ts +37 -46
  829. package/_src/FiberState/definition.ts +1 -2
  830. package/_src/Future/api.ts +67 -53
  831. package/_src/Hub/constructors.ts +80 -0
  832. package/_src/Hub/definition.ts +95 -89
  833. package/_src/Hub/internal.ts +115 -165
  834. package/_src/Hub.ts +1 -1
  835. package/_src/IO/api/acquireRelease.ts +1 -1
  836. package/_src/IO/api/acquireReleaseExit.ts +1 -1
  837. package/_src/IO/api/bracket.ts +1 -1
  838. package/_src/IO/api/bracketExit.ts +1 -1
  839. package/_src/IO/api/clockWith.ts +0 -1
  840. package/_src/IO/api/concurrency.ts +5 -7
  841. package/_src/IO/api/consoleWith.ts +0 -2
  842. package/_src/IO/api/core-scope.ts +36 -33
  843. package/_src/IO/api/ensuringChildren.ts +8 -7
  844. package/_src/IO/api/environment.ts +24 -42
  845. package/_src/IO/api/foreachC.ts +24 -12
  846. package/_src/IO/api/foreachExec.ts +1 -1
  847. package/_src/IO/api/forkIn.ts +7 -9
  848. package/_src/IO/api/fulfill.ts +5 -3
  849. package/_src/IO/api/interrupt.ts +37 -40
  850. package/_src/IO/api/onExit.ts +8 -10
  851. package/_src/IO/api/onTermination.ts +12 -14
  852. package/_src/IO/api/provideLayer.ts +8 -10
  853. package/_src/IO/api/provideSomeLayer.ts +5 -14
  854. package/_src/IO/api/race.ts +19 -21
  855. package/_src/IO/api/raceFirst.ts +5 -7
  856. package/_src/IO/api/repeat.ts +3 -5
  857. package/_src/IO/api/retry.ts +19 -21
  858. package/_src/IO/api/schedule.ts +20 -21
  859. package/_src/IO/api/scoped.ts +2 -2
  860. package/_src/IO/api/sequenceT.ts +7 -1
  861. package/_src/IO/api/stateful.ts +0 -2
  862. package/_src/IO/api/supervised.ts +5 -7
  863. package/_src/IO/api/timeout.ts +10 -16
  864. package/_src/IO/api/withFinalizer.ts +5 -7
  865. package/_src/IO/api/withFinalizerExit.ts +6 -5
  866. package/_src/IO/api/withRuntimeConfig.ts +12 -14
  867. package/_src/IO/api/zipC.ts +57 -62
  868. package/_src/IO/api.ts +512 -539
  869. package/_src/IO/definition.ts +21 -9
  870. package/_src/IO/runtime.ts +0 -12
  871. package/_src/IO.ts +0 -1
  872. package/_src/IOEnv/definition.ts +0 -2
  873. package/_src/IOEnv/services.ts +5 -4
  874. package/_src/Layer/MemoMap.ts +61 -63
  875. package/_src/Layer/api.ts +95 -104
  876. package/_src/Layer/definition.ts +0 -1
  877. package/_src/LogLevel.ts +24 -16
  878. package/_src/LogSpan.ts +16 -16
  879. package/_src/Logger/api.ts +18 -17
  880. package/_src/Logger/constructors.ts +9 -15
  881. package/_src/Queue/constructors.ts +22 -6
  882. package/_src/Queue/definition.ts +230 -81
  883. package/_src/Queue/internal.ts +9 -180
  884. package/_src/Queue/strategy.ts +9 -23
  885. package/_src/Queue.ts +1 -3
  886. package/_src/Ref/Atomic.ts +37 -4
  887. package/_src/Ref/Synchronized.ts +107 -0
  888. package/_src/Ref/constructors.ts +15 -0
  889. package/_src/Ref/definition.ts +86 -85
  890. package/_src/Ref.ts +1 -9
  891. package/_src/Reloadable/constructors.ts +2 -2
  892. package/_src/RuntimeConfig.ts +0 -2
  893. package/_src/STM/api/core-api.ts +32 -35
  894. package/_src/STM/api.ts +210 -200
  895. package/_src/STM/internal/Entry.ts +0 -10
  896. package/_src/STM/internal/Journal.ts +23 -26
  897. package/_src/STM.ts +0 -1
  898. package/_src/Schedule/Decision.ts +10 -8
  899. package/_src/Schedule/api/driver.ts +0 -4
  900. package/_src/Schedule/api.ts +419 -444
  901. package/_src/Schedule/definition.ts +0 -1
  902. package/_src/Scope/ReleaseMap/api/releaseAll.ts +23 -26
  903. package/_src/Scope/ReleaseMap/api.ts +77 -74
  904. package/_src/Scope/api.ts +16 -18
  905. package/_src/ScopedRef/api.ts +0 -3
  906. package/_src/ScopedRef/definition.ts +1 -2
  907. package/_src/Sink/api.ts +326 -357
  908. package/_src/State/api.ts +12 -8
  909. package/_src/State/internal.ts +1 -1
  910. package/_src/Stream/api/zipAllWith.ts +6 -5
  911. package/_src/Stream/api/zipWith.ts +5 -8
  912. package/_src/Stream/api/zipWithChunks.ts +6 -5
  913. package/_src/Stream/api.ts +1049 -1176
  914. package/_src/Stream/definition.ts +0 -2
  915. package/_src/Stream/internal/DebounceState.ts +16 -17
  916. package/_src/Stream/internal/Handoff.ts +31 -35
  917. package/_src/Stream/internal/Pull.ts +1 -2
  918. package/_src/Stream/internal/SinkEndReason.ts +13 -14
  919. package/_src/Stream/internal/Take.ts +21 -21
  920. package/_src/Stream/internal/util.ts +0 -2
  921. package/_src/SubscriptionRef.ts +44 -0
  922. package/_src/Supervisor/api.ts +39 -31
  923. package/_src/Supervisor/definition.ts +58 -0
  924. package/_src/SupervisorPatch.ts +111 -0
  925. package/_src/TExit/definition.ts +0 -8
  926. package/_src/TFuture/api.ts +23 -17
  927. package/_src/TFuture/definition.ts +0 -1
  928. package/_src/TReentrantLock/api.ts +14 -10
  929. package/_src/TReentrantLock/definition.ts +0 -7
  930. package/_src/TRef/api.ts +207 -209
  931. package/_src/TRef/definition.ts +0 -12
  932. package/_src/TSemaphore/api.ts +19 -18
  933. package/_src/TSemaphore/constructors.ts +7 -0
  934. package/_src/collection/immutable/Conc/dropUntilIO.ts +19 -21
  935. package/_src/collection/immutable/Conc/dropWhileIO.ts +21 -23
  936. package/_src/collection/immutable/Conc/filterIO.ts +15 -17
  937. package/_src/collection/immutable/Conc/findIO.ts +17 -19
  938. package/_src/collection/immutable/Conc/mapIO.ts +12 -10
  939. package/_src/collection/immutable/Conc/takeWhileIO.ts +27 -29
  940. package/_src/data/Exit/foreachIO.ts +8 -10
  941. package/_src/global.ts +11 -3
  942. package/_src/index.ts +3 -0
  943. package/_src/internal/Hub.ts +17 -27
  944. package/_src/internal/IsFatal.ts +14 -12
  945. package/_src/internal/MutableQueue.ts +8 -8
  946. package/_src/internal/StackTraceBuilder.ts +1 -2
  947. package/collection/immutable/Conc/dropUntilIO.d.ts +3 -3
  948. package/collection/immutable/Conc/dropWhileIO.d.ts +3 -3
  949. package/collection/immutable/Conc/filterIO.d.ts +3 -3
  950. package/collection/immutable/Conc/findIO.d.ts +2 -2
  951. package/collection/immutable/Conc/mapIO.d.ts +3 -3
  952. package/collection/immutable/Conc/takeWhileIO.d.ts +3 -3
  953. package/data/Exit/foreachIO.d.ts +3 -3
  954. package/global.d.ts +11 -3
  955. package/index.d.ts +3 -0
  956. package/internal/Hub.d.ts +2 -2
  957. package/internal/IsFatal.d.ts +3 -3
  958. package/internal/MutableQueue.d.ts +3 -3
  959. package/package.json +3 -3
  960. package/Hub/api.d.ts +0 -190
  961. package/Queue/api/dimapIO.d.ts +0 -41
  962. package/Queue/api/filterInputIO.d.ts +0 -33
  963. package/Queue/api/filterOutputIO.d.ts +0 -31
  964. package/Queue/api/operations.d.ts +0 -82
  965. package/Queue/api/poll.d.ts +0 -9
  966. package/Queue/api/takeBetween.d.ts +0 -11
  967. package/Queue/api/zipWithIO.d.ts +0 -44
  968. package/Queue/api.d.ts +0 -7
  969. package/Ref/Atomic/Atomic.d.ts +0 -18
  970. package/Ref/Atomic/api.d.ts +0 -53
  971. package/Ref/Derived.d.ts +0 -14
  972. package/Ref/DerivedAll.d.ts +0 -14
  973. package/Ref/Synchronized/api.d.ts +0 -100
  974. package/Ref/Synchronized/constructors.d.ts +0 -8
  975. package/Ref/Synchronized/definition.d.ts +0 -42
  976. package/Ref/api/collect.d.ts +0 -11
  977. package/Ref/api/dimap.d.ts +0 -56
  978. package/Ref/api/filter.d.ts +0 -20
  979. package/Ref/api/get.d.ts +0 -9
  980. package/Ref/api/match.d.ts +0 -13
  981. package/Ref/api/matchAll.d.ts +0 -11
  982. package/Ref/api/modify.d.ts +0 -79
  983. package/Ref/api/set.d.ts +0 -10
  984. package/Ref/api.d.ts +0 -23
  985. package/_cjs/Hub/api.cjs +0 -456
  986. package/_cjs/Hub/api.cjs.map +0 -1
  987. package/_cjs/Queue/api/dimapIO.cjs +0 -120
  988. package/_cjs/Queue/api/dimapIO.cjs.map +0 -1
  989. package/_cjs/Queue/api/filterInputIO.cjs +0 -84
  990. package/_cjs/Queue/api/filterInputIO.cjs.map +0 -1
  991. package/_cjs/Queue/api/filterOutputIO.cjs +0 -89
  992. package/_cjs/Queue/api/filterOutputIO.cjs.map +0 -1
  993. package/_cjs/Queue/api/operations.cjs +0 -147
  994. package/_cjs/Queue/api/operations.cjs.map +0 -1
  995. package/_cjs/Queue/api/poll.cjs +0 -27
  996. package/_cjs/Queue/api/poll.cjs.map +0 -1
  997. package/_cjs/Queue/api/takeBetween.cjs +0 -57
  998. package/_cjs/Queue/api/takeBetween.cjs.map +0 -1
  999. package/_cjs/Queue/api/zipWithIO.cjs +0 -97
  1000. package/_cjs/Queue/api/zipWithIO.cjs.map +0 -1
  1001. package/_cjs/Queue/api.cjs +0 -97
  1002. package/_cjs/Queue/api.cjs.map +0 -1
  1003. package/_cjs/Ref/Atomic/Atomic.cjs +0 -64
  1004. package/_cjs/Ref/Atomic/Atomic.cjs.map +0 -1
  1005. package/_cjs/Ref/Atomic/api.cjs +0 -156
  1006. package/_cjs/Ref/Atomic/api.cjs.map +0 -1
  1007. package/_cjs/Ref/Derived.cjs +0 -55
  1008. package/_cjs/Ref/Derived.cjs.map +0 -1
  1009. package/_cjs/Ref/DerivedAll.cjs +0 -55
  1010. package/_cjs/Ref/DerivedAll.cjs.map +0 -1
  1011. package/_cjs/Ref/Synchronized/api.cjs +0 -196
  1012. package/_cjs/Ref/Synchronized/api.cjs.map +0 -1
  1013. package/_cjs/Ref/Synchronized/constructors.cjs +0 -32
  1014. package/_cjs/Ref/Synchronized/constructors.cjs.map +0 -1
  1015. package/_cjs/Ref/Synchronized/definition.cjs +0 -88
  1016. package/_cjs/Ref/Synchronized/definition.cjs.map +0 -1
  1017. package/_cjs/Ref/api/collect.cjs +0 -31
  1018. package/_cjs/Ref/api/collect.cjs.map +0 -1
  1019. package/_cjs/Ref/api/dimap.cjs +0 -110
  1020. package/_cjs/Ref/api/dimap.cjs.map +0 -1
  1021. package/_cjs/Ref/api/filter.cjs +0 -45
  1022. package/_cjs/Ref/api/filter.cjs.map +0 -1
  1023. package/_cjs/Ref/api/get.cjs +0 -20
  1024. package/_cjs/Ref/api/get.cjs.map +0 -1
  1025. package/_cjs/Ref/api/match.cjs +0 -26
  1026. package/_cjs/Ref/api/match.cjs.map +0 -1
  1027. package/_cjs/Ref/api/matchAll.cjs +0 -24
  1028. package/_cjs/Ref/api/matchAll.cjs.map +0 -1
  1029. package/_cjs/Ref/api/modify.cjs +0 -239
  1030. package/_cjs/Ref/api/modify.cjs.map +0 -1
  1031. package/_cjs/Ref/api/set.cjs +0 -21
  1032. package/_cjs/Ref/api/set.cjs.map +0 -1
  1033. package/_cjs/Ref/api.cjs +0 -158
  1034. package/_cjs/Ref/api.cjs.map +0 -1
  1035. package/_mjs/Hub/api.mjs +0 -384
  1036. package/_mjs/Hub/api.mjs.map +0 -1
  1037. package/_mjs/Queue/api/dimapIO.mjs +0 -97
  1038. package/_mjs/Queue/api/dimapIO.mjs.map +0 -1
  1039. package/_mjs/Queue/api/filterInputIO.mjs +0 -63
  1040. package/_mjs/Queue/api/filterInputIO.mjs.map +0 -1
  1041. package/_mjs/Queue/api/filterOutputIO.mjs +0 -68
  1042. package/_mjs/Queue/api/filterOutputIO.mjs.map +0 -1
  1043. package/_mjs/Queue/api/operations.mjs +0 -122
  1044. package/_mjs/Queue/api/operations.mjs.map +0 -1
  1045. package/_mjs/Queue/api/poll.mjs +0 -14
  1046. package/_mjs/Queue/api/poll.mjs.map +0 -1
  1047. package/_mjs/Queue/api/takeBetween.mjs +0 -43
  1048. package/_mjs/Queue/api/takeBetween.mjs.map +0 -1
  1049. package/_mjs/Queue/api/zipWithIO.mjs +0 -74
  1050. package/_mjs/Queue/api/zipWithIO.mjs.map +0 -1
  1051. package/_mjs/Queue/api.mjs +0 -9
  1052. package/_mjs/Queue/api.mjs.map +0 -1
  1053. package/_mjs/Ref/Atomic/Atomic.mjs +0 -47
  1054. package/_mjs/Ref/Atomic/Atomic.mjs.map +0 -1
  1055. package/_mjs/Ref/Atomic/api.mjs +0 -127
  1056. package/_mjs/Ref/Atomic/api.mjs.map +0 -1
  1057. package/_mjs/Ref/Derived.mjs +0 -35
  1058. package/_mjs/Ref/Derived.mjs.map +0 -1
  1059. package/_mjs/Ref/DerivedAll.mjs +0 -35
  1060. package/_mjs/Ref/DerivedAll.mjs.map +0 -1
  1061. package/_mjs/Ref/Synchronized/api.mjs +0 -154
  1062. package/_mjs/Ref/Synchronized/api.mjs.map +0 -1
  1063. package/_mjs/Ref/Synchronized/constructors.mjs +0 -15
  1064. package/_mjs/Ref/Synchronized/constructors.mjs.map +0 -1
  1065. package/_mjs/Ref/Synchronized/definition.mjs +0 -66
  1066. package/_mjs/Ref/Synchronized/definition.mjs.map +0 -1
  1067. package/_mjs/Ref/api/collect.mjs +0 -17
  1068. package/_mjs/Ref/api/collect.mjs.map +0 -1
  1069. package/_mjs/Ref/api/dimap.mjs +0 -84
  1070. package/_mjs/Ref/api/dimap.mjs.map +0 -1
  1071. package/_mjs/Ref/api/filter.mjs +0 -29
  1072. package/_mjs/Ref/api/filter.mjs.map +0 -1
  1073. package/_mjs/Ref/api/get.mjs +0 -13
  1074. package/_mjs/Ref/api/get.mjs.map +0 -1
  1075. package/_mjs/Ref/api/match.mjs +0 -18
  1076. package/_mjs/Ref/api/match.mjs.map +0 -1
  1077. package/_mjs/Ref/api/matchAll.mjs +0 -16
  1078. package/_mjs/Ref/api/matchAll.mjs.map +0 -1
  1079. package/_mjs/Ref/api/modify.mjs +0 -204
  1080. package/_mjs/Ref/api/modify.mjs.map +0 -1
  1081. package/_mjs/Ref/api/set.mjs +0 -14
  1082. package/_mjs/Ref/api/set.mjs.map +0 -1
  1083. package/_mjs/Ref/api.mjs +0 -34
  1084. package/_mjs/Ref/api.mjs.map +0 -1
  1085. package/_src/Hub/api.ts +0 -461
  1086. package/_src/Queue/api/dimapIO.ts +0 -130
  1087. package/_src/Queue/api/filterInputIO.ts +0 -75
  1088. package/_src/Queue/api/filterOutputIO.ts +0 -76
  1089. package/_src/Queue/api/operations.ts +0 -139
  1090. package/_src/Queue/api/poll.ts +0 -14
  1091. package/_src/Queue/api/takeBetween.ts +0 -45
  1092. package/_src/Queue/api/zipWithIO.ts +0 -99
  1093. package/_src/Queue/api.ts +0 -9
  1094. package/_src/Ref/Atomic/Atomic.ts +0 -56
  1095. package/_src/Ref/Atomic/api.ts +0 -124
  1096. package/_src/Ref/Derived.ts +0 -71
  1097. package/_src/Ref/DerivedAll.ts +0 -75
  1098. package/_src/Ref/Synchronized/api.ts +0 -249
  1099. package/_src/Ref/Synchronized/constructors.ts +0 -12
  1100. package/_src/Ref/Synchronized/definition.ts +0 -126
  1101. package/_src/Ref/api/collect.ts +0 -19
  1102. package/_src/Ref/api/dimap.ts +0 -115
  1103. package/_src/Ref/api/filter.ts +0 -35
  1104. package/_src/Ref/api/get.ts +0 -17
  1105. package/_src/Ref/api/match.ts +0 -24
  1106. package/_src/Ref/api/matchAll.ts +0 -23
  1107. package/_src/Ref/api/modify.ts +0 -237
  1108. package/_src/Ref/api/set.ts +0 -19
  1109. package/_src/Ref/api.ts +0 -39
package/_mjs/Sink/api.mjs CHANGED
@@ -4,34 +4,31 @@ import * as tsplus_module_2 from "@fncts/base/collection/immutable/Conc/api";
4
4
  import * as tsplus_module_3 from "@fncts/io/Sink/definition";
5
5
  import * as tsplus_module_4 from "@fncts/io/Channel/api";
6
6
  import * as tsplus_module_5 from "@fncts/io/Channel/core-api";
7
- import * as tsplus_module_6 from "@fncts/io/Ref/api/set";
8
- import * as tsplus_module_7 from "@fncts/io/Ref/api/get";
9
- import * as tsplus_module_8 from "@fncts/io/Ref/constructors";
10
- import * as tsplus_module_9 from "@fncts/io/IO/api";
11
- import * as tsplus_module_10 from "@fncts/io/collection/immutable/Conc/mapIO";
12
- import * as tsplus_module_11 from "@fncts/io/collection/immutable/Conc/dropUntilIO";
13
- import * as tsplus_module_12 from "@fncts/io/collection/immutable/Conc/dropWhileIO";
14
- import * as tsplus_module_13 from "@fncts/io/IO/api/environment";
15
- import * as tsplus_module_14 from "@fncts/base/data/function/api";
16
- import * as tsplus_module_15 from "@fncts/io/collection/immutable/Conc/filterIO";
17
- import * as tsplus_module_16 from "@fncts/base/data/Maybe/constructors";
18
- import * as tsplus_module_17 from "@fncts/base/data/Either/destructors";
19
- import * as tsplus_module_18 from "@fncts/io/Queue/api/operations";
20
- import * as tsplus_module_19 from "@fncts/io/IO/api/acquireRelease";
21
- import * as tsplus_module_20 from "@fncts/base/data/Cause/api";
22
- import * as tsplus_module_21 from "@fncts/base/data/Maybe/definition";
23
- import * as tsplus_module_22 from "@fncts/base/data/Maybe/destructors";
24
- import * as tsplus_module_23 from "@fncts/base/collection/immutable/Conc";
25
- import * as tsplus_module_24 from "@fncts/base/collection/immutable/Conc/constructors";
26
- import * as tsplus_module_25 from "@fncts/base/data/Either/api";
27
- import * as tsplus_module_26 from "@fncts/base/data/Either/constructors";
28
- import * as tsplus_module_27 from "@fncts/io/Channel/internal/MergeDecision";
29
- import * as tsplus_module_28 from "@fncts/io/Channel/api/mergeWith";
30
- import * as tsplus_module_29 from "@fncts/io/Hub/api";
31
- import * as tsplus_module_30 from "@fncts/base/collection/Iterable/api";
32
- import * as tsplus_module_31 from "@fncts/io/Clock/api";
33
- import * as tsplus_module_32 from "@fncts/base/data/Duration/api";
34
- import * as tsplus_module_33 from "@fncts/base/data/Exit/api";
7
+ import * as tsplus_module_6 from "@fncts/io/Ref/constructors";
8
+ import * as tsplus_module_7 from "@fncts/io/IO/api";
9
+ import * as tsplus_module_8 from "@fncts/io/collection/immutable/Conc/mapIO";
10
+ import * as tsplus_module_9 from "@fncts/io/collection/immutable/Conc/dropUntilIO";
11
+ import * as tsplus_module_10 from "@fncts/io/collection/immutable/Conc/dropWhileIO";
12
+ import * as tsplus_module_11 from "@fncts/io/IO/api/environment";
13
+ import * as tsplus_module_12 from "@fncts/base/data/function/api";
14
+ import * as tsplus_module_13 from "@fncts/io/collection/immutable/Conc/filterIO";
15
+ import * as tsplus_module_14 from "@fncts/base/data/Maybe/constructors";
16
+ import * as tsplus_module_15 from "@fncts/base/data/Either/destructors";
17
+ import * as tsplus_module_16 from "@fncts/io/IO/api/acquireRelease";
18
+ import * as tsplus_module_17 from "@fncts/base/data/Cause/api";
19
+ import * as tsplus_module_18 from "@fncts/base/data/Maybe/definition";
20
+ import * as tsplus_module_19 from "@fncts/base/data/Maybe/destructors";
21
+ import * as tsplus_module_20 from "@fncts/base/collection/immutable/Conc";
22
+ import * as tsplus_module_21 from "@fncts/base/collection/immutable/Conc/constructors";
23
+ import * as tsplus_module_22 from "@fncts/base/data/Either/api";
24
+ import * as tsplus_module_23 from "@fncts/base/data/Either/constructors";
25
+ import * as tsplus_module_24 from "@fncts/io/Channel/internal/MergeDecision";
26
+ import * as tsplus_module_25 from "@fncts/io/Channel/api/mergeWith";
27
+ import * as tsplus_module_26 from "@fncts/io/Hub/constructors";
28
+ import * as tsplus_module_27 from "@fncts/base/collection/Iterable/api";
29
+ import * as tsplus_module_28 from "@fncts/io/Clock/api";
30
+ import * as tsplus_module_29 from "@fncts/base/data/Duration/api";
31
+ import * as tsplus_module_30 from "@fncts/base/data/Exit/api";
35
32
  export const collectAllWhileWith = collectAllWhileWith_1;
36
33
  export const contramap = contramap_1;
37
34
  export const contramapChunks = contramapChunks_1;
@@ -56,9 +53,9 @@ export const makeFoldLeft = makeFoldLeft_1;
56
53
  export const makeFoldIO = makeFoldIO_1;
57
54
  export const makeFoldWeightedDecompose = makeFoldWeightedDecompose_1;
58
55
  export const makeFoldWeightedDecomposeIO = makeFoldWeightedDecomposeIO_1;
59
- export const map_ = map_1;
60
- export const mapIO_ = mapIO_1;
61
- export const matchSink_ = matchSink_1;
56
+ export const map = map_1;
57
+ export const mapIO = mapIO_1;
58
+ export const matchSink = matchSink_1;
62
59
  export const raceBoth = raceBoth_1;
63
60
  export const raceWith = raceWith_1;
64
61
  export const serviceWith = serviceWith_1;
@@ -71,84 +68,98 @@ import { AtomicReference } from "@fncts/base/internal/AtomicReference";
71
68
  /**
72
69
  * Like {@link zip}, but keeps only the result from this sink
73
70
  *
74
- * @tsplus fluent fncts.io.Sink apFirst
71
+ * @tsplus pipeable fncts.io.Sink apFirst
75
72
  */
76
73
 
77
- export function apFirst(self, that, __tsplusTrace) {
78
- return zipWith_1(() => self, that, (z, _) => z, __tsplusTrace);
74
+ export function apFirst(that, __tsplusTrace) {
75
+ return self => {
76
+ return zipWith_1(that, (z, _) => z, __tsplusTrace)(() => self);
77
+ };
79
78
  }
80
79
  /**
81
80
  * Like {@link zipC}, but keeps only the result from this sink
82
81
  *
83
- * @tsplus fluent fncts.io.Sink apFirstC
82
+ * @tsplus pipeable fncts.io.Sink apFirstC
84
83
  */
85
84
 
86
- export function apFirstC(self, that, __tsplusTrace) {
87
- return zipWithC_1(() => self, that, (z, _) => z, __tsplusTrace);
85
+ export function apFirstC(that, __tsplusTrace) {
86
+ return self => {
87
+ return zipWithC_1(that, (z, _) => z, __tsplusTrace)(() => self);
88
+ };
88
89
  }
89
90
  /**
90
91
  * Like {@link zip}, but keeps only the result from the `that` sink
91
92
  *
92
- * @tsplus fluent fncts.io.Sink apSecond
93
+ * @tsplus pipeable fncts.io.Sink apSecond
93
94
  */
94
95
 
95
- export function apSecond(self, that, __tsplusTrace) {
96
- return zipWith_1(() => self, that, (_, z1) => z1, __tsplusTrace);
96
+ export function apSecond(that, __tsplusTrace) {
97
+ return self => {
98
+ return zipWith_1(that, (_, z1) => z1, __tsplusTrace)(() => self);
99
+ };
97
100
  }
98
101
  /**
99
102
  * Like {@link zipC}, but keeps only the result from the `that` sink
100
103
  *
101
- * @tsplus fluent fncts.io.Sink apSecondC
104
+ * @tsplus pipeable fncts.io.Sink apSecondC
102
105
  */
103
106
 
104
- export function apSecondC(self, that, __tsplusTrace) {
105
- return zipWithC_1(() => self, that, (_, z1) => z1, __tsplusTrace);
107
+ export function apSecondC(that, __tsplusTrace) {
108
+ return self => {
109
+ return zipWithC_1(that, (_, z1) => z1, __tsplusTrace)(() => self);
110
+ };
106
111
  }
107
112
  /**
108
113
  * Replaces this sink's result with the provided value.
109
114
  *
110
- * @tsplus fluent fncts.io.Sink as
115
+ * @tsplus pipeable fncts.io.Sink as
111
116
  */
112
117
 
113
- export function as(self, z, __tsplusTrace) {
114
- return map_1(self, () => z(), __tsplusTrace);
118
+ export function as(z, __tsplusTrace) {
119
+ return self => {
120
+ return map_1(() => z(), __tsplusTrace)(self);
121
+ };
115
122
  }
116
123
  /**
117
124
  * Repeatedly runs the sink and accumulates its results into a chunk
118
125
  *
119
- * @tsplus fluent fncts.io.Sink collectAll
126
+ * @tsplus pipeable fncts.io.Sink collectAll
120
127
  */
121
128
 
122
- export function collectAll(self, __tsplusTrace) {
123
- return collectAllWhileWith_1(self, () => tsplus_module_1.empty(), () => true, (s, z) => tsplus_module_2.append_(s, z), __tsplusTrace);
129
+ export function collectAll(__tsplusTrace) {
130
+ return self => {
131
+ return collectAllWhileWith_1(() => tsplus_module_1.empty(), () => true, (s, z) => tsplus_module_2.append(z)(s), __tsplusTrace)(self);
132
+ };
124
133
  }
125
134
  /**
126
135
  * Repeatedly runs the sink for as long as its results satisfy the predicate
127
136
  * `p`. The sink's results will be accumulated using the stepping function
128
137
  * `f`.
129
138
  *
130
- * @tsplus fluent fncts.io.Sink collectAllWhileWith
139
+ * @tsplus pipeable fncts.io.Sink collectAllWhileWith
131
140
  */
132
141
 
133
- function collectAllWhileWith_1(self, z, p, f, __tsplusTrace) {
134
- return new tsplus_module_3.Sink(tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => tsplus_module_9.zip_(tsplus_module_8.make(() => tsplus_module_1.empty(), __tsplusTrace), tsplus_module_8.make(() => false, __tsplusTrace), __tsplusTrace)), ([leftoversRef, upstreamDoneRef]) => {
135
- const upstreamMarker = tsplus_module_4.readWith(inp => tsplus_module_5.apSecond_(tsplus_module_4.writeNow(inp), upstreamMarker), tsplus_module_4.failNow, x => tsplus_module_4.as_(tsplus_module_4.fromIO(() => tsplus_module_6.set_(upstreamDoneRef, true, __tsplusTrace)), () => x));
142
+ function collectAllWhileWith_1(z, p, f, __tsplusTrace) {
143
+ return self => {
144
+ return new tsplus_module_3.Sink(tsplus_module_5.flatMap(([leftoversRef, upstreamDoneRef]) => {
145
+ const upstreamMarker = tsplus_module_4.readWith(inp => tsplus_module_5.apSecond(upstreamMarker)(tsplus_module_4.writeNow(inp)), tsplus_module_4.failNow, x => tsplus_module_4.as_(() => x)(tsplus_module_4.fromIO(() => upstreamDoneRef.set(true, __tsplusTrace))));
136
146
 
137
- function loop(currentResult, __tsplusTrace) {
138
- return tsplus_module_4.matchChannel_(tsplus_module_4.collectElements(self.channel), tsplus_module_4.failNow, ([leftovers, doneValue]) => {
139
- if (p(doneValue)) {
140
- return tsplus_module_5.apSecond_(tsplus_module_4.fromIO(() => tsplus_module_6.set_(leftoversRef, tsplus_module_2.flatten(leftovers), __tsplusTrace)), tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => tsplus_module_7.get(upstreamDoneRef, __tsplusTrace)), upstreamDone => {
141
- const accumulatedResult = f(currentResult, doneValue);
142
- if (upstreamDone) return tsplus_module_4.as_(tsplus_module_4.writeNow(tsplus_module_2.flatten(leftovers)), () => accumulatedResult);else return loop(accumulatedResult, __tsplusTrace);
143
- }));
144
- } else {
145
- return tsplus_module_4.as_(tsplus_module_4.writeNow(tsplus_module_2.flatten(leftovers)), () => currentResult);
146
- }
147
- });
148
- }
147
+ function loop(currentResult, __tsplusTrace) {
148
+ return tsplus_module_4.matchChannel(tsplus_module_4.failNow, ([leftovers, doneValue]) => {
149
+ if (p(doneValue)) {
150
+ return tsplus_module_5.apSecond(tsplus_module_5.flatMap(upstreamDone => {
151
+ const accumulatedResult = f(currentResult, doneValue);
152
+ if (upstreamDone) return tsplus_module_4.as_(() => accumulatedResult)(tsplus_module_4.writeNow(tsplus_module_2.flatten(leftovers)));else return loop(accumulatedResult, __tsplusTrace);
153
+ })(tsplus_module_4.fromIO(() => upstreamDoneRef.get)))(tsplus_module_4.fromIO(() => leftoversRef.set(tsplus_module_2.flatten(leftovers), __tsplusTrace)));
154
+ } else {
155
+ return tsplus_module_4.as_(() => currentResult)(tsplus_module_4.writeNow(tsplus_module_2.flatten(leftovers)));
156
+ }
157
+ })(tsplus_module_4.collectElements(self.channel));
158
+ }
149
159
 
150
- return tsplus_module_4.pipeTo_(tsplus_module_4.pipeTo_(upstreamMarker, tsplus_module_4.bufferChunk(leftoversRef)), loop(z(), __tsplusTrace));
151
- }));
160
+ return tsplus_module_4.pipeTo(loop(z(), __tsplusTrace))(tsplus_module_4.pipeTo(tsplus_module_4.bufferChunk(leftoversRef))(upstreamMarker));
161
+ })(tsplus_module_4.fromIO(() => tsplus_module_7.zip(tsplus_module_6.make(() => false, __tsplusTrace), __tsplusTrace)(tsplus_module_6.make(() => tsplus_module_1.empty(), __tsplusTrace)))));
162
+ };
152
163
  }
153
164
  /**
154
165
  * Collects the leftovers from the stream when the sink succeeds and returns
@@ -159,90 +170,106 @@ function collectAllWhileWith_1(self, z, p, f, __tsplusTrace) {
159
170
 
160
171
 
161
172
  export function collectLeftover(self, __tsplusTrace) {
162
- return new tsplus_module_3.Sink(tsplus_module_5.map_(tsplus_module_4.collectElements(self.channel), ([chunks, z]) => [z, tsplus_module_2.flatten(chunks)]));
173
+ return new tsplus_module_3.Sink(tsplus_module_5.map(([chunks, z]) => [z, tsplus_module_2.flatten(chunks)])(tsplus_module_4.collectElements(self.channel)));
163
174
  }
164
175
  /**
165
176
  * Transforms this sink's input elements.
166
177
  *
167
- * @tsplus fluent fncts.io.Sink contramap
178
+ * @tsplus pipeable fncts.io.Sink contramap
168
179
  */
169
180
 
170
- function contramap_1(self, f, __tsplusTrace) {
171
- return contramapChunks_1(self, chunk => tsplus_module_2.map_(chunk, f), __tsplusTrace);
181
+ function contramap_1(f, __tsplusTrace) {
182
+ return self => {
183
+ return contramapChunks_1(chunk => tsplus_module_2.map(f)(chunk), __tsplusTrace)(self);
184
+ };
172
185
  }
173
186
  /**
174
187
  * Transforms this sink's input chunks. `f` must preserve chunking-invariance
175
188
  *
176
- * @tsplus fluent fncts.io.Sink contramapChunks
189
+ * @tsplus pipeable fncts.io.Sink contramapChunks
177
190
  */
178
191
 
179
192
 
180
- function contramapChunks_1(self, f, __tsplusTrace) {
181
- const loop = tsplus_module_4.readWith(chunk => tsplus_module_5.apSecond_(tsplus_module_4.writeNow(f(chunk)), loop), tsplus_module_4.failNow, tsplus_module_5.succeedNow);
182
- return new tsplus_module_3.Sink(tsplus_module_4.pipeTo_(loop, self.channel));
193
+ function contramapChunks_1(f, __tsplusTrace) {
194
+ return self => {
195
+ const loop = tsplus_module_4.readWith(chunk => tsplus_module_5.apSecond(loop)(tsplus_module_4.writeNow(f(chunk))), tsplus_module_4.failNow, tsplus_module_5.succeedNow);
196
+ return new tsplus_module_3.Sink(tsplus_module_4.pipeTo(self.channel)(loop));
197
+ };
183
198
  }
184
199
  /**
185
200
  * Effectfully transforms this sink's input chunks. `f` must preserve
186
201
  * chunking-invariance
187
202
  *
188
- * @tsplus fluent fncts.io.Sink contramapChunksIO
203
+ * @tsplus pipeable fncts.io.Sink contramapChunksIO
189
204
  */
190
205
 
191
206
 
192
- function contramapChunksIO_1(self, f, __tsplusTrace) {
193
- const loop = tsplus_module_4.readWith(chunk => tsplus_module_5.apSecond_(tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => f(chunk)), tsplus_module_4.writeNow), loop), tsplus_module_4.failNow, tsplus_module_5.succeedNow);
194
- return new tsplus_module_3.Sink(tsplus_module_4.pipeToOrFail_(loop, self.channel));
207
+ function contramapChunksIO_1(f, __tsplusTrace) {
208
+ return self => {
209
+ const loop = tsplus_module_4.readWith(chunk => tsplus_module_5.apSecond(loop)(tsplus_module_5.flatMap(tsplus_module_4.writeNow)(tsplus_module_4.fromIO(() => f(chunk)))), tsplus_module_4.failNow, tsplus_module_5.succeedNow);
210
+ return new tsplus_module_3.Sink(tsplus_module_4.pipeToOrFail(self.channel)(loop));
211
+ };
195
212
  }
196
213
  /**
197
214
  * Effectfully transforms this sink's input elements.
198
215
  *
199
- * @tsplus fluent fncts.io.Sink contramapIO
216
+ * @tsplus pipeable fncts.io.Sink contramapIO
200
217
  */
201
218
 
202
219
 
203
- function contramapIO_1(self, f, __tsplusTrace) {
204
- return contramapChunksIO_1(self, chunk => tsplus_module_10.mapIO_(chunk, f, __tsplusTrace), __tsplusTrace);
220
+ function contramapIO_1(f, __tsplusTrace) {
221
+ return self => {
222
+ return contramapChunksIO_1(chunk => tsplus_module_8.mapIO(f, __tsplusTrace)(chunk), __tsplusTrace)(self);
223
+ };
205
224
  }
206
225
  /**
207
226
  * Transforms both inputs and result of this sink using the provided
208
227
  * functions.
209
228
  *
210
- * @tsplus fluent fncts.io.Sink dimap
229
+ * @tsplus pipeable fncts.io.Sink dimap
211
230
  */
212
231
 
213
232
 
214
- export function dimap(self, f, g, __tsplusTrace) {
215
- return map_1(contramap_1(self, f, __tsplusTrace), g, __tsplusTrace);
233
+ export function dimap(f, g, __tsplusTrace) {
234
+ return self => {
235
+ return map_1(g, __tsplusTrace)(contramap_1(f, __tsplusTrace)(self));
236
+ };
216
237
  }
217
238
  /**
218
239
  * Transforms both input chunks and result of this sink using the provided
219
240
  * functions.
220
241
  *
221
- * @tsplus fluent fncts.io.Sink dimapChunks
242
+ * @tsplus pipeable fncts.io.Sink dimapChunks
222
243
  */
223
244
 
224
- export function dimapChunks(self, f, g, __tsplusTrace) {
225
- return map_1(contramapChunks_1(self, f, __tsplusTrace), g, __tsplusTrace);
245
+ export function dimapChunks(f, g, __tsplusTrace) {
246
+ return self => {
247
+ return map_1(g, __tsplusTrace)(contramapChunks_1(f, __tsplusTrace)(self));
248
+ };
226
249
  }
227
250
  /**
228
251
  * Effectfully transforms both input chunks and result of this sink using the
229
252
  * provided functions. `f` and `g` must preserve chunking-invariance
230
253
  *
231
- * @tsplus fluent fncts.io.Sink dimapChunksIO
254
+ * @tsplus pipeable fncts.io.Sink dimapChunksIO
232
255
  */
233
256
 
234
- export function dimapChunksIO(self, f, g, __tsplusTrace) {
235
- return mapIO_1(contramapChunksIO_1(self, f, __tsplusTrace), g, __tsplusTrace);
257
+ export function dimapChunksIO(f, g, __tsplusTrace) {
258
+ return self => {
259
+ return mapIO_1(g, __tsplusTrace)(contramapChunksIO_1(f, __tsplusTrace)(self));
260
+ };
236
261
  }
237
262
  /**
238
263
  * Effectfully transforms both inputs and result of this sink using the
239
264
  * provided functions.
240
265
  *
241
- * @tsplus fluent fncts.io.Sink dimapIO
266
+ * @tsplus pipeable fncts.io.Sink dimapIO
242
267
  */
243
268
 
244
- export function dimapIO(self, f, g, __tsplusTrace) {
245
- return mapIO_1(contramapIO_1(self, f, __tsplusTrace), g, __tsplusTrace);
269
+ export function dimapIO(f, g, __tsplusTrace) {
270
+ return self => {
271
+ return mapIO_1(g, __tsplusTrace)(contramapIO_1(f, __tsplusTrace)(self));
272
+ };
246
273
  }
247
274
  /**
248
275
  * Returns a lazily constructed sink that may require effects for its
@@ -271,13 +298,13 @@ export const drain = /*#__PURE__*/new tsplus_module_3.Sink(drainLoop);
271
298
 
272
299
  export function makeDropUntil(p, __tsplusTrace) {
273
300
  const loop = tsplus_module_4.readWith(inp => {
274
- const leftover = tsplus_module_2.dropUntil(inp, p);
301
+ const leftover = tsplus_module_2.dropUntil(p)(inp);
275
302
  const more = tsplus_module_2.isEmpty(leftover);
276
303
 
277
304
  if (more) {
278
305
  return loop;
279
306
  } else {
280
- return tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftover), tsplus_module_4.id());
307
+ return tsplus_module_5.apSecond(tsplus_module_4.id())(tsplus_module_4.writeNow(leftover));
281
308
  }
282
309
  }, tsplus_module_4.failNow, () => tsplus_module_4.unit);
283
310
  return new tsplus_module_3.Sink(loop);
@@ -289,7 +316,7 @@ export function makeDropUntil(p, __tsplusTrace) {
289
316
  */
290
317
 
291
318
  export function makeDropUntilIO(p, __tsplusTrace) {
292
- const loop = tsplus_module_4.readWith(inp => tsplus_module_4.unwrap(() => tsplus_module_9.map_(tsplus_module_11.dropUntilIO(inp, p, __tsplusTrace), leftover => tsplus_module_2.isEmpty(leftover) ? loop : tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftover), tsplus_module_4.id()), __tsplusTrace)), tsplus_module_4.failNow, () => tsplus_module_4.unit);
319
+ const loop = tsplus_module_4.readWith(inp => tsplus_module_4.unwrap(() => tsplus_module_7.map(leftover => tsplus_module_2.isEmpty(leftover) ? loop : tsplus_module_5.apSecond(tsplus_module_4.id())(tsplus_module_4.writeNow(leftover)), __tsplusTrace)(tsplus_module_9.dropUntilIO(p, __tsplusTrace)(inp))), tsplus_module_4.failNow, () => tsplus_module_4.unit);
293
320
  return new tsplus_module_3.Sink(loop);
294
321
  }
295
322
  /**
@@ -300,13 +327,13 @@ export function makeDropUntilIO(p, __tsplusTrace) {
300
327
 
301
328
  export function makeDropWhile(predicate, __tsplusTrace) {
302
329
  const loop = tsplus_module_4.readWith(inp => {
303
- const leftover = tsplus_module_2.dropWhile_(inp, predicate);
330
+ const leftover = tsplus_module_2.dropWhile(predicate)(inp);
304
331
  const more = tsplus_module_2.isEmpty(leftover);
305
332
 
306
333
  if (more) {
307
334
  return loop;
308
335
  } else {
309
- return tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftover), tsplus_module_4.id());
336
+ return tsplus_module_5.apSecond(tsplus_module_4.id())(tsplus_module_4.writeNow(leftover));
310
337
  }
311
338
  }, tsplus_module_4.failNow, () => tsplus_module_4.unit);
312
339
  return new tsplus_module_3.Sink(loop);
@@ -319,7 +346,7 @@ export function makeDropWhile(predicate, __tsplusTrace) {
319
346
  */
320
347
 
321
348
  export function dropWhileIO(p, __tsplusTrace) {
322
- const loop = tsplus_module_4.readWith(inp => tsplus_module_4.unwrap(() => tsplus_module_9.map_(tsplus_module_12.dropWhileIO(inp, p, __tsplusTrace), leftover => tsplus_module_2.isEmpty(leftover) ? loop : tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftover), tsplus_module_4.id()), __tsplusTrace)), tsplus_module_4.failNow, () => tsplus_module_4.unit);
349
+ const loop = tsplus_module_4.readWith(inp => tsplus_module_4.unwrap(() => tsplus_module_7.map(leftover => tsplus_module_2.isEmpty(leftover) ? loop : tsplus_module_5.apSecond(tsplus_module_4.id())(tsplus_module_4.writeNow(leftover)), __tsplusTrace)(tsplus_module_10.dropWhileIO(p, __tsplusTrace)(inp))), tsplus_module_4.failNow, () => tsplus_module_4.unit);
323
350
  return new tsplus_module_3.Sink(loop);
324
351
  }
325
352
  /**
@@ -329,7 +356,7 @@ export function dropWhileIO(p, __tsplusTrace) {
329
356
  */
330
357
 
331
358
  export function environment(__tsplusTrace) {
332
- return fromIO_1(() => tsplus_module_13.environment(__tsplusTrace), __tsplusTrace);
359
+ return fromIO_1(() => tsplus_module_11.environment(__tsplusTrace), __tsplusTrace);
333
360
  }
334
361
  /**
335
362
  * Accesses the environment of the sink.
@@ -338,7 +365,7 @@ export function environment(__tsplusTrace) {
338
365
  */
339
366
 
340
367
  export function environmentWith(f, __tsplusTrace) {
341
- return fromIO_1(() => tsplus_module_13.environmentWith(f, __tsplusTrace), __tsplusTrace);
368
+ return fromIO_1(() => tsplus_module_11.environmentWith(f, __tsplusTrace), __tsplusTrace);
342
369
  }
343
370
  /**
344
371
  * Accesses the environment of the sink in the context of an effect.
@@ -347,7 +374,7 @@ export function environmentWith(f, __tsplusTrace) {
347
374
  */
348
375
 
349
376
  export function environmentWithIO(f, __tsplusTrace) {
350
- return fromIO_1(() => tsplus_module_13.environmentWithIO(f, __tsplusTrace), __tsplusTrace);
377
+ return fromIO_1(() => tsplus_module_11.environmentWithIO(f, __tsplusTrace), __tsplusTrace);
351
378
  }
352
379
  /**
353
380
  * Accesses the environment of the sink in the context of a sink.
@@ -356,7 +383,7 @@ export function environmentWithIO(f, __tsplusTrace) {
356
383
  */
357
384
 
358
385
  export function environmentWithSink(f, __tsplusTrace) {
359
- return new tsplus_module_3.Sink(tsplus_module_4.unwrap(() => tsplus_module_13.environmentWith(tsplus_module_14.compose_(f, s => s.channel), __tsplusTrace)));
386
+ return new tsplus_module_3.Sink(tsplus_module_4.unwrap(() => tsplus_module_11.environmentWith(tsplus_module_12.compose(s => s.channel)(f), __tsplusTrace)));
360
387
  }
361
388
  /**
362
389
  * A sink that always fails with the specified error.
@@ -404,7 +431,7 @@ function failNow_1(e, __tsplusTrace) {
404
431
 
405
432
 
406
433
  export function filterInput(self, p, __tsplusTrace) {
407
- return contramapChunks_1(self, chunk => tsplus_module_2.filter_(chunk, p), __tsplusTrace);
434
+ return contramapChunks_1(chunk => tsplus_module_2.filter(p)(chunk), __tsplusTrace)(self);
408
435
  }
409
436
  /**
410
437
  * Filters the sink's input with the given IO predicate
@@ -413,22 +440,24 @@ export function filterInput(self, p, __tsplusTrace) {
413
440
  */
414
441
 
415
442
  export function filterInputIO(self, p, __tsplusTrace) {
416
- return contramapChunksIO_1(self, chunk => tsplus_module_15.filterIO(chunk, p, __tsplusTrace), __tsplusTrace);
443
+ return contramapChunksIO_1(chunk => tsplus_module_13.filterIO(p, __tsplusTrace)(chunk), __tsplusTrace)(self);
417
444
  }
418
445
  /**
419
446
  * Creates a sink that produces values until one verifies the predicate `f`.
420
447
  *
421
- * @tsplus fluent fncts.io.Sink findIO
448
+ * @tsplus pipeable fncts.io.Sink findIO
422
449
  */
423
450
 
424
- export function findIO(self, f, __tsplusTrace) {
425
- return new tsplus_module_3.Sink(tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => tsplus_module_9.zip_(tsplus_module_8.make(() => tsplus_module_1.empty(), __tsplusTrace), tsplus_module_8.make(() => false, __tsplusTrace), __tsplusTrace)), ([leftoversRef, upstreamDoneRef]) => {
426
- const upstreamMarker = tsplus_module_4.readWith(inp => tsplus_module_5.apSecond_(tsplus_module_4.writeNow(inp), upstreamMarker), tsplus_module_4.failNow, x => tsplus_module_4.as_(tsplus_module_4.fromIO(() => tsplus_module_6.set_(upstreamDoneRef, true, __tsplusTrace)), () => x));
427
- const loop = tsplus_module_4.matchChannel_(tsplus_module_4.collectElements(self.channel), tsplus_module_4.failNow, ([leftovers, doneValue]) => tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => f(doneValue)), satisfied => tsplus_module_5.apSecond_(tsplus_module_4.fromIO(() => tsplus_module_6.set_(leftoversRef, tsplus_module_2.flatten(leftovers), __tsplusTrace)), tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => tsplus_module_7.get(upstreamDoneRef, __tsplusTrace)), upstreamDone => {
428
- if (satisfied) return tsplus_module_4.as_(tsplus_module_4.writeNow(tsplus_module_2.flatten(leftovers)), () => tsplus_module_16.just(doneValue));else if (upstreamDone) return tsplus_module_4.as_(tsplus_module_4.writeNow(tsplus_module_2.flatten(leftovers)), () => tsplus_module_16.nothing());else return loop;
429
- }))));
430
- return tsplus_module_4.pipeTo_(tsplus_module_4.pipeTo_(upstreamMarker, tsplus_module_4.bufferChunk(leftoversRef)), loop);
431
- }));
451
+ export function findIO(f, __tsplusTrace) {
452
+ return self => {
453
+ return new tsplus_module_3.Sink(tsplus_module_5.flatMap(([leftoversRef, upstreamDoneRef]) => {
454
+ const upstreamMarker = tsplus_module_4.readWith(inp => tsplus_module_5.apSecond(upstreamMarker)(tsplus_module_4.writeNow(inp)), tsplus_module_4.failNow, x => tsplus_module_4.as_(() => x)(tsplus_module_4.fromIO(() => upstreamDoneRef.set(true, __tsplusTrace))));
455
+ const loop = tsplus_module_4.matchChannel(tsplus_module_4.failNow, ([leftovers, doneValue]) => tsplus_module_5.flatMap(satisfied => tsplus_module_5.apSecond(tsplus_module_5.flatMap(upstreamDone => {
456
+ if (satisfied) return tsplus_module_4.as_(() => tsplus_module_14.just(doneValue))(tsplus_module_4.writeNow(tsplus_module_2.flatten(leftovers)));else if (upstreamDone) return tsplus_module_4.as_(() => tsplus_module_14.nothing())(tsplus_module_4.writeNow(tsplus_module_2.flatten(leftovers)));else return loop;
457
+ })(tsplus_module_4.fromIO(() => upstreamDoneRef.get)))(tsplus_module_4.fromIO(() => leftoversRef.set(tsplus_module_2.flatten(leftovers), __tsplusTrace))))(tsplus_module_4.fromIO(() => f(doneValue))))(tsplus_module_4.collectElements(self.channel));
458
+ return tsplus_module_4.pipeTo(loop)(tsplus_module_4.pipeTo(tsplus_module_4.bufferChunk(leftoversRef))(upstreamMarker));
459
+ })(tsplus_module_4.fromIO(() => tsplus_module_7.zip(tsplus_module_6.make(() => false, __tsplusTrace), __tsplusTrace)(tsplus_module_6.make(() => tsplus_module_1.empty(), __tsplusTrace)))));
460
+ };
432
461
  }
433
462
  /**
434
463
  * Runs this sink until it yields a result, then uses that result to create
@@ -437,11 +466,13 @@ export function findIO(self, f, __tsplusTrace) {
437
466
  *
438
467
  * This function essentially runs sinks in sequence.
439
468
  *
440
- * @tsplus fluent fncts.io.Sink flatMap
469
+ * @tsplus pipeable fncts.io.Sink flatMap
441
470
  */
442
471
 
443
- function flatMap_1(self, f, __tsplusTrace) {
444
- return matchSink_1(self, failNow_1, f, __tsplusTrace);
472
+ function flatMap_1(f, __tsplusTrace) {
473
+ return self => {
474
+ return matchSink_1(failNow_1, f, __tsplusTrace)(self);
475
+ };
445
476
  }
446
477
  /**
447
478
  * Creates a sink from a {@link Channel}
@@ -461,11 +492,11 @@ export function fromChannel(channel, __tsplusTrace) {
461
492
  */
462
493
 
463
494
  export function fromPush(push, __tsplusTrace) {
464
- return new tsplus_module_3.Sink(tsplus_module_4.unwrapScoped(() => tsplus_module_9.map_(push, fromPushPull, __tsplusTrace)));
495
+ return new tsplus_module_3.Sink(tsplus_module_4.unwrapScoped(() => tsplus_module_7.map(fromPushPull, __tsplusTrace)(push)));
465
496
  }
466
497
 
467
498
  function fromPushPull(push, __tsplusTrace) {
468
- return tsplus_module_4.readWith(inp => tsplus_module_4.matchChannel_(tsplus_module_4.fromIO(() => push(tsplus_module_16.just(inp))), ([r, leftovers]) => tsplus_module_17.match_(r, e => tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftovers), tsplus_module_4.failNow(e)), z => tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftovers), tsplus_module_5.succeedNow(z))), () => fromPushPull(push, __tsplusTrace)), tsplus_module_4.failNow, () => tsplus_module_4.matchChannel_(tsplus_module_4.fromIO(() => push(tsplus_module_16.nothing())), ([r, leftovers]) => tsplus_module_17.match_(r, e => tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftovers), tsplus_module_4.failNow(e)), z => tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftovers), tsplus_module_5.succeedNow(z))), () => tsplus_module_4.fromIO(() => tsplus_module_9.halt(() => new Error("empty sink"), __tsplusTrace))));
499
+ return tsplus_module_4.readWith(inp => tsplus_module_4.matchChannel(([r, leftovers]) => tsplus_module_15.match(e => tsplus_module_5.apSecond(tsplus_module_4.failNow(e))(tsplus_module_4.writeNow(leftovers)), z => tsplus_module_5.apSecond(tsplus_module_5.succeedNow(z))(tsplus_module_4.writeNow(leftovers)))(r), () => fromPushPull(push, __tsplusTrace))(tsplus_module_4.fromIO(() => push(tsplus_module_14.just(inp)))), tsplus_module_4.failNow, () => tsplus_module_4.matchChannel(([r, leftovers]) => tsplus_module_15.match(e => tsplus_module_5.apSecond(tsplus_module_4.failNow(e))(tsplus_module_4.writeNow(leftovers)), z => tsplus_module_5.apSecond(tsplus_module_5.succeedNow(z))(tsplus_module_4.writeNow(leftovers)))(r), () => tsplus_module_4.fromIO(() => tsplus_module_7.halt(() => new Error("empty sink"), __tsplusTrace)))(tsplus_module_4.fromIO(() => push(tsplus_module_14.nothing()))));
469
500
  }
470
501
  /**
471
502
  * Create a sink which enqueues each element into the specified queue.
@@ -475,7 +506,7 @@ function fromPushPull(push, __tsplusTrace) {
475
506
 
476
507
 
477
508
  function fromQueue_1(queue, __tsplusTrace) {
478
- return unwrap_1(() => tsplus_module_9.map_(tsplus_module_9.succeed(queue, __tsplusTrace), queue => makeForeachChunk_1(inp => tsplus_module_18.offerAll_(queue, inp, __tsplusTrace), __tsplusTrace), __tsplusTrace), __tsplusTrace);
509
+ return unwrap_1(() => tsplus_module_7.map(queue => makeForeachChunk_1(inp => queue.offerAll(inp, __tsplusTrace), __tsplusTrace), __tsplusTrace)(tsplus_module_7.succeed(queue, __tsplusTrace)), __tsplusTrace);
479
510
  }
480
511
  /**
481
512
  * Create a sink which enqueues each element into the specified queue. The
@@ -486,7 +517,7 @@ function fromQueue_1(queue, __tsplusTrace) {
486
517
 
487
518
 
488
519
  function fromQueueWithShutdown_1(queue, __tsplusTrace) {
489
- return unwrapScoped_1(() => tsplus_module_9.map_(tsplus_module_19.acquireRelease(() => tsplus_module_9.succeed(queue, __tsplusTrace), queue => tsplus_module_18.shutdown(queue, __tsplusTrace), __tsplusTrace), queue => fromQueue_1(() => queue, __tsplusTrace), __tsplusTrace), __tsplusTrace);
520
+ return unwrapScoped_1(() => tsplus_module_7.map(queue => fromQueue_1(() => queue, __tsplusTrace), __tsplusTrace)(tsplus_module_16.acquireRelease(() => tsplus_module_7.succeed(queue, __tsplusTrace), queue => queue.shutdown, __tsplusTrace)), __tsplusTrace);
490
521
  }
491
522
  /**
492
523
  * Create a sink which publishes each element to the specified hub.
@@ -525,7 +556,7 @@ function fromIO_1(b, __tsplusTrace) {
525
556
 
526
557
 
527
558
  export function halt(defect, __tsplusTrace) {
528
- return failCause_1(() => tsplus_module_20.halt(defect()), __tsplusTrace);
559
+ return failCause_1(() => tsplus_module_17.halt(defect()), __tsplusTrace);
529
560
  }
530
561
  /**
531
562
  * Creates a sink halting with the specified unchecked value.
@@ -534,7 +565,7 @@ export function halt(defect, __tsplusTrace) {
534
565
  */
535
566
 
536
567
  export function haltNow(defect, __tsplusTrace) {
537
- return failCauseNow_1(tsplus_module_20.halt(defect), __tsplusTrace);
568
+ return failCauseNow_1(tsplus_module_17.halt(defect), __tsplusTrace);
538
569
  }
539
570
  /**
540
571
  * Creates a sink containing the first value.
@@ -543,7 +574,7 @@ export function haltNow(defect, __tsplusTrace) {
543
574
  */
544
575
 
545
576
  export function head(__tsplusTrace) {
546
- return makeFold_1(() => tsplus_module_16.nothing(), elem => tsplus_module_21.isNothing(elem), (s, inp) => tsplus_module_22.match_(s, () => tsplus_module_16.just(inp), () => s), __tsplusTrace);
577
+ return makeFold_1(() => tsplus_module_14.nothing(), elem => tsplus_module_18.isNothing(elem), (s, inp) => tsplus_module_19.match(() => tsplus_module_14.just(inp), () => s)(s), __tsplusTrace);
547
578
  }
548
579
  /**
549
580
  * Drains the remaining elements from the stream after the sink finishes
@@ -562,7 +593,7 @@ function ignoreLeftover_1(self, __tsplusTrace) {
562
593
 
563
594
 
564
595
  export function last(__tsplusTrace) {
565
- return makeFoldLeft_1(() => tsplus_module_16.nothing(), (_, inp) => tsplus_module_16.just(inp), __tsplusTrace);
596
+ return makeFoldLeft_1(() => tsplus_module_14.nothing(), (_, inp) => tsplus_module_14.just(inp), __tsplusTrace);
566
597
  }
567
598
  /**
568
599
  * Creates a sink that does not consume any input but provides the given chunk
@@ -581,7 +612,7 @@ export function leftover(c, __tsplusTrace) {
581
612
  */
582
613
 
583
614
  export function log(message, __tsplusTrace) {
584
- return fromIO_1(() => tsplus_module_9.log(message, __tsplusTrace), __tsplusTrace);
615
+ return fromIO_1(() => tsplus_module_7.log(message, __tsplusTrace), __tsplusTrace);
585
616
  }
586
617
  /**
587
618
  * A sink that collects all of its inputs into a chunk.
@@ -594,7 +625,7 @@ export function makeCollectAll(__tsplusTrace) {
594
625
  }
595
626
 
596
627
  function collectLoop(state, __tsplusTrace) {
597
- return tsplus_module_4.readWithCause(inp => collectLoop(tsplus_module_2.concat_(state, inp), __tsplusTrace), tsplus_module_5.failCauseNow, () => tsplus_module_5.endNow(state));
628
+ return tsplus_module_4.readWithCause(inp => collectLoop(tsplus_module_2.concat(inp)(state), __tsplusTrace), tsplus_module_5.failCauseNow, () => tsplus_module_5.endNow(state));
598
629
  }
599
630
  /**
600
631
  * A sink that collects first `n` elements into a chunk. Note that the chunk
@@ -605,7 +636,7 @@ function collectLoop(state, __tsplusTrace) {
605
636
 
606
637
 
607
638
  export function makeCollectAllN(n, __tsplusTrace) {
608
- return flatMap_1(fromIO_1(() => tsplus_module_9.succeed(() => new tsplus_module_23.ConcBuilder(), __tsplusTrace), __tsplusTrace), builder => map_1(makeFoldUntil_1(() => builder, n, (builder, inp) => builder.append(inp), __tsplusTrace), builder => builder.result(), __tsplusTrace), __tsplusTrace);
639
+ return flatMap_1(builder => map_1(builder => builder.result(), __tsplusTrace)(makeFoldUntil_1(() => builder, n, (builder, inp) => builder.append(inp), __tsplusTrace)), __tsplusTrace)(fromIO_1(() => tsplus_module_7.succeed(() => new tsplus_module_20.ConcBuilder(), __tsplusTrace), __tsplusTrace));
609
640
  }
610
641
  /**
611
642
  * A sink that executes the provided effectful function for every element fed to it.
@@ -614,7 +645,7 @@ export function makeCollectAllN(n, __tsplusTrace) {
614
645
  */
615
646
 
616
647
  export function makeForeach(f, __tsplusTrace) {
617
- return makeForeachWhile_1(inp => tsplus_module_9.as_(f(inp), () => true, __tsplusTrace), __tsplusTrace);
648
+ return makeForeachWhile_1(inp => tsplus_module_7.as(() => true, __tsplusTrace)(f(inp)), __tsplusTrace);
618
649
  }
619
650
  /**
620
651
  * A sink that executes the provided effectful function for every chunk fed to
@@ -624,7 +655,7 @@ export function makeForeach(f, __tsplusTrace) {
624
655
  */
625
656
 
626
657
  function makeForeachChunk_1(f, __tsplusTrace) {
627
- const process = tsplus_module_4.readWithCause(inp => tsplus_module_5.apSecond_(tsplus_module_4.fromIO(() => f(inp)), process), tsplus_module_5.failCauseNow, () => tsplus_module_4.unit);
658
+ const process = tsplus_module_4.readWithCause(inp => tsplus_module_5.apSecond(process)(tsplus_module_4.fromIO(() => f(inp))), tsplus_module_5.failCauseNow, () => tsplus_module_4.unit);
628
659
  return new tsplus_module_3.Sink(process);
629
660
  }
630
661
  /**
@@ -645,7 +676,7 @@ function foreachWhileLoop(f, chunk, idx, len, cont, __tsplusTrace) {
645
676
  return cont;
646
677
  }
647
678
 
648
- return tsplus_module_4.catchAll_(tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => f(tsplus_module_2.unsafeGet_(chunk, idx))), b => b ? foreachWhileLoop(f, chunk, idx + 1, len, cont, __tsplusTrace) : tsplus_module_4.writeNow(tsplus_module_2.drop_(chunk, idx))), e => tsplus_module_5.apSecond_(tsplus_module_4.writeNow(tsplus_module_2.drop_(chunk, idx)), tsplus_module_4.failNow(e)));
679
+ return tsplus_module_4.catchAll(e => tsplus_module_5.apSecond(tsplus_module_4.failNow(e))(tsplus_module_4.writeNow(tsplus_module_2.drop(idx)(chunk))))(tsplus_module_5.flatMap(b => b ? foreachWhileLoop(f, chunk, idx + 1, len, cont, __tsplusTrace) : tsplus_module_4.writeNow(tsplus_module_2.drop(idx)(chunk)))(tsplus_module_4.fromIO(() => f(tsplus_module_2.unsafeGet(idx)(chunk)))));
649
680
  }
650
681
  /**
651
682
  * A sink that executes the provided effectful function for every chunk fed to
@@ -656,7 +687,7 @@ function foreachWhileLoop(f, chunk, idx, len, cont, __tsplusTrace) {
656
687
 
657
688
 
658
689
  export function makeForeachChunkWhile(f, __tsplusTrace) {
659
- const reader = tsplus_module_4.readWith(inp => tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => f(inp)), cont => cont ? reader : tsplus_module_4.unit), tsplus_module_4.failNow, () => tsplus_module_4.unit);
690
+ const reader = tsplus_module_4.readWith(inp => tsplus_module_5.flatMap(cont => cont ? reader : tsplus_module_4.unit)(tsplus_module_4.fromIO(() => f(inp))), tsplus_module_4.failNow, () => tsplus_module_4.unit);
660
691
  return new tsplus_module_3.Sink(reader);
661
692
  }
662
693
  /**
@@ -694,7 +725,7 @@ function foldChunkSplit(contFn, f, s, chunk, idx, len, __tsplusTrace) {
694
725
  if (idx_1 === len_1) {
695
726
  return [s_1, tsplus_module_1.empty()];
696
727
  } else {
697
- const s1 = f_1(s_1, tsplus_module_2.unsafeGet_(chunk_1, idx_1));
728
+ const s1 = f_1(s_1, tsplus_module_2.unsafeGet(idx_1)(chunk_1));
698
729
 
699
730
  if (contFn_1(s1)) {
700
731
  contFn_2 = contFn_1;
@@ -713,7 +744,7 @@ function foldChunkSplit(contFn, f, s, chunk, idx, len, __tsplusTrace) {
713
744
  __tsplusTrace_1 = __tsplusTrace_2;
714
745
  continue;
715
746
  } else {
716
- return [s1, tsplus_module_2.drop_(chunk_1, idx_1 + 1)];
747
+ return [s1, tsplus_module_2.drop(idx_1 + 1)(chunk_1)];
717
748
  }
718
749
  }
719
750
  }
@@ -727,7 +758,7 @@ function foldReader(s, contFn, f, __tsplusTrace) {
727
758
  const [nextS, leftovers] = foldChunkSplit(contFn, f, s, inp, 0, inp.length, __tsplusTrace);
728
759
 
729
760
  if (tsplus_module_2.isNonEmpty(leftovers)) {
730
- return tsplus_module_4.as_(tsplus_module_4.writeNow(leftovers), () => nextS);
761
+ return tsplus_module_4.as_(() => nextS)(tsplus_module_4.writeNow(leftovers));
731
762
  } else {
732
763
  return foldReader(nextS, contFn, f, __tsplusTrace);
733
764
  }
@@ -745,7 +776,7 @@ function foldReader(s, contFn, f, __tsplusTrace) {
745
776
 
746
777
 
747
778
  function makeFoldUntil_1(z, max, f, __tsplusTrace) {
748
- return unwrap_1(() => tsplus_module_9.map_(tsplus_module_9.succeed(max, __tsplusTrace), max => map_1(makeFold_1(() => [z(), 0], ([_, n]) => n < max, ([o, count], i) => [f(o, i), count + 1], __tsplusTrace), ([s]) => s, __tsplusTrace), __tsplusTrace), __tsplusTrace);
779
+ return unwrap_1(() => tsplus_module_7.map(max => map_1(([s]) => s, __tsplusTrace)(makeFold_1(() => [z(), 0], ([_, n]) => n < max, ([o, count], i) => [f(o, i), count + 1], __tsplusTrace)), __tsplusTrace)(tsplus_module_7.succeed(max, __tsplusTrace)), __tsplusTrace);
749
780
  }
750
781
  /**
751
782
  * A sink that folds its input chunks with the provided function, termination
@@ -789,7 +820,7 @@ function foldChunksIOReader(s, contFn, f, __tsplusTrace) {
789
820
  if (!contFn(s)) {
790
821
  return tsplus_module_5.succeedNow(s);
791
822
  } else {
792
- return tsplus_module_4.readWith(inp => tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => f(s, inp)), s => foldChunksIOReader(s, contFn, f, __tsplusTrace)), err => tsplus_module_4.failNow(err), _ => tsplus_module_5.succeedNow(_));
823
+ return tsplus_module_4.readWith(inp => tsplus_module_5.flatMap(s => foldChunksIOReader(s, contFn, f, __tsplusTrace))(tsplus_module_4.fromIO(() => f(s, inp))), err => tsplus_module_4.failNow(err), _ => tsplus_module_5.succeedNow(_));
793
824
  }
794
825
  }
795
826
  /**
@@ -846,15 +877,15 @@ function makeFoldIO_1(z, contFn, f, __tsplusTrace) {
846
877
 
847
878
  function foldChunkSplitIO(s, contFn, f, chunk, idx, len, __tsplusTrace) {
848
879
  if (idx === len) {
849
- return tsplus_module_9.succeedNow([s, tsplus_module_16.nothing()], __tsplusTrace);
880
+ return tsplus_module_7.succeedNow([s, tsplus_module_14.nothing()], __tsplusTrace);
850
881
  } else {
851
- return tsplus_module_9.flatMap_(f(s, tsplus_module_2.unsafeGet_(chunk, idx)), s1 => {
882
+ return tsplus_module_7.flatMap(s1 => {
852
883
  if (contFn(s1)) {
853
884
  return foldChunkSplitIO(s1, contFn, f, chunk, idx + 1, len, __tsplusTrace);
854
885
  } else {
855
- return tsplus_module_9.succeedNow([s1, tsplus_module_16.just(tsplus_module_2.drop_(chunk, idx + 1))], __tsplusTrace);
886
+ return tsplus_module_7.succeedNow([s1, tsplus_module_14.just(tsplus_module_2.drop(idx + 1)(chunk))], __tsplusTrace);
856
887
  }
857
- }, __tsplusTrace);
888
+ }, __tsplusTrace)(f(s, tsplus_module_2.unsafeGet(idx)(chunk)));
858
889
  }
859
890
  }
860
891
 
@@ -862,7 +893,7 @@ function foldIOReader(s, contFn, f, __tsplusTrace) {
862
893
  if (!contFn(s)) {
863
894
  return tsplus_module_5.succeedNow(s);
864
895
  } else {
865
- return tsplus_module_4.readWith(inp => tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => foldChunkSplitIO(s, contFn, f, inp, 0, inp.length, __tsplusTrace)), ([nextS, leftovers]) => tsplus_module_22.match_(leftovers, () => foldIOReader(nextS, contFn, f, __tsplusTrace), l => tsplus_module_4.as_(tsplus_module_4.writeNow(l), () => nextS))), err => tsplus_module_4.failNow(err), _ => tsplus_module_5.succeedNow(_));
896
+ return tsplus_module_4.readWith(inp => tsplus_module_5.flatMap(([nextS, leftovers]) => tsplus_module_19.match(() => foldIOReader(nextS, contFn, f, __tsplusTrace), l => tsplus_module_4.as_(() => nextS)(tsplus_module_4.writeNow(l)))(leftovers))(tsplus_module_4.fromIO(() => foldChunkSplitIO(s, contFn, f, inp, 0, inp.length, __tsplusTrace))), err => tsplus_module_4.failNow(err), _ => tsplus_module_5.succeedNow(_));
866
897
  }
867
898
  }
868
899
  /**
@@ -876,7 +907,7 @@ function foldIOReader(s, contFn, f, __tsplusTrace) {
876
907
 
877
908
 
878
909
  export function makeFoldUntilIO(z, max, f, __tsplusTrace) {
879
- return map_1(makeFoldIO_1(() => [z(), 0], ([_, n]) => n < max(), ([o, count], i) => tsplus_module_9.map_(f(o, i), s => [s, count + 1], __tsplusTrace), __tsplusTrace), ([s]) => s, __tsplusTrace);
910
+ return map_1(([s]) => s, __tsplusTrace)(makeFoldIO_1(() => [z(), 0], ([_, n]) => n < max(), ([o, count], i) => tsplus_module_7.map(s => [s, count + 1], __tsplusTrace)(f(o, i)), __tsplusTrace));
880
911
  }
881
912
  /**
882
913
  * Creates a sink that folds elements of type `In` into a structure of type
@@ -907,7 +938,7 @@ function makeFoldWeightedDecompose_1(z, costFn, max, decompose, f, __tsplusTrace
907
938
  if (idx === inp.length) {
908
939
  return [s, cost, dirty, tsplus_module_1.empty()];
909
940
  } else {
910
- const elem = tsplus_module_2.unsafeGet_(inp, idx);
941
+ const elem = tsplus_module_2.unsafeGet(idx)(inp);
911
942
  const total = cost + costFn(s, elem);
912
943
 
913
944
  if (total <= max) {
@@ -916,11 +947,11 @@ function makeFoldWeightedDecompose_1(z, costFn, max, decompose, f, __tsplusTrace
916
947
  const decomposed = decompose(elem);
917
948
 
918
949
  if (decomposed.length <= 1 && !dirty) {
919
- return [f(s, elem), total, true, tsplus_module_2.drop_(inp, idx + 1)];
950
+ return [f(s, elem), total, true, tsplus_module_2.drop(idx + 1)(inp)];
920
951
  } else if (decomposed.length <= 1 && dirty) {
921
- return [s, cost, dirty, tsplus_module_2.drop_(inp, idx)];
952
+ return [s, cost, dirty, tsplus_module_2.drop(idx)(inp)];
922
953
  } else {
923
- return fold(tsplus_module_2.concat_(decomposed, tsplus_module_2.drop_(inp, idx + 1)), s, max, dirty, cost, 0, __tsplusTrace);
954
+ return fold(tsplus_module_2.concat(tsplus_module_2.drop(idx + 1)(inp))(decomposed), s, max, dirty, cost, 0, __tsplusTrace);
924
955
  }
925
956
  }
926
957
  }
@@ -931,7 +962,7 @@ function makeFoldWeightedDecompose_1(z, costFn, max, decompose, f, __tsplusTrace
931
962
  const [nextS, nextCost, nextDirty, leftovers] = fold(inp, s, max, dirty, cost, 0, __tsplusTrace);
932
963
 
933
964
  if (tsplus_module_2.isNonEmpty(leftovers)) {
934
- return tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftovers), tsplus_module_5.succeedNow(nextS));
965
+ return tsplus_module_5.apSecond(tsplus_module_5.succeedNow(nextS))(tsplus_module_4.writeNow(leftovers));
935
966
  } else if (cost > max) {
936
967
  return tsplus_module_5.succeedNow(nextS);
937
968
  } else {
@@ -963,37 +994,37 @@ function makeFoldWeightedDecomposeIO_1(z, costFn, max, decompose, f, __tsplusTra
963
994
  return defer_1(() => {
964
995
  function fold(inp, s, max, dirty, cost, idx, __tsplusTrace) {
965
996
  if (idx === inp.length) {
966
- return tsplus_module_9.succeedNow([s, cost, dirty, tsplus_module_1.empty()], __tsplusTrace);
997
+ return tsplus_module_7.succeedNow([s, cost, dirty, tsplus_module_1.empty()], __tsplusTrace);
967
998
  } else {
968
- const elem = tsplus_module_2.unsafeGet_(inp, idx);
969
- return tsplus_module_9.flatMap_(tsplus_module_9.map_(costFn(s, elem), _ => cost + _, __tsplusTrace), total => {
999
+ const elem = tsplus_module_2.unsafeGet(idx)(inp);
1000
+ return tsplus_module_7.flatMap(total => {
970
1001
  if (total <= max) {
971
- return tsplus_module_9.flatMap_(f(s, elem), s => fold(inp, s, max, true, total, idx + 1, __tsplusTrace), __tsplusTrace);
1002
+ return tsplus_module_7.flatMap(s => fold(inp, s, max, true, total, idx + 1, __tsplusTrace), __tsplusTrace)(f(s, elem));
972
1003
  } else {
973
- return tsplus_module_9.flatMap_(decompose(elem), decomposed => {
1004
+ return tsplus_module_7.flatMap(decomposed => {
974
1005
  if (decomposed.length <= 1 && !dirty) {
975
- return tsplus_module_9.map_(f(s, elem), s => [s, total, true, tsplus_module_2.drop_(inp, idx + 1)], __tsplusTrace);
1006
+ return tsplus_module_7.map(s => [s, total, true, tsplus_module_2.drop(idx + 1)(inp)], __tsplusTrace)(f(s, elem));
976
1007
  } else if (decomposed.length <= 1 && dirty) {
977
- return tsplus_module_9.succeedNow([s, cost, dirty, tsplus_module_2.drop_(inp, idx)], __tsplusTrace);
1008
+ return tsplus_module_7.succeedNow([s, cost, dirty, tsplus_module_2.drop(idx)(inp)], __tsplusTrace);
978
1009
  } else {
979
- return fold(tsplus_module_2.concat_(decomposed, tsplus_module_2.drop_(inp, idx + 1)), s, max, dirty, cost, 0, __tsplusTrace);
1010
+ return fold(tsplus_module_2.concat(tsplus_module_2.drop(idx + 1)(inp))(decomposed), s, max, dirty, cost, 0, __tsplusTrace);
980
1011
  }
981
- }, __tsplusTrace);
1012
+ }, __tsplusTrace)(decompose(elem));
982
1013
  }
983
- }, __tsplusTrace);
1014
+ }, __tsplusTrace)(tsplus_module_7.map(_ => cost + _, __tsplusTrace)(costFn(s, elem)));
984
1015
  }
985
1016
  }
986
1017
 
987
1018
  function go(s, cost, dirty, max, __tsplusTrace) {
988
- return tsplus_module_4.readWith(inp => tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => fold(inp, s, max, dirty, cost, 0, __tsplusTrace)), ([nextS, nextCost, nextDirty, leftovers]) => {
1019
+ return tsplus_module_4.readWith(inp => tsplus_module_5.flatMap(([nextS, nextCost, nextDirty, leftovers]) => {
989
1020
  if (tsplus_module_2.isNonEmpty(leftovers)) {
990
- return tsplus_module_5.apSecond_(tsplus_module_4.writeNow(leftovers), tsplus_module_5.succeedNow(nextS));
1021
+ return tsplus_module_5.apSecond(tsplus_module_5.succeedNow(nextS))(tsplus_module_4.writeNow(leftovers));
991
1022
  } else if (cost > max) {
992
1023
  return tsplus_module_5.succeedNow(nextS);
993
1024
  } else {
994
1025
  return go(nextS, nextCost, nextDirty, max, __tsplusTrace);
995
1026
  }
996
- }), err => tsplus_module_4.failNow(err), _ => tsplus_module_5.succeedNow(s));
1027
+ })(tsplus_module_4.fromIO(() => fold(inp, s, max, dirty, cost, 0, __tsplusTrace))), err => tsplus_module_4.failNow(err), _ => tsplus_module_5.succeedNow(s));
997
1028
  }
998
1029
 
999
1030
  return new tsplus_module_3.Sink(go(z(), 0, false, max(), __tsplusTrace));
@@ -1014,7 +1045,7 @@ function makeFoldWeightedDecomposeIO_1(z, costFn, max, decompose, f, __tsplusTra
1014
1045
 
1015
1046
 
1016
1047
  export function makeFoldWeighted(z, costFn, max, f, __tsplusTrace) {
1017
- return makeFoldWeightedDecompose_1(z, costFn, max, tsplus_module_24.single, f, __tsplusTrace);
1048
+ return makeFoldWeightedDecompose_1(z, costFn, max, tsplus_module_21.single, f, __tsplusTrace);
1018
1049
  }
1019
1050
  /**
1020
1051
  * Creates a sink that effectfully folds elements of type `In` into a
@@ -1030,35 +1061,41 @@ export function makeFoldWeighted(z, costFn, max, f, __tsplusTrace) {
1030
1061
  */
1031
1062
 
1032
1063
  export function makeFoldWeightedIO(z, costFn, max, f, __tsplusTrace) {
1033
- return makeFoldWeightedDecomposeIO_1(z, costFn, max, inp => tsplus_module_9.succeedNow(tsplus_module_24.single(inp), __tsplusTrace), f, __tsplusTrace);
1064
+ return makeFoldWeightedDecomposeIO_1(z, costFn, max, inp => tsplus_module_7.succeedNow(tsplus_module_21.single(inp), __tsplusTrace), f, __tsplusTrace);
1034
1065
  }
1035
1066
  /**
1036
1067
  * Transforms this sink's result.
1037
1068
  *
1038
- * @tsplus fluent fncts.io.Sink map
1069
+ * @tsplus pipeable fncts.io.Sink map
1039
1070
  */
1040
1071
 
1041
- function map_1(self, f, __tsplusTrace) {
1042
- return new tsplus_module_3.Sink(tsplus_module_5.map_(self.channel, f));
1072
+ function map_1(f, __tsplusTrace) {
1073
+ return self => {
1074
+ return new tsplus_module_3.Sink(tsplus_module_5.map(f)(self.channel));
1075
+ };
1043
1076
  }
1044
1077
  /**
1045
1078
  * Transforms the errors emitted by this sink using `f`.
1046
1079
  *
1047
- * @tsplus fluent fncts.io.Sink mapError
1080
+ * @tsplus pipeable fncts.io.Sink mapError
1048
1081
  */
1049
1082
 
1050
1083
 
1051
- export function mapError_(self, f, __tsplusTrace) {
1052
- return new tsplus_module_3.Sink(tsplus_module_4.mapError_(self.channel, f));
1084
+ export function mapError(f, __tsplusTrace) {
1085
+ return self => {
1086
+ return new tsplus_module_3.Sink(tsplus_module_4.mapError(f)(self.channel));
1087
+ };
1053
1088
  }
1054
1089
  /**
1055
1090
  * Effectfully transforms this sink's result.
1056
1091
  *
1057
- * @tsplus fluent fncts.io.Sink mapIO
1092
+ * @tsplus pipeable fncts.io.Sink mapIO
1058
1093
  */
1059
1094
 
1060
- function mapIO_1(self, f, __tsplusTrace) {
1061
- return new tsplus_module_3.Sink(tsplus_module_4.mapIO_(self.channel, f));
1095
+ function mapIO_1(f, __tsplusTrace) {
1096
+ return self => {
1097
+ return new tsplus_module_3.Sink(tsplus_module_4.mapIO(f)(self.channel));
1098
+ };
1062
1099
  }
1063
1100
  /**
1064
1101
  * Runs this sink until it yields a result, then uses that result to create
@@ -1067,79 +1104,91 @@ function mapIO_1(self, f, __tsplusTrace) {
1067
1104
  *
1068
1105
  * This function essentially runs sinks in sequence.
1069
1106
  *
1070
- * @tsplus fluent fncts.io.Sink matchSink
1107
+ * @tsplus pipeable fncts.io.Sink matchSink
1071
1108
  */
1072
1109
 
1073
1110
 
1074
- function matchSink_1(self, onFailure, onSuccess, __tsplusTrace) {
1075
- return new tsplus_module_3.Sink(tsplus_module_4.matchChannel_(tsplus_module_4.doneCollect(self.channel), e => onFailure(e).channel, ([leftovers, z]) => tsplus_module_4.defer(() => {
1076
- const leftoversRef = new AtomicReference(tsplus_module_2.filter_(leftovers, c => tsplus_module_2.isNonEmpty(c)));
1077
- const refReader = tsplus_module_5.flatMap_(tsplus_module_5.succeed(() => leftoversRef.getAndSet(tsplus_module_1.empty())), chunk => tsplus_module_4.writeChunk(chunk));
1078
- const passthrough = tsplus_module_4.id();
1079
- const continuationSink = tsplus_module_4.pipeTo_(tsplus_module_5.apSecond_(refReader, passthrough), onSuccess(z).channel);
1080
- return tsplus_module_5.flatMap_(tsplus_module_4.doneCollect(continuationSink), ([newLeftovers, z1]) => tsplus_module_5.apSecond_(tsplus_module_5.flatMap_(tsplus_module_5.succeed(() => leftoversRef.get), tsplus_module_4.writeChunk), tsplus_module_4.as_(tsplus_module_4.writeChunk(newLeftovers), () => z1)));
1081
- })));
1111
+ function matchSink_1(onFailure, onSuccess, __tsplusTrace) {
1112
+ return self => {
1113
+ return new tsplus_module_3.Sink(tsplus_module_4.matchChannel(e => onFailure(e).channel, ([leftovers, z]) => tsplus_module_4.defer(() => {
1114
+ const leftoversRef = new AtomicReference(tsplus_module_2.filter(c => tsplus_module_2.isNonEmpty(c))(leftovers));
1115
+ const refReader = tsplus_module_5.flatMap(chunk => tsplus_module_4.writeChunk(chunk))(tsplus_module_5.succeed(() => leftoversRef.getAndSet(tsplus_module_1.empty())));
1116
+ const passthrough = tsplus_module_4.id();
1117
+ const continuationSink = tsplus_module_4.pipeTo(onSuccess(z).channel)(tsplus_module_5.apSecond(passthrough)(refReader));
1118
+ return tsplus_module_5.flatMap(([newLeftovers, z1]) => tsplus_module_5.apSecond(tsplus_module_4.as_(() => z1)(tsplus_module_4.writeChunk(newLeftovers)))(tsplus_module_5.flatMap(tsplus_module_4.writeChunk)(tsplus_module_5.succeed(() => leftoversRef.get))))(tsplus_module_4.doneCollect(continuationSink));
1119
+ }))(tsplus_module_4.doneCollect(self.channel)));
1120
+ };
1082
1121
  }
1083
1122
  /**
1084
1123
  * Switch to another sink in case of failure
1085
1124
  *
1086
- * @tsplus fluent fncts.io.Sink orElse
1125
+ * @tsplus pipeable fncts.io.Sink orElse
1087
1126
  */
1088
1127
 
1089
1128
 
1090
- export function orElse(self, that, __tsplusTrace) {
1091
- return defer_1(() => new tsplus_module_3.Sink(tsplus_module_4.orElse_(self.channel, that().channel)), __tsplusTrace);
1129
+ export function orElse(that, __tsplusTrace) {
1130
+ return self => {
1131
+ return defer_1(() => new tsplus_module_3.Sink(tsplus_module_4.orElse(that().channel)(self.channel)), __tsplusTrace);
1132
+ };
1092
1133
  }
1093
1134
  /**
1094
1135
  * Provides the sink with its required environment, which eliminates its
1095
1136
  * dependency on `R`.
1096
1137
  *
1097
- * @tsplus fluent fncts.io.Sink provideEnvironment
1138
+ * @tsplus pipeable fncts.io.Sink provideEnvironment
1098
1139
  */
1099
1140
 
1100
- export function provideEnvironment(self, r, __tsplusTrace) {
1101
- return new tsplus_module_3.Sink(tsplus_module_4.provideEnvironment_(self.channel, r));
1141
+ export function provideEnvironment(r, __tsplusTrace) {
1142
+ return self => {
1143
+ return new tsplus_module_3.Sink(tsplus_module_4.provideEnvironment(r)(self.channel));
1144
+ };
1102
1145
  }
1103
1146
  /**
1104
1147
  * Runs both sinks in parallel on the input, returning the result or the
1105
1148
  * error from the one that finishes first.
1106
1149
  *
1107
- * @tsplus fluent fncts.io.Sink race
1150
+ * @tsplus pipeable fncts.io.Sink race
1108
1151
  */
1109
1152
 
1110
- export function race(self, that, __tsplusTrace) {
1111
- return map_1(raceBoth_1(self, that), result => tsplus_module_25.merge(result), __tsplusTrace);
1153
+ export function race(that, __tsplusTrace) {
1154
+ return self => {
1155
+ return map_1(result => tsplus_module_22.merge(result), __tsplusTrace)(raceBoth_1(that)(self));
1156
+ };
1112
1157
  }
1113
1158
  /**
1114
1159
  * Runs both sinks in parallel on the input, returning the result or the error
1115
1160
  * from the one that finishes first.
1116
1161
  *
1117
- * @tsplus fluent fncts.io.Sink raceBoth
1162
+ * @tsplus pipeable fncts.io.Sink raceBoth
1118
1163
  */
1119
1164
 
1120
- function raceBoth_1(self, that, capacity = () => 16, __tsplusTrace) {
1121
- return raceWith_1(self, that, selfDone => tsplus_module_27.done(tsplus_module_9.map_(tsplus_module_9.fromExitNow(selfDone, __tsplusTrace), tsplus_module_26.left, __tsplusTrace)), thatDone => tsplus_module_27.done(tsplus_module_9.map_(tsplus_module_9.fromExitNow(thatDone, __tsplusTrace), tsplus_module_26.right, __tsplusTrace)), capacity, __tsplusTrace);
1165
+ function raceBoth_1(that, capacity = () => 16, __tsplusTrace) {
1166
+ return self => {
1167
+ return raceWith_1(that, selfDone => tsplus_module_24.done(tsplus_module_7.map(tsplus_module_23.left, __tsplusTrace)(tsplus_module_7.fromExitNow(selfDone, __tsplusTrace))), thatDone => tsplus_module_24.done(tsplus_module_7.map(tsplus_module_23.right, __tsplusTrace)(tsplus_module_7.fromExitNow(thatDone, __tsplusTrace))), capacity, __tsplusTrace)(self);
1168
+ };
1122
1169
  }
1123
1170
  /**
1124
1171
  * Runs both sinks in parallel on the input, using the specified merge
1125
1172
  * function as soon as one result or the other has been computed.
1126
1173
  *
1127
- * @tsplus fluent fncts.io.Sink raceWith
1174
+ * @tsplus pipeable fncts.io.Sink raceWith
1128
1175
  */
1129
1176
 
1130
1177
 
1131
- function raceWith_1(self, that, leftDone, rightDone, capacity = () => 16, __tsplusTrace) {
1132
- const scoped = tsplus_module_9.defer(() => {
1133
- const that0 = that();
1134
- const capacity0 = capacity();
1135
- return tsplus_module_9.flatMap_(tsplus_module_29.makeBounded(capacity(), __tsplusTrace), hub => tsplus_module_9.flatMap_(tsplus_module_4.fromHubScoped(() => hub), c1 => tsplus_module_9.map_(tsplus_module_4.fromHubScoped(() => hub), c2 => {
1136
- const reader = tsplus_module_4.toHub(() => hub);
1137
- const writer = tsplus_module_28.mergeWith_(tsplus_module_4.pipeTo_(c1, self.channel), tsplus_module_4.pipeTo_(c2, that0.channel), leftDone, rightDone);
1138
- const channel = tsplus_module_28.mergeWith_(reader, writer, () => tsplus_module_27.wait(tsplus_module_9.fromExitNow), done => tsplus_module_27.done(tsplus_module_9.fromExitNow(done, __tsplusTrace)));
1139
- return new tsplus_module_3.Sink(channel);
1140
- }, __tsplusTrace), __tsplusTrace), __tsplusTrace);
1141
- }, __tsplusTrace);
1142
- return unwrapScoped_1(() => scoped, __tsplusTrace);
1178
+ function raceWith_1(that, leftDone, rightDone, capacity = () => 16, __tsplusTrace) {
1179
+ return self => {
1180
+ const scoped = tsplus_module_7.defer(() => {
1181
+ const that0 = that();
1182
+ const capacity0 = capacity();
1183
+ return tsplus_module_7.flatMap(hub => tsplus_module_7.flatMap(c1 => tsplus_module_7.map(c2 => {
1184
+ const reader = tsplus_module_4.toHub(() => hub);
1185
+ const writer = tsplus_module_25.mergeWith(tsplus_module_4.pipeTo(that0.channel)(c2), leftDone, rightDone)(tsplus_module_4.pipeTo(self.channel)(c1));
1186
+ const channel = tsplus_module_25.mergeWith(writer, () => tsplus_module_24.wait(tsplus_module_7.fromExitNow), done => tsplus_module_24.done(tsplus_module_7.fromExitNow(done, __tsplusTrace)))(reader);
1187
+ return new tsplus_module_3.Sink(channel);
1188
+ }, __tsplusTrace)(tsplus_module_4.fromHubScoped(() => hub)), __tsplusTrace)(tsplus_module_4.fromHubScoped(() => hub)), __tsplusTrace)(tsplus_module_26.makeBounded(capacity(), __tsplusTrace));
1189
+ }, __tsplusTrace);
1190
+ return unwrapScoped_1(() => scoped, __tsplusTrace);
1191
+ };
1143
1192
  }
1144
1193
  /**
1145
1194
  * Accesses the specified service in the environment of the effect.
@@ -1152,7 +1201,7 @@ export function service(
1152
1201
  /** @tsplus auto */
1153
1202
  tag) {
1154
1203
  const tag_1 = tag;
1155
- return serviceWith_1(tsplus_module_14.identity, tag_1);
1204
+ return serviceWith_1(tsplus_module_12.identity, tag_1);
1156
1205
  }
1157
1206
  /**
1158
1207
  * Accesses the specified service in the environment of the sink.
@@ -1163,7 +1212,7 @@ tag) {
1163
1212
  function serviceWith_1(f,
1164
1213
  /** @tsplus auto */
1165
1214
  tag) {
1166
- return fromIO_1(() => tsplus_module_13.serviceWith(f, tag, fileName_1 + ":1550:36"), fileName_1 + ":1550:21");
1215
+ return fromIO_1(() => tsplus_module_11.serviceWith(f, tag, fileName_1 + ":1520:36"), fileName_1 + ":1520:21");
1167
1216
  }
1168
1217
  /**
1169
1218
  * Accesses the specified service in the environment of the sink in the
@@ -1176,7 +1225,7 @@ tag) {
1176
1225
  export function serviceWithIO(f,
1177
1226
  /** @tsplus auto */
1178
1227
  tag) {
1179
- return fromIO_1(() => tsplus_module_13.serviceWithIO(f, tag, fileName_1 + ":1563:38"), fileName_1 + ":1563:21");
1228
+ return fromIO_1(() => tsplus_module_11.serviceWithIO(f, tag, fileName_1 + ":1533:38"), fileName_1 + ":1533:21");
1180
1229
  }
1181
1230
  /**
1182
1231
  * Accesses the specified service in the environment of the sink in the
@@ -1188,18 +1237,20 @@ tag) {
1188
1237
  export function serviceWithSink(f,
1189
1238
  /** @tsplus auto */
1190
1239
  tag) {
1191
- return new tsplus_module_3.Sink(tsplus_module_4.unwrap(() => tsplus_module_13.serviceWith(tsplus_module_14.compose_(f, s => s.channel), tag, fileName_1 + ":1578:21")));
1240
+ return new tsplus_module_3.Sink(tsplus_module_4.unwrap(() => tsplus_module_11.serviceWith(tsplus_module_12.compose(s => s.channel)(f), tag, fileName_1 + ":1548:21")));
1192
1241
  }
1193
1242
  /**
1194
1243
  * Splits the sink on the specified predicate, returning a new sink that
1195
1244
  * consumes elements until an element after the first satisfies the specified
1196
1245
  * predicate.
1197
1246
  *
1198
- * @tsplus fluent fncts.io.Sink splitWhere
1247
+ * @tsplus pipeable fncts.io.Sink splitWhere
1199
1248
  */
1200
1249
 
1201
- export function splitWhere(self, p, __tsplusTrace) {
1202
- return new tsplus_module_3.Sink(tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => tsplus_module_8.make(() => tsplus_module_1.empty(), __tsplusTrace)), ref => tsplus_module_5.flatMap_(tsplus_module_4.collectElements(tsplus_module_4.pipeToOrFail_(splitter(p, false, ref, __tsplusTrace), self.channel)), ([leftovers, z]) => tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => tsplus_module_7.get(ref, __tsplusTrace)), leftover => tsplus_module_5.apSecond_(tsplus_module_4.writeNow(tsplus_module_2.concat_(leftover, tsplus_module_2.flatten(leftovers))), tsplus_module_5.succeedNow(z))))));
1250
+ export function splitWhere(p, __tsplusTrace) {
1251
+ return self => {
1252
+ return new tsplus_module_3.Sink(tsplus_module_5.flatMap(ref => tsplus_module_5.flatMap(([leftovers, z]) => tsplus_module_5.flatMap(leftover => tsplus_module_5.apSecond(tsplus_module_5.succeedNow(z))(tsplus_module_4.writeNow(tsplus_module_2.concat(tsplus_module_2.flatten(leftovers))(leftover))))(tsplus_module_4.fromIO(() => ref.get)))(tsplus_module_4.collectElements(tsplus_module_4.pipeToOrFail(self.channel)(splitter(p, false, ref, __tsplusTrace)))))(tsplus_module_4.fromIO(() => tsplus_module_6.make(() => tsplus_module_1.empty(), __tsplusTrace))));
1253
+ };
1203
1254
  }
1204
1255
 
1205
1256
  function splitter(p, written, leftovers, __tsplusTrace) {
@@ -1207,22 +1258,22 @@ function splitter(p, written, leftovers, __tsplusTrace) {
1207
1258
  if (tsplus_module_2.isEmpty(inp)) {
1208
1259
  return splitter(p, written, leftovers, __tsplusTrace);
1209
1260
  } else if (written) {
1210
- const index = tsplus_module_30.findIndex(inp, p);
1261
+ const index = tsplus_module_27.findIndex(p)(inp);
1211
1262
 
1212
1263
  if (index === -1) {
1213
- return tsplus_module_5.apSecond_(tsplus_module_4.writeNow(inp), splitter(p, true, leftovers, __tsplusTrace));
1264
+ return tsplus_module_5.apSecond(splitter(p, true, leftovers, __tsplusTrace))(tsplus_module_4.writeNow(inp));
1214
1265
  } else {
1215
- const [left, right] = tsplus_module_2.splitAt_(inp, index);
1216
- return tsplus_module_5.apSecond_(tsplus_module_4.writeNow(left), tsplus_module_4.fromIO(() => tsplus_module_6.set_(leftovers, right, __tsplusTrace)));
1266
+ const [left, right] = tsplus_module_2.splitAt(index)(inp);
1267
+ return tsplus_module_5.apSecond(tsplus_module_4.fromIO(() => leftovers.set(right, __tsplusTrace)))(tsplus_module_4.writeNow(left));
1217
1268
  }
1218
1269
  } else {
1219
- const index = tsplus_module_30.findIndex(inp, p);
1270
+ const index = tsplus_module_27.findIndex(p)(inp);
1220
1271
 
1221
1272
  if (index === -1) {
1222
- return tsplus_module_5.apSecond_(tsplus_module_4.writeNow(inp), splitter(p, true, leftovers, __tsplusTrace));
1273
+ return tsplus_module_5.apSecond(splitter(p, true, leftovers, __tsplusTrace))(tsplus_module_4.writeNow(inp));
1223
1274
  } else {
1224
- const [left, right] = tsplus_module_2.splitAt_(inp, Math.max(index, 1));
1225
- return tsplus_module_5.apSecond_(tsplus_module_4.writeNow(left), tsplus_module_4.fromIO(() => tsplus_module_6.set_(leftovers, right, __tsplusTrace)));
1275
+ const [left, right] = tsplus_module_2.splitAt(Math.max(index, 1))(inp);
1276
+ return tsplus_module_5.apSecond(tsplus_module_4.fromIO(() => leftovers.set(right, __tsplusTrace)))(tsplus_module_4.writeNow(left));
1226
1277
  }
1227
1278
  }
1228
1279
  }, tsplus_module_5.failCauseNow, tsplus_module_5.succeedNow);
@@ -1250,11 +1301,13 @@ export function succeedNow(z, __tsplusTrace) {
1250
1301
  * Summarize a sink by running an effect when the sink starts and again when
1251
1302
  * it completes
1252
1303
  *
1253
- * @tsplus fluent fncts.io.Sink summarized
1304
+ * @tsplus pipeable fncts.io.Sink summarized
1254
1305
  */
1255
1306
 
1256
- function summarized_1(self, summary, f, __tsplusTrace) {
1257
- return new tsplus_module_3.Sink(tsplus_module_4.unwrap(() => tsplus_module_9.map_(tsplus_module_9.succeed(summary, __tsplusTrace), summary => tsplus_module_5.flatMap_(tsplus_module_4.fromIO(() => summary), start => tsplus_module_5.flatMap_(self.channel, done => tsplus_module_5.map_(tsplus_module_4.fromIO(() => summary), end => tsplus_module_14.tuple(done, f(start, end))))), __tsplusTrace)));
1307
+ function summarized_1(summary, f, __tsplusTrace) {
1308
+ return self => {
1309
+ return new tsplus_module_3.Sink(tsplus_module_4.unwrap(() => tsplus_module_7.map(summary => tsplus_module_5.flatMap(start => tsplus_module_5.flatMap(done => tsplus_module_5.map(end => tsplus_module_12.tuple(done, f(start, end)))(tsplus_module_4.fromIO(() => summary)))(self.channel))(tsplus_module_4.fromIO(() => summary)), __tsplusTrace)(tsplus_module_7.succeed(summary, __tsplusTrace))));
1310
+ };
1258
1311
  }
1259
1312
  /**
1260
1313
  * @tsplus getter fncts.io.Sink timed
@@ -1262,7 +1315,7 @@ function summarized_1(self, summary, f, __tsplusTrace) {
1262
1315
 
1263
1316
 
1264
1317
  export function timed(self, __tsplusTrace) {
1265
- return summarized_1(self, () => tsplus_module_31.currentTime, (start, end) => tsplus_module_32.fromInterval(start, end), __tsplusTrace);
1318
+ return summarized_1(() => tsplus_module_28.currentTime, (start, end) => tsplus_module_29.fromInterval(start, end), __tsplusTrace)(self);
1266
1319
  }
1267
1320
  /**
1268
1321
  * Creates a sink produced from an effect.
@@ -1271,7 +1324,7 @@ export function timed(self, __tsplusTrace) {
1271
1324
  */
1272
1325
 
1273
1326
  function unwrap_1(io, __tsplusTrace) {
1274
- return new tsplus_module_3.Sink(tsplus_module_4.unwrap(() => tsplus_module_9.map_(io(), sink => sink.channel, __tsplusTrace)));
1327
+ return new tsplus_module_3.Sink(tsplus_module_4.unwrap(() => tsplus_module_7.map(sink => sink.channel, __tsplusTrace)(io())));
1275
1328
  }
1276
1329
  /**
1277
1330
  * Creates a sink produced from a scoped effect.
@@ -1281,50 +1334,58 @@ function unwrap_1(io, __tsplusTrace) {
1281
1334
 
1282
1335
 
1283
1336
  function unwrapScoped_1(scoped, __tsplusTrace) {
1284
- return new tsplus_module_3.Sink(tsplus_module_4.unwrapScoped(() => tsplus_module_9.map_(scoped(), sink => sink.channel, __tsplusTrace)));
1337
+ return new tsplus_module_3.Sink(tsplus_module_4.unwrapScoped(() => tsplus_module_7.map(sink => sink.channel, __tsplusTrace)(scoped())));
1285
1338
  }
1286
1339
  /**
1287
1340
  * Feeds inputs to this sink until it yields a result, then switches over to
1288
1341
  * the provided sink until it yields a result, finally combining the two
1289
1342
  * results into a tuple.
1290
1343
  *
1291
- * @tsplus fluent fncts.io.Sink zip
1344
+ * @tsplus pipeable fncts.io.Sink zip
1292
1345
  */
1293
1346
 
1294
1347
 
1295
- export function zip(self, that, __tsplusTrace) {
1296
- return zipWith_1(() => self, that, tsplus_module_14.tuple, __tsplusTrace);
1348
+ export function zip(that, __tsplusTrace) {
1349
+ return self => {
1350
+ return zipWith_1(that, tsplus_module_12.tuple, __tsplusTrace)(() => self);
1351
+ };
1297
1352
  }
1298
1353
  /**
1299
1354
  * Runs both sinks in parallel on the input and combines the results in a
1300
1355
  * tuple.
1301
1356
  *
1302
- * @tsplus fluent fncts.io.Sink zipC
1357
+ * @tsplus pipeable fncts.io.Sink zipC
1303
1358
  */
1304
1359
 
1305
- export function zipC(self, that, __tsplusTrace) {
1306
- return zipWithC_1(() => self, that, tsplus_module_14.tuple, __tsplusTrace);
1360
+ export function zipC(that, __tsplusTrace) {
1361
+ return self => {
1362
+ return zipWithC_1(that, tsplus_module_12.tuple, __tsplusTrace)(() => self);
1363
+ };
1307
1364
  }
1308
1365
  /**
1309
1366
  * Feeds inputs to this sink until it yields a result, then switches over to
1310
1367
  * the provided sink until it yields a result, finally combining the two
1311
1368
  * results with `f`.
1312
1369
  *
1313
- * @tsplus fluent fncts.io.Sink zipWith
1370
+ * @tsplus pipeable fncts.io.Sink zipWith
1314
1371
  */
1315
1372
 
1316
- function zipWith_1(self, that, f, __tsplusTrace) {
1317
- return defer_1(() => flatMap_1(self(), z => map_1(that(), z1 => f(z, z1), __tsplusTrace), __tsplusTrace), __tsplusTrace);
1373
+ function zipWith_1(that, f, __tsplusTrace) {
1374
+ return self => {
1375
+ return defer_1(() => flatMap_1(z => map_1(z1 => f(z, z1), __tsplusTrace)(that()), __tsplusTrace)(self()), __tsplusTrace);
1376
+ };
1318
1377
  }
1319
1378
  /**
1320
1379
  * Runs both sinks in parallel on the input and combines the results using the
1321
1380
  * provided function.
1322
1381
  *
1323
- * @tsplus fluent fncts.io.Sink zipWithC
1382
+ * @tsplus pipeable fncts.io.Sink zipWithC
1324
1383
  */
1325
1384
 
1326
1385
 
1327
- function zipWithC_1(self, that, f, __tsplusTrace) {
1328
- return defer_1(() => raceWith_1(self(), () => that(), exit => tsplus_module_33.match_(exit, err => tsplus_module_27.done(tsplus_module_9.failCauseNow(err, __tsplusTrace)), lz => tsplus_module_27.wait(exit => tsplus_module_33.match_(exit, cause => tsplus_module_9.failCauseNow(cause, __tsplusTrace), rz => tsplus_module_9.succeedNow(f(lz, rz), __tsplusTrace)))), exit => tsplus_module_33.match_(exit, err => tsplus_module_27.done(tsplus_module_9.failCauseNow(err, __tsplusTrace)), rz => tsplus_module_27.wait(exit => tsplus_module_33.match_(exit, cause => tsplus_module_9.failCauseNow(cause, __tsplusTrace), lz => tsplus_module_9.succeedNow(f(lz, rz), __tsplusTrace))))), __tsplusTrace);
1386
+ function zipWithC_1(that, f, __tsplusTrace) {
1387
+ return self => {
1388
+ return defer_1(() => raceWith_1(() => that(), exit => tsplus_module_30.match(err => tsplus_module_24.done(tsplus_module_7.failCauseNow(err, __tsplusTrace)), lz => tsplus_module_24.wait(exit => tsplus_module_30.match(cause => tsplus_module_7.failCauseNow(cause, __tsplusTrace), rz => tsplus_module_7.succeedNow(f(lz, rz), __tsplusTrace))(exit)))(exit), exit => tsplus_module_30.match(err => tsplus_module_24.done(tsplus_module_7.failCauseNow(err, __tsplusTrace)), rz => tsplus_module_24.wait(exit => tsplus_module_30.match(cause => tsplus_module_7.failCauseNow(cause, __tsplusTrace), lz => tsplus_module_7.succeedNow(f(lz, rz), __tsplusTrace))(exit)))(exit))(self()), __tsplusTrace);
1389
+ };
1329
1390
  }
1330
1391
  //# sourceMappingURL=api.mjs.map