@typed/fx 0.0.9 → 0.0.12
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.
- package/.eslintcache +1 -1
- package/cjs/Fx.d.ts +19 -8
- package/cjs/Fx.d.ts.map +1 -1
- package/cjs/Fx.js +12 -2
- package/cjs/Fx.js.map +1 -1
- package/cjs/Subject.d.ts +22 -0
- package/cjs/Subject.d.ts.map +1 -0
- package/cjs/Subject.js +58 -0
- package/cjs/Subject.js.map +1 -0
- package/cjs/_internal.d.ts +19 -20
- package/cjs/_internal.d.ts.map +1 -1
- package/cjs/_internal.js +21 -76
- package/cjs/_internal.js.map +1 -1
- package/cjs/combine.d.ts +4 -4
- package/cjs/combine.d.ts.map +1 -1
- package/cjs/combine.js +9 -13
- package/cjs/combine.js.map +1 -1
- package/cjs/continueWith.d.ts +2 -2
- package/cjs/continueWith.d.ts.map +1 -1
- package/cjs/continueWith.js +2 -3
- package/cjs/continueWith.js.map +1 -1
- package/cjs/debounce.d.ts +2 -11
- package/cjs/debounce.d.ts.map +1 -1
- package/cjs/debounce.js +4 -24
- package/cjs/debounce.js.map +1 -1
- package/cjs/delay.d.ts +2 -2
- package/cjs/delay.d.ts.map +1 -1
- package/cjs/delay.js +4 -5
- package/cjs/delay.js.map +1 -1
- package/cjs/during.d.ts +1 -1
- package/cjs/during.d.ts.map +1 -1
- package/cjs/during.js +6 -9
- package/cjs/during.js.map +1 -1
- package/cjs/filterLoop.d.ts +25 -0
- package/cjs/filterLoop.d.ts.map +1 -0
- package/cjs/filterLoop.js +108 -0
- package/cjs/filterLoop.js.map +1 -0
- package/cjs/filterMap.d.ts +24 -0
- package/cjs/filterMap.d.ts.map +1 -0
- package/cjs/{map.js → filterMap.js} +27 -40
- package/cjs/filterMap.js.map +1 -0
- package/cjs/flatMap.d.ts +2 -10
- package/cjs/flatMap.d.ts.map +1 -1
- package/cjs/flatMap.js +10 -25
- package/cjs/flatMap.js.map +1 -1
- package/cjs/flatMapConcurrently.d.ts +2 -2
- package/cjs/flatMapConcurrently.d.ts.map +1 -1
- package/cjs/flatMapConcurrently.js +3 -3
- package/cjs/flatMapConcurrently.js.map +1 -1
- package/cjs/fromEffect.d.ts +34 -15
- package/cjs/fromEffect.d.ts.map +1 -1
- package/cjs/fromEffect.js +28 -15
- package/cjs/fromEffect.js.map +1 -1
- package/cjs/fromIterable.d.ts +9 -0
- package/cjs/fromIterable.d.ts.map +1 -0
- package/cjs/{drain.js → fromIterable.js} +14 -13
- package/cjs/fromIterable.js.map +1 -0
- package/cjs/hold.d.ts +16 -17
- package/cjs/hold.d.ts.map +1 -1
- package/cjs/hold.js +28 -25
- package/cjs/hold.js.map +1 -1
- package/cjs/index.d.ts +19 -15
- package/cjs/index.d.ts.map +1 -1
- package/cjs/index.js +19 -28
- package/cjs/index.js.map +1 -1
- package/cjs/mapCause.d.ts +5 -0
- package/cjs/mapCause.d.ts.map +1 -0
- package/cjs/mapCause.js +41 -0
- package/cjs/mapCause.js.map +1 -0
- package/cjs/mapEffect.d.ts +4 -0
- package/cjs/mapEffect.d.ts.map +1 -0
- package/cjs/{never.js → mapEffect.js} +6 -4
- package/cjs/mapEffect.js.map +1 -0
- package/cjs/merge.d.ts +3 -3
- package/cjs/merge.d.ts.map +1 -1
- package/cjs/merge.js +7 -11
- package/cjs/merge.js.map +1 -1
- package/cjs/multicast.d.ts +20 -19
- package/cjs/multicast.d.ts.map +1 -1
- package/cjs/multicast.js +30 -34
- package/cjs/multicast.js.map +1 -1
- package/cjs/orElse.d.ts +2 -5
- package/cjs/orElse.d.ts.map +1 -1
- package/cjs/orElse.js +9 -11
- package/cjs/orElse.js.map +1 -1
- package/cjs/provide.d.ts +8 -8
- package/cjs/provide.d.ts.map +1 -1
- package/cjs/provide.js +23 -9
- package/cjs/provide.js.map +1 -1
- package/cjs/runCollect.d.ts +4 -0
- package/cjs/runCollect.d.ts.map +1 -0
- package/cjs/{from.js → runCollect.js} +6 -15
- package/cjs/runCollect.js.map +1 -0
- package/cjs/runDrain.d.ts +4 -0
- package/cjs/runDrain.d.ts.map +1 -0
- package/cjs/runDrain.js +38 -0
- package/cjs/runDrain.js.map +1 -0
- package/cjs/runObserve.d.ts +4 -0
- package/cjs/runObserve.d.ts.map +1 -0
- package/cjs/{takeUntil.js → runObserve.js} +6 -17
- package/cjs/runObserve.js.map +1 -0
- package/cjs/runReduce.d.ts +6 -0
- package/cjs/runReduce.d.ts.map +1 -0
- package/cjs/runReduce.js +50 -0
- package/cjs/runReduce.js.map +1 -0
- package/cjs/scheduled.d.ts +4 -4
- package/cjs/scheduled.d.ts.map +1 -1
- package/cjs/scheduled.js +8 -8
- package/cjs/scheduled.js.map +1 -1
- package/cjs/since.d.ts +1 -1
- package/cjs/since.d.ts.map +1 -1
- package/cjs/since.js +5 -9
- package/cjs/since.js.map +1 -1
- package/cjs/skipRepeats.d.ts +1 -1
- package/cjs/skipRepeats.d.ts.map +1 -1
- package/cjs/skipRepeats.js +4 -5
- package/cjs/skipRepeats.js.map +1 -1
- package/cjs/skipWhile.d.ts +3 -3
- package/cjs/skipWhile.d.ts.map +1 -1
- package/cjs/skipWhile.js +12 -15
- package/cjs/skipWhile.js.map +1 -1
- package/cjs/slice.d.ts +3 -3
- package/cjs/slice.d.ts.map +1 -1
- package/cjs/slice.js +15 -23
- package/cjs/slice.js.map +1 -1
- package/cjs/snapshot.d.ts +2 -2
- package/cjs/snapshot.d.ts.map +1 -1
- package/cjs/snapshot.js +6 -8
- package/cjs/snapshot.js.map +1 -1
- package/cjs/suspendSucceed.d.ts +1 -1
- package/cjs/suspendSucceed.d.ts.map +1 -1
- package/cjs/suspendSucceed.js +1 -25
- package/cjs/suspendSucceed.js.map +1 -1
- package/cjs/switchMap.d.ts +1 -9
- package/cjs/switchMap.d.ts.map +1 -1
- package/cjs/switchMap.js +5 -18
- package/cjs/switchMap.js.map +1 -1
- package/cjs/takeWhile.d.ts +3 -3
- package/cjs/takeWhile.d.ts.map +1 -1
- package/cjs/takeWhile.js +6 -38
- package/cjs/takeWhile.js.map +1 -1
- package/cjs/tapEffect.d.ts +5 -0
- package/cjs/tapEffect.d.ts.map +1 -0
- package/cjs/{observe.js → tapEffect.js} +8 -15
- package/cjs/tapEffect.js.map +1 -0
- package/cjs/throttle.d.ts +2 -2
- package/cjs/throttle.d.ts.map +1 -1
- package/cjs/throttle.js +6 -13
- package/cjs/throttle.js.map +1 -1
- package/cjs/transform.d.ts +13 -8
- package/cjs/transform.d.ts.map +1 -1
- package/cjs/transform.js +9 -2
- package/cjs/transform.js.map +1 -1
- package/cjs/until.d.ts +1 -1
- package/cjs/until.d.ts.map +1 -1
- package/cjs/until.js +5 -7
- package/cjs/until.js.map +1 -1
- package/{esm/fromCallback.d.ts → cjs/withEmitter.d.ts} +4 -4
- package/cjs/withEmitter.d.ts.map +1 -0
- package/cjs/{fromCallback.js → withEmitter.js} +22 -16
- package/cjs/withEmitter.js.map +1 -0
- package/cjs/zip.d.ts +4 -4
- package/cjs/zip.d.ts.map +1 -1
- package/cjs/zip.js +11 -15
- package/cjs/zip.js.map +1 -1
- package/cjs/zipIterable.d.ts +4 -0
- package/cjs/zipIterable.d.ts.map +1 -0
- package/cjs/{zipItems.js → zipIterable.js} +23 -20
- package/cjs/zipIterable.js.map +1 -0
- package/esm/Fx.d.ts +19 -8
- package/esm/Fx.d.ts.map +1 -1
- package/esm/Fx.js +10 -1
- package/esm/Fx.js.map +1 -1
- package/esm/Subject.d.ts +22 -0
- package/esm/Subject.d.ts.map +1 -0
- package/esm/Subject.js +32 -0
- package/esm/Subject.js.map +1 -0
- package/esm/_internal.d.ts +19 -20
- package/esm/_internal.d.ts.map +1 -1
- package/esm/_internal.js +16 -72
- package/esm/_internal.js.map +1 -1
- package/esm/combine.d.ts +4 -4
- package/esm/combine.d.ts.map +1 -1
- package/esm/combine.js +12 -16
- package/esm/combine.js.map +1 -1
- package/esm/continueWith.d.ts +2 -2
- package/esm/continueWith.d.ts.map +1 -1
- package/esm/continueWith.js +3 -4
- package/esm/continueWith.js.map +1 -1
- package/esm/debounce.d.ts +2 -11
- package/esm/debounce.d.ts.map +1 -1
- package/esm/debounce.js +7 -27
- package/esm/debounce.js.map +1 -1
- package/esm/delay.d.ts +2 -2
- package/esm/delay.d.ts.map +1 -1
- package/esm/delay.js +6 -7
- package/esm/delay.js.map +1 -1
- package/esm/during.d.ts +1 -1
- package/esm/during.d.ts.map +1 -1
- package/esm/during.js +9 -12
- package/esm/during.js.map +1 -1
- package/esm/filterLoop.d.ts +25 -0
- package/esm/filterLoop.d.ts.map +1 -0
- package/esm/filterLoop.js +76 -0
- package/esm/filterLoop.js.map +1 -0
- package/esm/filterMap.d.ts +24 -0
- package/esm/filterMap.d.ts.map +1 -0
- package/esm/filterMap.js +53 -0
- package/esm/filterMap.js.map +1 -0
- package/esm/flatMap.d.ts +2 -10
- package/esm/flatMap.d.ts.map +1 -1
- package/esm/flatMap.js +9 -24
- package/esm/flatMap.js.map +1 -1
- package/esm/flatMapConcurrently.d.ts +2 -2
- package/esm/flatMapConcurrently.d.ts.map +1 -1
- package/esm/flatMapConcurrently.js +3 -3
- package/esm/flatMapConcurrently.js.map +1 -1
- package/esm/fromEffect.d.ts +34 -15
- package/esm/fromEffect.d.ts.map +1 -1
- package/esm/fromEffect.js +25 -13
- package/esm/fromEffect.js.map +1 -1
- package/esm/fromIterable.d.ts +9 -0
- package/esm/fromIterable.d.ts.map +1 -0
- package/esm/fromIterable.js +14 -0
- package/esm/fromIterable.js.map +1 -0
- package/esm/hold.d.ts +16 -17
- package/esm/hold.d.ts.map +1 -1
- package/esm/hold.js +28 -25
- package/esm/hold.js.map +1 -1
- package/esm/index.d.ts +19 -15
- package/esm/index.d.ts.map +1 -1
- package/esm/index.js +19 -16
- package/esm/index.js.map +1 -1
- package/esm/mapCause.d.ts +5 -0
- package/esm/mapCause.d.ts.map +1 -0
- package/esm/mapCause.js +13 -0
- package/esm/mapCause.js.map +1 -0
- package/esm/mapEffect.d.ts +4 -0
- package/esm/mapEffect.d.ts.map +1 -0
- package/esm/mapEffect.js +5 -0
- package/esm/mapEffect.js.map +1 -0
- package/esm/merge.d.ts +3 -3
- package/esm/merge.d.ts.map +1 -1
- package/esm/merge.js +9 -13
- package/esm/merge.js.map +1 -1
- package/esm/multicast.d.ts +20 -19
- package/esm/multicast.d.ts.map +1 -1
- package/esm/multicast.js +33 -37
- package/esm/multicast.js.map +1 -1
- package/esm/orElse.d.ts +2 -5
- package/esm/orElse.d.ts.map +1 -1
- package/esm/orElse.js +10 -10
- package/esm/orElse.js.map +1 -1
- package/esm/provide.d.ts +8 -8
- package/esm/provide.d.ts.map +1 -1
- package/esm/provide.js +20 -6
- package/esm/provide.js.map +1 -1
- package/esm/runCollect.d.ts +4 -0
- package/esm/runCollect.d.ts.map +1 -0
- package/esm/runCollect.js +7 -0
- package/esm/runCollect.js.map +1 -0
- package/esm/runDrain.d.ts +4 -0
- package/esm/runDrain.d.ts.map +1 -0
- package/esm/runDrain.js +11 -0
- package/esm/runDrain.js.map +1 -0
- package/esm/runObserve.d.ts +4 -0
- package/esm/runObserve.d.ts.map +1 -0
- package/esm/runObserve.js +8 -0
- package/esm/runObserve.js.map +1 -0
- package/esm/runReduce.d.ts +6 -0
- package/esm/runReduce.d.ts.map +1 -0
- package/esm/runReduce.js +22 -0
- package/esm/runReduce.js.map +1 -0
- package/esm/scheduled.d.ts +4 -4
- package/esm/scheduled.d.ts.map +1 -1
- package/esm/scheduled.js +8 -8
- package/esm/scheduled.js.map +1 -1
- package/esm/since.d.ts +1 -1
- package/esm/since.d.ts.map +1 -1
- package/esm/since.js +8 -12
- package/esm/since.js.map +1 -1
- package/esm/skipRepeats.d.ts +1 -1
- package/esm/skipRepeats.d.ts.map +1 -1
- package/esm/skipRepeats.js +5 -6
- package/esm/skipRepeats.js.map +1 -1
- package/esm/skipWhile.d.ts +3 -3
- package/esm/skipWhile.d.ts.map +1 -1
- package/esm/skipWhile.js +13 -16
- package/esm/skipWhile.js.map +1 -1
- package/esm/slice.d.ts +3 -3
- package/esm/slice.d.ts.map +1 -1
- package/esm/slice.js +17 -25
- package/esm/slice.js.map +1 -1
- package/esm/snapshot.d.ts +2 -2
- package/esm/snapshot.d.ts.map +1 -1
- package/esm/snapshot.js +8 -10
- package/esm/snapshot.js.map +1 -1
- package/esm/suspendSucceed.d.ts +1 -1
- package/esm/suspendSucceed.d.ts.map +1 -1
- package/esm/suspendSucceed.js +1 -2
- package/esm/suspendSucceed.js.map +1 -1
- package/esm/switchMap.d.ts +1 -9
- package/esm/switchMap.d.ts.map +1 -1
- package/esm/switchMap.js +6 -18
- package/esm/switchMap.js.map +1 -1
- package/esm/takeWhile.d.ts +3 -3
- package/esm/takeWhile.d.ts.map +1 -1
- package/esm/takeWhile.js +8 -17
- package/esm/takeWhile.js.map +1 -1
- package/esm/tapEffect.d.ts +5 -0
- package/esm/tapEffect.d.ts.map +1 -0
- package/esm/tapEffect.js +6 -0
- package/esm/tapEffect.js.map +1 -0
- package/esm/throttle.d.ts +2 -2
- package/esm/throttle.d.ts.map +1 -1
- package/esm/throttle.js +9 -16
- package/esm/throttle.js.map +1 -1
- package/esm/transform.d.ts +13 -8
- package/esm/transform.d.ts.map +1 -1
- package/esm/transform.js +6 -1
- package/esm/transform.js.map +1 -1
- package/esm/until.d.ts +1 -1
- package/esm/until.d.ts.map +1 -1
- package/esm/until.js +8 -10
- package/esm/until.js.map +1 -1
- package/{cjs/fromCallback.d.ts → esm/withEmitter.d.ts} +4 -4
- package/esm/withEmitter.d.ts.map +1 -0
- package/esm/withEmitter.js +26 -0
- package/esm/withEmitter.js.map +1 -0
- package/esm/zip.d.ts +4 -4
- package/esm/zip.d.ts.map +1 -1
- package/esm/zip.js +14 -18
- package/esm/zip.js.map +1 -1
- package/esm/zipIterable.d.ts +4 -0
- package/esm/zipIterable.d.ts.map +1 -0
- package/esm/zipIterable.js +26 -0
- package/esm/zipIterable.js.map +1 -0
- package/package.json +107 -113
- package/perf/_internal.ts +39 -35
- package/perf/cases/filter-map-reduce.ts +48 -0
- package/perf/cases/flatMap.ts +49 -0
- package/perf/cases/switchMap.ts +36 -0
- package/perf/readme-base.md +14 -0
- package/perf/readme.md +40 -0
- package/perf/runFullSuite.ts +37 -0
- package/perf/runPerfTest.ts +18 -0
- package/perf/tsconfig.json +1 -1
- package/src/Fx.ts +35 -10
- package/src/Subject.ts +46 -0
- package/src/_internal.ts +59 -114
- package/src/combine.test.ts +15 -16
- package/src/combine.ts +44 -48
- package/src/continueWith.test.ts +26 -0
- package/src/continueWith.ts +9 -11
- package/src/debounce.test.ts +4 -6
- package/src/debounce.ts +30 -49
- package/src/delay.test.ts +5 -6
- package/src/delay.ts +9 -8
- package/src/during.test.ts +39 -0
- package/src/during.ts +43 -47
- package/src/filterLoop.test.ts +63 -0
- package/src/filterLoop.ts +143 -0
- package/src/filterMap.test.ts +33 -0
- package/src/filterMap.ts +71 -0
- package/src/flatMap.test.ts +39 -12
- package/src/flatMap.ts +25 -51
- package/src/flatMapConcurrently.test.ts +23 -0
- package/src/flatMapConcurrently.ts +6 -12
- package/src/fromEffect.ts +74 -26
- package/src/fromIterable.ts +15 -0
- package/src/hold.test.ts +3 -3
- package/src/hold.ts +48 -44
- package/src/index.ts +19 -15
- package/src/mapCause.test.ts +34 -0
- package/src/mapCause.ts +16 -0
- package/src/mapEffect.test.ts +21 -0
- package/src/mapEffect.ts +17 -0
- package/src/merge.test.ts +10 -30
- package/src/merge.ts +17 -38
- package/src/multicast.test.ts +22 -28
- package/src/multicast.ts +71 -57
- package/src/orElse.test.ts +22 -0
- package/src/orElse.ts +21 -34
- package/src/periodic.test.ts +4 -4
- package/src/provide.test.ts +56 -0
- package/src/provide.ts +47 -36
- package/src/runCollect.ts +19 -0
- package/src/runDrain.ts +23 -0
- package/src/runObserve.ts +31 -0
- package/src/runReduce.ts +64 -0
- package/src/scheduled.ts +28 -26
- package/src/since.test.ts +40 -0
- package/src/since.ts +25 -42
- package/src/skipRepeats.test.ts +28 -0
- package/src/skipRepeats.ts +8 -9
- package/src/skipWhile.test.ts +44 -0
- package/src/skipWhile.ts +36 -22
- package/src/slice.test.ts +12 -10
- package/src/slice.ts +36 -42
- package/src/snapshot.test.ts +51 -0
- package/src/snapshot.ts +48 -37
- package/src/suspendSucceed.ts +2 -4
- package/src/switchMap.test.ts +23 -13
- package/src/switchMap.ts +32 -50
- package/src/takeWhile.test.ts +44 -0
- package/src/takeWhile.ts +20 -25
- package/src/tapEffect.ts +24 -0
- package/src/throttle.test.ts +5 -7
- package/src/throttle.ts +37 -42
- package/src/transform.ts +14 -6
- package/src/until.test.ts +8 -14
- package/src/until.ts +22 -32
- package/src/withEmitter.test.ts +28 -0
- package/src/withEmitter.ts +49 -0
- package/src/zip.test.ts +12 -13
- package/src/zip.ts +45 -52
- package/src/zipIterable.test.ts +19 -0
- package/src/zipIterable.ts +51 -0
- package/cjs/Sink.d.ts +0 -25
- package/cjs/Sink.d.ts.map +0 -1
- package/cjs/Sink.js +0 -66
- package/cjs/Sink.js.map +0 -1
- package/cjs/TSemaphore.d.ts +0 -4
- package/cjs/TSemaphore.d.ts.map +0 -1
- package/cjs/TSemaphore.js +0 -33
- package/cjs/TSemaphore.js.map +0 -1
- package/cjs/drain.d.ts +0 -7
- package/cjs/drain.d.ts.map +0 -1
- package/cjs/drain.js.map +0 -1
- package/cjs/empty.d.ts +0 -3
- package/cjs/empty.d.ts.map +0 -1
- package/cjs/empty.js +0 -9
- package/cjs/empty.js.map +0 -1
- package/cjs/from.d.ts +0 -11
- package/cjs/from.d.ts.map +0 -1
- package/cjs/from.js.map +0 -1
- package/cjs/fromCallback.d.ts.map +0 -1
- package/cjs/fromCallback.js.map +0 -1
- package/cjs/loop.d.ts +0 -4
- package/cjs/loop.d.ts.map +0 -1
- package/cjs/loop.js +0 -34
- package/cjs/loop.js.map +0 -1
- package/cjs/map.d.ts +0 -28
- package/cjs/map.d.ts.map +0 -1
- package/cjs/map.js.map +0 -1
- package/cjs/never.d.ts +0 -2
- package/cjs/never.d.ts.map +0 -1
- package/cjs/never.js.map +0 -1
- package/cjs/observe.d.ts +0 -7
- package/cjs/observe.d.ts.map +0 -1
- package/cjs/observe.js.map +0 -1
- package/cjs/reduce.d.ts +0 -7
- package/cjs/reduce.d.ts.map +0 -1
- package/cjs/reduce.js +0 -64
- package/cjs/reduce.js.map +0 -1
- package/cjs/takeUntil.d.ts +0 -4
- package/cjs/takeUntil.d.ts.map +0 -1
- package/cjs/takeUntil.js.map +0 -1
- package/cjs/tap.d.ts +0 -9
- package/cjs/tap.d.ts.map +0 -1
- package/cjs/tap.js +0 -54
- package/cjs/tap.js.map +0 -1
- package/cjs/zipItems.d.ts +0 -4
- package/cjs/zipItems.d.ts.map +0 -1
- package/cjs/zipItems.js.map +0 -1
- package/esm/Sink.d.ts +0 -25
- package/esm/Sink.d.ts.map +0 -1
- package/esm/Sink.js +0 -31
- package/esm/Sink.js.map +0 -1
- package/esm/TSemaphore.d.ts +0 -4
- package/esm/TSemaphore.d.ts.map +0 -1
- package/esm/TSemaphore.js +0 -5
- package/esm/TSemaphore.js.map +0 -1
- package/esm/drain.d.ts +0 -7
- package/esm/drain.d.ts.map +0 -1
- package/esm/drain.js +0 -12
- package/esm/drain.js.map +0 -1
- package/esm/empty.d.ts +0 -3
- package/esm/empty.d.ts.map +0 -1
- package/esm/empty.js +0 -5
- package/esm/empty.js.map +0 -1
- package/esm/from.d.ts +0 -11
- package/esm/from.d.ts.map +0 -1
- package/esm/from.js +0 -15
- package/esm/from.js.map +0 -1
- package/esm/fromCallback.d.ts.map +0 -1
- package/esm/fromCallback.js +0 -20
- package/esm/fromCallback.js.map +0 -1
- package/esm/loop.d.ts +0 -4
- package/esm/loop.d.ts.map +0 -1
- package/esm/loop.js +0 -29
- package/esm/loop.js.map +0 -1
- package/esm/map.d.ts +0 -28
- package/esm/map.d.ts.map +0 -1
- package/esm/map.js +0 -64
- package/esm/map.js.map +0 -1
- package/esm/never.d.ts +0 -2
- package/esm/never.d.ts.map +0 -1
- package/esm/never.js +0 -4
- package/esm/never.js.map +0 -1
- package/esm/observe.d.ts +0 -7
- package/esm/observe.d.ts.map +0 -1
- package/esm/observe.js +0 -12
- package/esm/observe.js.map +0 -1
- package/esm/reduce.d.ts +0 -7
- package/esm/reduce.d.ts.map +0 -1
- package/esm/reduce.js +0 -35
- package/esm/reduce.js.map +0 -1
- package/esm/takeUntil.d.ts +0 -4
- package/esm/takeUntil.d.ts.map +0 -1
- package/esm/takeUntil.js +0 -19
- package/esm/takeUntil.js.map +0 -1
- package/esm/tap.d.ts +0 -9
- package/esm/tap.d.ts.map +0 -1
- package/esm/tap.js +0 -23
- package/esm/tap.js.map +0 -1
- package/esm/zipItems.d.ts +0 -4
- package/esm/zipItems.d.ts.map +0 -1
- package/esm/zipItems.js +0 -23
- package/esm/zipItems.js.map +0 -1
- package/perf/filter-map-reduce.ts +0 -49
- package/perf/flatMap.ts +0 -48
- package/perf/switchMap.ts +0 -40
- package/src/Sink.ts +0 -84
- package/src/TSemaphore.ts +0 -8
- package/src/drain.ts +0 -21
- package/src/empty.ts +0 -5
- package/src/from.test.ts +0 -18
- package/src/from.ts +0 -18
- package/src/fromCallback.ts +0 -40
- package/src/loop.ts +0 -37
- package/src/map.ts +0 -83
- package/src/never.ts +0 -5
- package/src/observe.ts +0 -24
- package/src/reduce.ts +0 -81
- package/src/takeUntil.ts +0 -29
- package/src/tap.ts +0 -48
- package/src/zipItems.test.ts +0 -21
- package/src/zipItems.ts +0 -41
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import * as EffectStream from '@effect/core/Stream/Stream'
|
|
2
|
+
import { pipe } from '@fp-ts/data/Function'
|
|
3
|
+
import * as M from '@most/core'
|
|
4
|
+
import * as Chunk from '@tsplus/stdlib/collections/Chunk'
|
|
5
|
+
import * as rxjs from 'rxjs'
|
|
6
|
+
|
|
7
|
+
import {
|
|
8
|
+
array,
|
|
9
|
+
effectTsStreamTest,
|
|
10
|
+
fxEffectTest,
|
|
11
|
+
iterations,
|
|
12
|
+
mostStreamTest,
|
|
13
|
+
rxjsObservableTest,
|
|
14
|
+
} from '../_internal.js'
|
|
15
|
+
|
|
16
|
+
import * as Stream from '@/index.js'
|
|
17
|
+
|
|
18
|
+
const filterEvens = (x: number) => x % 2 === 0
|
|
19
|
+
const addOne = (x: number) => x + 1
|
|
20
|
+
const add = (x: number, y: number): number => x + y
|
|
21
|
+
|
|
22
|
+
export const name = 'filter -> map -> scan ' + iterations + ' integers'
|
|
23
|
+
|
|
24
|
+
export const cases = [
|
|
25
|
+
fxEffectTest(() =>
|
|
26
|
+
pipe(
|
|
27
|
+
Stream.fromIterable(array),
|
|
28
|
+
Stream.filter(filterEvens),
|
|
29
|
+
Stream.map(addOne),
|
|
30
|
+
Stream.runReduce(0, add),
|
|
31
|
+
),
|
|
32
|
+
),
|
|
33
|
+
mostStreamTest(() =>
|
|
34
|
+
pipe(M.periodic(0), M.withItems(array), M.filter(filterEvens), M.map(addOne), M.scan(add, 0)),
|
|
35
|
+
),
|
|
36
|
+
rxjsObservableTest(() =>
|
|
37
|
+
pipe(rxjs.from(array), rxjs.filter(filterEvens), rxjs.map(addOne), rxjs.scan(add, 0)),
|
|
38
|
+
),
|
|
39
|
+
|
|
40
|
+
effectTsStreamTest(() =>
|
|
41
|
+
pipe(
|
|
42
|
+
EffectStream.fromChunk(Chunk.from(array)),
|
|
43
|
+
EffectStream.filter(filterEvens),
|
|
44
|
+
EffectStream.map(addOne),
|
|
45
|
+
EffectStream.scan(0, add),
|
|
46
|
+
),
|
|
47
|
+
),
|
|
48
|
+
]
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import * as EffectStream from '@effect/core/Stream/Stream'
|
|
2
|
+
import { pipe } from '@fp-ts/data/Function'
|
|
3
|
+
import * as M from '@most/core'
|
|
4
|
+
import * as Chunk from '@tsplus/stdlib/collections/Chunk'
|
|
5
|
+
import * as rxjs from 'rxjs'
|
|
6
|
+
|
|
7
|
+
import {
|
|
8
|
+
array,
|
|
9
|
+
effectTsStreamTest,
|
|
10
|
+
fxTest,
|
|
11
|
+
iterations,
|
|
12
|
+
mostStreamTest,
|
|
13
|
+
rxjsObservableTest,
|
|
14
|
+
} from '../_internal.js'
|
|
15
|
+
|
|
16
|
+
import * as Stream from '@/index.js'
|
|
17
|
+
|
|
18
|
+
const nestedArray = array.map((x) => Array.from({ length: x }, (_, i) => x * 1000 + i))
|
|
19
|
+
|
|
20
|
+
const add = (x: number, y: number): number => x + y
|
|
21
|
+
|
|
22
|
+
export const name = 'flatMap ' + iterations + ' x ' + iterations + ' integers'
|
|
23
|
+
export const cases = [
|
|
24
|
+
fxTest(() =>
|
|
25
|
+
pipe(
|
|
26
|
+
Stream.fromIterable(nestedArray),
|
|
27
|
+
Stream.flatMap(Stream.fromIterable),
|
|
28
|
+
Stream.scan(0, add),
|
|
29
|
+
),
|
|
30
|
+
),
|
|
31
|
+
mostStreamTest(() =>
|
|
32
|
+
pipe(
|
|
33
|
+
M.periodic(0),
|
|
34
|
+
M.withItems(nestedArray),
|
|
35
|
+
M.chain((ns) => pipe(M.periodic(0), M.withItems(ns))),
|
|
36
|
+
M.scan(add, 0),
|
|
37
|
+
),
|
|
38
|
+
),
|
|
39
|
+
rxjsObservableTest(() =>
|
|
40
|
+
pipe(rxjs.from(nestedArray), rxjs.flatMap(rxjs.from), rxjs.scan(add, 0)),
|
|
41
|
+
),
|
|
42
|
+
effectTsStreamTest(() =>
|
|
43
|
+
pipe(
|
|
44
|
+
EffectStream.fromChunk(Chunk.from(nestedArray)),
|
|
45
|
+
EffectStream.flatMap((ns) => EffectStream.fromChunk(Chunk.from(ns))),
|
|
46
|
+
EffectStream.scan(0, add),
|
|
47
|
+
),
|
|
48
|
+
),
|
|
49
|
+
]
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { pipe } from '@fp-ts/data/Function'
|
|
2
|
+
import * as M from '@most/core'
|
|
3
|
+
import * as rxjs from 'rxjs'
|
|
4
|
+
|
|
5
|
+
import { array, fxTest, iterations, mostStreamTest, rxjsObservableTest } from '../_internal.js'
|
|
6
|
+
|
|
7
|
+
import * as Stream from '@/index.js'
|
|
8
|
+
|
|
9
|
+
const nestedArray = array.map((x) => Array.from({ length: x }, (_, i) => x * 1000 + i))
|
|
10
|
+
|
|
11
|
+
const add = (x: number, y: number): number => x + y
|
|
12
|
+
|
|
13
|
+
export const name = 'switchMap ' + iterations + ' x ' + iterations + ' integers'
|
|
14
|
+
|
|
15
|
+
export const cases = [
|
|
16
|
+
fxTest(() =>
|
|
17
|
+
pipe(
|
|
18
|
+
Stream.fromIterable(nestedArray),
|
|
19
|
+
Stream.switchMap(Stream.fromIterable),
|
|
20
|
+
Stream.scan(0, add),
|
|
21
|
+
),
|
|
22
|
+
),
|
|
23
|
+
mostStreamTest(() =>
|
|
24
|
+
pipe(
|
|
25
|
+
M.periodic(0),
|
|
26
|
+
M.withItems(nestedArray),
|
|
27
|
+
M.map((ns) => pipe(M.periodic(0), M.withItems(ns))),
|
|
28
|
+
M.switchLatest,
|
|
29
|
+
M.scan(add, 0),
|
|
30
|
+
),
|
|
31
|
+
),
|
|
32
|
+
rxjsObservableTest(() =>
|
|
33
|
+
pipe(rxjs.from(nestedArray), rxjs.switchMap(rxjs.from), rxjs.scan(add, 0)),
|
|
34
|
+
),
|
|
35
|
+
// Effect Stream is pull-based and does not offer switchMap
|
|
36
|
+
]
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
# Performance Tests
|
|
2
|
+
|
|
3
|
+
Here is the latest output of the perf test suite run on a 2020 13" macbook pro.
|
|
4
|
+
It is worth noting that all the tests utilize entirely synchronous workflows, and thus
|
|
5
|
+
have a great favoring towards Most.js/RxJS in terms of raw performance overhead.
|
|
6
|
+
|
|
7
|
+
If you need strict performance over push-based streams, definitely use Most.js, but if you are
|
|
8
|
+
interested in the superpowers of `Effect`, and are interested in using push-based streams as a means
|
|
9
|
+
of orchestration `Fx` is still a great bet as it won't often be your bottleneck.
|
|
10
|
+
|
|
11
|
+
If you need strict performance no matter what, none of these abstractions should be utilized at all.
|
|
12
|
+
|
|
13
|
+
## Test Results
|
|
14
|
+
|
package/perf/readme.md
ADDED
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
# Performance Tests
|
|
2
|
+
|
|
3
|
+
Here is the latest output of the perf test suite run on a 2020 13" macbook pro.
|
|
4
|
+
It is worth noting that all the tests utilize entirely synchronous workflows, and thus
|
|
5
|
+
have a great favoring towards Most.js/RxJS in terms of raw performance overhead.
|
|
6
|
+
|
|
7
|
+
If you need strict performance over push-based streams, definitely use Most.js, but if you are
|
|
8
|
+
interested in the superpowers of `Effect`, and are interested in using push-based streams as a means
|
|
9
|
+
of orchestration `Fx` is still a great bet as it won't often be your bottleneck.
|
|
10
|
+
|
|
11
|
+
If you need strict performance no matter what, none of these abstractions should be utilized at all.
|
|
12
|
+
|
|
13
|
+
## Test Results
|
|
14
|
+
|
|
15
|
+
### filter -> map -> scan 10000 integers
|
|
16
|
+
| Library | Ops/sec | ± | Samples |
|
|
17
|
+
| --------------|------------|--------|---------|
|
|
18
|
+
| Fx | 3801.43 | 5.81% | 82 |
|
|
19
|
+
| @most/core | 384094.58 | 12.96% | 64 |
|
|
20
|
+
| RxJS @7 | 2255.04 | 12.60% | 87 |
|
|
21
|
+
| Effect/Stream | 91.50 | 29.12% | 41 |
|
|
22
|
+
-------------------------------------------------------
|
|
23
|
+
|
|
24
|
+
### flatMap 10000 x 10000 integers
|
|
25
|
+
| Library | Ops/sec | ± | Samples |
|
|
26
|
+
| --------------|------------|--------|---------|
|
|
27
|
+
| Fx | 6474.91 | 11.85% | 76 |
|
|
28
|
+
| @most/core | 276654.02 | 19.33% | 46 |
|
|
29
|
+
| RxJS @7 | 10322.11 | 52.99% | 77 |
|
|
30
|
+
| Effect/Stream | 2.29 | 124.34% | 9 |
|
|
31
|
+
-------------------------------------------------------
|
|
32
|
+
|
|
33
|
+
### switchMap 10000 x 10000 integers
|
|
34
|
+
| Library | Ops/sec | ± | Samples |
|
|
35
|
+
| --------------|------------|--------|---------|
|
|
36
|
+
| Fx | 4759.84 | 13.52% | 63 |
|
|
37
|
+
| @most/core | 300663.64 | 14.57% | 55 |
|
|
38
|
+
| RxJS @7 | 16469.83 | 2.63% | 75 |
|
|
39
|
+
-------------------------------------------------------
|
|
40
|
+
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { spawnSync } from 'node:child_process'
|
|
2
|
+
import * as fs from 'node:fs'
|
|
3
|
+
import { basename, dirname, join } from 'node:path'
|
|
4
|
+
import { fileURLToPath } from 'node:url'
|
|
5
|
+
|
|
6
|
+
const currentDir = dirname(fileURLToPath(import.meta.url))
|
|
7
|
+
const casesDir = join(currentDir, '/cases')
|
|
8
|
+
|
|
9
|
+
export const runPerfTestPath = join(currentDir, 'runPerfTest.ts')
|
|
10
|
+
export const readmeBasePath = join(currentDir, 'readme-base.md')
|
|
11
|
+
export const readmePath = join(currentDir, 'readme.md')
|
|
12
|
+
export const fileNames = fs.readdirSync(casesDir).map((x) => basename(x))
|
|
13
|
+
|
|
14
|
+
let readmeContent = fs.readFileSync(readmeBasePath, 'utf-8').toString()
|
|
15
|
+
|
|
16
|
+
for (const fileName of fileNames) {
|
|
17
|
+
console.log('Running', 'cases/' + basename(fileName), '\n')
|
|
18
|
+
|
|
19
|
+
const { stdout } = spawnSync(`node`, [
|
|
20
|
+
`--loader`,
|
|
21
|
+
`@esbuild-kit/esm-loader`,
|
|
22
|
+
`${runPerfTestPath}`,
|
|
23
|
+
`${fileName}`,
|
|
24
|
+
])
|
|
25
|
+
|
|
26
|
+
const output = stdout.toString()
|
|
27
|
+
|
|
28
|
+
console.log(output)
|
|
29
|
+
|
|
30
|
+
readmeContent += output
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
if (fs.existsSync(readmePath)) {
|
|
34
|
+
fs.unlinkSync(readmePath)
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
fs.writeFileSync(readmePath, readmeContent)
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import process from 'node:process'
|
|
2
|
+
|
|
3
|
+
import { runPerformanceTest } from './_internal.js'
|
|
4
|
+
|
|
5
|
+
const fileName = process.argv.slice(2).filter((x) => x.trim() !== '--')[0]
|
|
6
|
+
|
|
7
|
+
async function main() {
|
|
8
|
+
const { name, cases } = await import(
|
|
9
|
+
`./cases/${fileName}${fileName.endsWith('.ts') ? '' : '.ts'}`
|
|
10
|
+
)
|
|
11
|
+
|
|
12
|
+
runPerformanceTest({ name, cases }, () => process.exit(0))
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
main().catch((error) => {
|
|
16
|
+
console.error(error)
|
|
17
|
+
process.exit(1)
|
|
18
|
+
})
|
package/perf/tsconfig.json
CHANGED
package/src/Fx.ts
CHANGED
|
@@ -1,18 +1,43 @@
|
|
|
1
|
+
import { Cause } from '@effect/core/io/Cause'
|
|
1
2
|
import * as Effect from '@effect/core/io/Effect'
|
|
3
|
+
import { Scope } from '@effect/core/io/Scope'
|
|
2
4
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
export interface Fx<R, E, A, E1 = never> {
|
|
6
|
-
readonly run: <R2, E2, B>(sink: Sink<E, A, R2, E2, B>) => Effect.Effect<R | R2, E1 | E2, B>
|
|
5
|
+
export interface Fx<R, E, A> {
|
|
6
|
+
run<R2>(emitter: Emitter<R2, E, A>): Effect.Effect<R | R2 | Scope, never, unknown>
|
|
7
7
|
}
|
|
8
8
|
|
|
9
|
-
export function Fx<R, E, A
|
|
10
|
-
return {
|
|
9
|
+
export function Fx<R, E, A>(run: Fx<R, E, A>['run']): Fx<R, E, A> {
|
|
10
|
+
return {
|
|
11
|
+
run,
|
|
12
|
+
}
|
|
11
13
|
}
|
|
12
14
|
|
|
13
15
|
export namespace Fx {
|
|
14
|
-
export type ResourcesOf<T> = T extends Fx<infer R, any, any
|
|
15
|
-
export type ErrorsOf<T> = T extends Fx<any, infer E, any
|
|
16
|
-
export type OutputOf<T> = T extends Fx<any, any, infer A
|
|
17
|
-
|
|
16
|
+
export type ResourcesOf<T> = T extends Fx<infer R, any, any> ? R : never
|
|
17
|
+
export type ErrorsOf<T> = T extends Fx<any, infer E, any> ? E : never
|
|
18
|
+
export type OutputOf<T> = T extends Fx<any, any, infer A> ? A : never
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export interface Emitter<R, E, A> {
|
|
22
|
+
readonly emit: (a: A) => Effect.Effect<R, never, unknown>
|
|
23
|
+
readonly failCause: (e: Cause<E>) => Effect.Effect<R, never, unknown>
|
|
24
|
+
readonly end: Effect.Effect<R, never, unknown>
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export function Emitter<R, E, A>(
|
|
28
|
+
emit: Emitter<R, E, A>['emit'],
|
|
29
|
+
failCause: Emitter<R, E, A>['failCause'],
|
|
30
|
+
end: Emitter<R, E, A>['end'],
|
|
31
|
+
): Emitter<R, E, A> {
|
|
32
|
+
return {
|
|
33
|
+
emit,
|
|
34
|
+
failCause,
|
|
35
|
+
end,
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export namespace Emitter {
|
|
40
|
+
export type ResourcesOf<T> = T extends Emitter<infer R, any, any> ? R : never
|
|
41
|
+
export type ErrorsOf<T> = T extends Emitter<any, infer E, any> ? E : never
|
|
42
|
+
export type OutputOf<T> = T extends Emitter<any, any, infer A> ? A : never
|
|
18
43
|
}
|
package/src/Subject.ts
ADDED
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import * as Effect from '@effect/core/io/Effect'
|
|
2
|
+
import * as Maybe from '@tsplus/stdlib/data/Maybe'
|
|
3
|
+
import { pipe } from 'node_modules/@fp-ts/data/Function.js'
|
|
4
|
+
import { LazyArg } from 'node_modules/@tsplus/stdlib/data/Function.js'
|
|
5
|
+
|
|
6
|
+
import { Emitter, Fx } from './Fx.js'
|
|
7
|
+
import { never } from './fromEffect.js'
|
|
8
|
+
import { Hold } from './hold.js'
|
|
9
|
+
import { Multicast } from './multicast.js'
|
|
10
|
+
|
|
11
|
+
export interface Subject<E, A> extends Emitter<never, E, A>, Fx<never, E, A> {}
|
|
12
|
+
|
|
13
|
+
export namespace Subject {
|
|
14
|
+
export const unsafeMake = <E, A>(): Subject<E, A> => new Multicast<never, E, A>(never)
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export interface HoldSubject<E, A> extends Subject<E, A> {
|
|
18
|
+
readonly get: Effect.Effect<never, never, Maybe.Maybe<A>>
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export namespace HoldSubject {
|
|
22
|
+
export const unsafeMake = <E, A>(): HoldSubject<E, A> => new Hold<never, E, A>(never)
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export interface BehaviorSubject<E, A> extends Subject<E, A> {
|
|
26
|
+
readonly get: Effect.Effect<never, never, A>
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export namespace BehaviorSubject {
|
|
30
|
+
export const unsafeMake = <E, A>(initial: LazyArg<A>): BehaviorSubject<E, A> => {
|
|
31
|
+
const hold = new Hold<never, E, A>(never)
|
|
32
|
+
|
|
33
|
+
// We're mutating a protected variable here to ensure an initial value is held.
|
|
34
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
35
|
+
// @ts-expect-error
|
|
36
|
+
hold._value = Maybe.some(initial())
|
|
37
|
+
|
|
38
|
+
return {
|
|
39
|
+
emit: hold.emit.bind(hold),
|
|
40
|
+
failCause: hold.failCause.bind(hold),
|
|
41
|
+
end: hold.end,
|
|
42
|
+
run: hold.run.bind(hold),
|
|
43
|
+
get: pipe(hold.get, Effect.map(Maybe.getOrElse(initial))),
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
package/src/_internal.ts
CHANGED
|
@@ -1,129 +1,74 @@
|
|
|
1
|
+
import {
|
|
2
|
+
CountdownLatch,
|
|
3
|
+
CountdownLatchInternal,
|
|
4
|
+
} from '@effect/core/concurrent/CountdownLatch/definition'
|
|
5
|
+
import * as Cause from '@effect/core/io/Cause'
|
|
1
6
|
import * as Deferred from '@effect/core/io/Deferred'
|
|
2
7
|
import * as Effect from '@effect/core/io/Effect'
|
|
3
|
-
import { Exit } from '@effect/core/io/Exit'
|
|
4
|
-
import * as Fiber from '@effect/core/io/Fiber'
|
|
5
8
|
import * as Ref from '@effect/core/io/Ref'
|
|
6
|
-
import * as Schedule from '@effect/core/io/Schedule'
|
|
7
9
|
import { pipe } from '@fp-ts/data/Function'
|
|
8
|
-
import * as
|
|
9
|
-
import { isSome } from '@tsplus/stdlib/data/Maybe'
|
|
10
|
+
import * as Maybe from '@tsplus/stdlib/data/Maybe'
|
|
10
11
|
|
|
11
|
-
export const
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
const ref = yield* $(Ref.makeSynchronized(() => initialCount))
|
|
17
|
-
const deferred = yield* $(Deferred.make<E, A>())
|
|
18
|
-
const increment = ref.update((a) => a + 1)
|
|
19
|
-
const decrement = ref.update((a) => Math.max(0, a - 1))
|
|
20
|
-
const refCount = ref.get
|
|
12
|
+
export const EARLY_EXIT_FAILURE = Symbol('EarlyExitFailure')
|
|
13
|
+
export interface EarlyExitFailure {
|
|
14
|
+
readonly sym: typeof EARLY_EXIT_FAILURE
|
|
15
|
+
}
|
|
16
|
+
export const EarlyExitFailure: EarlyExitFailure = { sym: EARLY_EXIT_FAILURE }
|
|
21
17
|
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
endIfComplete: <R>(effect: Effect.Effect<R, E, A>): Effect.Effect<R, never, void> =>
|
|
25
|
-
Effect.gen(function* ($) {
|
|
26
|
-
if ((yield* $(ended.get)) && (yield* $(refCount)) === 0) {
|
|
27
|
-
yield* $(pipe(effect, Effect.intoDeferred(deferred)))
|
|
28
|
-
}
|
|
29
|
-
}),
|
|
30
|
-
error: <R>(effect: Effect.Effect<R, E, A>): Effect.Effect<R, never, void> =>
|
|
31
|
-
Effect.gen(function* ($) {
|
|
32
|
-
yield* $(ended.set(true))
|
|
33
|
-
yield* $(pipe(effect, Effect.intoDeferred(deferred)))
|
|
34
|
-
}),
|
|
35
|
-
increment,
|
|
36
|
-
decrement,
|
|
37
|
-
refCount,
|
|
38
|
-
ended: ended.get,
|
|
39
|
-
end: ended.set(true),
|
|
40
|
-
}
|
|
41
|
-
})
|
|
18
|
+
export function isEarlyExitFailure(u: unknown): u is EarlyExitFailure {
|
|
19
|
+
return typeof u === 'object' && u !== null && (u as any).sym === EARLY_EXIT_FAILURE
|
|
42
20
|
}
|
|
43
21
|
|
|
44
|
-
export
|
|
45
|
-
f: (cb: (exit: Exit<E, A>) => Effect.Effect<never, never, never>) => Effect.Effect<R2, E2, A>,
|
|
46
|
-
): Effect.Effect<R2, E | E2, A> {
|
|
47
|
-
return Effect.scoped(
|
|
48
|
-
Effect.gen(function* ($) {
|
|
49
|
-
const deferred = yield* $(Deferred.make<E, A>())
|
|
50
|
-
const fiber = yield* $(
|
|
51
|
-
Effect.forkScoped(
|
|
52
|
-
f((exit) => {
|
|
53
|
-
deferred.unsafeDone(Effect.done(exit))
|
|
22
|
+
export const exitEarly = Effect.die(EarlyExitFailure)
|
|
54
23
|
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
24
|
+
export const onEarlyExitFailure =
|
|
25
|
+
<R2, E2, B>(handler: Effect.Effect<R2, E2, B>) =>
|
|
26
|
+
<R, E, A>(effect: Effect.Effect<R, E, A>): Effect.Effect<R | R2, E | E2, A | B> =>
|
|
27
|
+
pipe(
|
|
28
|
+
effect,
|
|
29
|
+
Effect.foldCauseEffect<E, A, R | R2, E | E2, A | B, R | R2, E | E2, A | B>(
|
|
30
|
+
(e) =>
|
|
31
|
+
pipe(
|
|
32
|
+
e,
|
|
33
|
+
Cause.dieMaybe,
|
|
34
|
+
Maybe.fold(
|
|
35
|
+
() => Effect.failCause(e),
|
|
36
|
+
(d) => (isEarlyExitFailure(d) ? handler : Effect.failCause(e)),
|
|
37
|
+
),
|
|
38
|
+
),
|
|
39
|
+
Effect.succeed,
|
|
40
|
+
),
|
|
41
|
+
)
|
|
59
42
|
|
|
60
|
-
|
|
43
|
+
/**
|
|
44
|
+
* A small wrapper around CountdownLatch which enables incrementing
|
|
45
|
+
* the latch count dynamically
|
|
46
|
+
*/
|
|
47
|
+
export type DynamicCountdownLatch = {
|
|
48
|
+
readonly increment: Effect.Effect<never, never, void>
|
|
49
|
+
readonly latch: CountdownLatch
|
|
50
|
+
}
|
|
61
51
|
|
|
62
|
-
|
|
63
|
-
|
|
52
|
+
export function makeDynamicCountdownLatch(
|
|
53
|
+
initialCount: number,
|
|
54
|
+
): Effect.Effect<never, never, DynamicCountdownLatch> {
|
|
55
|
+
return pipe(
|
|
56
|
+
Ref.makeRef<number>(() => initialCount),
|
|
57
|
+
Effect.zipWith(Deferred.make<never, void>(), (ref, deferred) => ({
|
|
58
|
+
increment: ref.update((x) => x + 1),
|
|
59
|
+
latch: new CountdownLatchInternal(ref, deferred),
|
|
60
|
+
})),
|
|
64
61
|
)
|
|
65
62
|
}
|
|
66
63
|
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
):
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
return result as unknown as { readonly [K in keyof Refs]: RefOutput<Refs[K]> }
|
|
80
|
-
})
|
|
81
|
-
|
|
82
|
-
const set = (a: { readonly [K in keyof Refs]: RefOutput<Refs[K]> }) =>
|
|
83
|
-
Effect.gen(function* ($) {
|
|
84
|
-
let i = 0
|
|
85
|
-
for (const ref of refs) {
|
|
86
|
-
yield* $(ref.set(a[i++]))
|
|
87
|
-
}
|
|
88
|
-
})
|
|
89
|
-
|
|
90
|
-
const tupledRef = {
|
|
91
|
-
[Ref.RefSym]: Ref.RefSym,
|
|
92
|
-
get,
|
|
93
|
-
set,
|
|
94
|
-
update: (f) =>
|
|
95
|
-
pipe(
|
|
96
|
-
get,
|
|
97
|
-
Effect.flatMap((a) => set(f(a))),
|
|
98
|
-
),
|
|
99
|
-
updateSome: (f) =>
|
|
100
|
-
pipe(
|
|
101
|
-
get,
|
|
102
|
-
Effect.map(f),
|
|
103
|
-
Effect.flatMap((a) => (isSome(a) ? set(a.value) : Effect.unit)),
|
|
104
|
-
),
|
|
105
|
-
modify: (f) =>
|
|
106
|
-
pipe(
|
|
107
|
-
get,
|
|
108
|
-
Effect.map(f),
|
|
109
|
-
Effect.flatMap(([b, a]) => pipe(a, set, Effect.as(b))),
|
|
110
|
-
),
|
|
111
|
-
modifySome: (fallback, f) =>
|
|
112
|
-
pipe(
|
|
113
|
-
get,
|
|
114
|
-
Effect.map(f),
|
|
115
|
-
Effect.flatMap((maybe) =>
|
|
116
|
-
isSome(maybe)
|
|
117
|
-
? pipe(maybe.value[1], set, Effect.as(maybe.value[0]))
|
|
118
|
-
: Effect.succeed(fallback),
|
|
119
|
-
),
|
|
120
|
-
),
|
|
121
|
-
getAndSet: (a) => pipe(get, Effect.zipLeft(set(a))),
|
|
122
|
-
getAndUpdate: (f) => pipe(get, Effect.zipLeft(tupledRef.update(f))),
|
|
123
|
-
getAndUpdateSome: (f) => pipe(get, Effect.zipLeft(tupledRef.updateSome(f))),
|
|
124
|
-
updateAndGet: (f) => pipe(tupledRef.update(f), Effect.zipRight(get)),
|
|
125
|
-
updateSomeAndGet: (f) => pipe(tupledRef.updateSome(f), Effect.zipRight(get)),
|
|
126
|
-
} as Ref.Ref<{ readonly [K in keyof Refs]: RefOutput<Refs[K]> }>
|
|
127
|
-
|
|
128
|
-
return tupledRef
|
|
64
|
+
export function withDynamicCountdownLatch<R, E, A, R2, E2, B>(
|
|
65
|
+
initialCount: number,
|
|
66
|
+
f: (latch: DynamicCountdownLatch) => Effect.Effect<R, E, A>,
|
|
67
|
+
onEnd: Effect.Effect<R2, E2, B>,
|
|
68
|
+
): Effect.Effect<R | R2, E | E2, B> {
|
|
69
|
+
return pipe(
|
|
70
|
+
makeDynamicCountdownLatch(initialCount),
|
|
71
|
+
Effect.tap(f),
|
|
72
|
+
Effect.flatMap(({ latch }) => pipe(latch.await, Effect.zipRight(onEnd))),
|
|
73
|
+
)
|
|
129
74
|
}
|
package/src/combine.test.ts
CHANGED
|
@@ -1,34 +1,33 @@
|
|
|
1
1
|
import { deepStrictEqual } from 'assert'
|
|
2
2
|
|
|
3
|
-
import
|
|
3
|
+
import * as Effect from '@effect/core/io/Effect'
|
|
4
4
|
import { pipe } from '@fp-ts/data/Function'
|
|
5
5
|
import * as Duration from '@tsplus/stdlib/data/Duration'
|
|
6
6
|
|
|
7
|
-
import
|
|
8
|
-
import { delay } from './delay.js'
|
|
9
|
-
import { flatMap } from './flatMap.js'
|
|
10
|
-
import { from } from './from.js'
|
|
11
|
-
import { collectAll } from './reduce.js'
|
|
7
|
+
import * as Fx from './index.js'
|
|
12
8
|
|
|
13
9
|
describe(import.meta.url, () => {
|
|
14
10
|
describe('combine', () => {
|
|
15
11
|
it('combines 2 fx together', async () => {
|
|
16
12
|
const values = [1, 2, 3]
|
|
17
13
|
const test = pipe(
|
|
18
|
-
|
|
19
|
-
flatMap((a) =>
|
|
20
|
-
pipe(
|
|
14
|
+
Fx.fromIterable(values),
|
|
15
|
+
Fx.flatMap((a) =>
|
|
16
|
+
pipe(
|
|
17
|
+
Fx.fromIterable([a, a + 1]),
|
|
18
|
+
Fx.combine(pipe(Fx.fromIterable([a * a, a ** a]), Fx.delay(Duration.millis(10)))),
|
|
19
|
+
),
|
|
21
20
|
),
|
|
22
21
|
)
|
|
23
|
-
const events = await pipe(test,
|
|
22
|
+
const events = await pipe(test, Fx.runCollect, Effect.unsafeRunPromise)
|
|
24
23
|
|
|
25
24
|
deepStrictEqual(events, [
|
|
26
|
-
[
|
|
27
|
-
[
|
|
28
|
-
[
|
|
29
|
-
[
|
|
30
|
-
[
|
|
31
|
-
[
|
|
25
|
+
[1 + 1, 1 * 1],
|
|
26
|
+
[2 + 1, 2 * 2],
|
|
27
|
+
[3 + 1, 3 * 3],
|
|
28
|
+
[1 + 1, 1 ** 1],
|
|
29
|
+
[2 + 1, 2 ** 2],
|
|
30
|
+
[3 + 1, 3 ** 3],
|
|
32
31
|
])
|
|
33
32
|
})
|
|
34
33
|
})
|