@typed/fx 0.0.4 → 0.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (461) hide show
  1. package/.eslintcache +1 -1
  2. package/cjs/Cause/Cause.d.ts +10 -0
  3. package/cjs/Cause/Cause.d.ts.map +1 -1
  4. package/cjs/Cause/Cause.js +37 -2
  5. package/cjs/Cause/Cause.js.map +1 -1
  6. package/cjs/Cause/Renderer.js +1 -1
  7. package/cjs/Cause/Renderer.js.map +1 -1
  8. package/cjs/Env/Env.d.ts +9 -1
  9. package/cjs/Env/Env.d.ts.map +1 -1
  10. package/cjs/Env/Env.js +32 -5
  11. package/cjs/Env/Env.js.map +1 -1
  12. package/cjs/Fiber/fromScope.d.ts +5 -0
  13. package/cjs/Fiber/fromScope.d.ts.map +1 -0
  14. package/cjs/Fiber/fromScope.js +17 -0
  15. package/cjs/Fiber/fromScope.js.map +1 -0
  16. package/cjs/FiberRef/builtins.d.ts +4 -1
  17. package/cjs/FiberRef/builtins.d.ts.map +1 -1
  18. package/cjs/FiberRef/builtins.js +40 -13
  19. package/cjs/FiberRef/builtins.js.map +1 -1
  20. package/cjs/FiberRuntime/FiberRuntime.d.ts.map +1 -1
  21. package/cjs/FiberRuntime/FiberRuntime.js +23 -14
  22. package/cjs/FiberRuntime/FiberRuntime.js.map +1 -1
  23. package/cjs/Fx/Fx.d.ts +4 -3
  24. package/cjs/Fx/Fx.d.ts.map +1 -1
  25. package/cjs/Fx/Fx.js +25 -24
  26. package/cjs/Fx/Fx.js.map +1 -1
  27. package/cjs/Fx/join.d.ts +1 -1
  28. package/cjs/Fx/join.d.ts.map +1 -1
  29. package/cjs/Fx/join.js +1 -1
  30. package/cjs/Fx/join.js.map +1 -1
  31. package/cjs/Schedule/ScheduleState.d.ts +3 -0
  32. package/cjs/Schedule/ScheduleState.d.ts.map +1 -1
  33. package/cjs/Schedule/ScheduleState.js +3 -0
  34. package/cjs/Schedule/ScheduleState.js.map +1 -1
  35. package/cjs/Scheduler/RootScheduler.d.ts.map +1 -1
  36. package/cjs/Scheduler/RootScheduler.js +4 -5
  37. package/cjs/Scheduler/RootScheduler.js.map +1 -1
  38. package/cjs/Scheduler/Scheduler.d.ts +2 -2
  39. package/cjs/Scheduler/Scheduler.d.ts.map +1 -1
  40. package/cjs/Scheduler/Scheduler.js.map +1 -1
  41. package/cjs/Scheduler/callbackScheduler.d.ts.map +1 -1
  42. package/cjs/Scheduler/callbackScheduler.js +1 -0
  43. package/cjs/Scheduler/callbackScheduler.js.map +1 -1
  44. package/cjs/Scheduler/runSchedule.d.ts +1 -1
  45. package/cjs/Scheduler/runSchedule.d.ts.map +1 -1
  46. package/cjs/Scheduler/runSchedule.js +3 -2
  47. package/cjs/Scheduler/runSchedule.js.map +1 -1
  48. package/cjs/Scope/LocalScope.d.ts.map +1 -1
  49. package/cjs/Scope/LocalScope.js +8 -8
  50. package/cjs/Scope/LocalScope.js.map +1 -1
  51. package/cjs/Semaphore/Semaphore.d.ts +9 -9
  52. package/cjs/Semaphore/Semaphore.d.ts.map +1 -1
  53. package/cjs/Semaphore/Semaphore.js +34 -15
  54. package/cjs/Semaphore/Semaphore.js.map +1 -1
  55. package/cjs/Sink/Sink.d.ts +1 -0
  56. package/cjs/Sink/Sink.d.ts.map +1 -1
  57. package/cjs/Sink/Sink.js +11 -1
  58. package/cjs/Sink/Sink.js.map +1 -1
  59. package/cjs/Stream/Stream.d.ts +5 -14
  60. package/cjs/Stream/Stream.d.ts.map +1 -1
  61. package/cjs/Stream/Stream.js.map +1 -1
  62. package/cjs/Stream/acquirePermit.d.ts +15 -0
  63. package/cjs/Stream/acquirePermit.d.ts.map +1 -0
  64. package/cjs/Stream/acquirePermit.js +43 -0
  65. package/cjs/Stream/acquirePermit.js.map +1 -0
  66. package/cjs/Stream/bimap.d.ts +33 -4
  67. package/cjs/Stream/bimap.d.ts.map +1 -1
  68. package/cjs/Stream/bimap.js +109 -12
  69. package/cjs/Stream/bimap.js.map +1 -1
  70. package/cjs/Stream/continueWith.d.ts +4 -3
  71. package/cjs/Stream/continueWith.d.ts.map +1 -1
  72. package/cjs/Stream/continueWith.js +9 -6
  73. package/cjs/Stream/continueWith.js.map +1 -1
  74. package/cjs/Stream/delay.d.ts +4 -0
  75. package/cjs/Stream/delay.d.ts.map +1 -0
  76. package/cjs/Stream/delay.js +30 -0
  77. package/cjs/Stream/delay.js.map +1 -0
  78. package/cjs/Stream/drain.d.ts +2 -2
  79. package/cjs/Stream/drain.d.ts.map +1 -1
  80. package/cjs/Stream/drain.js +5 -5
  81. package/cjs/Stream/drain.js.map +1 -1
  82. package/cjs/Stream/empty.d.ts.map +1 -1
  83. package/cjs/Stream/empty.js +1 -2
  84. package/cjs/Stream/empty.js.map +1 -1
  85. package/cjs/Stream/flatMap.d.ts +7 -5
  86. package/cjs/Stream/flatMap.d.ts.map +1 -1
  87. package/cjs/Stream/flatMap.js +33 -19
  88. package/cjs/Stream/flatMap.js.map +1 -1
  89. package/cjs/Stream/flatMapConcurrently.d.ts +6 -0
  90. package/cjs/Stream/flatMapConcurrently.d.ts.map +1 -0
  91. package/cjs/Stream/flatMapConcurrently.js +25 -0
  92. package/cjs/Stream/flatMapConcurrently.js.map +1 -0
  93. package/cjs/Stream/flatMapFx.d.ts +5 -1
  94. package/cjs/Stream/flatMapFx.d.ts.map +1 -1
  95. package/cjs/Stream/flatMapFx.js +18 -3
  96. package/cjs/Stream/flatMapFx.js.map +1 -1
  97. package/cjs/Stream/foldMap.d.ts +11 -0
  98. package/cjs/Stream/foldMap.d.ts.map +1 -0
  99. package/cjs/Stream/foldMap.js +67 -0
  100. package/cjs/Stream/foldMap.js.map +1 -0
  101. package/cjs/Stream/fromArray.d.ts +2 -0
  102. package/cjs/Stream/fromArray.d.ts.map +1 -0
  103. package/cjs/Stream/fromArray.js +12 -0
  104. package/cjs/Stream/fromArray.js.map +1 -0
  105. package/cjs/Stream/fromCallback.d.ts +4 -3
  106. package/cjs/Stream/fromCallback.d.ts.map +1 -1
  107. package/cjs/Stream/fromCallback.js +26 -26
  108. package/cjs/Stream/fromCallback.js.map +1 -1
  109. package/cjs/Stream/fromFx.d.ts +23 -8
  110. package/cjs/Stream/fromFx.d.ts.map +1 -1
  111. package/cjs/Stream/fromFx.js +36 -16
  112. package/cjs/Stream/fromFx.js.map +1 -1
  113. package/cjs/Stream/hkt.d.ts +24 -1
  114. package/cjs/Stream/hkt.d.ts.map +1 -1
  115. package/cjs/Stream/hkt.js +43 -5
  116. package/cjs/Stream/hkt.js.map +1 -1
  117. package/cjs/Stream/hold.d.ts +27 -0
  118. package/cjs/Stream/hold.d.ts.map +1 -0
  119. package/cjs/Stream/hold.js +94 -0
  120. package/cjs/Stream/hold.js.map +1 -0
  121. package/cjs/Stream/index.d.ts +14 -1
  122. package/cjs/Stream/index.d.ts.map +1 -1
  123. package/cjs/Stream/index.js +14 -1
  124. package/cjs/Stream/index.js.map +1 -1
  125. package/cjs/Stream/lazy.d.ts +3 -0
  126. package/cjs/Stream/lazy.d.ts.map +1 -0
  127. package/cjs/Stream/lazy.js +9 -0
  128. package/cjs/Stream/lazy.js.map +1 -0
  129. package/cjs/Stream/merge.d.ts +18 -0
  130. package/cjs/Stream/merge.d.ts.map +1 -0
  131. package/cjs/Stream/merge.js +84 -0
  132. package/cjs/Stream/merge.js.map +1 -0
  133. package/cjs/Stream/multicast.d.ts +27 -0
  134. package/cjs/Stream/multicast.d.ts.map +1 -0
  135. package/cjs/Stream/multicast.js +83 -0
  136. package/cjs/Stream/multicast.js.map +1 -0
  137. package/cjs/Stream/orElse.d.ts +17 -0
  138. package/cjs/Stream/orElse.d.ts.map +1 -0
  139. package/cjs/Stream/orElse.js +105 -0
  140. package/cjs/Stream/orElse.js.map +1 -0
  141. package/cjs/Stream/periodic.d.ts +1 -1
  142. package/cjs/Stream/periodic.d.ts.map +1 -1
  143. package/cjs/Stream/periodic.js +1 -1
  144. package/cjs/Stream/periodic.js.map +1 -1
  145. package/cjs/Stream/provide.d.ts +8 -0
  146. package/cjs/Stream/provide.d.ts.map +1 -0
  147. package/cjs/Stream/provide.js +42 -0
  148. package/cjs/Stream/provide.js.map +1 -0
  149. package/cjs/Stream/run.d.ts +2 -2
  150. package/cjs/Stream/run.d.ts.map +1 -1
  151. package/cjs/Stream/run.js +1 -1
  152. package/cjs/Stream/run.js.map +1 -1
  153. package/cjs/Stream/scan.d.ts +17 -0
  154. package/cjs/Stream/scan.d.ts.map +1 -0
  155. package/cjs/Stream/scan.js +32 -0
  156. package/cjs/Stream/scan.js.map +1 -0
  157. package/cjs/Stream/scheduled.d.ts +12 -3
  158. package/cjs/Stream/scheduled.d.ts.map +1 -1
  159. package/cjs/Stream/scheduled.js +23 -5
  160. package/cjs/Stream/scheduled.js.map +1 -1
  161. package/cjs/Stream/setFiberRefLocally.d.ts +15 -0
  162. package/cjs/Stream/setFiberRefLocally.d.ts.map +1 -0
  163. package/cjs/Stream/setFiberRefLocally.js +53 -0
  164. package/cjs/Stream/setFiberRefLocally.js.map +1 -0
  165. package/cjs/Stream/skipRepeats.d.ts +5 -0
  166. package/cjs/Stream/skipRepeats.d.ts.map +1 -0
  167. package/cjs/Stream/skipRepeats.js +36 -0
  168. package/cjs/Stream/skipRepeats.js.map +1 -0
  169. package/cjs/Stream/switchMap.d.ts +18 -0
  170. package/cjs/Stream/switchMap.d.ts.map +1 -0
  171. package/cjs/Stream/switchMap.js +124 -0
  172. package/cjs/Stream/switchMap.js.map +1 -0
  173. package/cjs/Stream/tap.d.ts +2 -1
  174. package/cjs/Stream/tap.d.ts.map +1 -1
  175. package/cjs/Stream/tap.js +4 -2
  176. package/cjs/Stream/tap.js.map +1 -1
  177. package/cjs/Supervisor/index.d.ts +2 -0
  178. package/cjs/Supervisor/index.d.ts.map +1 -1
  179. package/cjs/Supervisor/index.js +2 -0
  180. package/cjs/Supervisor/index.js.map +1 -1
  181. package/cjs/Supervisor/inheritFiberRefs.d.ts +2 -0
  182. package/cjs/Supervisor/inheritFiberRefs.d.ts.map +1 -0
  183. package/cjs/Supervisor/inheritFiberRefs.js +17 -0
  184. package/cjs/Supervisor/inheritFiberRefs.js.map +1 -0
  185. package/cjs/Timeline/index.js.map +1 -1
  186. package/esm/Cause/Cause.d.ts +10 -0
  187. package/esm/Cause/Cause.d.ts.map +1 -1
  188. package/esm/Cause/Cause.js +27 -0
  189. package/esm/Cause/Cause.js.map +1 -1
  190. package/esm/Cause/Renderer.js +1 -1
  191. package/esm/Cause/Renderer.js.map +1 -1
  192. package/esm/Env/Env.d.ts +9 -1
  193. package/esm/Env/Env.d.ts.map +1 -1
  194. package/esm/Env/Env.js +8 -5
  195. package/esm/Env/Env.js.map +1 -1
  196. package/esm/Fiber/fromScope.d.ts +5 -0
  197. package/esm/Fiber/fromScope.d.ts.map +1 -0
  198. package/esm/Fiber/fromScope.js +13 -0
  199. package/esm/Fiber/fromScope.js.map +1 -0
  200. package/esm/FiberRef/builtins.d.ts +4 -1
  201. package/esm/FiberRef/builtins.d.ts.map +1 -1
  202. package/esm/FiberRef/builtins.js +36 -12
  203. package/esm/FiberRef/builtins.js.map +1 -1
  204. package/esm/FiberRuntime/FiberRuntime.d.ts.map +1 -1
  205. package/esm/FiberRuntime/FiberRuntime.js +23 -14
  206. package/esm/FiberRuntime/FiberRuntime.js.map +1 -1
  207. package/esm/Fx/Fx.d.ts +4 -3
  208. package/esm/Fx/Fx.d.ts.map +1 -1
  209. package/esm/Fx/Fx.js +22 -22
  210. package/esm/Fx/Fx.js.map +1 -1
  211. package/esm/Fx/join.d.ts +1 -1
  212. package/esm/Fx/join.d.ts.map +1 -1
  213. package/esm/Fx/join.js +1 -1
  214. package/esm/Fx/join.js.map +1 -1
  215. package/esm/Schedule/ScheduleState.d.ts +3 -0
  216. package/esm/Schedule/ScheduleState.d.ts.map +1 -1
  217. package/esm/Schedule/ScheduleState.js +3 -0
  218. package/esm/Schedule/ScheduleState.js.map +1 -1
  219. package/esm/Scheduler/RootScheduler.d.ts.map +1 -1
  220. package/esm/Scheduler/RootScheduler.js +4 -5
  221. package/esm/Scheduler/RootScheduler.js.map +1 -1
  222. package/esm/Scheduler/Scheduler.d.ts +2 -2
  223. package/esm/Scheduler/Scheduler.d.ts.map +1 -1
  224. package/esm/Scheduler/Scheduler.js.map +1 -1
  225. package/esm/Scheduler/callbackScheduler.d.ts.map +1 -1
  226. package/esm/Scheduler/callbackScheduler.js +1 -0
  227. package/esm/Scheduler/callbackScheduler.js.map +1 -1
  228. package/esm/Scheduler/runSchedule.d.ts +1 -1
  229. package/esm/Scheduler/runSchedule.d.ts.map +1 -1
  230. package/esm/Scheduler/runSchedule.js +4 -3
  231. package/esm/Scheduler/runSchedule.js.map +1 -1
  232. package/esm/Scope/LocalScope.d.ts.map +1 -1
  233. package/esm/Scope/LocalScope.js +8 -8
  234. package/esm/Scope/LocalScope.js.map +1 -1
  235. package/esm/Semaphore/Semaphore.d.ts +9 -9
  236. package/esm/Semaphore/Semaphore.d.ts.map +1 -1
  237. package/esm/Semaphore/Semaphore.js +11 -15
  238. package/esm/Semaphore/Semaphore.js.map +1 -1
  239. package/esm/Sink/Sink.d.ts +1 -0
  240. package/esm/Sink/Sink.d.ts.map +1 -1
  241. package/esm/Sink/Sink.js +10 -1
  242. package/esm/Sink/Sink.js.map +1 -1
  243. package/esm/Stream/Stream.d.ts +5 -14
  244. package/esm/Stream/Stream.d.ts.map +1 -1
  245. package/esm/Stream/Stream.js.map +1 -1
  246. package/esm/Stream/acquirePermit.d.ts +15 -0
  247. package/esm/Stream/acquirePermit.d.ts.map +1 -0
  248. package/esm/Stream/acquirePermit.js +15 -0
  249. package/esm/Stream/acquirePermit.js.map +1 -0
  250. package/esm/Stream/bimap.d.ts +33 -4
  251. package/esm/Stream/bimap.d.ts.map +1 -1
  252. package/esm/Stream/bimap.js +102 -11
  253. package/esm/Stream/bimap.js.map +1 -1
  254. package/esm/Stream/continueWith.d.ts +4 -3
  255. package/esm/Stream/continueWith.d.ts.map +1 -1
  256. package/esm/Stream/continueWith.js +9 -6
  257. package/esm/Stream/continueWith.js.map +1 -1
  258. package/esm/Stream/delay.d.ts +4 -0
  259. package/esm/Stream/delay.d.ts.map +1 -0
  260. package/esm/Stream/delay.js +26 -0
  261. package/esm/Stream/delay.js.map +1 -0
  262. package/esm/Stream/drain.d.ts +2 -2
  263. package/esm/Stream/drain.d.ts.map +1 -1
  264. package/esm/Stream/drain.js +6 -6
  265. package/esm/Stream/drain.js.map +1 -1
  266. package/esm/Stream/empty.d.ts.map +1 -1
  267. package/esm/Stream/empty.js +1 -2
  268. package/esm/Stream/empty.js.map +1 -1
  269. package/esm/Stream/flatMap.d.ts +7 -5
  270. package/esm/Stream/flatMap.d.ts.map +1 -1
  271. package/esm/Stream/flatMap.js +32 -19
  272. package/esm/Stream/flatMap.js.map +1 -1
  273. package/esm/Stream/flatMapConcurrently.d.ts +6 -0
  274. package/esm/Stream/flatMapConcurrently.d.ts.map +1 -0
  275. package/esm/Stream/flatMapConcurrently.js +19 -0
  276. package/esm/Stream/flatMapConcurrently.js.map +1 -0
  277. package/esm/Stream/flatMapFx.d.ts +5 -1
  278. package/esm/Stream/flatMapFx.d.ts.map +1 -1
  279. package/esm/Stream/flatMapFx.js +16 -4
  280. package/esm/Stream/flatMapFx.js.map +1 -1
  281. package/esm/Stream/foldMap.d.ts +11 -0
  282. package/esm/Stream/foldMap.d.ts.map +1 -0
  283. package/esm/Stream/foldMap.js +38 -0
  284. package/esm/Stream/foldMap.js.map +1 -0
  285. package/esm/Stream/fromArray.d.ts +2 -0
  286. package/esm/Stream/fromArray.d.ts.map +1 -0
  287. package/esm/Stream/fromArray.js +8 -0
  288. package/esm/Stream/fromArray.js.map +1 -0
  289. package/esm/Stream/fromCallback.d.ts +4 -3
  290. package/esm/Stream/fromCallback.d.ts.map +1 -1
  291. package/esm/Stream/fromCallback.js +26 -26
  292. package/esm/Stream/fromCallback.js.map +1 -1
  293. package/esm/Stream/fromFx.d.ts +23 -8
  294. package/esm/Stream/fromFx.d.ts.map +1 -1
  295. package/esm/Stream/fromFx.js +24 -14
  296. package/esm/Stream/fromFx.js.map +1 -1
  297. package/esm/Stream/hkt.d.ts +24 -1
  298. package/esm/Stream/hkt.d.ts.map +1 -1
  299. package/esm/Stream/hkt.js +41 -4
  300. package/esm/Stream/hkt.js.map +1 -1
  301. package/esm/Stream/hold.d.ts +27 -0
  302. package/esm/Stream/hold.d.ts.map +1 -0
  303. package/esm/Stream/hold.js +66 -0
  304. package/esm/Stream/hold.js.map +1 -0
  305. package/esm/Stream/index.d.ts +14 -1
  306. package/esm/Stream/index.d.ts.map +1 -1
  307. package/esm/Stream/index.js +14 -1
  308. package/esm/Stream/index.js.map +1 -1
  309. package/esm/Stream/lazy.d.ts +3 -0
  310. package/esm/Stream/lazy.d.ts.map +1 -0
  311. package/esm/Stream/lazy.js +5 -0
  312. package/esm/Stream/lazy.js.map +1 -0
  313. package/esm/Stream/merge.d.ts +18 -0
  314. package/esm/Stream/merge.d.ts.map +1 -0
  315. package/esm/Stream/merge.js +55 -0
  316. package/esm/Stream/merge.js.map +1 -0
  317. package/esm/Stream/multicast.d.ts +27 -0
  318. package/esm/Stream/multicast.d.ts.map +1 -0
  319. package/esm/Stream/multicast.js +55 -0
  320. package/esm/Stream/multicast.js.map +1 -0
  321. package/esm/Stream/orElse.d.ts +17 -0
  322. package/esm/Stream/orElse.d.ts.map +1 -0
  323. package/esm/Stream/orElse.js +77 -0
  324. package/esm/Stream/orElse.js.map +1 -0
  325. package/esm/Stream/periodic.d.ts +1 -1
  326. package/esm/Stream/periodic.d.ts.map +1 -1
  327. package/esm/Stream/periodic.js +1 -1
  328. package/esm/Stream/periodic.js.map +1 -1
  329. package/esm/Stream/provide.d.ts +8 -0
  330. package/esm/Stream/provide.d.ts.map +1 -0
  331. package/esm/Stream/provide.js +13 -0
  332. package/esm/Stream/provide.js.map +1 -0
  333. package/esm/Stream/run.d.ts +2 -2
  334. package/esm/Stream/run.d.ts.map +1 -1
  335. package/esm/Stream/run.js +2 -2
  336. package/esm/Stream/run.js.map +1 -1
  337. package/esm/Stream/scan.d.ts +17 -0
  338. package/esm/Stream/scan.d.ts.map +1 -0
  339. package/esm/Stream/scan.js +27 -0
  340. package/esm/Stream/scan.js.map +1 -0
  341. package/esm/Stream/scheduled.d.ts +12 -3
  342. package/esm/Stream/scheduled.d.ts.map +1 -1
  343. package/esm/Stream/scheduled.js +16 -4
  344. package/esm/Stream/scheduled.js.map +1 -1
  345. package/esm/Stream/setFiberRefLocally.d.ts +15 -0
  346. package/esm/Stream/setFiberRefLocally.d.ts.map +1 -0
  347. package/esm/Stream/setFiberRefLocally.js +25 -0
  348. package/esm/Stream/setFiberRefLocally.js.map +1 -0
  349. package/esm/Stream/skipRepeats.d.ts +5 -0
  350. package/esm/Stream/skipRepeats.d.ts.map +1 -0
  351. package/esm/Stream/skipRepeats.js +31 -0
  352. package/esm/Stream/skipRepeats.js.map +1 -0
  353. package/esm/Stream/switchMap.d.ts +18 -0
  354. package/esm/Stream/switchMap.d.ts.map +1 -0
  355. package/esm/Stream/switchMap.js +95 -0
  356. package/esm/Stream/switchMap.js.map +1 -0
  357. package/esm/Stream/tap.d.ts +2 -1
  358. package/esm/Stream/tap.d.ts.map +1 -1
  359. package/esm/Stream/tap.js +3 -2
  360. package/esm/Stream/tap.js.map +1 -1
  361. package/esm/Supervisor/index.d.ts +2 -0
  362. package/esm/Supervisor/index.d.ts.map +1 -1
  363. package/esm/Supervisor/index.js +2 -0
  364. package/esm/Supervisor/index.js.map +1 -1
  365. package/esm/Supervisor/inheritFiberRefs.d.ts +2 -0
  366. package/esm/Supervisor/inheritFiberRefs.d.ts.map +1 -0
  367. package/esm/Supervisor/inheritFiberRefs.js +14 -0
  368. package/esm/Supervisor/inheritFiberRefs.js.map +1 -0
  369. package/esm/Timeline/index.js.map +1 -1
  370. package/package.json +173 -37
  371. package/perf/Stream-filter-map-reduce.test.ts +103 -0
  372. package/readme.md +1 -1
  373. package/src/Cause/Cause.ts +63 -0
  374. package/src/Cause/Renderer.ts +1 -1
  375. package/src/Env/Env.ts +15 -5
  376. package/src/Fiber/fromScope.ts +19 -0
  377. package/src/FiberRef/builtins.ts +63 -11
  378. package/src/FiberRuntime/FiberRuntime.ts +35 -28
  379. package/src/Fx/Fx.test.ts +2 -2
  380. package/src/Fx/Fx.ts +11 -10
  381. package/src/Fx/join.ts +4 -4
  382. package/src/Schedule/ScheduleState.ts +3 -0
  383. package/src/Scheduler/RootScheduler.ts +7 -9
  384. package/src/Scheduler/Scheduler.ts +5 -6
  385. package/src/Scheduler/callbackScheduler.ts +1 -0
  386. package/src/Scheduler/runSchedule.ts +5 -2
  387. package/src/Scope/LocalScope.ts +8 -6
  388. package/src/Semaphore/Semaphore.ts +12 -19
  389. package/src/Sink/Sink.ts +11 -1
  390. package/src/Stream/Stream.ts +9 -15
  391. package/src/Stream/acquirePermit.ts +32 -0
  392. package/src/Stream/bimap.ts +164 -12
  393. package/src/Stream/continueWith.ts +11 -7
  394. package/src/Stream/delay.ts +43 -0
  395. package/src/Stream/drain.ts +8 -7
  396. package/src/Stream/empty.ts +1 -2
  397. package/src/Stream/flatMap.test.ts +8 -21
  398. package/src/Stream/flatMap.ts +46 -24
  399. package/src/Stream/flatMapConcurrently.test.ts +77 -0
  400. package/src/Stream/flatMapConcurrently.ts +34 -0
  401. package/src/Stream/flatMapFx.ts +37 -4
  402. package/src/Stream/foldMap.ts +88 -0
  403. package/src/Stream/fromArray.ts +8 -0
  404. package/src/Stream/fromCallback.test.ts +3 -16
  405. package/src/Stream/fromCallback.ts +48 -29
  406. package/src/Stream/fromFx.test.ts +3 -24
  407. package/src/Stream/fromFx.ts +54 -28
  408. package/src/Stream/hkt.ts +59 -10
  409. package/src/Stream/hold.test.ts +52 -0
  410. package/src/Stream/hold.ts +117 -0
  411. package/src/Stream/index.ts +14 -1
  412. package/src/Stream/lazy.ts +5 -0
  413. package/src/Stream/logging.test.ts +8 -3
  414. package/src/Stream/merge.test.ts +31 -0
  415. package/src/Stream/merge.ts +76 -0
  416. package/src/Stream/multicast.test.ts +32 -0
  417. package/src/Stream/multicast.ts +114 -0
  418. package/src/Stream/orElse.ts +107 -0
  419. package/src/Stream/periodic.ts +2 -2
  420. package/src/Stream/provide.test.ts +78 -0
  421. package/src/Stream/provide.ts +34 -0
  422. package/src/Stream/run.ts +6 -3
  423. package/src/Stream/scan.test.ts +28 -0
  424. package/src/Stream/scan.ts +46 -0
  425. package/src/Stream/scheduled.test.ts +9 -1
  426. package/src/Stream/scheduled.ts +46 -12
  427. package/src/Stream/setFiberRefLocally.ts +38 -0
  428. package/src/Stream/skipRepeats.ts +41 -0
  429. package/src/Stream/switchMap.test.ts +43 -0
  430. package/src/Stream/switchMap.ts +145 -0
  431. package/src/Stream/tap.ts +6 -3
  432. package/src/Supervisor/index.ts +2 -0
  433. package/src/Supervisor/inheritFiberRefs.ts +17 -0
  434. package/src/Timeline/index.ts +1 -0
  435. package/cjs/Effect/Effect.d.ts +0 -199
  436. package/cjs/Effect/Effect.d.ts.map +0 -1
  437. package/cjs/Effect/Effect.js +0 -66
  438. package/cjs/Effect/Effect.js.map +0 -1
  439. package/cjs/Stream/map.d.ts +0 -14
  440. package/cjs/Stream/map.d.ts.map +0 -1
  441. package/cjs/Stream/map.js +0 -30
  442. package/cjs/Stream/map.js.map +0 -1
  443. package/cjs/test.d.ts +0 -1
  444. package/cjs/test.d.ts.map +0 -1
  445. package/cjs/test.js +0 -2
  446. package/cjs/test.js.map +0 -1
  447. package/esm/Effect/Effect.d.ts +0 -199
  448. package/esm/Effect/Effect.d.ts.map +0 -1
  449. package/esm/Effect/Effect.js +0 -50
  450. package/esm/Effect/Effect.js.map +0 -1
  451. package/esm/Stream/map.d.ts +0 -14
  452. package/esm/Stream/map.d.ts.map +0 -1
  453. package/esm/Stream/map.js +0 -25
  454. package/esm/Stream/map.js.map +0 -1
  455. package/esm/test.d.ts +0 -1
  456. package/esm/test.d.ts.map +0 -1
  457. package/esm/test.js +0 -2
  458. package/esm/test.js.map +0 -1
  459. package/src/Effect/Effect.ts +0 -109
  460. package/src/Stream/map.ts +0 -35
  461. package/src/test.ts +0 -0
