@typed/fx 0.0.4 → 0.0.6

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 (368) 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.js +1 -1
  9. package/cjs/Env/Env.js.map +1 -1
  10. package/cjs/Fiber/fromScope.d.ts +5 -0
  11. package/cjs/Fiber/fromScope.d.ts.map +1 -0
  12. package/cjs/Fiber/fromScope.js +17 -0
  13. package/cjs/Fiber/fromScope.js.map +1 -0
  14. package/cjs/FiberContext/FiberContext.js +1 -1
  15. package/cjs/FiberContext/FiberContext.js.map +1 -1
  16. package/cjs/FiberRef/builtins.d.ts.map +1 -1
  17. package/cjs/FiberRef/builtins.js +6 -6
  18. package/cjs/FiberRef/builtins.js.map +1 -1
  19. package/cjs/FiberRuntime/FiberRuntime.d.ts.map +1 -1
  20. package/cjs/FiberRuntime/FiberRuntime.js +22 -13
  21. package/cjs/FiberRuntime/FiberRuntime.js.map +1 -1
  22. package/cjs/Fx/Fx.d.ts +3 -2
  23. package/cjs/Fx/Fx.d.ts.map +1 -1
  24. package/cjs/Fx/Fx.js +24 -22
  25. package/cjs/Fx/Fx.js.map +1 -1
  26. package/cjs/Fx/join.d.ts +1 -1
  27. package/cjs/Fx/join.d.ts.map +1 -1
  28. package/cjs/Fx/join.js +1 -1
  29. package/cjs/Fx/join.js.map +1 -1
  30. package/cjs/Schedule/ScheduleState.d.ts +3 -0
  31. package/cjs/Schedule/ScheduleState.d.ts.map +1 -1
  32. package/cjs/Schedule/ScheduleState.js +3 -0
  33. package/cjs/Schedule/ScheduleState.js.map +1 -1
  34. package/cjs/Scheduler/RootScheduler.d.ts.map +1 -1
  35. package/cjs/Scheduler/RootScheduler.js +4 -5
  36. package/cjs/Scheduler/RootScheduler.js.map +1 -1
  37. package/cjs/Scheduler/Scheduler.d.ts +2 -2
  38. package/cjs/Scheduler/Scheduler.d.ts.map +1 -1
  39. package/cjs/Scheduler/Scheduler.js.map +1 -1
  40. package/cjs/Scheduler/callbackScheduler.d.ts.map +1 -1
  41. package/cjs/Scheduler/callbackScheduler.js +1 -0
  42. package/cjs/Scheduler/callbackScheduler.js.map +1 -1
  43. package/cjs/Scheduler/runSchedule.d.ts +1 -1
  44. package/cjs/Scheduler/runSchedule.d.ts.map +1 -1
  45. package/cjs/Scheduler/runSchedule.js +3 -2
  46. package/cjs/Scheduler/runSchedule.js.map +1 -1
  47. package/cjs/Scope/LocalScope.d.ts.map +1 -1
  48. package/cjs/Scope/LocalScope.js +8 -8
  49. package/cjs/Scope/LocalScope.js.map +1 -1
  50. package/cjs/Semaphore/Semaphore.d.ts +9 -9
  51. package/cjs/Semaphore/Semaphore.d.ts.map +1 -1
  52. package/cjs/Semaphore/Semaphore.js +34 -15
  53. package/cjs/Semaphore/Semaphore.js.map +1 -1
  54. package/cjs/Sink/Sink.d.ts +1 -0
  55. package/cjs/Sink/Sink.d.ts.map +1 -1
  56. package/cjs/Sink/Sink.js +11 -1
  57. package/cjs/Sink/Sink.js.map +1 -1
  58. package/cjs/Stream/Stream.d.ts +5 -10
  59. package/cjs/Stream/Stream.d.ts.map +1 -1
  60. package/cjs/Stream/Stream.js.map +1 -1
  61. package/cjs/Stream/acquirePermit.d.ts +15 -0
  62. package/cjs/Stream/acquirePermit.d.ts.map +1 -0
  63. package/cjs/Stream/acquirePermit.js +43 -0
  64. package/cjs/Stream/acquirePermit.js.map +1 -0
  65. package/cjs/Stream/bimap.d.ts +5 -4
  66. package/cjs/Stream/bimap.d.ts.map +1 -1
  67. package/cjs/Stream/bimap.js +11 -9
  68. package/cjs/Stream/bimap.js.map +1 -1
  69. package/cjs/Stream/continueWith.d.ts +4 -3
  70. package/cjs/Stream/continueWith.d.ts.map +1 -1
  71. package/cjs/Stream/continueWith.js +9 -6
  72. package/cjs/Stream/continueWith.js.map +1 -1
  73. package/cjs/Stream/drain.d.ts +2 -2
  74. package/cjs/Stream/drain.d.ts.map +1 -1
  75. package/cjs/Stream/drain.js +5 -5
  76. package/cjs/Stream/drain.js.map +1 -1
  77. package/cjs/Stream/empty.d.ts.map +1 -1
  78. package/cjs/Stream/empty.js +1 -2
  79. package/cjs/Stream/empty.js.map +1 -1
  80. package/cjs/Stream/flatMap.d.ts +7 -5
  81. package/cjs/Stream/flatMap.d.ts.map +1 -1
  82. package/cjs/Stream/flatMap.js +43 -17
  83. package/cjs/Stream/flatMap.js.map +1 -1
  84. package/cjs/Stream/flatMapConcurrently.d.ts +5 -0
  85. package/cjs/Stream/flatMapConcurrently.d.ts.map +1 -0
  86. package/cjs/Stream/flatMapConcurrently.js +20 -0
  87. package/cjs/Stream/flatMapConcurrently.js.map +1 -0
  88. package/cjs/Stream/flatMapFx.d.ts +5 -1
  89. package/cjs/Stream/flatMapFx.d.ts.map +1 -1
  90. package/cjs/Stream/flatMapFx.js +18 -3
  91. package/cjs/Stream/flatMapFx.js.map +1 -1
  92. package/cjs/Stream/fromCallback.d.ts +4 -3
  93. package/cjs/Stream/fromCallback.d.ts.map +1 -1
  94. package/cjs/Stream/fromCallback.js +26 -26
  95. package/cjs/Stream/fromCallback.js.map +1 -1
  96. package/cjs/Stream/fromFx.d.ts +14 -8
  97. package/cjs/Stream/fromFx.d.ts.map +1 -1
  98. package/cjs/Stream/fromFx.js +24 -15
  99. package/cjs/Stream/fromFx.js.map +1 -1
  100. package/cjs/Stream/hold.d.ts +27 -0
  101. package/cjs/Stream/hold.d.ts.map +1 -0
  102. package/cjs/Stream/hold.js +94 -0
  103. package/cjs/Stream/hold.js.map +1 -0
  104. package/cjs/Stream/index.d.ts +8 -0
  105. package/cjs/Stream/index.d.ts.map +1 -1
  106. package/cjs/Stream/index.js +8 -0
  107. package/cjs/Stream/index.js.map +1 -1
  108. package/cjs/Stream/lazy.d.ts +3 -0
  109. package/cjs/Stream/lazy.d.ts.map +1 -0
  110. package/cjs/Stream/lazy.js +9 -0
  111. package/cjs/Stream/lazy.js.map +1 -0
  112. package/cjs/Stream/map.d.ts +4 -3
  113. package/cjs/Stream/map.d.ts.map +1 -1
  114. package/cjs/Stream/map.js +11 -8
  115. package/cjs/Stream/map.js.map +1 -1
  116. package/cjs/Stream/merge.d.ts +18 -0
  117. package/cjs/Stream/merge.d.ts.map +1 -0
  118. package/cjs/Stream/merge.js +84 -0
  119. package/cjs/Stream/merge.js.map +1 -0
  120. package/cjs/Stream/multicast.d.ts +27 -0
  121. package/cjs/Stream/multicast.d.ts.map +1 -0
  122. package/cjs/Stream/multicast.js +83 -0
  123. package/cjs/Stream/multicast.js.map +1 -0
  124. package/cjs/Stream/orElse.d.ts +17 -0
  125. package/cjs/Stream/orElse.d.ts.map +1 -0
  126. package/cjs/Stream/orElse.js +118 -0
  127. package/cjs/Stream/orElse.js.map +1 -0
  128. package/cjs/Stream/periodic.d.ts +1 -1
  129. package/cjs/Stream/periodic.d.ts.map +1 -1
  130. package/cjs/Stream/periodic.js +1 -1
  131. package/cjs/Stream/periodic.js.map +1 -1
  132. package/cjs/Stream/scan.d.ts +17 -0
  133. package/cjs/Stream/scan.d.ts.map +1 -0
  134. package/cjs/Stream/scan.js +32 -0
  135. package/cjs/Stream/scan.js.map +1 -0
  136. package/cjs/Stream/scheduled.d.ts +12 -3
  137. package/cjs/Stream/scheduled.d.ts.map +1 -1
  138. package/cjs/Stream/scheduled.js +23 -5
  139. package/cjs/Stream/scheduled.js.map +1 -1
  140. package/cjs/Stream/setFiberRefLocally.d.ts +15 -0
  141. package/cjs/Stream/setFiberRefLocally.d.ts.map +1 -0
  142. package/cjs/Stream/setFiberRefLocally.js +51 -0
  143. package/cjs/Stream/setFiberRefLocally.js.map +1 -0
  144. package/cjs/Stream/switchMap.d.ts +18 -0
  145. package/cjs/Stream/switchMap.d.ts.map +1 -0
  146. package/cjs/Stream/switchMap.js +136 -0
  147. package/cjs/Stream/switchMap.js.map +1 -0
  148. package/cjs/Stream/tap.d.ts +2 -1
  149. package/cjs/Stream/tap.d.ts.map +1 -1
  150. package/cjs/Stream/tap.js +4 -2
  151. package/cjs/Stream/tap.js.map +1 -1
  152. package/cjs/Timeline/index.js.map +1 -1
  153. package/esm/Cause/Cause.d.ts +10 -0
  154. package/esm/Cause/Cause.d.ts.map +1 -1
  155. package/esm/Cause/Cause.js +27 -0
  156. package/esm/Cause/Cause.js.map +1 -1
  157. package/esm/Cause/Renderer.js +1 -1
  158. package/esm/Cause/Renderer.js.map +1 -1
  159. package/esm/Env/Env.js +1 -1
  160. package/esm/Env/Env.js.map +1 -1
  161. package/esm/Fiber/fromScope.d.ts +5 -0
  162. package/esm/Fiber/fromScope.d.ts.map +1 -0
  163. package/esm/Fiber/fromScope.js +13 -0
  164. package/esm/Fiber/fromScope.js.map +1 -0
  165. package/esm/FiberContext/FiberContext.js +1 -1
  166. package/esm/FiberContext/FiberContext.js.map +1 -1
  167. package/esm/FiberRef/builtins.d.ts.map +1 -1
  168. package/esm/FiberRef/builtins.js +6 -6
  169. package/esm/FiberRef/builtins.js.map +1 -1
  170. package/esm/FiberRuntime/FiberRuntime.d.ts.map +1 -1
  171. package/esm/FiberRuntime/FiberRuntime.js +22 -13
  172. package/esm/FiberRuntime/FiberRuntime.js.map +1 -1
  173. package/esm/Fx/Fx.d.ts +3 -2
  174. package/esm/Fx/Fx.d.ts.map +1 -1
  175. package/esm/Fx/Fx.js +21 -20
  176. package/esm/Fx/Fx.js.map +1 -1
  177. package/esm/Fx/join.d.ts +1 -1
  178. package/esm/Fx/join.d.ts.map +1 -1
  179. package/esm/Fx/join.js +1 -1
  180. package/esm/Fx/join.js.map +1 -1
  181. package/esm/Schedule/ScheduleState.d.ts +3 -0
  182. package/esm/Schedule/ScheduleState.d.ts.map +1 -1
  183. package/esm/Schedule/ScheduleState.js +3 -0
  184. package/esm/Schedule/ScheduleState.js.map +1 -1
  185. package/esm/Scheduler/RootScheduler.d.ts.map +1 -1
  186. package/esm/Scheduler/RootScheduler.js +4 -5
  187. package/esm/Scheduler/RootScheduler.js.map +1 -1
  188. package/esm/Scheduler/Scheduler.d.ts +2 -2
  189. package/esm/Scheduler/Scheduler.d.ts.map +1 -1
  190. package/esm/Scheduler/Scheduler.js.map +1 -1
  191. package/esm/Scheduler/callbackScheduler.d.ts.map +1 -1
  192. package/esm/Scheduler/callbackScheduler.js +1 -0
  193. package/esm/Scheduler/callbackScheduler.js.map +1 -1
  194. package/esm/Scheduler/runSchedule.d.ts +1 -1
  195. package/esm/Scheduler/runSchedule.d.ts.map +1 -1
  196. package/esm/Scheduler/runSchedule.js +4 -3
  197. package/esm/Scheduler/runSchedule.js.map +1 -1
  198. package/esm/Scope/LocalScope.d.ts.map +1 -1
  199. package/esm/Scope/LocalScope.js +8 -8
  200. package/esm/Scope/LocalScope.js.map +1 -1
  201. package/esm/Semaphore/Semaphore.d.ts +9 -9
  202. package/esm/Semaphore/Semaphore.d.ts.map +1 -1
  203. package/esm/Semaphore/Semaphore.js +11 -15
  204. package/esm/Semaphore/Semaphore.js.map +1 -1
  205. package/esm/Sink/Sink.d.ts +1 -0
  206. package/esm/Sink/Sink.d.ts.map +1 -1
  207. package/esm/Sink/Sink.js +10 -1
  208. package/esm/Sink/Sink.js.map +1 -1
  209. package/esm/Stream/Stream.d.ts +5 -10
  210. package/esm/Stream/Stream.d.ts.map +1 -1
  211. package/esm/Stream/Stream.js.map +1 -1
  212. package/esm/Stream/acquirePermit.d.ts +15 -0
  213. package/esm/Stream/acquirePermit.d.ts.map +1 -0
  214. package/esm/Stream/acquirePermit.js +15 -0
  215. package/esm/Stream/acquirePermit.js.map +1 -0
  216. package/esm/Stream/bimap.d.ts +5 -4
  217. package/esm/Stream/bimap.d.ts.map +1 -1
  218. package/esm/Stream/bimap.js +11 -9
  219. package/esm/Stream/bimap.js.map +1 -1
  220. package/esm/Stream/continueWith.d.ts +4 -3
  221. package/esm/Stream/continueWith.d.ts.map +1 -1
  222. package/esm/Stream/continueWith.js +9 -6
  223. package/esm/Stream/continueWith.js.map +1 -1
  224. package/esm/Stream/drain.d.ts +2 -2
  225. package/esm/Stream/drain.d.ts.map +1 -1
  226. package/esm/Stream/drain.js +6 -6
  227. package/esm/Stream/drain.js.map +1 -1
  228. package/esm/Stream/empty.d.ts.map +1 -1
  229. package/esm/Stream/empty.js +1 -2
  230. package/esm/Stream/empty.js.map +1 -1
  231. package/esm/Stream/flatMap.d.ts +7 -5
  232. package/esm/Stream/flatMap.d.ts.map +1 -1
  233. package/esm/Stream/flatMap.js +43 -18
  234. package/esm/Stream/flatMap.js.map +1 -1
  235. package/esm/Stream/flatMapConcurrently.d.ts +5 -0
  236. package/esm/Stream/flatMapConcurrently.d.ts.map +1 -0
  237. package/esm/Stream/flatMapConcurrently.js +15 -0
  238. package/esm/Stream/flatMapConcurrently.js.map +1 -0
  239. package/esm/Stream/flatMapFx.d.ts +5 -1
  240. package/esm/Stream/flatMapFx.d.ts.map +1 -1
  241. package/esm/Stream/flatMapFx.js +16 -4
  242. package/esm/Stream/flatMapFx.js.map +1 -1
  243. package/esm/Stream/fromCallback.d.ts +4 -3
  244. package/esm/Stream/fromCallback.d.ts.map +1 -1
  245. package/esm/Stream/fromCallback.js +26 -26
  246. package/esm/Stream/fromCallback.js.map +1 -1
  247. package/esm/Stream/fromFx.d.ts +14 -8
  248. package/esm/Stream/fromFx.d.ts.map +1 -1
  249. package/esm/Stream/fromFx.js +13 -13
  250. package/esm/Stream/fromFx.js.map +1 -1
  251. package/esm/Stream/hold.d.ts +27 -0
  252. package/esm/Stream/hold.d.ts.map +1 -0
  253. package/esm/Stream/hold.js +66 -0
  254. package/esm/Stream/hold.js.map +1 -0
  255. package/esm/Stream/index.d.ts +8 -0
  256. package/esm/Stream/index.d.ts.map +1 -1
  257. package/esm/Stream/index.js +8 -0
  258. package/esm/Stream/index.js.map +1 -1
  259. package/esm/Stream/lazy.d.ts +3 -0
  260. package/esm/Stream/lazy.d.ts.map +1 -0
  261. package/esm/Stream/lazy.js +5 -0
  262. package/esm/Stream/lazy.js.map +1 -0
  263. package/esm/Stream/map.d.ts +4 -3
  264. package/esm/Stream/map.d.ts.map +1 -1
  265. package/esm/Stream/map.js +11 -8
  266. package/esm/Stream/map.js.map +1 -1
  267. package/esm/Stream/merge.d.ts +18 -0
  268. package/esm/Stream/merge.d.ts.map +1 -0
  269. package/esm/Stream/merge.js +55 -0
  270. package/esm/Stream/merge.js.map +1 -0
  271. package/esm/Stream/multicast.d.ts +27 -0
  272. package/esm/Stream/multicast.d.ts.map +1 -0
  273. package/esm/Stream/multicast.js +55 -0
  274. package/esm/Stream/multicast.js.map +1 -0
  275. package/esm/Stream/orElse.d.ts +17 -0
  276. package/esm/Stream/orElse.d.ts.map +1 -0
  277. package/esm/Stream/orElse.js +90 -0
  278. package/esm/Stream/orElse.js.map +1 -0
  279. package/esm/Stream/periodic.d.ts +1 -1
  280. package/esm/Stream/periodic.d.ts.map +1 -1
  281. package/esm/Stream/periodic.js +1 -1
  282. package/esm/Stream/periodic.js.map +1 -1
  283. package/esm/Stream/scan.d.ts +17 -0
  284. package/esm/Stream/scan.d.ts.map +1 -0
  285. package/esm/Stream/scan.js +27 -0
  286. package/esm/Stream/scan.js.map +1 -0
  287. package/esm/Stream/scheduled.d.ts +12 -3
  288. package/esm/Stream/scheduled.d.ts.map +1 -1
  289. package/esm/Stream/scheduled.js +16 -4
  290. package/esm/Stream/scheduled.js.map +1 -1
  291. package/esm/Stream/setFiberRefLocally.d.ts +15 -0
  292. package/esm/Stream/setFiberRefLocally.d.ts.map +1 -0
  293. package/esm/Stream/setFiberRefLocally.js +23 -0
  294. package/esm/Stream/setFiberRefLocally.js.map +1 -0
  295. package/esm/Stream/switchMap.d.ts +18 -0
  296. package/esm/Stream/switchMap.d.ts.map +1 -0
  297. package/esm/Stream/switchMap.js +107 -0
  298. package/esm/Stream/switchMap.js.map +1 -0
  299. package/esm/Stream/tap.d.ts +2 -1
  300. package/esm/Stream/tap.d.ts.map +1 -1
  301. package/esm/Stream/tap.js +3 -2
  302. package/esm/Stream/tap.js.map +1 -1
  303. package/esm/Timeline/index.js.map +1 -1
  304. package/package.json +111 -21
  305. package/readme.md +1 -1
  306. package/src/Cause/Cause.ts +63 -0
  307. package/src/Cause/Renderer.ts +1 -1
  308. package/src/Env/Env.ts +1 -1
  309. package/src/Fiber/fromScope.ts +19 -0
  310. package/src/FiberContext/FiberContext.ts +1 -1
  311. package/src/FiberRef/builtins.ts +19 -10
  312. package/src/FiberRuntime/FiberRuntime.ts +32 -25
  313. package/src/Fx/Fx.test.ts +2 -2
  314. package/src/Fx/Fx.ts +10 -9
  315. package/src/Fx/join.ts +4 -4
  316. package/src/Schedule/ScheduleState.ts +3 -0
  317. package/src/Scheduler/RootScheduler.ts +7 -9
  318. package/src/Scheduler/Scheduler.ts +5 -6
  319. package/src/Scheduler/callbackScheduler.ts +1 -0
  320. package/src/Scheduler/runSchedule.ts +5 -2
  321. package/src/Scope/LocalScope.ts +8 -6
  322. package/src/Semaphore/Semaphore.ts +12 -19
  323. package/src/Sink/Sink.ts +11 -1
  324. package/src/Stream/Stream.ts +9 -11
  325. package/src/Stream/acquirePermit.ts +32 -0
  326. package/src/Stream/bimap.ts +16 -9
  327. package/src/Stream/continueWith.ts +11 -7
  328. package/src/Stream/drain.ts +8 -7
  329. package/src/Stream/empty.ts +1 -2
  330. package/src/Stream/flatMap.test.ts +8 -21
  331. package/src/Stream/flatMap.ts +58 -23
  332. package/src/Stream/flatMapConcurrently.test.ts +77 -0
  333. package/src/Stream/flatMapConcurrently.ts +30 -0
  334. package/src/Stream/flatMapFx.ts +37 -4
  335. package/src/Stream/fromCallback.test.ts +3 -16
  336. package/src/Stream/fromCallback.ts +48 -29
  337. package/src/Stream/fromFx.test.ts +3 -24
  338. package/src/Stream/fromFx.ts +47 -30
  339. package/src/Stream/hold.test.ts +52 -0
  340. package/src/Stream/hold.ts +117 -0
  341. package/src/Stream/index.ts +8 -0
  342. package/src/Stream/lazy.ts +5 -0
  343. package/src/Stream/logging.test.ts +8 -3
  344. package/src/Stream/map.ts +25 -11
  345. package/src/Stream/merge.test.ts +31 -0
  346. package/src/Stream/merge.ts +76 -0
  347. package/src/Stream/multicast.test.ts +32 -0
  348. package/src/Stream/multicast.ts +114 -0
  349. package/src/Stream/orElse.ts +123 -0
  350. package/src/Stream/periodic.ts +2 -2
  351. package/src/Stream/scan.test.ts +28 -0
  352. package/src/Stream/scan.ts +46 -0
  353. package/src/Stream/scheduled.test.ts +9 -1
  354. package/src/Stream/scheduled.ts +46 -12
  355. package/src/Stream/setFiberRefLocally.ts +44 -0
  356. package/src/Stream/switchMap.test.ts +43 -0
  357. package/src/Stream/switchMap.ts +159 -0
  358. package/src/Stream/tap.ts +6 -3
  359. package/src/Timeline/index.ts +1 -0
  360. package/cjs/Effect/Effect.d.ts +0 -199
  361. package/cjs/Effect/Effect.d.ts.map +0 -1
  362. package/cjs/Effect/Effect.js +0 -66
  363. package/cjs/Effect/Effect.js.map +0 -1
  364. package/esm/Effect/Effect.d.ts +0 -199
  365. package/esm/Effect/Effect.d.ts.map +0 -1
  366. package/esm/Effect/Effect.js +0 -50
  367. package/esm/Effect/Effect.js.map +0 -1
  368. package/src/Effect/Effect.ts +0 -109