@@ -0,0 +1,78 @@
1
+ import { deepStrictEqual } from 'assert'
2
+
3
+ import { pipe } from 'hkt-ts'
4
+
5
+ import { collectAll } from './_internal.test.js'
6
+
7
+ import * as Stream from './index.js'
8
+
9
+ import { Env } from '@/Env/Env.js'
10
+ import * as Fx from '@/Fx/index.js'
11
+ import { Id } from '@/Service/Id.js'
12
+ import { testSuite } from '@/_internal/suite.js'
13
+
14
+ testSuite(import.meta.url, () => {
15
+ const value = Math.random()
16
+ class Foo extends Id {
17
+ constructor(readonly foo: typeof value) {
18
+ super()
19
+ }
20
+ }
21
+
22
+ describe('provide', () => {
23
+ it('should provide the environment', async () => {
24
+ const stream = pipe(
25
+ Stream.now(value),
26
+ Stream.flatMapFx((a) =>
27
+ pipe(
28
+ Foo.ask(),
29
+ Fx.flatMap((foo) => Fx.now(a + foo.foo)),
30
+ ),
31
+ ),
32
+ Stream.provide(Env(Foo.id(), new Foo(value))),
33
+ )
34
+
35
+ const events = await collectAll(stream)
36
+
37
+ deepStrictEqual(events, [value * 2])
38
+ })
39
+ })
40
+
41
+ describe('provideService', () => {
42
+ it('should provide the service', async () => {
43
+ const stream = pipe(
44
+ Stream.now(value),
45
+ Stream.flatMapFx((a) =>
46
+ pipe(
47
+ Foo.ask(),
48
+ Fx.flatMap((foo) => Fx.now(a + foo.foo)),
49
+ ),
50
+ ),
51
+ Stream.provideService(Foo.id(), new Foo(value)),
52
+ )
53
+
54
+ const events = await collectAll(stream)
55
+
56
+ deepStrictEqual(events, [value * 2])
57
+ })
58
+ })
59
+
60
+ describe('provideLayer', () => {
61
+ it('should provide the layer', async () => {
62
+ const stream = pipe(
63
+ Stream.now(value),
64
+ Stream.flatMapFx((a) =>
65
+ pipe(
66
+ Foo.ask(),
67
+ Fx.flatMap((foo) => Fx.now(a + foo.foo)),
68
+ ),
69
+ ),
70
+ Stream.provideLayer(Foo.layerOf(value)),
71
+ )
72
+
73
+ const events = await collectAll(stream)
74
+
75
+ deepStrictEqual(events, [value * 2])
76
+ })
77
+ })
78
+ })
@@ -0,0 +1,34 @@
1
+ import { pipe } from 'hkt-ts'
2
+
3
+ import { Stream } from './Stream.js'
4
+
5
+ import { Env } from '@/Env/Env.js'
6
+ import * as Fx from '@/Fx/index.js'
7
+ import { Layer } from '@/Layer/Layer.js'
8
+ import { Service } from '@/Service/Service.js'
9
+
10
+ export function provide<R>(env: Env<R>) {
11
+ return <E, A>(stream: Stream<R, E, A>): Stream<never, E, A> =>
12
+ Stream((sink, scheduler, context) => Fx.provide(env)(stream.fork(sink, scheduler, context)))
13
+ }
14
+
15
+ export function provideService<S, I extends S>(service: Service<S>, impl: I) {
16
+ return <R, E, A>(stream: Stream<R, E, A>): Stream<Exclude<R, S>, E, A> =>
17
+ Stream((sink, scheduler, context) =>
18
+ pipe(stream.fork(sink, scheduler, context), Fx.provideService(service, impl)),
19
+ )
20
+ }
21
+
22
+ export function provideLayer<R2, E2, S>(layer: Layer<R2, E2, S>) {
23
+ return <R, E, A>(stream: Stream<R | S, E, A>): Stream<Exclude<R | R2, S>, E | E2, A> =>
24
+ Stream((sink, scheduler, context) =>
25
+ pipe(
26
+ Fx.getFiberContext,
27
+ Fx.flatMap((c) => stream.fork(sink, scheduler, c.fork())),
28
+ Fx.provideLayer(layer),
29
+ Fx.orElseCause((cause) => Fx.fork(sink.error(cause))),
30
+ Fx.flatMap((f) => Fx.join(f)),
31
+ Fx.forkInContext(context),
32
+ ),
33
+ )
34
+ }
package/src/Stream/run.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { flow, pipe } from 'hkt-ts/function'
1
+ import { pipe } from 'hkt-ts/function'
2
2
 
3
3
  import { Stream } from './Stream.js'
4
4
  import { drain } from './drain.js'
@@ -7,8 +7,11 @@ import * as Fx from '@/Fx/index.js'
7
7
  import { Scheduler } from '@/Scheduler/Scheduler.js'
8
8
 
9
9
  export function run(scheduler: Scheduler) {
10
- return <E, A>(stream: Stream<never, E, A>): Fx.Fx<never, E, unknown> =>
10
+ return <E, A>(stream: Stream<Scheduler, E, A>): Fx.Fx<never, E, unknown> =>
11
11
  pipe(drain(stream), Fx.flatMap(Fx.join), Fx.provideService(Scheduler, scheduler))
12
12
  }
13
13
 
14
- export const runMain = (scheduler: Scheduler) => flow(run(scheduler), Fx.runMain)
14
+ export const runMain =
15
+ (scheduler: Scheduler) =>
16
+ <E, A>(stream: Stream<Scheduler, E, A>): Promise<unknown> =>
17
+ pipe(stream, run(scheduler), Fx.runMain)
@@ -0,0 +1,28 @@
1
+ import { deepStrictEqual } from 'assert'
2
+
3
+ import { pipe } from 'hkt-ts'
4
+
5
+ import { collectAll } from './_internal.test.js'
6
+ import { continueWith } from './continueWith.js'
7
+ import { flatMap } from './flatMap.js'
8
+ import { now } from './fromFx.js'
9
+ import { scan } from './scan.js'
10
+
11
+ import { testSuite } from '@/_internal/suite.js'
12
+
13
+ testSuite(import.meta.url, () => {
14
+ describe(scan.name, () => {
15
+ const stream = pipe(
16
+ now(1),
17
+ continueWith(() => now(2)),
18
+ flatMap((n) => now(n + 1)),
19
+ scan((acc, n) => acc + n, 0),
20
+ )
21
+
22
+ it('accumulates values', async () => {
23
+ const values = await collectAll(stream)
24
+
25
+ deepStrictEqual(values, [2, 5])
26
+ })
27
+ })
28
+ })
@@ -0,0 +1,46 @@
1
+ import { Stream } from './Stream.js'
2
+
3
+ import { FiberContext } from '@/FiberContext/FiberContext.js'
4
+ import { Live } from '@/FiberId/FiberId.js'
5
+ import { lazy } from '@/Fx/index.js'
6
+ import { Scheduler } from '@/Scheduler/index.js'
7
+ import { Sink, addTrace } from '@/Sink/Sink.js'
8
+
9
+ export function scan<A, B>(f: (b: B, a: A) => B, b: B, __trace?: string) {
10
+ return <R, E>(stream: Stream<R, E, A>) => ScanStream.make(stream, f, b, __trace)
11
+ }
12
+
13
+ export class ScanStream<R, E, A, B> implements Stream<R, E, B> {
14
+ protected state: B
15
+
16
+ constructor(
17
+ readonly stream: Stream<R, E, A>,
18
+ readonly f: (b: B, a: A) => B,
19
+ readonly b: B,
20
+ readonly __trace?: string,
21
+ ) {
22
+ this.state = b
23
+ }
24
+
25
+ readonly fork = <E2>(sink: Sink<E, B, E2>, scheduler: Scheduler, context: FiberContext<Live>) =>
26
+ this.stream.fork(
27
+ addTrace(
28
+ {
29
+ ...sink,
30
+ event: (a) => lazy(() => sink.event((this.state = this.f(this.state, a)))),
31
+ },
32
+ this.__trace,
33
+ ),
34
+ scheduler,
35
+ context,
36
+ )
37
+
38
+ static make<R, E, A, B>(
39
+ stream: Stream<R, E, A>,
40
+ f: (b: B, a: A) => B,
41
+ b: B,
42
+ __trace?: string,
43
+ ): Stream<R, E, B> {
44
+ return new ScanStream(stream, f, b, __trace)
45
+ }
46
+ }
@@ -3,7 +3,7 @@ import { deepStrictEqual } from 'assert'
3
3
  import { NonNegativeInteger } from 'hkt-ts/number'