@@ -0,0 +1,117 @@
1
+ import { pipe } from 'hkt-ts'
2
+ import { Just, Maybe, Nothing, isJust, toArray } from 'hkt-ts/Maybe'
3
+
4
+ import { Stream } from './Stream.js'
5
+ import { MulticastStream } from './multicast.js'
6
+
7
+ import { Cause } from '@/Cause/index.js'
8
+ import { Fiber } from '@/Fiber/Fiber.js'
9
+ import { FiberContext } from '@/FiberContext/FiberContext.js'
10
+ import { FiberId } from '@/FiberId/FiberId.js'
11
+ import { getServiceFromFiberRefs } from '@/FiberRef/builtins.js'
12
+ import * as Fx from '@/Fx/index.js'
13
+ import { Scheduler } from '@/Scheduler/Scheduler.js'
14
+ import { Sink } from '@/Sink/Sink.js'
15
+
16
+ export function hold<R, E, A>(stream: Stream<R, E, A>) {
17
+ return new HoldStream(stream)
18
+ }
19
+
20
+ export class HoldStream<R, E, A> extends MulticastStream<R, E, A> implements Stream<R, E, A> {
21
+ protected value: Maybe<A> = Nothing
22
+ protected pendingSinks: Array<readonly [Sink<E, A, never>, FiberContext<FiberId.Live>, A[]]> = []
23
+ protected scheduledFiber: Fiber<any, any> | undefined
24
+
25
+ constructor(readonly stream: Stream<R, E, A>) {
26
+ super(stream)
27
+ }
28
+
29
+ fork<E2>(sink: Sink<E, A, E2>, scheduler: Scheduler, context: FiberContext<FiberId.Live>) {
30
+ if (this.shouldScheduleFlush()) {
31
+ return pipe(
32
+ this.scheduleFlush(sink, scheduler, context),
33
+ Fx.flatMap(() => super.fork(sink, scheduler, context)),
34
+ )
35
+ }
36
+
37
+ return super.fork(sink, scheduler, context)
38
+ }
39
+
40
+ event = (value: A) => {
41
+ this.addValue(value)
42
+
43
+ return pipe(
44
+ this.flushPending(),
45
+ Fx.flatMap(() => super.event(value)),
46
+ )
47
+ }
48
+
49
+ error = (cause: Cause<E>) => {
50
+ return pipe(
51
+ this.flushPending(),
52
+ Fx.flatMap(() => super.error(cause)),
53
+ )
54
+ }
55
+
56
+ get end() {
57
+ return pipe(
58
+ this.flushPending(),
59
+ Fx.flatMap(() => super.end),
60
+ )
61
+ }
62
+
63
+ shouldScheduleFlush() {
64
+ return isJust(this.value) && this.observers.length > 0
65
+ }
66
+
67
+ flushPending(): Fx.Of<unknown> {
68
+ // eslint-disable-next-line @typescript-eslint/no-this-alias
69
+ const that = this
70
+
71
+ if (this.pendingSinks.length > 0) {
72
+ return Fx.zipAll(
73
+ this.pendingSinks.map((observer) =>
74
+ observer[2].length > 0
75
+ ? pipe(
76
+ Fx.Fx(function* () {
77
+ that.pendingSinks.splice(that.pendingSinks.indexOf(observer), 1)
78
+
79
+ for (const a of observer[2]) {
80
+ yield* Fx.forkJoinInContext(observer[1].fork())(observer[0].event(a))
81
+ }
82
+ }),
83
+ )
84
+ : Fx.unit,
85
+ ),
86
+ )
87
+ }
88
+
89
+ return Fx.unit
90
+ }
91
+
92
+ scheduleFlush<E2>(
93
+ sink: Sink<E, A, E2>,
94
+ scheduler: Scheduler,
95
+ context: FiberContext<FiberId.Live>,
96
+ ): Fx.Of<unknown> {
97
+ this.pendingSinks.push([sink as any, context, [...toArray(this.value)]])
98
+
99
+ const fx = this.scheduledFiber ? this.scheduledFiber.interruptAs(FiberId.None) : Fx.unit
100
+
101
+ this.scheduledFiber = scheduler.asap(
102
+ this.flushPending(),
103
+ { get: getServiceFromFiberRefs(context.fiberRefs.fork()) },
104
+ context.fork(),
105
+ )
106
+
107
+ return fx
108
+ }
109
+
110
+ protected addValue(value: A) {
111
+ this.value = Just(value)
112
+
113
+ this.pendingSinks.forEach(([, , values]) => {
114
+ values.push(value)
115
+ })
116
+ }
117
+ }
@@ -1,14 +1,22 @@
1
+ export * from './acquirePermit.js'
1
2
  export * from './bimap.js'