4
4
 
5
5
  import { collectAll } from './_internal.test.js'
6
- import { scheduled } from './scheduled.js'
6
+ import { at, scheduled } from './scheduled.js'
7
7
 
8
8
  import * as Fx from '@/Fx/index.js'
9
9
  import * as Schedule from '@/Schedule/index.js'
@@ -31,4 +31,12 @@ testSuite(import.meta.url, () => {
31
31
  )
32
32
  })
33
33
  })
34
+
35
+ describe(at.name, () => {
36
+ it('runs Fx at a given time', async () => {
37
+ const value = Math.random()
38
+
39
+ deepStrictEqual(await collectAll(at(Delay(5))(value)), [value])
40
+ })
41
+ })
34
42
  })
@@ -1,21 +1,55 @@
1
+ import { pipe } from 'hkt-ts'
2
+ import { NonNegativeInteger } from 'hkt-ts/number'
3
+
1
4
  import { Stream } from './Stream.js'
2
5
 
3
6
  import { Env } from '@/Env/Env.js'
4
- import * as Fx from '@/Fx/Fx.js'
5
- import { span } from '@/Fx/logging.js'
6
- import { Schedule } from '@/Schedule/Schedule.js'
7
+ import { FiberContext } from '@/FiberContext/FiberContext.js'
8
+ import * as Fx from '@/Fx/index.js'
9
+ import * as Schedule from '@/Schedule/Schedule.js'
10
+ import { Scheduler } from '@/Scheduler/Scheduler.js'
11
+ import { Sink } from '@/Sink/Sink.js'
12
+ import { Delay } from '@/Time/index.js'
13
+ import { FiberId } from '@/index.js'
7
14
 
8
- export function scheduled(schedule: Schedule) {
15
+ export function scheduled(schedule: Schedule.Schedule, __trace?: string) {
9
16
  return <R, E, A>(fx: Fx.Fx<R, E, A>): Stream<R, E, A> =>
10
- Stream((sink, scheduler, context) =>
11
- Fx.asksEnv((env: Env<R>) =>
12
- scheduler.schedule(
13
- Fx.matchCause(sink.error, sink.event)(fx),
14
- env,
15
- schedule,
16
- context,
17
- span('Stream.scheduled'),
17
+ Stream(<E2>(sink: Sink<E, A, E2>, scheduler: Scheduler, context: FiberContext<FiberId.Live>) =>
18
+ pipe(
19
+ Fx.asksEnv(
20
+ (env: Env<R>) =>
21
+ scheduler.schedule(
22
+ Fx.matchCause(sink.error, sink.event, __trace)(fx),
23
+ env,
24
+ schedule,
25
+ context,
26
+ () => sink.end,
27
+ ),
28
+ __trace,
18
29
  ),
19
30
  ),
20
31
  )
21
32
  }
33
+
34
+ export function at(delay: Delay, __trace?: string) {
35
+ return <A>(value: A): Stream<never, never, A> =>
36
+ scheduled(Schedule.delayed(delay), __trace)(Fx.now(value))
37
+ }
38
+
39
+ export function repeated(period: Delay, __trace?: string) {
40
+ return <A>(value: A): Stream<never, never, A> =>
41
+ scheduled(Schedule.periodic(period), __trace)(Fx.now(value))
42
+ }
43
+
44
+ export const exponential = (delay: Delay, __trace?: string) =>
45
+ scheduled(Schedule.exponential(delay), __trace)
46
+
47
+ export const forever = scheduled(Schedule.forever, 'Scheduled.forever')
48
+
49
+ export const recurring = (amount: NonNegativeInteger, __trace?: string) =>
50
+ scheduled(Schedule.recurring(amount), __trace)
51
+
52
+ export const retries = (amount: NonNegativeInteger, __trace?: string) =>
53
+ scheduled(Schedule.retries(amount), __trace)
54
+
55
+ export const spaced = (delay: Delay, __trace?: string) => scheduled(Schedule.spaced(delay), __trace)
@@ -0,0 +1,38 @@
1
+ import { pipe } from 'hkt-ts'
2
+
3
+ import { Stream } from './Stream.js'
4
+
5
+ import { FiberContext } from '@/FiberContext/FiberContext.js'
6
+ import { FiberId } from '@/FiberId/FiberId.js'
7
+ import { FiberRef } from '@/FiberRef/FiberRef.js'
8
+ import * as FiberRefs from '@/FiberRefs/FiberRefs.js'
9
+ import { flatMap, fromLazy } from '@/Fx/Fx.js'
10
+ import { Scheduler } from '@/Scheduler/Scheduler.js'
11
+ import { Sink } from '@/Sink/Sink.js'
12
+
13
+ export function setFiberRefLocally<R, E, A>(fiberRef: FiberRef<R, E, A>, value: () => A) {
14
+ return <R2, E2, A2>(fx: Stream<R2, E2, A2>) => new SetFiberRefLocallyStream(fx, fiberRef, value)
15
+ }
16
+
17
+ export class SetFiberRefLocallyStream<R, E, A, R2, E2, A2> implements Stream<R2, E2, A2> {
18
+ constructor(
19
+ readonly stream: Stream<R2, E2, A2>,
20
+ readonly fiberRef: FiberRef<R, E, A>,
21
+ readonly value: () => A,
22
+ ) {}
23
+
24
+ fork<E3>(sink: Sink<E2, A2, E3>, scheduler: Scheduler, context: FiberContext<FiberId.Live>) {
25
+ return pipe(
26
+ fromLazy(() => {
27
+ // SetFiberRef
28
+ FiberRefs.setFiberRefLocally(this.fiberRef, this.value())(context.fiberRefs)
29
+
30
+ // Ensure it is popped off when the stream ends
31
+ context.scope.ensuring(() =>
32
+ fromLazy(() => FiberRefs.popLocalFiberRef(this.fiberRef)(context.fiberRefs)),
33
+ )
34
+ }),
35
+ flatMap(() => this.stream.fork(sink, scheduler, context)),
36
+ )
37
+ }
38
+ }
@@ -0,0 +1,41 @@
1
+ import { Maybe } from 'hkt-ts'
2
+ import { DeepEquals, Eq } from 'hkt-ts/Typeclass/Eq'
3
+
4
+ import { Stream } from './Stream.js'
5
+
6
+ import { unit } from '@/Fx/index.js'
7
+ import { Sink, addTrace } from '@/Sink/Sink.js'
8
+
9
+ export function skipRepeatsWith<A>(
10
+ E: Eq<A>,
11
+ __trace?: string,
12
+ ): <R, E>(stream: Stream<R, E, A>) => Stream<R, E, A> {
13
+ return (stream) =>
14
+ Stream((sink, scheduler, context) =>
15
+ stream.fork(addTrace(new SkipRepeatsSink(sink, E), __trace), scheduler, context),
16
+ )
17
+ }
18
+
19
+ export function skipRepeats<R, E, A>(stream: Stream<R, E, A>, __trace?: string): Stream<R, E, A> {
20
+ return skipRepeatsWith<A>(DeepEquals, __trace)(stream)
21
+ }
22
+
23
+ class SkipRepeatsSink<E, A, E2> implements Sink<E, A, E2> {
24
+ constructor(readonly sink: Sink<E, A, E2>, readonly E: Eq<A>) {}
25
+
26
+ protected last: Maybe.Maybe<A> = Maybe.Nothing
27
+ protected elem = Maybe.contains(this.E)
28
+
29
+ event(value: A) {
30
+ if (this.elem(value)(this.last)) {
31
+ return unit
32
+ }
33
+
34
+ this.last = Maybe.Just(value)
35
+
36
+ return this.sink.event(value)
37
+ }
38
+
39
+ error = this.sink.error
40
+ end = this.sink.end
41
+ }
@@ -0,0 +1,43 @@
1
+ import { deepStrictEqual } from 'assert'
2
+
3
+ import { pipe } from 'hkt-ts'
4
+
5
+ import { collectAll } from './_internal.test.js'
6
+ import { now } from './fromFx.js'
7
+ import { merge } from './merge.js'
8
+ import { at } from './scheduled.js'
9
+ import { switchMap } from './switchMap.js'
10
+
11
+ import { Delay } from '@/Time/index.js'
12
+ import { testSuite } from '@/_internal/suite.js'
13
+
14
+ testSuite(import.meta.url, () => {
15
+ describe(switchMap.name, () => {
16
+ const value = Math.random()
17
+ const stream = pipe(
18
+ now(value),
19
+ switchMap((a) => now(a + 1)),
20
+ )
21
+
22
+ it('is collectable', async () => {
23
+ const events = await collectAll(stream)
24
+ deepStrictEqual(events, [value + 1])
25
+ })
26
+
27
+ it('is collectable with multiple subscribers', async () => {
28
+ const events = await Promise.all([collectAll(stream), collectAll(stream)])
29
+ deepStrictEqual(events, [[value + 1], [value + 1]])
30
+ })
31
+
32
+ it('cancels the previous stream', async () => {
33
+ const stream = pipe(
34
+ at(Delay(0))(1),
35
+ merge(at(Delay(50))(5)),
36
+ switchMap((a) => pipe(now(a), merge(at(Delay(100))(a + 1)))),
37
+ )
38
+
39
+ const events = await collectAll(stream)
40
+ deepStrictEqual(events, [1, 5, 6])
41
+ })
42
+ })
43
+ })
@@ -0,0 +1,145 @@
1
+ import { flow, pipe } from 'hkt-ts'
2
+
3
+ import { Stream } from './Stream.js'
4
+ import { MapStream } from './bimap.js'
5
+
6
+ import { Cause } from '@/Cause/index.js'
7
+ import { Disposable, Settable, settable } from '@/Disposable/Disposable.js'
8
+ import { Env } from '@/Env/Env.js'
9
+ import { Fiber } from '@/Fiber/Fiber.js'
10
+ import { FiberContext } from '@/FiberContext/FiberContext.js'
11
+ import { Live } from '@/FiberId/FiberId.js'
12
+ import * as Fx from '@/Fx/index.js'
13
+ import { access, lazy, unit } from '@/Fx/index.js'
14
+ import { Scheduler } from '@/Scheduler/Scheduler.js'
15
+ import { Lock } from '@/Semaphore/Semaphore.js'
16
+ import * as Sink from '@/Sink/Sink.js'
17
+ import * as Supervisor from '@/Supervisor/index.js'
18
+
19
+ export function switchMap<A, R2, E2, B>(
20
+ f: (a: A) => Stream<R2, E2, B>,
21
+ __trace?: string,
22
+ ): <R, E>(stream: Stream<R, E, A>) => Stream<R | R2, E | E2, B> {
23
+ return (stream) => SwitchMapStream.make(stream, f, __trace)
24
+ }
25
+
26
+ export function switchLatest<R, E, R2, E2, A>(
27
+ stream: Stream<R, E, Stream<R2, E2, A>>,
28
+ __trace?: string,
29
+ ): Stream<R | R2, E | E2, A> {
30
+ return switchMap((a: Stream<R2, E2, A>) => a, __trace)(stream)
31
+ }
32
+
33
+ export class SwitchMapStream<R, E, A, R2, E2, B> implements Stream<R | R2, E | E2, B> {
34
+ constructor(
35
+ readonly stream: Stream<R, E, A>,
36
+ readonly f: (a: A) => Stream<R2, E2, B>,
37
+ readonly __trace?: string,
38
+ ) {}
39
+
40
+ fork<E3>(sink: Sink.Sink<E | E2, B, E3>, scheduler: Scheduler, context: FiberContext<Live>) {
41
+ const { stream, f } = this
42
+
43
+ return access((env: Env<R | R2>) =>
44
+ stream.fork(
45
+ new SwitchMapSink(sink, scheduler, context, f, env, this.__trace),
46
+ scheduler,
47
+ context,
48
+ ),
49
+ )
50
+ }
51
+
52
+ static make<R, E, A, R2, E2, B>(
53
+ stream: Stream<R, E, A>,
54
+ f: (a: A) => Stream<R2, E2, B>,
55
+ __trace?: string,
56
+ ): Stream<R | R2, E | E2, B> {
57
+ if (stream instanceof MapStream) {
58
+ return SwitchMapStream.make(stream.stream, flow(stream.f, f), __trace)
59
+ }
60
+
61
+ return new SwitchMapStream(stream, f, __trace)
62
+ }
63
+ }
64
+
65
+ class SwitchMapSink<R, E, A, R2, E2, B, E3> implements Sink.Sink<E | E2, A, E3> {
66
+ protected _ended = false
67
+ protected _fibers: Array<Fiber<E3, any>> = []
68
+ protected _lock = new Lock()
69
+
70
+ constructor(
71
+ readonly sink: Sink.Sink<E | E2, B, E3>,
72
+ readonly scheduler: Scheduler,
73
+ readonly context: FiberContext<Live>,
74
+ readonly f: (a: A) => Stream<R2, E2, B>,
75
+ readonly env: Env<R | R2>,
76
+ readonly __trace?: string,
77
+ ) {}
78
+
79
+ event = (a: A): Fx.IO<E3, unknown> =>
80
+ Fx.lazy(() => {
81
+ const forked = this.context.fork({
82
+ supervisor: Supervisor.and(Supervisor.inheritFiberRefs)(this.context.supervisor),
83
+ })
84
+
85
+ const cleanup: Fx.Of<unknown> = Fx.zipAll(this._fibers.map((f) => f.interruptAs(forked.id)))
86
+ const disposable = settable()
87
+ const sink = this.innerSink(disposable)
88
+
89
+ return pipe(
90
+ cleanup, // eslint-disable-next-line @typescript-eslint/no-unused-vars
91
+ Fx.flatMap(() => this.f(a).fork(Sink.addTrace(sink, this.__trace), this.scheduler, forked)),
92
+ Fx.tapLazy((fiber) => {
93
+ this._fibers.push(fiber)
94
+
95
+ disposable.add(
96
+ Disposable(() => {
97
+ this._fibers.splice(this._fibers.indexOf(fiber), 1)
98
+ }),
99
+ )
100
+ }),
101
+ Fx.flatMap((fiber) =>
102
+ pipe(
103
+ fiber,
104
+ Fx.join,
105
+ Fx.tapLazy(() => disposable.dispose()),
106
+ ),
107
+ ),
108
+ (x) => x,
109
+ Fx.provide(this.env),
110
+ )
111
+ })
112
+
113
+ error = (cause: Cause<E | E2>) => {
114
+ return lazy(() => {
115
+ this._ended = true
116
+
117
+ return this.sink.error(cause)
118
+ })
119
+ }
120
+
121
+ end = lazy(() => {
122
+ this._ended = true
123
+
124
+ return this.endIfCompleted()
125
+ })
126
+
127
+ protected endIfCompleted() {
128
+ if (this._ended && this._fibers.length === 0) {
129
+ return this.sink.end
130
+ }
131
+
132
+ return unit
133
+ }
134
+
135
+ protected innerSink(disposable: Settable): Sink.Sink<E | E2, B, E3> {
136
+ return {
137
+ event: this.sink.event,
138
+ error: this.error,
139
+ end: lazy(() => {
140
+ disposable.dispose()
141
+ return this.endIfCompleted()
142
+ }),
143
+ }
144
+ }
145
+ }
package/src/Stream/tap.ts CHANGED
@@ -3,10 +3,10 @@ import { pipe } from 'hkt-ts/function'
3
3
  import { Stream } from './Stream.js'
4
4
  import { flatMapFx } from './flatMapFx.js'
5
5
 
6
- import { Fx, map } from '@/Fx/Fx.js'
6
+ import { Fx, fromLazy, map } from '@/Fx/Fx.js'
7
7
 
8
8
  export const tap =
9
- <A, R2, E2, B>(f: (a: A) => Fx<R2, E2, B>) =>
9
+ <A, R2, E2, B>(f: (a: A) => Fx<R2, E2, B>, __trace?: string) =>
10
10
  <R, E>(stream: Stream<R, E, A>): Stream<R | R2, E | E2, A> =>
11
11
  pipe(
12
12
  stream,
@@ -16,6 +16,9 @@ export const tap =
16
16
  f(a),
17
17
  map(() => a),
18
18
  ),
19
- 'Stream.tap',
19
+ __trace,
20
20
  ),
21
21
  )
22
+
23
+ export const tapLazy = <A, B>(f: (a: A) => B, __trace?: string) =>
24
+ tap((a: A) => fromLazy(() => f(a)), __trace)
@@ -1,2 +1,4 @@
1
+ export * from './inheritFiberRefs.js'
2
+ export * from './maxFailures.js'
1
3
  export * from './Supervisor.js'
2
4
  export * from './trackIn.js'
@@ -0,0 +1,17 @@
1
+ import { isRight } from 'hkt-ts/Either'
2
+ import { isJust } from 'hkt-ts/Maybe'
3
+
4
+ import { None } from './Supervisor.js'
5
+
6
+ import { join } from '@/FiberRefs/FiberRefs.js'
7
+
8
+ export const inheritFiberRefs = None.extend({
9
+ onEnd: () => (fiber, exit) => {
10
+ const parentContext = fiber.context.parent
11
+
12
+ // Merge FiberRefs upon successful completion
13
+ if (isRight(exit) && isJust(parentContext)) {
14
+ join(parentContext.value.fiberRefs, fiber.context.fiberRefs)
15
+ }
16
+ },
17
+ })
@@ -51,6 +51,7 @@ class TimelineImpl<A> implements Timeline<A> {
51
51
 
52
52
  readonly add = (time: UnixTime, a: A): Disposable => {
53
53
  insertByTime(time, a, this.timeSlots)
54
+
54
55
  this.onUpdated?.()
55
56
 
56
57
  return Disposable(() => this.remove(time, a))