2
3
  export * from './continueWith.js'
3
4
  export * from './drain.js'
4
5
  export * from './empty.js'
5
6
  export * from './flatMap.js'
7
+ export * from './flatMapConcurrently.js'
6
8
  export * from './flatMapFx.js'
7
9
  export * from './fromCallback.js'
8
10
  export * from './fromFx.js'
9
11
  export * from './hkt.js'
12
+ export * from './hold.js'
13
+ export * from './lazy.js'
10
14
  export * from './map.js'
15
+ export * from './merge.js'
16
+ export * from './multicast.js'
11
17
  export * from './periodic.js'
18
+ export * from './setFiberRefLocally.js'
19
+ export * from './scan.js'
12
20
  export * from './scheduled.js'
13
21
  export * from './Stream.js'
14
22
  export * from './tap.js'
@@ -0,0 +1,5 @@
1
+ import { Stream } from './Stream.js'
2
+
3
+ export function lazy<R, E, A>(f: () => Stream<R, E, A>): Stream<R, E, A> {
4
+ return Stream((sink, scheduler, context) => f().fork(sink, scheduler, context))
5
+ }
@@ -1,6 +1,7 @@
1
1
  import { flow, pipe } from 'hkt-ts'
2
2
 
3
3
  import { continueWith } from './continueWith.js'
4
+ import { flatMap } from './flatMap.js'
4
5
  import { now } from './fromFx.js'
5
6
  import { runMain } from './run.js'
6
7
  import { tap } from './tap.js'
@@ -13,9 +14,13 @@ testSuite(import.meta.url, () => {
13
14
  describe('Logging Streams', () => {
14
15
  it('should log the stream', async () => {
15
16
  const stream = pipe(
16
- now(1),
17
- continueWith(() => now(2)),
18
- tap(flow(String, Fx.log)),
17
+ now(1, 'now1'),
18
+ continueWith(() => now(2, 'now2'), 'continueWith'),
19
+ flatMap((n) => now(n + 1, 'now+1'), 'flatMap'),
20
+ tap(
21
+ flow((n) => String(n), Fx.log),
22
+ 'tap',
23
+ ),
19
24
  )
20
25
 
21
26
  await runMain(RootScheduler())(stream)
package/src/Stream/map.ts CHANGED
@@ -5,31 +5,45 @@ import { Stream } from './Stream.js'
5
5
  import { FiberContext } from '@/FiberContext/FiberContext.js'
6
6
  import { Live } from '@/FiberId/FiberId.js'
7
7
  import { Scheduler } from '@/Scheduler/Scheduler.js'
8
- import { Sink } from '@/Sink/Sink.js'
8
+ import { Sink, addTrace } from '@/Sink/Sink.js'
9
9
 
10
- export function map<A, B>(f: (a: A) => B): <R, E>(stream: Stream<R, E, A>) => Stream<R, E, B> {
11
- return (stream) => MapStream.make(stream, f)
10
+ export function map<A, B>(
11
+ f: (a: A) => B,
12
+ __trace?: string,
13
+ ): <R, E>(stream: Stream<R, E, A>) => Stream<R, E, B> {
14
+ return (stream) => MapStream.make(stream, f, __trace)
12
15
  }
13
16
 
14
17
  export class MapStream<R, E, A, B> implements Stream<R, E, B> {
15
- constructor(readonly stream: Stream<R, E, A>, readonly f: (a: A) => B) {}
18
+ constructor(
19
+ readonly stream: Stream<R, E, A>,
20
+ readonly f: (a: A) => B,
21
+ readonly __trace?: string,
22
+ ) {}
16
23
 
17
24
  fork<E2>(sink: Sink<E, B, E2>, scheduler: Scheduler, context: FiberContext<Live>) {
18
25
  return this.stream.fork(
19
- {
20
- ...sink,
21
- event: flow(this.f, sink.event),
22
- },
26
+ addTrace(
27
+ {
28
+ ...sink,
29
+ event: flow(this.f, sink.event),
30
+ },
31
+ this.__trace,
32
+ ),
23
33
  scheduler,
24
34
  context,
25
35
  )
26
36
  }
27
37
 
28
- static make<R, E, A, B>(stream: Stream<R, E, A>, f: (a: A) => B): Stream<R, E, B> {
38
+ static make<R, E, A, B>(
39
+ stream: Stream<R, E, A>,
40
+ f: (a: A) => B,
41
+ __trace?: string,
42
+ ): Stream<R, E, B> {
29
43
  if (stream instanceof MapStream) {
30
- return MapStream.make(stream.stream, flow(stream.f, f))
44
+ return MapStream.make(stream.stream, flow(stream.f, f), __trace)
31
45
  }
32
46
 
33
- return new MapStream(stream, f)
47
+ return new MapStream(stream, f, __trace)
34
48
  }
35
49
  }
@@ -0,0 +1,31 @@
1
+ import { deepStrictEqual } from 'assert'
2
+
3
+ import { pipe } from 'hkt-ts/function'
4
+
5
+ import { collectAll } from './_internal.test.js'
6
+ import { fromCallback } from './fromCallback.js'
7
+ import { merge } from './merge.js'
8
+
9
+ import { testSuite } from '@/_internal/suite.js'
10
+
11
+ testSuite(import.meta.url, () => {
12
+ const stream = pipe(
13
+ fromCallback<never, number>(async ({ event, end }) => {
14
+ await event(1)
15
+ await event(2)
16
+ await event(3)
17
+ await end()
18
+ }),
19
+ merge(
20
+ fromCallback<never, number>(async ({ event, end }) => {
21
+ await event(4)
22
+ await event(5)
23
+ await end()
24
+ }),
25
+ ),
26
+ )
27
+
28
+ it('merges together 2 streams concurrenctly', async () => {
29
+ deepStrictEqual(await collectAll(stream), [1, 4, 2, 5, 3])
30
+ })
31
+ })
@@ -0,0 +1,76 @@
1
+ import { NonNegativeInteger } from 'hkt-ts/number'
2
+
3
+ import { ErrorsOf, OutputOf, ResourcesOf, Stream } from './Stream.js'
4
+ import { empty } from './empty.js'
5
+
6
+ import { AtomicCounter, decrement } from '@/Atomic/AtomicCounter.js'
7
+ import { Fiber } from '@/Fiber/Fiber.js'
8
+ import { both } from '@/Fiber/hkt.js'
9
+ import { FiberContext } from '@/FiberContext/FiberContext.js'
10
+ import { Live } from '@/FiberId/FiberId.js'
11
+ import * as Fx from '@/Fx/index.js'
12
+ import { Scheduler } from '@/Scheduler/Scheduler.js'
13
+ import { Sink, addTrace } from '@/Sink/Sink.js'
14
+
15
+ export function merge<R2, E2, B>(second: Stream<R2, E2, B>, __trace?: string) {
16
+ return <R, E, A>(first: Stream<R, E, A>): Stream<R | R2, E | E2, A | B> =>
17
+ MergeStream.make(first, second, __trace)
18
+ }
19
+
20
+ export function mergeArray<Streams extends ReadonlyArray<Stream<any, any, any>>>(
21
+ streams: readonly [...Streams],
22
+ __trace?: string,
23
+ ): Stream<ResourcesOf<Streams[number]>, ErrorsOf<Streams[number]>, OutputOf<Streams[number]>> {
24
+ if (streams.length === 0) {
25
+ return empty
26
+ }
27
+
28
+ const [first, ...rest] = streams
29
+
30
+ return rest.reduce((acc, stream) => merge(stream, __trace)(acc), first)
31
+ }
32
+
33
+ export class MergeStream<R, E, A, R2, E2, B> implements Stream<R | R2, E | E2, A | B> {
34
+ constructor(
35
+ readonly first: Stream<R, E, A>,
36
+ readonly second: Stream<R2, E2, B>,
37
+ readonly __trace?: string,
38
+ ) {}
39
+
40
+ fork = <E3>(sink: Sink<E | E2, A | B, E3>, scheduler: Scheduler, context: FiberContext<Live>) => {
41
+ const { first, second, __trace } = this
42
+ const mergeSink = addTrace(
43
+ new MergeSink<E | E2, A | B, E3>(sink, AtomicCounter(NonNegativeInteger(2))),
44
+ __trace,
45
+ )
46
+
47
+ return Fx.Fx(function* () {
48
+ const firstFiber: Fiber<E3, any> = yield* first.fork(mergeSink, scheduler, context)
49
+ const secondFiber: Fiber<E3, any> = yield* second.fork(mergeSink, scheduler, context.fork())
50
+
51
+ return both(secondFiber)(firstFiber)
52
+ })
53
+ }
54
+
55
+ static make<R, E, A, R2, E2, B>(
56
+ first: Stream<R, E, A>,
57
+ second: Stream<R2, E2, B>,
58
+ __trace?: string,
59
+ ): Stream<R | R2, E | E2, A | B> {
60
+ return new MergeStream(first, second, __trace)
61
+ }
62
+ }
63
+
64
+ class MergeSink<E, A, E2> implements Sink<E, A, E2> {
65
+ constructor(readonly sink: Sink<E, A, E2>, readonly refCount: AtomicCounter) {}
66
+
67
+ event = this.sink.event
68
+ error = this.sink.error
69
+ end = Fx.lazy(() => {
70
+ if (decrement(this.refCount) === 0) {
71
+ return this.sink.end
72
+ }
73
+
74
+ return Fx.unit
75
+ })
76
+ }
@@ -0,0 +1,32 @@
1
+ import { deepStrictEqual } from 'assert'
2
+
3
+ import { collectAll } from './_internal.test.js'
4
+ import { fromCallback } from './fromCallback.js'
5
+ import { multicast } from './multicast.js'
6
+
7
+ import { testSuite } from '@/_internal/suite.js'
8
+
9
+ testSuite(import.meta.url, () => {
10
+ describe(multicast.name, () => {
11
+ it('effeciently shares underlying stream', async () => {
12
+ let started = 0
13
+ const value = Math.random()
14
+ const stream = multicast(
15
+ fromCallback<never, number>(async ({ event, end }) => {
16
+ started++
17
+ event(value)
18
+ event(value + 1)
19
+ event(value + 2)
20
+ end()
21
+ }),
22
+ )
23
+
24
+ const a = collectAll(stream)
25
+ const b = collectAll(stream)
26
+
27
+ deepStrictEqual(await a, [value, value + 1, value + 2])
28
+ deepStrictEqual(await b, [value, value + 1, value + 2])
29
+ deepStrictEqual(started, 1)
30
+ })
31
+ })
32
+ })
@@ -0,0 +1,114 @@
1
+ import { pipe } from 'hkt-ts'
2
+
3
+ import { Stream } from './Stream.js'
4
+
5
+ import { Cause } from '@/Cause/Cause.js'
6
+ import { fromScope } from '@/Fiber/fromScope.js'
7
+ import { FiberContext } from '@/FiberContext/FiberContext.js'
8
+ import { FiberId } from '@/FiberId/index.js'
9
+ import * as Fx from '@/Fx/index.js'
10
+ import { Scheduler } from '@/Scheduler/index.js'
11
+ import { Sink } from '@/Sink/Sink.js'
12
+ import { Fiber } from '@/index.js'
13
+
14
+ export function multicast<R, E, A>(stream: Stream<R, E, A>) {
15
+ return new MulticastStream(stream)
16
+ }
17
+
18
+ type Observer<E, A, E2> = {
19
+ sink: Sink<E, A, E2>
20
+ scheduler: Scheduler
21
+ context: FiberContext<FiberId.Live>
22
+ }
23
+
24
+ // TODO: how to create a synthetic fiber around multicasted streams?
25
+
26
+ export class MulticastStream<R, E, A> implements Stream<R, E, A>, Sink<E, A, any> {
27
+ protected observers: Array<Observer<E, A, any>> = []
28
+ protected fiber: Fiber.Fiber<any, any> | undefined
29
+
30
+ constructor(readonly stream: Stream<R, E, A>) {
31
+ this.event = this.event.bind(this)
32
+ this.error = this.error.bind(this)
33
+ }
34
+
35
+ fork<E2>(sink: Sink<E, A, E2>, scheduler: Scheduler, context: FiberContext<FiberId.Live>) {
36
+ return Fx.lazy(() => {
37
+ const observer: Observer<E, A, E2> = {
38
+ sink,
39
+ scheduler,
40
+ context,
41
+ }
42
+
43
+ const l = this.observers.length
44
+
45
+ this.observers.push(observer)
46
+
47
+ if (l === 0) {
48
+ return pipe(
49
+ this.stream.fork(this, scheduler, context),
50
+ Fx.tapLazy((fiber) => (this.fiber = fiber)),
51
+ Fx.map(() => this.createFiber(observer)),
52
+ )
53
+ }
54
+
55
+ return Fx.fromLazy(() => this.createFiber(observer))
56
+ })
57
+ }
58
+
59
+ event(a: A) {
60
+ return Fx.zipAll(
61
+ this.observers.map(({ sink, context }) =>
62
+ pipe(sink.event(a), Fx.forkJoinInContext(context.fork())),
63
+ ),
64
+ )
65
+ }
66
+
67
+ error(cause: Cause<E>) {
68
+ return pipe(
69
+ Fx.zipAll(
70
+ this.observers.map(({ sink, context }) =>
71
+ pipe(sink.error(cause), Fx.forkJoinInContext(context.fork())),
72
+ ),
73
+ ),
74
+ Fx.tap((): Fx.Of<any> => (this.fiber ? this.fiber.interruptAs(FiberId.None) : Fx.unit)),
75
+ Fx.tapLazy(() => (this.observers = [])),
76
+ )
77
+ }
78
+
79
+ get end() {
80
+ return pipe(
81
+ Fx.lazy(() =>
82
+ Fx.zipAll(
83
+ this.observers.map(({ sink, context }) =>
84
+ pipe(sink.end, Fx.forkJoinInContext(context.fork())),
85
+ ),
86
+ ),
87
+ ),
88
+ Fx.tapLazy(() => (this.observers = [])),
89
+ )
90
+ }
91
+
92
+ protected createFiber = <E2>(observer: Observer<E, A, E2>) => {
93
+ const { context } = observer
94
+ context.scope.ensuring(() =>
95
+ pipe(
96
+ Fx.fromLazy(() => {
97
+ const index = this.observers.indexOf(observer)
98
+
99
+ if (index >= 0) {
100
+ this.observers.splice(index, 1)
101
+ }
102
+ }),
103
+ Fx.flatMap(
104
+ (): Fx.Of<any> =>
105
+ this.observers.length === 0 && this.fiber
106
+ ? this.fiber.interruptAs(context.id)
107
+ : Fx.unit,
108
+ ),
109
+ ),
110
+ )
111
+
112
+ return fromScope(new FiberId.Synthetic([context.id]), context.fiberRefs, context.scope)
113
+ }
114
+ }
@@ -0,0 +1,123 @@
1
+ import { pipe } from 'hkt-ts'
2
+ import { isRight } from 'hkt-ts/Either'
3
+ import { isJust } from 'hkt-ts/Maybe'
4
+
5
+ import { Stream } from './Stream.js'
6
+
7
+ import { AtomicCounter, decrement, increment } from '@/Atomic/AtomicCounter.js'
8
+ import { Cause } from '@/Cause/index.js'
9
+ import { Env } from '@/Env/Env.js'
10
+ import { FiberContext } from '@/FiberContext/FiberContext.js'
11
+ import { Live } from '@/FiberId/FiberId.js'
12
+ import * as FiberRefs from '@/FiberRefs/index.js'
13
+ import * as Fx from '@/Fx/index.js'
14
+ import { access, lazy, provideService, unit } from '@/Fx/index.js'
15
+ import { Scheduler } from '@/Scheduler/Scheduler.js'
16
+ import * as Sink from '@/Sink/Sink.js'
17
+ import { None, and } from '@/Supervisor/Supervisor.js'
18
+
19
+ export function orElse<E, R2, E2, B>(
20
+ f: (cause: Cause<E>) => Stream<R2, E2, B>,
21
+ __trace?: string,
22
+ ): <R, A>(stream: Stream<R, E, A>) => Stream<R | R2, E2, A | B> {
23
+ return (stream) => OrElseStream.make(stream, f, __trace)
24
+ }
25
+
26
+ export class OrElseStream<R, E, A, R2, E2, B> implements Stream<R | R2, E2, A | B> {
27
+ constructor(
28
+ readonly stream: Stream<R, E, A>,
29
+ readonly f: (cause: Cause<E>) => Stream<R2, E2, B>,
30
+ readonly __trace?: string,
31
+ ) {}
32
+
33
+ fork<E3>(sink: Sink.Sink<E2, A | B, E3>, scheduler: Scheduler, context: FiberContext<Live>) {
34
+ const { stream, f } = this
35
+
36
+ return access((env: Env<R | R2>) =>
37
+ pipe(
38
+ stream.fork(
39
+ new OrElseSink(sink, scheduler, context, f, env, this.__trace),
40
+ scheduler,
41
+ context,
42
+ ),
43
+ provideService(Scheduler, scheduler),
44
+ ),
45
+ )
46
+ }
47
+
48
+ static make<R, E, A, R2, E2, B>(
49
+ stream: Stream<R, E, A>,
50
+ f: (cause: Cause<E>) => Stream<R2, E2, B>,
51
+ __trace?: string,
52
+ ): Stream<R | R2, E2, A | B> {
53
+ return new OrElseStream(stream, f, __trace)
54
+ }
55
+ }
56
+
57
+ class OrElseSink<R, E, A, R2, E2, B, E3> implements Sink.Sink<E, A, E3> {
58
+ protected _running = AtomicCounter()
59
+ protected _ended = false
60
+ protected supervisor = None.extend({
61
+ onEnd: () => (fiber, exit) => {
62
+ const parentContext = fiber.context.parent
63
+
64
+ // Merge FiberRefs upon successful completion
65
+ if (isRight(exit) && isJust(parentContext)) {
66
+ FiberRefs.join(parentContext.value.fiberRefs, fiber.context.fiberRefs)
67
+ }
68
+ },
69
+ })
70
+
71
+ constructor(
72
+ readonly sink: Sink.Sink<E2, A | B, E3>,
73
+ readonly scheduler: Scheduler,
74
+ readonly context: FiberContext<Live>,
75
+ readonly f: (cause: Cause<E>) => Stream<R2, E2, B>,
76
+ readonly env: Env<R | R2>,
77
+ readonly __trace?: string,
78
+ ) {}
79
+
80
+ event = this.sink.event
81
+
82
+ error = (cause: Cause<E>) => {
83
+ return lazy(() => {
84
+ const forked = this.context.fork({
85
+ supervisor: and(this.supervisor)(this.context.supervisor),
86
+ })
87
+
88
+ increment(this._running)
89
+
90
+ return pipe(
91
+ this.f(cause).fork(Sink.addTrace(this.innerSink(), this.__trace), this.scheduler, forked),
92
+ Fx.provide(this.env),
93
+ )
94
+ })
95
+ }
96
+
97
+ end = lazy(() => {
98
+ this._ended = true
99
+
100
+ return this.endIfCompleted()
101
+ })
102
+
103
+ protected endIfCompleted() {
104
+ return lazy(() => {
105
+ if (this._ended && this._running.get() === 0) {
106
+ return this.sink.end
107
+ }
108
+
109
+ return unit
110
+ })
111
+ }
112
+
113
+ protected innerSink(): Sink.Sink<E2, B, E3> {
114
+ return {
115
+ event: this.sink.event,
116
+ error: this.sink.error,
117
+ end: lazy(() => {
118
+ decrement(this._running)
119
+ return this.endIfCompleted()
120
+ }),
121
+ }
122
+ }
123
+ }
@@ -5,5 +5,5 @@ import * as Fx from '@/Fx/Fx.js'
5
5
  import * as Schedule from '@/Schedule/index.js'
6
6
  import { Delay } from '@/Time/index.js'
7
7
 
8
- export const periodic = (period: Delay): Stream<never, never, void> =>
9
- scheduled(Schedule.periodic(period))(Fx.unit)
8
+ export const periodic = (period: Delay, __trace?: string): Stream<never, never, void> =>
9
+ scheduled(Schedule.periodic(period), __trace)(Fx.unit)
@@ -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
+ }