@fncts/io 0.0.12 → 0.0.15
Sign up to get free protection for your applications and to get access to all the features.
- package/Cached/api.d.ts +3 -4
- package/Channel/UpstreamPullStrategy/definition.d.ts +1 -1
- package/Channel/api/interruptWhen.d.ts +1 -1
- package/Channel/api/mapOutIOC.d.ts +2 -2
- package/Channel/api/mergeAll.d.ts +1 -1
- package/Channel/api/mergeAllUnboundedWith.d.ts +1 -1
- package/Channel/api/mergeAllWith.d.ts +3 -3
- package/Channel/api/mergeMap.d.ts +1 -1
- package/Channel/api/mergeWith.d.ts +3 -3
- package/Channel/api/runScoped.d.ts +1 -2
- package/Channel/api/toPull.d.ts +2 -3
- package/Channel/api/zipC.d.ts +3 -3
- package/Channel/api.d.ts +56 -57
- package/Channel/core-api.d.ts +12 -12
- package/Channel/definition.d.ts +36 -22
- package/Channel/internal/AsyncInputConsumer.d.ts +1 -1
- package/Channel/internal/AsyncInputProducer.d.ts +1 -1
- package/Channel/internal/ChannelExecutor.d.ts +5 -5
- package/Channel/internal/ChannelState.d.ts +1 -1
- package/Channel/internal/MergeDecision.d.ts +2 -2
- package/Channel/internal/MergeState.d.ts +2 -2
- package/Channel/internal/SingleProducerAsyncInput.d.ts +5 -5
- package/Clock/api.d.ts +3 -3
- package/Clock/definition.d.ts +2 -2
- package/Clock/live.d.ts +3 -3
- package/Console/api.d.ts +1 -1
- package/Fiber/FiberContext.d.ts +12 -12
- package/Fiber/api/await.d.ts +2 -2
- package/Fiber/api/awaitAll.d.ts +2 -2
- package/Fiber/api/children.d.ts +1 -1
- package/Fiber/api/collectAll.d.ts +3 -3
- package/Fiber/api/evalOn.d.ts +1 -1
- package/Fiber/api/evalOnIO.d.ts +1 -1
- package/Fiber/api/fromIO.d.ts +1 -1
- package/Fiber/api/id.d.ts +2 -2
- package/Fiber/api/inheritRefs.d.ts +1 -1
- package/Fiber/api/interrupt.d.ts +2 -2
- package/Fiber/api/interruptAll.d.ts +3 -3
- package/Fiber/api/interruptAs.d.ts +3 -3
- package/Fiber/api/join.d.ts +1 -1
- package/Fiber/api/joinAll.d.ts +1 -1
- package/Fiber/api/mapFiber.d.ts +1 -1
- package/Fiber/api/mapIO.d.ts +2 -2
- package/Fiber/api/poll.d.ts +3 -3
- package/Fiber/api/zipWith.d.ts +1 -1
- package/Fiber/constructors.d.ts +8 -8
- package/Fiber/definition.d.ts +4 -4
- package/FiberRef/api/locallyScoped.d.ts +1 -2
- package/FiberRef/api/locallyScopedWith.d.ts +1 -2
- package/FiberRef/api.d.ts +8 -8
- package/FiberRef/constructors.d.ts +2 -3
- package/FiberRef/unsafe.d.ts +11 -5
- package/FiberRefs/api.d.ts +4 -4
- package/FiberRefs/definition.d.ts +3 -3
- package/FiberRefs/join.d.ts +2 -2
- package/FiberScope/constructors.d.ts +1 -1
- package/FiberScope/definition.d.ts +1 -1
- package/FiberState/api.d.ts +1 -1
- package/FiberState/constructors.d.ts +3 -3
- package/FiberState/definition.d.ts +3 -3
- package/FiberStatus/constructors.d.ts +1 -1
- package/FiberStatus/definition.d.ts +1 -1
- package/Future/api.d.ts +18 -18
- package/Future/constructors.d.ts +3 -3
- package/Future/definition.d.ts +2 -2
- package/Hub/api.d.ts +22 -23
- package/Hub/definition.d.ts +6 -7
- package/Hub/internal.d.ts +1 -2
- package/IO/api/acquireRelease.d.ts +2 -3
- package/IO/api/acquireReleaseExit.d.ts +3 -4
- package/IO/api/acquireReleaseInterruptible.d.ts +2 -3
- package/IO/api/acquireReleaseInterruptibleExit.d.ts +3 -4
- package/IO/api/addFinalizer.d.ts +2 -3
- package/IO/api/addFinalizerExit.d.ts +2 -3
- package/IO/api/asyncIO.d.ts +1 -1
- package/IO/api/bracket.d.ts +2 -2
- package/IO/api/bracketExit.d.ts +3 -3
- package/IO/api/clockWith.d.ts +1 -1
- package/IO/api/concurrency.d.ts +4 -4
- package/IO/api/concurrentFinalizers.d.ts +1 -2
- package/IO/api/consoleWith.d.ts +2 -2
- package/IO/api/core-scope.d.ts +4 -4
- package/IO/api/ensuringChildren.d.ts +1 -1
- package/IO/api/environment.d.ts +10 -12
- package/IO/api/foreachC.d.ts +2 -2
- package/IO/api/foreachExec.d.ts +1 -1
- package/IO/api/forkScoped.d.ts +1 -2
- package/IO/api/fulfill.d.ts +1 -1
- package/IO/api/interrupt.d.ts +8 -8
- package/IO/api/onExit.d.ts +2 -2
- package/IO/api/onTermination.d.ts +4 -4
- package/IO/api/provideLayer.d.ts +1 -1
- package/IO/api/provideSomeLayer.d.ts +1 -1
- package/IO/api/race.d.ts +1 -1
- package/IO/api/raceFirst.d.ts +1 -1
- package/IO/api/randomWith.d.ts +2 -2
- package/IO/api/repeat.d.ts +6 -6
- package/IO/api/retry.d.ts +5 -5
- package/IO/api/schedule.d.ts +3 -3
- package/IO/api/scope.d.ts +1 -2
- package/IO/api/scopeWith.d.ts +1 -2
- package/IO/api/scoped.d.ts +3 -4
- package/IO/api/sequenceT.d.ts +4 -4
- package/IO/api/sleep.d.ts +2 -2
- package/IO/api/stateful.d.ts +3 -4
- package/IO/api/timeout.d.ts +4 -4
- package/IO/api/withEarlyRelease.d.ts +1 -2
- package/IO/api/withFinalizer.d.ts +1 -2
- package/IO/api/withFinalizerExit.d.ts +2 -3
- package/IO/api/withRuntimeConfig.d.ts +2 -2
- package/IO/api/zipC.d.ts +4 -4
- package/IO/api.d.ts +94 -94
- package/IO/definition.d.ts +44 -34
- package/IO/runtime.d.ts +23 -17
- package/IOEnv/definition.d.ts +2 -3
- package/IOEnv/live.d.ts +1 -1
- package/IOEnv/services.d.ts +1 -1
- package/IOSpec.d.ts +7 -8
- package/Layer/MemoMap.d.ts +8 -9
- package/Layer/api.d.ts +41 -43
- package/Layer/definition.d.ts +22 -16
- package/Logger/api.d.ts +2 -2
- package/Logger/definition.d.ts +4 -4
- package/Queue/api/dimapIO.d.ts +6 -6
- package/Queue/api/filterInputIO.d.ts +6 -6
- package/Queue/api/filterOutputIO.d.ts +8 -8
- package/Queue/api/operations.d.ts +10 -10
- package/Queue/api/poll.d.ts +2 -2
- package/Queue/api/takeBetween.d.ts +1 -1
- package/Queue/api/zipWithIO.d.ts +9 -9
- package/Queue/constructors.d.ts +4 -4
- package/Queue/definition.d.ts +10 -10
- package/Queue/internal.d.ts +1 -1
- package/Queue/strategy.d.ts +10 -10
- package/Random/api.d.ts +8 -8
- package/Random/definition.d.ts +5 -5
- package/Random/live.d.ts +5 -5
- package/Ref/Atomic/Atomic.d.ts +4 -4
- package/Ref/Atomic/api.d.ts +11 -11
- package/Ref/Derived.d.ts +4 -4
- package/Ref/DerivedAll.d.ts +4 -4
- package/Ref/Synchronized/api.d.ts +16 -16
- package/Ref/Synchronized/constructors.d.ts +2 -2
- package/Ref/Synchronized/definition.d.ts +3 -3
- package/Ref/api/collect.d.ts +2 -2
- package/Ref/api/dimap.d.ts +8 -8
- package/Ref/api/filter.d.ts +3 -3
- package/Ref/api/get.d.ts +1 -1
- package/Ref/api/match.d.ts +1 -1
- package/Ref/api/matchAll.d.ts +1 -1
- package/Ref/api/modify.d.ts +10 -10
- package/Ref/api/set.d.ts +1 -1
- package/Ref/constructors.d.ts +3 -3
- package/Ref/definition.d.ts +15 -15
- package/RuntimeConfig.d.ts +2 -2
- package/STM/api/core-api.d.ts +5 -5
- package/STM/api/core-constructors.d.ts +9 -9
- package/STM/api.d.ts +60 -72
- package/STM/definition.d.ts +10 -9
- package/STM/driver.d.ts +2 -2
- package/STM/internal/CommitState.d.ts +1 -1
- package/STM/internal/Journal.d.ts +7 -6
- package/STM/internal/TryCommit.d.ts +1 -1
- package/Schedule/Decision.d.ts +10 -4
- package/Schedule/Driver.d.ts +4 -4
- package/Schedule/api/driver.d.ts +1 -1
- package/Schedule/api.d.ts +85 -73
- package/Schedule/definition.d.ts +1 -1
- package/Scope/Finalizer/definition.d.ts +3 -3
- package/Scope/ReleaseMap/api/releaseAll.d.ts +2 -2
- package/Scope/ReleaseMap/api.d.ts +7 -7
- package/Scope/ReleaseMap/definition.d.ts +3 -3
- package/Scope/api.d.ts +9 -10
- package/Scope/definition.d.ts +2 -2
- package/ScopedRef/api.d.ts +2 -3
- package/ScopedRef/definition.d.ts +1 -2
- package/Sink/api.d.ts +73 -74
- package/State/api.d.ts +2 -3
- package/Stream/api/zipAllWith.d.ts +3 -3
- package/Stream/api/zipWith.d.ts +1 -1
- package/Stream/api/zipWithChunks.d.ts +4 -4
- package/Stream/api.d.ts +171 -166
- package/Stream/definition.d.ts +3 -3
- package/Stream/internal/Handoff.d.ts +2 -2
- package/Stream/internal/Pull.d.ts +2 -2
- package/Stream/internal/Take.d.ts +4 -4
- package/Stream/internal/util.d.ts +1 -1
- package/Supervisor/api.d.ts +3 -3
- package/Supervisor/constructors.d.ts +6 -6
- package/Supervisor/definition.d.ts +3 -3
- package/TExit/constructors.d.ts +1 -1
- package/TExit/definition.d.ts +1 -1
- package/TFuture/api.d.ts +7 -7
- package/TFuture/constructors.d.ts +4 -4
- package/TFuture/definition.d.ts +3 -3
- package/TReentrantLock/api.d.ts +18 -19
- package/TReentrantLock/definition.d.ts +2 -2
- package/TRef/api.d.ts +15 -15
- package/TRef/constructors.d.ts +5 -5
- package/TRef/definition.d.ts +2 -2
- package/TSemaphore/api.d.ts +7 -7
- package/TSemaphore/constructors.d.ts +1 -1
- package/TSemaphore/definition.d.ts +1 -1
- package/_cjs/Cached/api.cjs +5 -5
- package/_cjs/Cached/api.cjs.map +1 -1
- package/_cjs/Channel/api/interruptWhen.cjs +1 -1
- package/_cjs/Channel/api/interruptWhen.cjs.map +1 -1
- package/_cjs/Channel/api/mapOutIOC.cjs +2 -2
- package/_cjs/Channel/api/mapOutIOC.cjs.map +1 -1
- package/_cjs/Channel/api/mergeAllWith.cjs +11 -11
- package/_cjs/Channel/api/mergeAllWith.cjs.map +1 -1
- package/_cjs/Channel/api/mergeWith.cjs +5 -5
- package/_cjs/Channel/api/mergeWith.cjs.map +1 -1
- package/_cjs/Channel/api/run.cjs +3 -1
- package/_cjs/Channel/api/run.cjs.map +1 -1
- package/_cjs/Channel/api.cjs +7 -7
- package/_cjs/Channel/api.cjs.map +1 -1
- package/_cjs/Channel/core-api.cjs.map +1 -1
- package/_cjs/Channel/definition.cjs.map +1 -1
- package/_cjs/Channel/internal/ChannelExecutor.cjs +6 -6
- package/_cjs/Channel/internal/ChannelExecutor.cjs.map +1 -1
- package/_cjs/Channel/internal/ChannelState.cjs +2 -1
- package/_cjs/Channel/internal/ChannelState.cjs.map +1 -1
- package/_cjs/Channel/internal/SingleProducerAsyncInput.cjs +16 -16
- package/_cjs/Channel/internal/SingleProducerAsyncInput.cjs.map +1 -1
- package/_cjs/Clock/live.cjs.map +1 -1
- package/_cjs/Console/api.cjs +5 -3
- package/_cjs/Console/api.cjs.map +1 -1
- package/_cjs/Fiber/FiberContext.cjs +8 -10
- package/_cjs/Fiber/FiberContext.cjs.map +1 -1
- package/_cjs/Fiber/api/await.cjs +1 -1
- package/_cjs/Fiber/api/await.cjs.map +1 -1
- package/_cjs/Fiber/api/awaitAll.cjs +2 -4
- package/_cjs/Fiber/api/awaitAll.cjs.map +1 -1
- package/_cjs/Fiber/api/children.cjs +1 -1
- package/_cjs/Fiber/api/children.cjs.map +1 -1
- package/_cjs/Fiber/api/collectAll.cjs +2 -4
- package/_cjs/Fiber/api/collectAll.cjs.map +1 -1
- package/_cjs/Fiber/api/evalOn.cjs +1 -1
- package/_cjs/Fiber/api/evalOn.cjs.map +1 -1
- package/_cjs/Fiber/api/evalOnIO.cjs +2 -4
- package/_cjs/Fiber/api/evalOnIO.cjs.map +1 -1
- package/_cjs/Fiber/api/fromIO.cjs +2 -4
- package/_cjs/Fiber/api/fromIO.cjs.map +1 -1
- package/_cjs/Fiber/api/id.cjs +1 -1
- package/_cjs/Fiber/api/id.cjs.map +1 -1
- package/_cjs/Fiber/api/inheritRefs.cjs +1 -1
- package/_cjs/Fiber/api/inheritRefs.cjs.map +1 -1
- package/_cjs/Fiber/api/interrupt.cjs +2 -4
- package/_cjs/Fiber/api/interrupt.cjs.map +1 -1
- package/_cjs/Fiber/api/interruptAll.cjs +4 -5
- package/_cjs/Fiber/api/interruptAll.cjs.map +1 -1
- package/_cjs/Fiber/api/interruptAs.cjs +1 -1
- package/_cjs/Fiber/api/interruptAs.cjs.map +1 -1
- package/_cjs/Fiber/api/interruptFork.cjs +1 -1
- package/_cjs/Fiber/api/interruptFork.cjs.map +1 -1
- package/_cjs/Fiber/api/join.cjs +2 -4
- package/_cjs/Fiber/api/join.cjs.map +1 -1
- package/_cjs/Fiber/api/joinAll.cjs +2 -4
- package/_cjs/Fiber/api/joinAll.cjs.map +1 -1
- package/_cjs/Fiber/api/mapFiber.cjs +2 -4
- package/_cjs/Fiber/api/mapFiber.cjs.map +1 -1
- package/_cjs/Fiber/api/mapIO.cjs +4 -5
- package/_cjs/Fiber/api/mapIO.cjs.map +1 -1
- package/_cjs/Fiber/api/poll.cjs +1 -1
- package/_cjs/Fiber/api/poll.cjs.map +1 -1
- package/_cjs/Fiber/api/zipWith.cjs +2 -4
- package/_cjs/Fiber/api/zipWith.cjs.map +1 -1
- package/_cjs/Fiber/constructors.cjs +10 -11
- package/_cjs/Fiber/constructors.cjs.map +1 -1
- package/_cjs/FiberRef/api/locallyScoped.cjs +2 -4
- package/_cjs/FiberRef/api/locallyScoped.cjs.map +1 -1
- package/_cjs/FiberRef/api/locallyScopedWith.cjs +2 -4
- package/_cjs/FiberRef/api/locallyScopedWith.cjs.map +1 -1
- package/_cjs/FiberRef/api.cjs +13 -14
- package/_cjs/FiberRef/api.cjs.map +1 -1
- package/_cjs/FiberRef/constructors.cjs +4 -6
- package/_cjs/FiberRef/constructors.cjs.map +1 -1
- package/_cjs/FiberRef/unsafe.cjs +9 -1
- package/_cjs/FiberRef/unsafe.cjs.map +1 -1
- package/_cjs/Future/api.cjs +30 -31
- package/_cjs/Future/api.cjs.map +1 -1
- package/_cjs/Future/constructors.cjs +4 -5
- package/_cjs/Future/constructors.cjs.map +1 -1
- package/_cjs/Hub/api.cjs +44 -44
- package/_cjs/Hub/api.cjs.map +1 -1
- package/_cjs/Hub/internal.cjs +16 -24
- package/_cjs/Hub/internal.cjs.map +1 -1
- package/_cjs/IO/api/acquireRelease.cjs +2 -4
- package/_cjs/IO/api/acquireRelease.cjs.map +1 -1
- package/_cjs/IO/api/acquireReleaseExit.cjs +1 -1
- package/_cjs/IO/api/acquireReleaseExit.cjs.map +1 -1
- package/_cjs/IO/api/acquireReleaseInterruptibleExit.cjs +1 -1
- package/_cjs/IO/api/acquireReleaseInterruptibleExit.cjs.map +1 -1
- package/_cjs/IO/api/addFinalizer.cjs +1 -1
- package/_cjs/IO/api/addFinalizer.cjs.map +1 -1
- package/_cjs/IO/api/addFinalizerExit.cjs +5 -11
- package/_cjs/IO/api/addFinalizerExit.cjs.map +1 -1
- package/_cjs/IO/api/asyncIO.cjs +5 -7
- package/_cjs/IO/api/asyncIO.cjs.map +1 -1
- package/_cjs/IO/api/bracket.cjs +2 -2
- package/_cjs/IO/api/bracket.cjs.map +1 -1
- package/_cjs/IO/api/bracketExit.cjs +2 -4
- package/_cjs/IO/api/bracketExit.cjs.map +1 -1
- package/_cjs/IO/api/concurrency.cjs +7 -7
- package/_cjs/IO/api/concurrency.cjs.map +1 -1
- package/_cjs/IO/api/concurrentFinalizers.cjs +2 -4
- package/_cjs/IO/api/concurrentFinalizers.cjs.map +1 -1
- package/_cjs/IO/api/consoleWith.cjs +3 -3
- package/_cjs/IO/api/consoleWith.cjs.map +1 -1
- package/_cjs/IO/api/core-scope.cjs +4 -4
- package/_cjs/IO/api/core-scope.cjs.map +1 -1
- package/_cjs/IO/api/ensuringChildren.cjs +2 -4
- package/_cjs/IO/api/ensuringChildren.cjs.map +1 -1
- package/_cjs/IO/api/environment.cjs +6 -8
- package/_cjs/IO/api/environment.cjs.map +1 -1
- package/_cjs/IO/api/foreachC.cjs +25 -27
- package/_cjs/IO/api/foreachC.cjs.map +1 -1
- package/_cjs/IO/api/foreachExec.cjs +2 -4
- package/_cjs/IO/api/foreachExec.cjs.map +1 -1
- package/_cjs/IO/api/forkIn.cjs +1 -1
- package/_cjs/IO/api/forkIn.cjs.map +1 -1
- package/_cjs/IO/api/forkScoped.cjs +1 -1
- package/_cjs/IO/api/forkScoped.cjs.map +1 -1
- package/_cjs/IO/api/fulfill.cjs +2 -4
- package/_cjs/IO/api/fulfill.cjs.map +1 -1
- package/_cjs/IO/api/interrupt.cjs +13 -13
- package/_cjs/IO/api/interrupt.cjs.map +1 -1
- package/_cjs/IO/api/memoize.cjs +4 -8
- package/_cjs/IO/api/memoize.cjs.map +1 -1
- package/_cjs/IO/api/onExit.cjs +2 -2
- package/_cjs/IO/api/onExit.cjs.map +1 -1
- package/_cjs/IO/api/onTermination.cjs +2 -2
- package/_cjs/IO/api/onTermination.cjs.map +1 -1
- package/_cjs/IO/api/once.cjs +1 -1
- package/_cjs/IO/api/once.cjs.map +1 -1
- package/_cjs/IO/api/provideLayer.cjs +2 -4
- package/_cjs/IO/api/provideLayer.cjs.map +1 -1
- package/_cjs/IO/api/provideSomeLayer.cjs +2 -3
- package/_cjs/IO/api/provideSomeLayer.cjs.map +1 -1
- package/_cjs/IO/api/race.cjs +4 -6
- package/_cjs/IO/api/race.cjs.map +1 -1
- package/_cjs/IO/api/raceFirst.cjs +2 -4
- package/_cjs/IO/api/raceFirst.cjs.map +1 -1
- package/_cjs/IO/api/randomWith.cjs +3 -3
- package/_cjs/IO/api/randomWith.cjs.map +1 -1
- package/_cjs/IO/api/repeat.cjs +10 -11
- package/_cjs/IO/api/repeat.cjs.map +1 -1
- package/_cjs/IO/api/retry.cjs +8 -9
- package/_cjs/IO/api/retry.cjs.map +1 -1
- package/_cjs/IO/api/schedule.cjs +6 -7
- package/_cjs/IO/api/schedule.cjs.map +1 -1
- package/_cjs/IO/api/scope.cjs +1 -1
- package/_cjs/IO/api/scope.cjs.map +1 -1
- package/_cjs/IO/api/scopeWith.cjs +2 -4
- package/_cjs/IO/api/scopeWith.cjs.map +1 -1
- package/_cjs/IO/api/scoped.cjs +4 -5
- package/_cjs/IO/api/scoped.cjs.map +1 -1
- package/_cjs/IO/api/stateful.cjs +1 -1
- package/_cjs/IO/api/stateful.cjs.map +1 -1
- package/_cjs/IO/api/timeout.cjs +3 -4
- package/_cjs/IO/api/timeout.cjs.map +1 -1
- package/_cjs/IO/api/withChildren.cjs +1 -1
- package/_cjs/IO/api/withChildren.cjs.map +1 -1
- package/_cjs/IO/api/withEarlyRelease.cjs +2 -4
- package/_cjs/IO/api/withEarlyRelease.cjs.map +1 -1
- package/_cjs/IO/api/withFinalizer.cjs +2 -2
- package/_cjs/IO/api/withFinalizer.cjs.map +1 -1
- package/_cjs/IO/api/withFinalizerExit.cjs +2 -4
- package/_cjs/IO/api/withFinalizerExit.cjs.map +1 -1
- package/_cjs/IO/api/withRuntimeConfig.cjs +2 -4
- package/_cjs/IO/api/withRuntimeConfig.cjs.map +1 -1
- package/_cjs/IO/api/zipC.cjs +5 -6
- package/_cjs/IO/api/zipC.cjs.map +1 -1
- package/_cjs/IO/api.cjs +112 -112
- package/_cjs/IO/api.cjs.map +1 -1
- package/_cjs/IO/definition.cjs +5 -8
- package/_cjs/IO/definition.cjs.map +1 -1
- package/_cjs/IO/runtime.cjs +57 -20
- package/_cjs/IO/runtime.cjs.map +1 -1
- package/_cjs/IOEnv/live.cjs +3 -1
- package/_cjs/IOEnv/live.cjs.map +1 -1
- package/_cjs/Layer/MemoMap.cjs +45 -62
- package/_cjs/Layer/MemoMap.cjs.map +1 -1
- package/_cjs/Layer/api.cjs +84 -83
- package/_cjs/Layer/api.cjs.map +1 -1
- package/_cjs/Layer/definition.cjs +14 -7
- package/_cjs/Layer/definition.cjs.map +1 -1
- package/_cjs/Queue/api/dimapIO.cjs +14 -14
- package/_cjs/Queue/api/dimapIO.cjs.map +1 -1
- package/_cjs/Queue/api/filterInputIO.cjs +6 -6
- package/_cjs/Queue/api/filterInputIO.cjs.map +1 -1
- package/_cjs/Queue/api/filterOutputIO.cjs +6 -6
- package/_cjs/Queue/api/filterOutputIO.cjs.map +1 -1
- package/_cjs/Queue/api/operations.cjs +13 -13
- package/_cjs/Queue/api/operations.cjs.map +1 -1
- package/_cjs/Queue/api/poll.cjs +2 -4
- package/_cjs/Queue/api/poll.cjs.map +1 -1
- package/_cjs/Queue/api/takeBetween.cjs +10 -12
- package/_cjs/Queue/api/takeBetween.cjs.map +1 -1
- package/_cjs/Queue/api/zipWithIO.cjs +12 -12
- package/_cjs/Queue/api/zipWithIO.cjs.map +1 -1
- package/_cjs/Queue/constructors.cjs +8 -10
- package/_cjs/Queue/constructors.cjs.map +1 -1
- package/_cjs/Queue/internal.cjs +17 -17
- package/_cjs/Queue/internal.cjs.map +1 -1
- package/_cjs/Queue/strategy.cjs +16 -20
- package/_cjs/Queue/strategy.cjs.map +1 -1
- package/_cjs/Random/api.cjs +15 -13
- package/_cjs/Random/api.cjs.map +1 -1
- package/_cjs/Random/live.cjs +4 -4
- package/_cjs/Random/live.cjs.map +1 -1
- package/_cjs/Ref/Atomic/Atomic.cjs.map +1 -1
- package/_cjs/Ref/Atomic/api.cjs +19 -21
- package/_cjs/Ref/Atomic/api.cjs.map +1 -1
- package/_cjs/Ref/Derived.cjs.map +1 -1
- package/_cjs/Ref/DerivedAll.cjs +1 -1
- package/_cjs/Ref/DerivedAll.cjs.map +1 -1
- package/_cjs/Ref/Synchronized/api.cjs +25 -26
- package/_cjs/Ref/Synchronized/api.cjs.map +1 -1
- package/_cjs/Ref/Synchronized/constructors.cjs +8 -14
- package/_cjs/Ref/Synchronized/constructors.cjs.map +1 -1
- package/_cjs/Ref/Synchronized/definition.cjs +1 -1
- package/_cjs/Ref/Synchronized/definition.cjs.map +1 -1
- package/_cjs/Ref/api/collect.cjs +1 -1
- package/_cjs/Ref/api/collect.cjs.map +1 -1
- package/_cjs/Ref/api/dimap.cjs +12 -12
- package/_cjs/Ref/api/dimap.cjs.map +1 -1
- package/_cjs/Ref/api/filter.cjs +2 -2
- package/_cjs/Ref/api/filter.cjs.map +1 -1
- package/_cjs/Ref/api/get.cjs +1 -1
- package/_cjs/Ref/api/get.cjs.map +1 -1
- package/_cjs/Ref/api/modify.cjs +29 -30
- package/_cjs/Ref/api/modify.cjs.map +1 -1
- package/_cjs/Ref/api/set.cjs +1 -1
- package/_cjs/Ref/api/set.cjs.map +1 -1
- package/_cjs/Ref/constructors.cjs +3 -4
- package/_cjs/Ref/constructors.cjs.map +1 -1
- package/_cjs/STM/api/core-api.cjs +8 -8
- package/_cjs/STM/api/core-api.cjs.map +1 -1
- package/_cjs/STM/api/core-constructors.cjs +6 -6
- package/_cjs/STM/api/core-constructors.cjs.map +1 -1
- package/_cjs/STM/api.cjs +129 -148
- package/_cjs/STM/api.cjs.map +1 -1
- package/_cjs/STM/definition.cjs.map +1 -1
- package/_cjs/STM/driver.cjs +10 -6
- package/_cjs/STM/driver.cjs.map +1 -1
- package/_cjs/STM/internal/Journal.cjs +20 -22
- package/_cjs/STM/internal/Journal.cjs.map +1 -1
- package/_cjs/Schedule/Decision.cjs +17 -0
- package/_cjs/Schedule/Decision.cjs.map +1 -1
- package/_cjs/Schedule/api/driver.cjs +18 -21
- package/_cjs/Schedule/api/driver.cjs.map +1 -1
- package/_cjs/Schedule/api.cjs +205 -180
- package/_cjs/Schedule/api.cjs.map +1 -1
- package/_cjs/Scope/Finalizer/definition.cjs +4 -6
- package/_cjs/Scope/Finalizer/definition.cjs.map +1 -1
- package/_cjs/Scope/ReleaseMap/api/releaseAll.cjs +3 -5
- package/_cjs/Scope/ReleaseMap/api/releaseAll.cjs.map +1 -1
- package/_cjs/Scope/ReleaseMap/api.cjs +14 -15
- package/_cjs/Scope/ReleaseMap/api.cjs.map +1 -1
- package/_cjs/Scope/ReleaseMap/constructors.cjs +1 -1
- package/_cjs/Scope/ReleaseMap/constructors.cjs.map +1 -1
- package/_cjs/Scope/ReleaseMap/definition.cjs +2 -4
- package/_cjs/Scope/ReleaseMap/definition.cjs.map +1 -1
- package/_cjs/Scope/api.cjs +20 -30
- package/_cjs/Scope/api.cjs.map +1 -1
- package/_cjs/ScopedRef/api.cjs +14 -22
- package/_cjs/ScopedRef/api.cjs.map +1 -1
- package/_cjs/Sink/api.cjs +92 -88
- package/_cjs/Sink/api.cjs.map +1 -1
- package/_cjs/State/api.cjs +5 -7
- package/_cjs/State/api.cjs.map +1 -1
- package/_cjs/Stream/api/zipAllWith.cjs +22 -24
- package/_cjs/Stream/api/zipAllWith.cjs.map +1 -1
- package/_cjs/Stream/api/zipWith.cjs +2 -2
- package/_cjs/Stream/api/zipWith.cjs.map +1 -1
- package/_cjs/Stream/api/zipWithChunks.cjs +20 -22
- package/_cjs/Stream/api/zipWithChunks.cjs.map +1 -1
- package/_cjs/Stream/api.cjs +436 -419
- package/_cjs/Stream/api.cjs.map +1 -1
- package/_cjs/Stream/internal/Handoff.cjs +12 -12
- package/_cjs/Stream/internal/Handoff.cjs.map +1 -1
- package/_cjs/Stream/internal/Pull.cjs +1 -1
- package/_cjs/Stream/internal/Pull.cjs.map +1 -1
- package/_cjs/Stream/internal/Take.cjs +1 -1
- package/_cjs/Stream/internal/Take.cjs.map +1 -1
- package/_cjs/Supervisor/api.cjs +3 -1
- package/_cjs/Supervisor/api.cjs.map +1 -1
- package/_cjs/Supervisor/constructors.cjs +14 -8
- package/_cjs/Supervisor/constructors.cjs.map +1 -1
- package/_cjs/TFuture/api.cjs +10 -10
- package/_cjs/TFuture/api.cjs.map +1 -1
- package/_cjs/TFuture/constructors.cjs +4 -4
- package/_cjs/TFuture/constructors.cjs.map +1 -1
- package/_cjs/TFuture/definition.cjs +2 -4
- package/_cjs/TFuture/definition.cjs.map +1 -1
- package/_cjs/TReentrantLock/api.cjs +41 -42
- package/_cjs/TReentrantLock/api.cjs.map +1 -1
- package/_cjs/TRef/api.cjs +40 -40
- package/_cjs/TRef/api.cjs.map +1 -1
- package/_cjs/TRef/constructors.cjs +6 -6
- package/_cjs/TRef/constructors.cjs.map +1 -1
- package/_cjs/TSemaphore/api.cjs +20 -21
- package/_cjs/TSemaphore/api.cjs.map +1 -1
- package/_cjs/TSemaphore/constructors.cjs +2 -2
- package/_cjs/TSemaphore/constructors.cjs.map +1 -1
- package/_cjs/TSemaphore/definition.cjs +2 -4
- package/_cjs/TSemaphore/definition.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/dropUntilIO.cjs +1 -1
- package/_cjs/collection/immutable/Conc/dropUntilIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/dropWhileIO.cjs +1 -1
- package/_cjs/collection/immutable/Conc/dropWhileIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/filterIO.cjs +5 -7
- package/_cjs/collection/immutable/Conc/filterIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/findIO.cjs +7 -9
- package/_cjs/collection/immutable/Conc/findIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/mapIO.cjs +3 -5
- package/_cjs/collection/immutable/Conc/mapIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/takeWhileIO.cjs +7 -9
- package/_cjs/collection/immutable/Conc/takeWhileIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc.cjs +26 -0
- package/_cjs/collection/immutable/Conc.cjs.map +1 -1
- package/_cjs/data/Exit/foreachIO.cjs +2 -4
- package/_cjs/data/Exit/foreachIO.cjs.map +1 -1
- package/_cjs/global.cjs +6 -0
- package/_cjs/global.cjs.map +1 -0
- package/_cjs/index.cjs +6 -0
- package/_cjs/index.cjs.map +1 -0
- package/_cjs/internal/Scheduler.cjs +64 -14
- package/_cjs/internal/Scheduler.cjs.map +1 -1
- package/_mjs/Cached/api.mjs +5 -5
- package/_mjs/Cached/api.mjs.map +1 -1
- package/_mjs/Channel/api/interruptWhen.mjs +1 -1
- package/_mjs/Channel/api/interruptWhen.mjs.map +1 -1
- package/_mjs/Channel/api/mapOutIOC.mjs +2 -2
- package/_mjs/Channel/api/mapOutIOC.mjs.map +1 -1
- package/_mjs/Channel/api/mergeAllWith.mjs +11 -11
- package/_mjs/Channel/api/mergeAllWith.mjs.map +1 -1
- package/_mjs/Channel/api/mergeWith.mjs +6 -5
- package/_mjs/Channel/api/mergeWith.mjs.map +1 -1
- package/_mjs/Channel/api/run.mjs +2 -1
- package/_mjs/Channel/api/run.mjs.map +1 -1
- package/_mjs/Channel/api.mjs +7 -7
- package/_mjs/Channel/api.mjs.map +1 -1
- package/_mjs/Channel/core-api.mjs.map +1 -1
- package/_mjs/Channel/definition.mjs.map +1 -1
- package/_mjs/Channel/internal/ChannelExecutor.mjs +6 -6
- package/_mjs/Channel/internal/ChannelExecutor.mjs.map +1 -1
- package/_mjs/Channel/internal/ChannelState.mjs +2 -1
- package/_mjs/Channel/internal/ChannelState.mjs.map +1 -1
- package/_mjs/Channel/internal/SingleProducerAsyncInput.mjs +16 -16
- package/_mjs/Channel/internal/SingleProducerAsyncInput.mjs.map +1 -1
- package/_mjs/Clock/live.mjs.map +1 -1
- package/_mjs/Console/api.mjs +4 -3
- package/_mjs/Console/api.mjs.map +1 -1
- package/_mjs/Fiber/FiberContext.mjs +9 -9
- package/_mjs/Fiber/FiberContext.mjs.map +1 -1
- package/_mjs/Fiber/api/await.mjs +1 -1
- package/_mjs/Fiber/api/await.mjs.map +1 -1
- package/_mjs/Fiber/api/awaitAll.mjs +2 -3
- package/_mjs/Fiber/api/awaitAll.mjs.map +1 -1
- package/_mjs/Fiber/api/children.mjs +1 -1
- package/_mjs/Fiber/api/children.mjs.map +1 -1
- package/_mjs/Fiber/api/collectAll.mjs +2 -3
- package/_mjs/Fiber/api/collectAll.mjs.map +1 -1
- package/_mjs/Fiber/api/evalOn.mjs +1 -1
- package/_mjs/Fiber/api/evalOn.mjs.map +1 -1
- package/_mjs/Fiber/api/evalOnIO.mjs +2 -3
- package/_mjs/Fiber/api/evalOnIO.mjs.map +1 -1
- package/_mjs/Fiber/api/fromIO.mjs +2 -3
- package/_mjs/Fiber/api/fromIO.mjs.map +1 -1
- package/_mjs/Fiber/api/id.mjs +1 -1
- package/_mjs/Fiber/api/id.mjs.map +1 -1
- package/_mjs/Fiber/api/inheritRefs.mjs +1 -1
- package/_mjs/Fiber/api/inheritRefs.mjs.map +1 -1
- package/_mjs/Fiber/api/interrupt.mjs +2 -3
- package/_mjs/Fiber/api/interrupt.mjs.map +1 -1
- package/_mjs/Fiber/api/interruptAll.mjs +4 -5
- package/_mjs/Fiber/api/interruptAll.mjs.map +1 -1
- package/_mjs/Fiber/api/interruptAs.mjs +1 -1
- package/_mjs/Fiber/api/interruptAs.mjs.map +1 -1
- package/_mjs/Fiber/api/interruptFork.mjs +1 -1
- package/_mjs/Fiber/api/interruptFork.mjs.map +1 -1
- package/_mjs/Fiber/api/join.mjs +2 -3
- package/_mjs/Fiber/api/join.mjs.map +1 -1
- package/_mjs/Fiber/api/joinAll.mjs +2 -3
- package/_mjs/Fiber/api/joinAll.mjs.map +1 -1
- package/_mjs/Fiber/api/mapFiber.mjs +2 -3
- package/_mjs/Fiber/api/mapFiber.mjs.map +1 -1
- package/_mjs/Fiber/api/mapIO.mjs +4 -5
- package/_mjs/Fiber/api/mapIO.mjs.map +1 -1
- package/_mjs/Fiber/api/poll.mjs +1 -1
- package/_mjs/Fiber/api/poll.mjs.map +1 -1
- package/_mjs/Fiber/api/zipWith.mjs +2 -3
- package/_mjs/Fiber/api/zipWith.mjs.map +1 -1
- package/_mjs/Fiber/constructors.mjs +10 -11
- package/_mjs/Fiber/constructors.mjs.map +1 -1
- package/_mjs/FiberRef/api/locallyScoped.mjs +2 -3
- package/_mjs/FiberRef/api/locallyScoped.mjs.map +1 -1
- package/_mjs/FiberRef/api/locallyScopedWith.mjs +2 -3
- package/_mjs/FiberRef/api/locallyScopedWith.mjs.map +1 -1
- package/_mjs/FiberRef/api.mjs +13 -14
- package/_mjs/FiberRef/api.mjs.map +1 -1
- package/_mjs/FiberRef/constructors.mjs +4 -5
- package/_mjs/FiberRef/constructors.mjs.map +1 -1
- package/_mjs/FiberRef/unsafe.mjs +6 -0
- package/_mjs/FiberRef/unsafe.mjs.map +1 -1
- package/_mjs/Future/api.mjs +30 -31
- package/_mjs/Future/api.mjs.map +1 -1
- package/_mjs/Future/constructors.mjs +4 -5
- package/_mjs/Future/constructors.mjs.map +1 -1
- package/_mjs/Hub/api.mjs +44 -44
- package/_mjs/Hub/api.mjs.map +1 -1
- package/_mjs/Hub/internal.mjs +16 -24
- package/_mjs/Hub/internal.mjs.map +1 -1
- package/_mjs/IO/api/acquireRelease.mjs +2 -3
- package/_mjs/IO/api/acquireRelease.mjs.map +1 -1
- package/_mjs/IO/api/acquireReleaseExit.mjs +1 -1
- package/_mjs/IO/api/acquireReleaseExit.mjs.map +1 -1
- package/_mjs/IO/api/acquireReleaseInterruptibleExit.mjs +1 -1
- package/_mjs/IO/api/acquireReleaseInterruptibleExit.mjs.map +1 -1
- package/_mjs/IO/api/addFinalizer.mjs +1 -1
- package/_mjs/IO/api/addFinalizer.mjs.map +1 -1
- package/_mjs/IO/api/addFinalizerExit.mjs +5 -10
- package/_mjs/IO/api/addFinalizerExit.mjs.map +1 -1
- package/_mjs/IO/api/asyncIO.mjs +5 -6
- package/_mjs/IO/api/asyncIO.mjs.map +1 -1
- package/_mjs/IO/api/bracket.mjs +2 -2
- package/_mjs/IO/api/bracket.mjs.map +1 -1
- package/_mjs/IO/api/bracketExit.mjs +2 -3
- package/_mjs/IO/api/bracketExit.mjs.map +1 -1
- package/_mjs/IO/api/concurrency.mjs +7 -7
- package/_mjs/IO/api/concurrency.mjs.map +1 -1
- package/_mjs/IO/api/concurrentFinalizers.mjs +2 -3
- package/_mjs/IO/api/concurrentFinalizers.mjs.map +1 -1
- package/_mjs/IO/api/consoleWith.mjs +3 -3
- package/_mjs/IO/api/consoleWith.mjs.map +1 -1
- package/_mjs/IO/api/core-scope.mjs +4 -4
- package/_mjs/IO/api/core-scope.mjs.map +1 -1
- package/_mjs/IO/api/ensuringChildren.mjs +2 -3
- package/_mjs/IO/api/ensuringChildren.mjs.map +1 -1
- package/_mjs/IO/api/environment.mjs +6 -8
- package/_mjs/IO/api/environment.mjs.map +1 -1
- package/_mjs/IO/api/foreachC.mjs +25 -26
- package/_mjs/IO/api/foreachC.mjs.map +1 -1
- package/_mjs/IO/api/foreachExec.mjs +2 -3
- package/_mjs/IO/api/foreachExec.mjs.map +1 -1
- package/_mjs/IO/api/forkIn.mjs +1 -1
- package/_mjs/IO/api/forkIn.mjs.map +1 -1
- package/_mjs/IO/api/forkScoped.mjs +1 -1
- package/_mjs/IO/api/forkScoped.mjs.map +1 -1
- package/_mjs/IO/api/fulfill.mjs +2 -3
- package/_mjs/IO/api/fulfill.mjs.map +1 -1
- package/_mjs/IO/api/interrupt.mjs +13 -13
- package/_mjs/IO/api/interrupt.mjs.map +1 -1
- package/_mjs/IO/api/memoize.mjs +4 -8
- package/_mjs/IO/api/memoize.mjs.map +1 -1
- package/_mjs/IO/api/onExit.mjs +2 -2
- package/_mjs/IO/api/onExit.mjs.map +1 -1
- package/_mjs/IO/api/onTermination.mjs +2 -2
- package/_mjs/IO/api/onTermination.mjs.map +1 -1
- package/_mjs/IO/api/once.mjs +1 -1
- package/_mjs/IO/api/once.mjs.map +1 -1
- package/_mjs/IO/api/provideLayer.mjs +2 -3
- package/_mjs/IO/api/provideLayer.mjs.map +1 -1
- package/_mjs/IO/api/provideSomeLayer.mjs +2 -3
- package/_mjs/IO/api/provideSomeLayer.mjs.map +1 -1
- package/_mjs/IO/api/race.mjs +4 -5
- package/_mjs/IO/api/race.mjs.map +1 -1
- package/_mjs/IO/api/raceFirst.mjs +2 -3
- package/_mjs/IO/api/raceFirst.mjs.map +1 -1
- package/_mjs/IO/api/randomWith.mjs +3 -3
- package/_mjs/IO/api/randomWith.mjs.map +1 -1
- package/_mjs/IO/api/repeat.mjs +10 -11
- package/_mjs/IO/api/repeat.mjs.map +1 -1
- package/_mjs/IO/api/retry.mjs +8 -9
- package/_mjs/IO/api/retry.mjs.map +1 -1
- package/_mjs/IO/api/schedule.mjs +6 -7
- package/_mjs/IO/api/schedule.mjs.map +1 -1
- package/_mjs/IO/api/scope.mjs +1 -1
- package/_mjs/IO/api/scope.mjs.map +1 -1
- package/_mjs/IO/api/scopeWith.mjs +2 -3
- package/_mjs/IO/api/scopeWith.mjs.map +1 -1
- package/_mjs/IO/api/scoped.mjs +4 -5
- package/_mjs/IO/api/scoped.mjs.map +1 -1
- package/_mjs/IO/api/stateful.mjs +1 -1
- package/_mjs/IO/api/stateful.mjs.map +1 -1
- package/_mjs/IO/api/timeout.mjs +3 -4
- package/_mjs/IO/api/timeout.mjs.map +1 -1
- package/_mjs/IO/api/withChildren.mjs +1 -1
- package/_mjs/IO/api/withChildren.mjs.map +1 -1
- package/_mjs/IO/api/withEarlyRelease.mjs +2 -3
- package/_mjs/IO/api/withEarlyRelease.mjs.map +1 -1
- package/_mjs/IO/api/withFinalizer.mjs +2 -2
- package/_mjs/IO/api/withFinalizer.mjs.map +1 -1
- package/_mjs/IO/api/withFinalizerExit.mjs +2 -3
- package/_mjs/IO/api/withFinalizerExit.mjs.map +1 -1
- package/_mjs/IO/api/withRuntimeConfig.mjs +2 -3
- package/_mjs/IO/api/withRuntimeConfig.mjs.map +1 -1
- package/_mjs/IO/api/zipC.mjs +5 -6
- package/_mjs/IO/api/zipC.mjs.map +1 -1
- package/_mjs/IO/api.mjs +112 -112
- package/_mjs/IO/api.mjs.map +1 -1
- package/_mjs/IO/definition.mjs +3 -5
- package/_mjs/IO/definition.mjs.map +1 -1
- package/_mjs/IO/runtime.mjs +51 -18
- package/_mjs/IO/runtime.mjs.map +1 -1
- package/_mjs/IOEnv/live.mjs +2 -1
- package/_mjs/IOEnv/live.mjs.map +1 -1
- package/_mjs/Layer/MemoMap.mjs +43 -60
- package/_mjs/Layer/MemoMap.mjs.map +1 -1
- package/_mjs/Layer/api.mjs +84 -84
- package/_mjs/Layer/api.mjs.map +1 -1
- package/_mjs/Layer/definition.mjs +14 -7
- package/_mjs/Layer/definition.mjs.map +1 -1
- package/_mjs/Queue/api/dimapIO.mjs +14 -14
- package/_mjs/Queue/api/dimapIO.mjs.map +1 -1
- package/_mjs/Queue/api/filterInputIO.mjs +6 -6
- package/_mjs/Queue/api/filterInputIO.mjs.map +1 -1
- package/_mjs/Queue/api/filterOutputIO.mjs +6 -6
- package/_mjs/Queue/api/filterOutputIO.mjs.map +1 -1
- package/_mjs/Queue/api/operations.mjs +13 -13
- package/_mjs/Queue/api/operations.mjs.map +1 -1
- package/_mjs/Queue/api/poll.mjs +2 -3
- package/_mjs/Queue/api/poll.mjs.map +1 -1
- package/_mjs/Queue/api/takeBetween.mjs +10 -11
- package/_mjs/Queue/api/takeBetween.mjs.map +1 -1
- package/_mjs/Queue/api/zipWithIO.mjs +12 -12
- package/_mjs/Queue/api/zipWithIO.mjs.map +1 -1
- package/_mjs/Queue/constructors.mjs +8 -9
- package/_mjs/Queue/constructors.mjs.map +1 -1
- package/_mjs/Queue/internal.mjs +17 -17
- package/_mjs/Queue/internal.mjs.map +1 -1
- package/_mjs/Queue/strategy.mjs +16 -20
- package/_mjs/Queue/strategy.mjs.map +1 -1
- package/_mjs/Random/api.mjs +14 -13
- package/_mjs/Random/api.mjs.map +1 -1
- package/_mjs/Random/live.mjs +4 -4
- package/_mjs/Random/live.mjs.map +1 -1
- package/_mjs/Ref/Atomic/Atomic.mjs.map +1 -1
- package/_mjs/Ref/Atomic/api.mjs +19 -20
- package/_mjs/Ref/Atomic/api.mjs.map +1 -1
- package/_mjs/Ref/Derived.mjs.map +1 -1
- package/_mjs/Ref/DerivedAll.mjs +1 -1
- package/_mjs/Ref/DerivedAll.mjs.map +1 -1
- package/_mjs/Ref/Synchronized/api.mjs +25 -26
- package/_mjs/Ref/Synchronized/api.mjs.map +1 -1
- package/_mjs/Ref/Synchronized/constructors.mjs +8 -13
- package/_mjs/Ref/Synchronized/constructors.mjs.map +1 -1
- package/_mjs/Ref/Synchronized/definition.mjs +1 -1
- package/_mjs/Ref/Synchronized/definition.mjs.map +1 -1
- package/_mjs/Ref/api/collect.mjs +1 -1
- package/_mjs/Ref/api/collect.mjs.map +1 -1
- package/_mjs/Ref/api/dimap.mjs +12 -12
- package/_mjs/Ref/api/dimap.mjs.map +1 -1
- package/_mjs/Ref/api/filter.mjs +2 -2
- package/_mjs/Ref/api/filter.mjs.map +1 -1
- package/_mjs/Ref/api/get.mjs +1 -1
- package/_mjs/Ref/api/get.mjs.map +1 -1
- package/_mjs/Ref/api/modify.mjs +29 -30
- package/_mjs/Ref/api/modify.mjs.map +1 -1
- package/_mjs/Ref/api/set.mjs +1 -1
- package/_mjs/Ref/api/set.mjs.map +1 -1
- package/_mjs/Ref/constructors.mjs +3 -4
- package/_mjs/Ref/constructors.mjs.map +1 -1
- package/_mjs/STM/api/core-api.mjs +8 -8
- package/_mjs/STM/api/core-api.mjs.map +1 -1
- package/_mjs/STM/api/core-constructors.mjs +6 -6
- package/_mjs/STM/api/core-constructors.mjs.map +1 -1
- package/_mjs/STM/api.mjs +122 -142
- package/_mjs/STM/api.mjs.map +1 -1
- package/_mjs/STM/definition.mjs.map +1 -1
- package/_mjs/STM/driver.mjs +9 -6
- package/_mjs/STM/driver.mjs.map +1 -1
- package/_mjs/STM/internal/Journal.mjs +20 -21
- package/_mjs/STM/internal/Journal.mjs.map +1 -1
- package/_mjs/Schedule/Decision.mjs +9 -0
- package/_mjs/Schedule/Decision.mjs.map +1 -1
- package/_mjs/Schedule/api/driver.mjs +17 -20
- package/_mjs/Schedule/api/driver.mjs.map +1 -1
- package/_mjs/Schedule/api.mjs +198 -177
- package/_mjs/Schedule/api.mjs.map +1 -1
- package/_mjs/Scope/Finalizer/definition.mjs +4 -5
- package/_mjs/Scope/Finalizer/definition.mjs.map +1 -1
- package/_mjs/Scope/ReleaseMap/api/releaseAll.mjs +3 -4
- package/_mjs/Scope/ReleaseMap/api/releaseAll.mjs.map +1 -1
- package/_mjs/Scope/ReleaseMap/api.mjs +14 -15
- package/_mjs/Scope/ReleaseMap/api.mjs.map +1 -1
- package/_mjs/Scope/ReleaseMap/constructors.mjs +1 -1
- package/_mjs/Scope/ReleaseMap/constructors.mjs.map +1 -1
- package/_mjs/Scope/ReleaseMap/definition.mjs +2 -3
- package/_mjs/Scope/ReleaseMap/definition.mjs.map +1 -1
- package/_mjs/Scope/api.mjs +20 -30
- package/_mjs/Scope/api.mjs.map +1 -1
- package/_mjs/ScopedRef/api.mjs +14 -22
- package/_mjs/ScopedRef/api.mjs.map +1 -1
- package/_mjs/Sink/api.mjs +92 -88
- package/_mjs/Sink/api.mjs.map +1 -1
- package/_mjs/State/api.mjs +5 -6
- package/_mjs/State/api.mjs.map +1 -1
- package/_mjs/Stream/api/zipAllWith.mjs +22 -23
- package/_mjs/Stream/api/zipAllWith.mjs.map +1 -1
- package/_mjs/Stream/api/zipWith.mjs +2 -2
- package/_mjs/Stream/api/zipWith.mjs.map +1 -1
- package/_mjs/Stream/api/zipWithChunks.mjs +20 -21
- package/_mjs/Stream/api/zipWithChunks.mjs.map +1 -1
- package/_mjs/Stream/api.mjs +430 -417
- package/_mjs/Stream/api.mjs.map +1 -1
- package/_mjs/Stream/internal/Handoff.mjs +12 -12
- package/_mjs/Stream/internal/Handoff.mjs.map +1 -1
- package/_mjs/Stream/internal/Pull.mjs +1 -1
- package/_mjs/Stream/internal/Pull.mjs.map +1 -1
- package/_mjs/Stream/internal/Take.mjs +1 -1
- package/_mjs/Stream/internal/Take.mjs.map +1 -1
- package/_mjs/Supervisor/api.mjs +2 -1
- package/_mjs/Supervisor/api.mjs.map +1 -1
- package/_mjs/Supervisor/constructors.mjs +9 -6
- package/_mjs/Supervisor/constructors.mjs.map +1 -1
- package/_mjs/TFuture/api.mjs +10 -10
- package/_mjs/TFuture/api.mjs.map +1 -1
- package/_mjs/TFuture/constructors.mjs +4 -4
- package/_mjs/TFuture/constructors.mjs.map +1 -1
- package/_mjs/TFuture/definition.mjs +2 -3
- package/_mjs/TFuture/definition.mjs.map +1 -1
- package/_mjs/TReentrantLock/api.mjs +41 -42
- package/_mjs/TReentrantLock/api.mjs.map +1 -1
- package/_mjs/TRef/api.mjs +40 -40
- package/_mjs/TRef/api.mjs.map +1 -1
- package/_mjs/TRef/constructors.mjs +6 -6
- package/_mjs/TRef/constructors.mjs.map +1 -1
- package/_mjs/TSemaphore/api.mjs +17 -18
- package/_mjs/TSemaphore/api.mjs.map +1 -1
- package/_mjs/TSemaphore/constructors.mjs +2 -2
- package/_mjs/TSemaphore/constructors.mjs.map +1 -1
- package/_mjs/TSemaphore/definition.mjs +2 -3
- package/_mjs/TSemaphore/definition.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/dropUntilIO.mjs +1 -1
- package/_mjs/collection/immutable/Conc/dropUntilIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/dropWhileIO.mjs +1 -1
- package/_mjs/collection/immutable/Conc/dropWhileIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/filterIO.mjs +5 -6
- package/_mjs/collection/immutable/Conc/filterIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/findIO.mjs +7 -8
- package/_mjs/collection/immutable/Conc/findIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/mapIO.mjs +3 -4
- package/_mjs/collection/immutable/Conc/mapIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/takeWhileIO.mjs +7 -8
- package/_mjs/collection/immutable/Conc/takeWhileIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc.mjs +2 -0
- package/_mjs/collection/immutable/Conc.mjs.map +1 -1
- package/_mjs/data/Exit/foreachIO.mjs +2 -3
- package/_mjs/data/Exit/foreachIO.mjs.map +1 -1
- package/_mjs/global.mjs +2 -0
- package/_mjs/global.mjs.map +1 -0
- package/_mjs/index.mjs +2 -0
- package/_mjs/index.mjs.map +1 -0
- package/_mjs/internal/Scheduler.mjs +62 -15
- package/_mjs/internal/Scheduler.mjs.map +1 -1
- package/_src/Cached/api.ts +4 -3
- package/_src/Channel/api/interruptWhen.ts +1 -1
- package/_src/Channel/api/mapOutIOC.ts +2 -2
- package/_src/Channel/api/mergeAll.ts +1 -1
- package/_src/Channel/api/mergeAllUnboundedWith.ts +1 -1
- package/_src/Channel/api/mergeAllWith.ts +3 -3
- package/_src/Channel/api/mergeMap.ts +1 -1
- package/_src/Channel/api/mergeWith.ts +9 -9
- package/_src/Channel/api/runScoped.ts +1 -1
- package/_src/Channel/api/toPull.ts +1 -1
- package/_src/Channel/api/zipC.ts +3 -3
- package/_src/Channel/api.ts +73 -73
- package/_src/Channel/core-api.ts +11 -13
- package/_src/Channel/definition.ts +19 -19
- package/_src/Channel/internal/MergeDecision.ts +1 -1
- package/_src/Clock/live.ts +1 -1
- package/_src/Console/api.ts +1 -1
- package/_src/Fiber/FiberContext.ts +10 -8
- package/_src/Fiber/api/await.ts +1 -1
- package/_src/Fiber/api/awaitAll.ts +1 -1
- package/_src/Fiber/api/children.ts +1 -1
- package/_src/Fiber/api/collectAll.ts +4 -1
- package/_src/Fiber/api/evalOn.ts +6 -1
- package/_src/Fiber/api/evalOnIO.ts +2 -1
- package/_src/Fiber/api/fromIO.ts +1 -1
- package/_src/Fiber/api/id.ts +1 -1
- package/_src/Fiber/api/inheritRefs.ts +1 -1
- package/_src/Fiber/api/interrupt.ts +1 -1
- package/_src/Fiber/api/interruptAll.ts +2 -2
- package/_src/Fiber/api/interruptAs.ts +1 -1
- package/_src/Fiber/api/join.ts +1 -1
- package/_src/Fiber/api/joinAll.ts +1 -1
- package/_src/Fiber/api/mapFiber.ts +5 -1
- package/_src/Fiber/api/mapIO.ts +6 -2
- package/_src/Fiber/api/poll.ts +1 -1
- package/_src/Fiber/api/zipWith.ts +1 -0
- package/_src/Fiber/constructors.ts +5 -5
- package/_src/Fiber/definition.ts +1 -1
- package/_src/FiberRef/api/locallyScoped.ts +1 -1
- package/_src/FiberRef/api/locallyScopedWith.ts +5 -1
- package/_src/FiberRef/api.ts +7 -7
- package/_src/FiberRef/constructors.ts +4 -2
- package/_src/FiberRef/unsafe.ts +7 -0
- package/_src/Future/api.ts +24 -16
- package/_src/Future/constructors.ts +2 -2
- package/_src/Hub/api.ts +50 -23
- package/_src/Hub/definition.ts +6 -6
- package/_src/Hub/internal.ts +15 -15
- package/_src/IO/api/acquireRelease.ts +2 -1
- package/_src/IO/api/acquireReleaseExit.ts +1 -1
- package/_src/IO/api/acquireReleaseInterruptible.ts +1 -1
- package/_src/IO/api/acquireReleaseInterruptibleExit.ts +1 -1
- package/_src/IO/api/addFinalizer.ts +1 -4
- package/_src/IO/api/addFinalizerExit.ts +6 -5
- package/_src/IO/api/asyncIO.ts +4 -1
- package/_src/IO/api/bracket.ts +2 -1
- package/_src/IO/api/bracketExit.ts +2 -1
- package/_src/IO/api/concurrency.ts +6 -3
- package/_src/IO/api/concurrentFinalizers.ts +1 -1
- package/_src/IO/api/consoleWith.ts +1 -1
- package/_src/IO/api/core-scope.ts +1 -1
- package/_src/IO/api/ensuringChildren.ts +3 -2
- package/_src/IO/api/environment.ts +9 -11
- package/_src/IO/api/foreachC.ts +33 -6
- package/_src/IO/api/foreachExec.ts +1 -0
- package/_src/IO/api/forkScoped.ts +1 -1
- package/_src/IO/api/fulfill.ts +1 -1
- package/_src/IO/api/interrupt.ts +13 -5
- package/_src/IO/api/memoize.ts +3 -3
- package/_src/IO/api/onExit.ts +2 -1
- package/_src/IO/api/onTermination.ts +2 -2
- package/_src/IO/api/provideLayer.ts +1 -0
- package/_src/IO/api/provideSomeLayer.ts +1 -3
- package/_src/IO/api/race.ts +6 -2
- package/_src/IO/api/raceFirst.ts +6 -2
- package/_src/IO/api/randomWith.ts +1 -1
- package/_src/IO/api/repeat.ts +7 -7
- package/_src/IO/api/retry.ts +7 -7
- package/_src/IO/api/schedule.ts +4 -3
- package/_src/IO/api/scope.ts +1 -1
- package/_src/IO/api/scopeWith.ts +1 -1
- package/_src/IO/api/scoped.ts +2 -2
- package/_src/IO/api/sequenceT.ts +1 -1
- package/_src/IO/api/stateful.ts +1 -1
- package/_src/IO/api/timeout.ts +5 -1
- package/_src/IO/api/withChildren.ts +1 -1
- package/_src/IO/api/withEarlyRelease.ts +4 -1
- package/_src/IO/api/withFinalizer.ts +2 -1
- package/_src/IO/api/withFinalizerExit.ts +2 -1
- package/_src/IO/api/withRuntimeConfig.ts +5 -1
- package/_src/IO/api/zipC.ts +7 -2
- package/_src/IO/api.ts +125 -75
- package/_src/IO/definition.ts +32 -27
- package/_src/IO/runtime.ts +48 -1
- package/_src/IOEnv/definition.ts +1 -1
- package/_src/Layer/MemoMap.ts +41 -34
- package/_src/Layer/api.ts +82 -49
- package/_src/Layer/definition.ts +11 -8
- package/_src/Queue/api/dimapIO.ts +21 -11
- package/_src/Queue/api/filterInputIO.ts +6 -4
- package/_src/Queue/api/filterOutputIO.ts +8 -6
- package/_src/Queue/api/operations.ts +28 -10
- package/_src/Queue/api/poll.ts +4 -1
- package/_src/Queue/api/takeBetween.ts +6 -1
- package/_src/Queue/api/zipWithIO.ts +13 -10
- package/_src/Queue/constructors.ts +4 -4
- package/_src/Queue/definition.ts +10 -10
- package/_src/Queue/internal.ts +7 -7
- package/_src/Queue/strategy.ts +18 -10
- package/_src/Random/api.ts +5 -5
- package/_src/Random/definition.ts +5 -5
- package/_src/Random/live.ts +4 -4
- package/_src/Ref/Atomic/Atomic.ts +3 -3
- package/_src/Ref/Atomic/api.ts +10 -10
- package/_src/Ref/Derived.ts +3 -3
- package/_src/Ref/DerivedAll.ts +3 -3
- package/_src/Ref/Synchronized/api.ts +33 -18
- package/_src/Ref/Synchronized/constructors.ts +5 -5
- package/_src/Ref/Synchronized/definition.ts +2 -2
- package/_src/Ref/api/collect.ts +1 -0
- package/_src/Ref/api/dimap.ts +7 -0
- package/_src/Ref/api/filter.ts +2 -0
- package/_src/Ref/api/get.ts +5 -2
- package/_src/Ref/api/modify.ts +21 -9
- package/_src/Ref/api/set.ts +5 -1
- package/_src/Ref/constructors.ts +2 -2
- package/_src/Ref/definition.ts +14 -14
- package/_src/STM/api/core-api.ts +20 -7
- package/_src/STM/api/core-constructors.ts +7 -7
- package/_src/STM/api.ts +150 -116
- package/_src/STM/definition.ts +6 -6
- package/_src/STM/driver.ts +3 -3
- package/_src/STM/internal/Journal.ts +25 -16
- package/_src/Schedule/Decision.ts +10 -3
- package/_src/Schedule/Driver.ts +2 -2
- package/_src/Schedule/api/driver.ts +6 -6
- package/_src/Schedule/api.ts +182 -82
- package/_src/Schedule/definition.ts +1 -1
- package/_src/Scope/Finalizer/definition.ts +2 -2
- package/_src/Scope/ReleaseMap/api/releaseAll.ts +6 -1
- package/_src/Scope/ReleaseMap/api.ts +15 -5
- package/_src/Scope/ReleaseMap/definition.ts +1 -1
- package/_src/Scope/api.ts +23 -15
- package/_src/ScopedRef/api.ts +12 -17
- package/_src/ScopedRef/definition.ts +1 -1
- package/_src/Sink/api.ts +111 -85
- package/_src/State/api.ts +1 -1
- package/_src/Stream/api/zipAllWith.ts +5 -2
- package/_src/Stream/api/zipWith.ts +2 -1
- package/_src/Stream/api/zipWithChunks.ts +5 -2
- package/_src/Stream/api.ts +484 -216
- package/_src/Stream/definition.ts +3 -3
- package/_src/Stream/internal/Take.ts +1 -1
- package/_src/Supervisor/constructors.ts +7 -3
- package/_src/TFuture/api.ts +5 -5
- package/_src/TFuture/constructors.ts +2 -2
- package/_src/TFuture/definition.ts +1 -1
- package/_src/TReentrantLock/api.ts +18 -18
- package/_src/TRef/api.ts +36 -14
- package/_src/TRef/constructors.ts +4 -4
- package/_src/TSemaphore/api.ts +7 -7
- package/_src/TSemaphore/constructors.ts +1 -1
- package/_src/TSemaphore/definition.ts +1 -1
- package/_src/collection/immutable/Conc/filterIO.ts +5 -1
- package/_src/collection/immutable/Conc/findIO.ts +6 -1
- package/_src/collection/immutable/Conc/mapIO.ts +1 -1
- package/_src/collection/immutable/Conc/takeWhileIO.ts +5 -1
- package/_src/collection/immutable/Conc.ts +2 -0
- package/_src/data/Exit/foreachIO.ts +1 -0
- package/_src/global.ts +149 -0
- package/_src/index.ts +42 -0
- package/_src/internal/Scheduler.ts +59 -15
- package/collection/immutable/Conc/filterIO.d.ts +1 -1
- package/collection/immutable/Conc/findIO.d.ts +2 -2
- package/collection/immutable/Conc/mapIO.d.ts +1 -1
- package/collection/immutable/Conc/takeWhileIO.d.ts +1 -1
- package/collection/immutable/Conc.d.ts +2 -0
- package/data/Exit/foreachIO.d.ts +2 -2
- package/global.d.ts +149 -0
- package/index.d.ts +40 -0
- package/internal/Scheduler.d.ts +18 -1
- package/package.json +7 -3
- package/_cjs/demo.cjs +0 -15
- package/_cjs/demo.cjs.map +0 -1
- package/_mjs/demo.mjs +0 -7
- package/_mjs/demo.mjs.map +0 -1
- package/_src/demo.ts +0 -6
- package/demo.d.ts +0 -1
package/_src/Future/api.ts
CHANGED
@@ -8,7 +8,7 @@ import { Done, FutureStateTag, Pending } from "@fncts/io/Future/definition";
|
|
8
8
|
*
|
9
9
|
* @tsplus fluent fncts.io.Future done
|
10
10
|
*/
|
11
|
-
export function done_<E, A>(future: Future<E, A>, exit: Exit<E, A
|
11
|
+
export function done_<E, A>(future: Future<E, A>, exit: Exit<E, A>, __tsplusTrace?: string): UIO<boolean> {
|
12
12
|
return future.fulfillWith(IO.fromExitNow(exit));
|
13
13
|
}
|
14
14
|
|
@@ -18,7 +18,7 @@ export function done_<E, A>(future: Future<E, A>, exit: Exit<E, A>): UIO<boolean
|
|
18
18
|
*
|
19
19
|
* @tsplus fluent fncts.io.Future fail
|
20
20
|
*/
|
21
|
-
export function fail_<E, A>(future: Future<E, A>, e: E): UIO<boolean> {
|
21
|
+
export function fail_<E, A>(future: Future<E, A>, e: E, __tsplusTrace?: string): UIO<boolean> {
|
22
22
|
return future.fulfillWith(IO.failNow(e));
|
23
23
|
}
|
24
24
|
|
@@ -28,7 +28,7 @@ export function fail_<E, A>(future: Future<E, A>, e: E): UIO<boolean> {
|
|
28
28
|
*
|
29
29
|
* @tsplus fluent fncts.io.Future failCause
|
30
30
|
*/
|
31
|
-
export function failCause_<E, A>(future: Future<E, A>, cause: Cause<E
|
31
|
+
export function failCause_<E, A>(future: Future<E, A>, cause: Cause<E>, __tsplusTrace?: string): UIO<boolean> {
|
32
32
|
return future.fulfillWith(IO.failCauseNow(cause));
|
33
33
|
}
|
34
34
|
|
@@ -41,7 +41,11 @@ export function failCause_<E, A>(future: Future<E, A>, cause: Cause<E>): UIO<boo
|
|
41
41
|
*
|
42
42
|
* @tsplus fluent fncts.io.Future fulfill
|
43
43
|
*/
|
44
|
-
export function fulfill_<R, E, A>(
|
44
|
+
export function fulfill_<R, E, A>(
|
45
|
+
future: Future<E, A>,
|
46
|
+
io: IO<R, E, A>,
|
47
|
+
__tsplusTrace?: string,
|
48
|
+
): IO<R, never, boolean> {
|
45
49
|
return IO.uninterruptibleMask(({ restore }) => restore(io).result.flatMap((exit) => future.done(exit)));
|
46
50
|
}
|
47
51
|
|
@@ -60,7 +64,7 @@ export function fulfill_<R, E, A>(future: Future<E, A>, io: IO<R, E, A>): IO<R,
|
|
60
64
|
*
|
61
65
|
* @tsplus fluent fncts.io.Future fulfillWith
|
62
66
|
*/
|
63
|
-
export function fulfillWith_<E, A>(future: Future<E, A>, io: FIO<E, A
|
67
|
+
export function fulfillWith_<E, A>(future: Future<E, A>, io: FIO<E, A>, __tsplusTrace?: string): UIO<boolean> {
|
64
68
|
return IO.succeed(() => {
|
65
69
|
switch (future.state._tag) {
|
66
70
|
case FutureStateTag.Done: {
|
@@ -84,7 +88,7 @@ export function fulfillWith_<E, A>(future: Future<E, A>, io: FIO<E, A>): UIO<boo
|
|
84
88
|
*
|
85
89
|
* @tsplus fluent fncts.io.Future halt
|
86
90
|
*/
|
87
|
-
export function halt_<E, A>(future: Future<E, A>, defect: unknown): UIO<boolean> {
|
91
|
+
export function halt_<E, A>(future: Future<E, A>, defect: unknown, __tsplusTrace?: string): UIO<boolean> {
|
88
92
|
return future.fulfillWith(IO.haltNow(defect));
|
89
93
|
}
|
90
94
|
|
@@ -94,7 +98,7 @@ export function halt_<E, A>(future: Future<E, A>, defect: unknown): UIO<boolean>
|
|
94
98
|
*
|
95
99
|
* @tsplus getter fncts.io.Future interrupt
|
96
100
|
*/
|
97
|
-
export function interrupt<E, A>(future: Future<E, A
|
101
|
+
export function interrupt<E, A>(future: Future<E, A>, __tsplusTrace?: string): UIO<boolean> {
|
98
102
|
return IO.fiberId.flatMap((id) => future.fulfillWith(IO.interruptAs(id)));
|
99
103
|
}
|
100
104
|
|
@@ -104,7 +108,7 @@ export function interrupt<E, A>(future: Future<E, A>): UIO<boolean> {
|
|
104
108
|
*
|
105
109
|
* @tsplus fluent fncts.io.Future interruptAs
|
106
110
|
*/
|
107
|
-
export function interruptAs_<E, A>(future: Future<E, A>, id: FiberId): UIO<boolean> {
|
111
|
+
export function interruptAs_<E, A>(future: Future<E, A>, id: FiberId, __tsplusTrace?: string): UIO<boolean> {
|
108
112
|
return future.fulfillWith(IO.interruptAs(id));
|
109
113
|
}
|
110
114
|
|
@@ -114,7 +118,7 @@ export function interruptAs_<E, A>(future: Future<E, A>, id: FiberId): UIO<boole
|
|
114
118
|
*
|
115
119
|
* @tsplus getter fncts.io.Future isDone
|
116
120
|
*/
|
117
|
-
export function isDone<E, A>(future: Future<E, A
|
121
|
+
export function isDone<E, A>(future: Future<E, A>, __tsplusTrace?: string): UIO<boolean> {
|
118
122
|
return IO.succeed(future.state._tag === FutureStateTag.Done);
|
119
123
|
}
|
120
124
|
|
@@ -124,7 +128,7 @@ export function isDone<E, A>(future: Future<E, A>): UIO<boolean> {
|
|
124
128
|
*
|
125
129
|
* @tsplus getter fncts.io.Future poll
|
126
130
|
*/
|
127
|
-
export function poll<E, A>(future: Future<E, A
|
131
|
+
export function poll<E, A>(future: Future<E, A>, __tsplusTrace?: string): UIO<Maybe<FIO<E, A>>> {
|
128
132
|
return IO.succeed(() => {
|
129
133
|
switch (future.state._tag) {
|
130
134
|
case FutureStateTag.Done: {
|
@@ -142,7 +146,7 @@ export function poll<E, A>(future: Future<E, A>): UIO<Maybe<FIO<E, A>>> {
|
|
142
146
|
*
|
143
147
|
* @tsplus fluent fncts.io.Future succeed
|
144
148
|
*/
|
145
|
-
export function succeed_<A, E>(future: Future<E, A>, a: A) {
|
149
|
+
export function succeed_<A, E>(future: Future<E, A>, a: A, __tsplusTrace?: string) {
|
146
150
|
return future.fulfillWith(IO.succeedNow(a));
|
147
151
|
}
|
148
152
|
|
@@ -152,7 +156,7 @@ export function succeed_<A, E>(future: Future<E, A>, a: A) {
|
|
152
156
|
*
|
153
157
|
* @tsplus fluent fncts.io.Future unsafeDone
|
154
158
|
*/
|
155
|
-
export function unsafeDone_<E, A>(future: Future<E, A>, io: FIO<E, A
|
159
|
+
export function unsafeDone_<E, A>(future: Future<E, A>, io: FIO<E, A>, __tsplusTrace?: string) {
|
156
160
|
if (future.state._tag === FutureStateTag.Pending) {
|
157
161
|
const state = future.state;
|
158
162
|
future.state = new Done(io);
|
@@ -165,7 +169,7 @@ export function unsafeDone_<E, A>(future: Future<E, A>, io: FIO<E, A>) {
|
|
165
169
|
/**
|
166
170
|
* @tsplus fluent fncts.io.Future unsafeSucceed
|
167
171
|
*/
|
168
|
-
export function unsafeSucceed_<A>(future: Future<never, A>, a: A): void {
|
172
|
+
export function unsafeSucceed_<A>(future: Future<never, A>, a: A, __tsplusTrace?: string): void {
|
169
173
|
future.unsafeDone(IO.succeedNow(a));
|
170
174
|
}
|
171
175
|
|
@@ -175,8 +179,8 @@ export function unsafeSucceed_<A>(future: Future<never, A>, a: A): void {
|
|
175
179
|
*
|
176
180
|
* @tsplus getter fncts.io.Future await
|
177
181
|
*/
|
178
|
-
export function wait<E, A>(future: Future<E, A
|
179
|
-
return IO.asyncInterrupt<
|
182
|
+
export function wait<E, A>(future: Future<E, A>, __tsplusTrace?: string): IO<never, E, A> {
|
183
|
+
return IO.asyncInterrupt<never, E, A>((k) => {
|
180
184
|
switch (future.state._tag) {
|
181
185
|
case FutureStateTag.Done: {
|
182
186
|
return Either.right(future.state.value);
|
@@ -189,7 +193,11 @@ export function wait<E, A>(future: Future<E, A>): IO<unknown, E, A> {
|
|
189
193
|
}, future.blockingOn);
|
190
194
|
}
|
191
195
|
|
192
|
-
function interruptJoiner<E, A>(
|
196
|
+
function interruptJoiner<E, A>(
|
197
|
+
future: Future<E, A>,
|
198
|
+
joiner: (a: FIO<E, A>) => void,
|
199
|
+
__tsplusTrace?: string,
|
200
|
+
): Canceler<never> {
|
193
201
|
return IO.succeed(() => {
|
194
202
|
switch (future.state._tag) {
|
195
203
|
case FutureStateTag.Pending: {
|
@@ -5,7 +5,7 @@ import { Future, Pending } from "@fncts/io/Future/definition";
|
|
5
5
|
*
|
6
6
|
* @tsplus static fncts.io.FutureOps make
|
7
7
|
*/
|
8
|
-
export function make<E, A>(): IO<
|
8
|
+
export function make<E, A>(__tsplusTrace?: string): IO<never, never, Future<E, A>> {
|
9
9
|
return IO.fiberId.flatMap((id) => Future.makeAs<E, A>(id));
|
10
10
|
}
|
11
11
|
|
@@ -14,7 +14,7 @@ export function make<E, A>(): IO<unknown, never, Future<E, A>> {
|
|
14
14
|
*
|
15
15
|
* @tsplus static fncts.io.FutureOps makeAs
|
16
16
|
*/
|
17
|
-
export function makeAs<E, A>(fiberId: FiberId) {
|
17
|
+
export function makeAs<E, A>(fiberId: FiberId, __tsplusTrace?: string) {
|
18
18
|
return IO.succeed(unsafeMake<E, A>(fiberId));
|
19
19
|
}
|
20
20
|
|
package/_src/Hub/api.ts
CHANGED
@@ -16,7 +16,10 @@ import { QueueInternal } from "@fncts/io/Queue";
|
|
16
16
|
*
|
17
17
|
* @tsplus getter fncts.io.Hub awaitShutdown
|
18
18
|
*/
|
19
|
-
export function awaitShutdown<RA, RB, EA, EB, A, B>(
|
19
|
+
export function awaitShutdown<RA, RB, EA, EB, A, B>(
|
20
|
+
self: PHub<RA, RB, EA, EB, A, B>,
|
21
|
+
__tsplusTrace?: string,
|
22
|
+
): UIO<void> {
|
20
23
|
concrete(self);
|
21
24
|
return self.awaitShutdown;
|
22
25
|
}
|
@@ -26,7 +29,7 @@ export function awaitShutdown<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A
|
|
26
29
|
*
|
27
30
|
* @tsplus getter fncts.io.Hub capacity
|
28
31
|
*/
|
29
|
-
export function capacity<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B
|
32
|
+
export function capacity<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B>, __tsplusTrace?: string): number {
|
30
33
|
concrete(self);
|
31
34
|
return self.capacity;
|
32
35
|
}
|
@@ -40,13 +43,14 @@ export function capacity<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B>)
|
|
40
43
|
export function contramapIO_<RA, RB, RC, EA, EB, EC, A, B, C>(
|
41
44
|
self: PHub<RA, RB, EA, EB, A, B>,
|
42
45
|
f: (c: C) => IO<RC, EC, A>,
|
43
|
-
|
46
|
+
__tsplusTrace?: string,
|
47
|
+
): PHub<RC | RA, RB, EA | EC, EB, C, B> {
|
44
48
|
return self.dimapIO(f, IO.succeedNow);
|
45
49
|
}
|
46
50
|
|
47
51
|
class DimapIO<RA, RB, RC, RD, EA, EB, EC, ED, A, B, C, D> extends PHubInternal<
|
48
|
-
RC
|
49
|
-
RD
|
52
|
+
RC | RA,
|
53
|
+
RD | RB,
|
50
54
|
EA | EC,
|
51
55
|
EB | ED,
|
52
56
|
C,
|
@@ -79,6 +83,7 @@ export function dimap_<RA, RB, EA, EB, A, B, C, D>(
|
|
79
83
|
self: PHub<RA, RB, EA, EB, A, B>,
|
80
84
|
f: (c: C) => A,
|
81
85
|
g: (b: B) => D,
|
86
|
+
__tsplusTrace?: string,
|
82
87
|
): PHub<RA, RB, EA, EB, C, D> {
|
83
88
|
return self.dimapIO(
|
84
89
|
(c) => IO.succeedNow(f(c)),
|
@@ -96,12 +101,13 @@ export function dimapIO_<RA, RB, RC, RD, EA, EB, EC, ED, A, B, C, D>(
|
|
96
101
|
source: PHub<RA, RB, EA, EB, A, B>,
|
97
102
|
f: (c: C) => IO<RC, EC, A>,
|
98
103
|
g: (b: B) => IO<RD, ED, D>,
|
99
|
-
|
104
|
+
__tsplusTrace?: string,
|
105
|
+
): PHub<RC | RA, RD | RB, EA | EC, EB | ED, C, D> {
|
100
106
|
concrete(source);
|
101
107
|
return new DimapIO(source, f, g);
|
102
108
|
}
|
103
109
|
|
104
|
-
class FilterInputIO<RA, RA1, RB, EA, EA1, EB, A, B> extends PHubInternal<RA
|
110
|
+
class FilterInputIO<RA, RA1, RB, EA, EA1, EB, A, B> extends PHubInternal<RA | RA1, RB, EA | EA1, EB, A, B> {
|
105
111
|
constructor(readonly source: PHubInternal<RA, RB, EA, EB, A, B>, readonly f: (a: A) => IO<RA1, EA1, boolean>) {
|
106
112
|
super();
|
107
113
|
}
|
@@ -125,7 +131,8 @@ class FilterInputIO<RA, RA1, RB, EA, EA1, EB, A, B> extends PHubInternal<RA & RA
|
|
125
131
|
export function filterInputIO_<RA, RA1, RB, EA, EA1, EB, A, B>(
|
126
132
|
source: PHub<RA, RB, EA, EB, A, B>,
|
127
133
|
f: (a: A) => IO<RA1, EA1, boolean>,
|
128
|
-
|
134
|
+
__tsplusTrace?: string,
|
135
|
+
): PHub<RA | RA1, RB, EA | EA1, EB, A, B> {
|
129
136
|
concrete(source);
|
130
137
|
return new FilterInputIO(source, f);
|
131
138
|
}
|
@@ -135,11 +142,15 @@ export function filterInputIO_<RA, RA1, RB, EA, EA1, EB, A, B>(
|
|
135
142
|
*
|
136
143
|
* @tsplus fluent fncts.io.Hub filterInput
|
137
144
|
*/
|
138
|
-
export function filterInput_<RA, RB, EA, EB, A, B>(
|
145
|
+
export function filterInput_<RA, RB, EA, EB, A, B>(
|
146
|
+
self: PHub<RA, RB, EA, EB, A, B>,
|
147
|
+
f: (a: A) => boolean,
|
148
|
+
__tsplusTrace?: string,
|
149
|
+
) {
|
139
150
|
return self.filterInputIO((a) => IO.succeedNow(f(a)));
|
140
151
|
}
|
141
152
|
|
142
|
-
class FilterOutputIO<RA, RB, RB1, EA, EB, EB1, A, B> extends PHubInternal<RA, RB
|
153
|
+
class FilterOutputIO<RA, RB, RB1, EA, EB, EB1, A, B> extends PHubInternal<RA, RB | RB1, EA, EB | EB1, A, B> {
|
143
154
|
constructor(readonly source: PHubInternal<RA, RB, EA, EB, A, B>, readonly f: (a: B) => IO<RB1, EB1, boolean>) {
|
144
155
|
super();
|
145
156
|
}
|
@@ -162,7 +173,8 @@ class FilterOutputIO<RA, RB, RB1, EA, EB, EB1, A, B> extends PHubInternal<RA, RB
|
|
162
173
|
export function filterOutputIO_<RA, RB, RB1, EA, EB, EB1, A, B>(
|
163
174
|
source: PHub<RA, RB, EA, EB, A, B>,
|
164
175
|
f: (a: B) => IO<RB1, EB1, boolean>,
|
165
|
-
|
176
|
+
__tsplusTrace?: string,
|
177
|
+
): PHub<RA, RB | RB1, EA, EB | EB1, A, B> {
|
166
178
|
concrete(source);
|
167
179
|
return new FilterOutputIO(source, f);
|
168
180
|
}
|
@@ -175,6 +187,7 @@ export function filterOutputIO_<RA, RB, RB1, EA, EB, EB1, A, B>(
|
|
175
187
|
export function filterOutput_<RA, RB, EA, EB, A, B>(
|
176
188
|
self: PHub<RA, RB, EA, EB, A, B>,
|
177
189
|
f: (b: B) => boolean,
|
190
|
+
__tsplusTrace?: string,
|
178
191
|
): PHub<RA, RB, EA, EB, A, B> {
|
179
192
|
return self.filterOutputIO((b) => IO.succeedNow(f(b)));
|
180
193
|
}
|
@@ -184,7 +197,10 @@ export function filterOutput_<RA, RB, EA, EB, A, B>(
|
|
184
197
|
*
|
185
198
|
* @tsplus getter fncts.io.Hub isShutdown
|
186
199
|
*/
|
187
|
-
export function isShutdown<RA, RB, EA, EB, A, B>(
|
200
|
+
export function isShutdown<RA, RB, EA, EB, A, B>(
|
201
|
+
self: PHub<RA, RB, EA, EB, A, B>,
|
202
|
+
__tsplusTrace?: string,
|
203
|
+
): UIO<boolean> {
|
188
204
|
concrete(self);
|
189
205
|
return self.isShutdown;
|
190
206
|
}
|
@@ -198,7 +214,7 @@ export function isShutdown<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B
|
|
198
214
|
*
|
199
215
|
* @tsplus static fncts.io.HubOps makeBounded
|
200
216
|
*/
|
201
|
-
export function makeBounded<A>(requestedCapacity: number): UIO<Hub<A>> {
|
217
|
+
export function makeBounded<A>(requestedCapacity: number, __tsplusTrace?: string): UIO<Hub<A>> {
|
202
218
|
return IO.succeed(HubInternal.makeBounded<A>(requestedCapacity)).flatMap((hub) =>
|
203
219
|
makeHubInternal(hub, new BackPressure()),
|
204
220
|
);
|
@@ -212,7 +228,7 @@ export function makeBounded<A>(requestedCapacity: number): UIO<Hub<A>> {
|
|
212
228
|
*
|
213
229
|
* @tsplus static fncts.io.HubOps makeDropping
|
214
230
|
*/
|
215
|
-
export function makeDropping<A>(requestedCapacity: number): UIO<Hub<A>> {
|
231
|
+
export function makeDropping<A>(requestedCapacity: number, __tsplusTrace?: string): UIO<Hub<A>> {
|
216
232
|
return IO.succeed(HubInternal.makeBounded<A>(requestedCapacity)).flatMap((hub) =>
|
217
233
|
makeHubInternal(hub, new Dropping()),
|
218
234
|
);
|
@@ -226,7 +242,7 @@ export function makeDropping<A>(requestedCapacity: number): UIO<Hub<A>> {
|
|
226
242
|
*
|
227
243
|
* @tsplus static fncts.io.HubOps makeSliding
|
228
244
|
*/
|
229
|
-
export function makeSliding<A>(requestedCapacity: number): UIO<Hub<A>> {
|
245
|
+
export function makeSliding<A>(requestedCapacity: number, __tsplusTrace?: string): UIO<Hub<A>> {
|
230
246
|
return IO.succeed(HubInternal.makeBounded<A>(requestedCapacity)).flatMap((hub) =>
|
231
247
|
makeHubInternal(hub, new Sliding()),
|
232
248
|
);
|
@@ -237,7 +253,7 @@ export function makeSliding<A>(requestedCapacity: number): UIO<Hub<A>> {
|
|
237
253
|
*
|
238
254
|
* @tsplus static fncts.io.HubOps makeUnbounded
|
239
255
|
*/
|
240
|
-
export function makeUnbounded<A>(): UIO<Hub<A>> {
|
256
|
+
export function makeUnbounded<A>(__tsplusTrace?: string): UIO<Hub<A>> {
|
241
257
|
return IO.succeed(HubInternal.makeUnbounded<A>()).flatMap((hub) => makeHubInternal(hub, new Dropping()));
|
242
258
|
}
|
243
259
|
|
@@ -249,6 +265,7 @@ export function makeUnbounded<A>(): UIO<Hub<A>> {
|
|
249
265
|
export function map_<RA, RB, EA, EB, A, B, C>(
|
250
266
|
self: PHub<RA, RB, EA, EB, A, B>,
|
251
267
|
f: (b: B) => C,
|
268
|
+
__tsplusTrace?: string,
|
252
269
|
): PHub<RA, RB, EA, EB, A, C> {
|
253
270
|
return self.mapIO((b) => IO.succeedNow(f(b)));
|
254
271
|
}
|
@@ -262,7 +279,8 @@ export function map_<RA, RB, EA, EB, A, B, C>(
|
|
262
279
|
export function mapIO_<RA, RB, RC, EA, EB, EC, A, B, C>(
|
263
280
|
self: PHub<RA, RB, EA, EB, A, B>,
|
264
281
|
f: (b: B) => IO<RC, EC, C>,
|
265
|
-
|
282
|
+
__tsplusTrace?: string,
|
283
|
+
): PHub<RA, RC | RB, EA, EB | EC, A, C> {
|
266
284
|
return self.dimapIO(IO.succeedNow, f);
|
267
285
|
}
|
268
286
|
|
@@ -279,7 +297,7 @@ class ToQueue<RA, RB, EA, EB, A, B> extends QueueInternal<RA, never, EA, unknown
|
|
279
297
|
takeAll = IO.succeedNow(Conc.empty<never>());
|
280
298
|
offer = (a: A): IO<RA, EA, boolean> => this.source.publish(a);
|
281
299
|
offerAll = (as: Iterable<A>): IO<RA, EA, boolean> => this.source.publishAll(as);
|
282
|
-
takeUpTo = (): IO<
|
300
|
+
takeUpTo = (): IO<never, never, Conc<never>> => IO.succeedNow(Conc.empty());
|
283
301
|
}
|
284
302
|
|
285
303
|
/**
|
@@ -288,7 +306,11 @@ class ToQueue<RA, RB, EA, EB, A, B> extends QueueInternal<RA, never, EA, unknown
|
|
288
306
|
*
|
289
307
|
* @tsplus fluent fncts.io.Hub publish
|
290
308
|
*/
|
291
|
-
export function publish_<RA, RB, EA, EB, A, B>(
|
309
|
+
export function publish_<RA, RB, EA, EB, A, B>(
|
310
|
+
self: PHub<RA, RB, EA, EB, A, B>,
|
311
|
+
a: A,
|
312
|
+
__tsplusTrace?: string,
|
313
|
+
): IO<RA, EA, boolean> {
|
292
314
|
concrete(self);
|
293
315
|
return self.publish(a);
|
294
316
|
}
|
@@ -302,6 +324,7 @@ export function publish_<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B>,
|
|
302
324
|
export function publishAll_<RA, RB, EA, EB, A, B>(
|
303
325
|
self: PHub<RA, RB, EA, EB, A, B>,
|
304
326
|
as: Iterable<A>,
|
327
|
+
__tsplusTrace?: string,
|
305
328
|
): IO<RA, EA, boolean> {
|
306
329
|
concrete(self);
|
307
330
|
return self.publishAll(as);
|
@@ -312,7 +335,7 @@ export function publishAll_<RA, RB, EA, EB, A, B>(
|
|
312
335
|
*
|
313
336
|
* @tsplus getter fncts.io.Hub shutdown
|
314
337
|
*/
|
315
|
-
export function shutdown<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B
|
338
|
+
export function shutdown<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B>, __tsplusTrace?: string): UIO<void> {
|
316
339
|
concrete(self);
|
317
340
|
return self.shutdown;
|
318
341
|
}
|
@@ -326,7 +349,8 @@ export function shutdown<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B>)
|
|
326
349
|
*/
|
327
350
|
export function subscribe<RA, RB, EA, EB, A, B>(
|
328
351
|
self: PHub<RA, RB, EA, EB, A, B>,
|
329
|
-
|
352
|
+
__tsplusTrace?: string,
|
353
|
+
): IO<Scope, never, Hub.Dequeue<RB, EB, B>> {
|
330
354
|
concrete(self);
|
331
355
|
return self.subscribe;
|
332
356
|
}
|
@@ -336,7 +360,7 @@ export function subscribe<RA, RB, EA, EB, A, B>(
|
|
336
360
|
*
|
337
361
|
* @tsplus getter fncts.io.Hub size
|
338
362
|
*/
|
339
|
-
export function size<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B
|
363
|
+
export function size<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B>, __tsplusTrace?: string): UIO<number> {
|
340
364
|
concrete(self);
|
341
365
|
return self.size;
|
342
366
|
}
|
@@ -346,7 +370,10 @@ export function size<RA, RB, EA, EB, A, B>(self: PHub<RA, RB, EA, EB, A, B>): UI
|
|
346
370
|
*
|
347
371
|
* @tsplus getter fncts.io.Hub toQueue
|
348
372
|
*/
|
349
|
-
export function toQueue<RA, RB, EA, EB, A, B>(
|
373
|
+
export function toQueue<RA, RB, EA, EB, A, B>(
|
374
|
+
source: PHub<RA, RB, EA, EB, A, B>,
|
375
|
+
__tsplusTrace?: string,
|
376
|
+
): Hub.Enqueue<RA, EA, A> {
|
350
377
|
concrete(source);
|
351
378
|
return new ToQueue(source);
|
352
379
|
}
|
package/_src/Hub/definition.ts
CHANGED
@@ -13,8 +13,8 @@ export type HubTypeId = typeof HubTypeId;
|
|
13
13
|
*/
|
14
14
|
export interface PHub<RA, RB, EA, EB, A, B> {
|
15
15
|
readonly _typeId: HubTypeId;
|
16
|
-
readonly _RA: (
|
17
|
-
readonly _RB: (
|
16
|
+
readonly _RA: () => RA;
|
17
|
+
readonly _RB: () => RB;
|
18
18
|
readonly _EA: () => EA;
|
19
19
|
readonly _EB: () => EB;
|
20
20
|
readonly _A: (_: A) => void;
|
@@ -24,7 +24,7 @@ export interface PHub<RA, RB, EA, EB, A, B> {
|
|
24
24
|
/**
|
25
25
|
* @tsplus type fncts.io.Hub
|
26
26
|
*/
|
27
|
-
export interface Hub<A> extends PHub<
|
27
|
+
export interface Hub<A> extends PHub<never, never, never, never, A, A> {}
|
28
28
|
|
29
29
|
/**
|
30
30
|
* @tsplus type fncts.io.HubOps
|
@@ -40,8 +40,8 @@ export declare namespace Hub {
|
|
40
40
|
|
41
41
|
export abstract class PHubInternal<RA, RB, EA, EB, A, B> implements PHub<RA, RB, EA, EB, A, B> {
|
42
42
|
_typeId: HubTypeId = HubTypeId;
|
43
|
-
readonly _RA!: (
|
44
|
-
readonly _RB!: (
|
43
|
+
readonly _RA!: () => RA;
|
44
|
+
readonly _RB!: () => RB;
|
45
45
|
readonly _EA!: () => EA;
|
46
46
|
readonly _EB!: () => EB;
|
47
47
|
readonly _A!: (_: A) => void;
|
@@ -89,7 +89,7 @@ export abstract class PHubInternal<RA, RB, EA, EB, A, B> implements PHub<RA, RB,
|
|
89
89
|
* can be evaluated multiple times within the scope of the managed to take a
|
90
90
|
* message from the hub each time.
|
91
91
|
*/
|
92
|
-
abstract subscribe: IO<
|
92
|
+
abstract subscribe: IO<Scope, never, Hub.Dequeue<RB, EB, B>>;
|
93
93
|
}
|
94
94
|
|
95
95
|
/**
|
package/_src/Hub/internal.ts
CHANGED
@@ -125,10 +125,10 @@ export class BackPressure<A> extends Strategy<A> {
|
|
125
125
|
get shutdown(): UIO<void> {
|
126
126
|
// eslint-disable-next-line @typescript-eslint/no-this-alias
|
127
127
|
const self = this;
|
128
|
-
return
|
129
|
-
const fiberId =
|
130
|
-
const publishers =
|
131
|
-
|
128
|
+
return Do((_) => {
|
129
|
+
const fiberId = _(IO.fiberId);
|
130
|
+
const publishers = _(IO.succeed(self.publishers.unsafeDequeueAll));
|
131
|
+
_(IO.foreachC(publishers, ([_, future, last]) => (last ? future.interruptAs(fiberId) : IO.unit)));
|
132
132
|
});
|
133
133
|
}
|
134
134
|
|
@@ -254,7 +254,7 @@ export class Sliding<A> extends Strategy<A> {
|
|
254
254
|
}
|
255
255
|
}
|
256
256
|
|
257
|
-
class UnsafeSubscription<A> extends QueueInternal<never,
|
257
|
+
class UnsafeSubscription<A> extends QueueInternal<never, never, unknown, never, never, A> {
|
258
258
|
constructor(
|
259
259
|
readonly hub: HubInternal<A>,
|
260
260
|
readonly subscribers: HashSet<HashedPair<HubInternal.Subscription<A>, MutableQueue<Future<never, A>>>>,
|
@@ -294,7 +294,7 @@ class UnsafeSubscription<A> extends QueueInternal<never, unknown, unknown, never
|
|
294
294
|
|
295
295
|
offerAll = (_: Iterable<never>): IO<never, unknown, boolean> => IO.succeedNow(false);
|
296
296
|
|
297
|
-
take: IO<
|
297
|
+
take: IO<never, never, A> = IO.fiberId.flatMap((fiberId) =>
|
298
298
|
IO.defer(() => {
|
299
299
|
if (this.shutdownFlag.get) {
|
300
300
|
return IO.interrupt;
|
@@ -327,7 +327,7 @@ class UnsafeSubscription<A> extends QueueInternal<never, unknown, unknown, never
|
|
327
327
|
}),
|
328
328
|
);
|
329
329
|
|
330
|
-
takeAll: IO<
|
330
|
+
takeAll: IO<never, never, Conc<A>> = IO.defer(() => {
|
331
331
|
if (this.shutdownFlag.get) {
|
332
332
|
return IO.interrupt;
|
333
333
|
}
|
@@ -339,7 +339,7 @@ class UnsafeSubscription<A> extends QueueInternal<never, unknown, unknown, never
|
|
339
339
|
return IO.succeedNow(as);
|
340
340
|
});
|
341
341
|
|
342
|
-
takeUpTo = (n: number): IO<
|
342
|
+
takeUpTo = (n: number): IO<never, never, Conc<A>> => {
|
343
343
|
return IO.defer(() => {
|
344
344
|
if (this.shutdownFlag.get) {
|
345
345
|
return IO.interrupt;
|
@@ -395,7 +395,7 @@ export function subscribersHashSet<A>(): HashSet<
|
|
395
395
|
return HashSet.empty<HashedPair<HubInternal.Subscription<A>, MutableQueue<Future<never, A>>>>();
|
396
396
|
}
|
397
397
|
|
398
|
-
class UnsafeHub<A> extends PHubInternal<
|
398
|
+
class UnsafeHub<A> extends PHubInternal<never, never, never, never, A, A> {
|
399
399
|
constructor(
|
400
400
|
readonly hub: HubInternal<A>,
|
401
401
|
readonly subscribers: HashSet<HashedPair<HubInternal.Subscription<A>, MutableQueue<Future<never, A>>>>,
|
@@ -431,14 +431,14 @@ class UnsafeHub<A> extends PHubInternal<unknown, unknown, never, never, A, A> {
|
|
431
431
|
return IO.succeed(this.hub.size());
|
432
432
|
});
|
433
433
|
|
434
|
-
subscribe: IO<
|
434
|
+
subscribe: IO<Scope, never, Queue.Dequeue<A>> = IO.acquireRelease(
|
435
435
|
makeSubscription(this.hub, this.subscribers, this.strategy).tap((dequeue) =>
|
436
436
|
this.scope.addFinalizer(dequeue.shutdown),
|
437
437
|
),
|
438
438
|
(dequeue) => dequeue.shutdown,
|
439
439
|
);
|
440
440
|
|
441
|
-
publish = (a: A): IO<
|
441
|
+
publish = (a: A): IO<never, never, boolean> =>
|
442
442
|
IO.defer(() => {
|
443
443
|
if (this.shutdownFlag.get) {
|
444
444
|
return IO.interrupt;
|
@@ -452,7 +452,7 @@ class UnsafeHub<A> extends PHubInternal<unknown, unknown, never, never, A, A> {
|
|
452
452
|
return this.strategy.handleSurplus(this.hub, this.subscribers, Conc.single(a), this.shutdownFlag);
|
453
453
|
});
|
454
454
|
|
455
|
-
publishAll = (as: Iterable<A>): IO<
|
455
|
+
publishAll = (as: Iterable<A>): IO<never, never, boolean> =>
|
456
456
|
IO.defer(() => {
|
457
457
|
if (this.shutdownFlag.get) {
|
458
458
|
return IO.interrupt;
|
@@ -485,9 +485,9 @@ export function unsafeMakeHub<A>(
|
|
485
485
|
}
|
486
486
|
|
487
487
|
export function makeHubInternal<A>(hub: HubInternal<A>, strategy: Strategy<A>): UIO<Hub<A>> {
|
488
|
-
return
|
489
|
-
const scope =
|
490
|
-
const future =
|
488
|
+
return Do((_) => {
|
489
|
+
const scope = _(Scope.make);
|
490
|
+
const future = _(Future.make<never, void>());
|
491
491
|
return unsafeMakeHub(hub, subscribersHashSet(), scope, future, new AtomicBoolean(false), strategy);
|
492
492
|
});
|
493
493
|
}
|
@@ -5,6 +5,7 @@
|
|
5
5
|
export function acquireRelease<R, E, A, R1>(
|
6
6
|
acquire: Lazy<IO<R, E, A>>,
|
7
7
|
release: (a: A) => IO<R1, never, any>,
|
8
|
-
|
8
|
+
__tsplusTrace?: string,
|
9
|
+
): IO<R | R1 | Scope, E, A> {
|
9
10
|
return IO.acquireReleaseExit(acquire, (a, _) => release(a));
|
10
11
|
}
|
@@ -6,6 +6,6 @@ export function acquireReleaseExit<R, E, A, R1>(
|
|
6
6
|
acquire: Lazy<IO<R, E, A>>,
|
7
7
|
release: (a: A, exit: Exit<any, any>) => IO<R1, never, any>,
|
8
8
|
__tsplusTrace?: string,
|
9
|
-
): IO<R
|
9
|
+
): IO<R | R1 | Scope, E, A> {
|
10
10
|
return IO.uninterruptible(IO.defer(acquire).tap((a) => IO.addFinalizerExit((exit) => release(a, exit))));
|
11
11
|
}
|
@@ -5,6 +5,6 @@ export function acquireReleaseInterruptible<R, E, A, R1>(
|
|
5
5
|
acquire: Lazy<IO<R, E, A>>,
|
6
6
|
release: IO<R1, never, any>,
|
7
7
|
__tsplusTrace?: string,
|
8
|
-
): IO<R
|
8
|
+
): IO<R | R1 | Scope, E, A> {
|
9
9
|
return IO.acquireReleaseInterruptibleExit(acquire, () => release);
|
10
10
|
}
|
@@ -5,6 +5,6 @@ export function acquireReleaseInterruptibleExit<R, E, A, R1>(
|
|
5
5
|
acquire: Lazy<IO<R, E, A>>,
|
6
6
|
release: (exit: Exit<any, any>) => IO<R1, never, any>,
|
7
7
|
__tsplusTrace?: string,
|
8
|
-
): IO<R
|
8
|
+
): IO<R | R1 | Scope, E, A> {
|
9
9
|
return IO.defer(acquire).ensuring(IO.addFinalizerExit(release));
|
10
10
|
}
|
@@ -1,9 +1,6 @@
|
|
1
1
|
/**
|
2
2
|
* @tsplus static fncts.io.IOOps addFinalizer
|
3
3
|
*/
|
4
|
-
export function addFinalizer<R>(
|
5
|
-
finalizer: Lazy<URIO<R, any>>,
|
6
|
-
__tsplusTrace?: string,
|
7
|
-
): IO<R & Has<Scope>, never, void> {
|
4
|
+
export function addFinalizer<R>(finalizer: Lazy<URIO<R, any>>, __tsplusTrace?: string): IO<R | Scope, never, void> {
|
8
5
|
return IO.addFinalizerExit(() => finalizer());
|
9
6
|
}
|
@@ -3,10 +3,11 @@
|
|
3
3
|
*/
|
4
4
|
export function addFinalizerExit<R>(
|
5
5
|
finalizer: (exit: Exit<any, any>) => URIO<R, any>,
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
const
|
10
|
-
|
6
|
+
__tsplusTrace?: string,
|
7
|
+
): IO<R | Scope, never, void> {
|
8
|
+
return Do((_) => {
|
9
|
+
const environment = _(IO.environment<R>());
|
10
|
+
const scope = _(IO.scope);
|
11
|
+
_(scope.addFinalizerExit(Finalizer.get((exit) => finalizer(exit).provideEnvironment(environment))));
|
11
12
|
});
|
12
13
|
}
|
package/_src/IO/api/asyncIO.ts
CHANGED
@@ -1,7 +1,10 @@
|
|
1
1
|
/**
|
2
2
|
* @tsplus static fncts.io.IOOps asyncIO
|
3
3
|
*/
|
4
|
-
export function asyncIO<R, E, A>(
|
4
|
+
export function asyncIO<R, E, A>(
|
5
|
+
register: (k: (_: IO<R, E, A>) => void) => IO<R, E, void>,
|
6
|
+
__tsplusTrace?: string,
|
7
|
+
): IO<R, E, A> {
|
5
8
|
return Do((Δ) => {
|
6
9
|
const f = Δ(Future.make<E, A>());
|
7
10
|
const r = Δ(IO.runtime<R>());
|
package/_src/IO/api/bracket.ts
CHANGED
@@ -25,6 +25,7 @@ export function bracket_<R, E, A, R1, E1, A1, R2, E2, A2>(
|
|
25
25
|
acquire: Lazy<IO<R, E, A>>,
|
26
26
|
use: (a: A) => IO<R1, E1, A1>,
|
27
27
|
release: (a: A) => IO<R2, E2, A2>,
|
28
|
-
|
28
|
+
__tsplusTrace?: string,
|
29
|
+
): IO<R | R1 | R2, E | E1 | E2, A1> {
|
29
30
|
return IO.bracketExit(acquire, use, release);
|
30
31
|
}
|
@@ -12,7 +12,8 @@ export function bracketExit_<R, E, A, E1, R1, A1, R2, E2>(
|
|
12
12
|
acquire: Lazy<IO<R, E, A>>,
|
13
13
|
use: (a: A) => IO<R1, E1, A1>,
|
14
14
|
release: (a: A, e: Exit<E1, A1>) => IO<R2, E2, any>,
|
15
|
-
|
15
|
+
__tsplusTrace?: string,
|
16
|
+
): IO<R | R1 | R2, E | E1 | E2, A1> {
|
16
17
|
return IO.uninterruptibleMask(({ restore }) =>
|
17
18
|
acquire().flatMap((a) =>
|
18
19
|
IO.defer(restore(use(a))).result.flatMap((exit) =>
|
@@ -17,7 +17,10 @@ export const concurrency: UIO<Maybe<number>> = Concurrency.get;
|
|
17
17
|
*
|
18
18
|
* @tsplus static fncts.io.IOOps concurrencyWith
|
19
19
|
*/
|
20
|
-
export function concurrencyWith<R, E, A>(
|
20
|
+
export function concurrencyWith<R, E, A>(
|
21
|
+
f: (concurrency: Maybe<number>) => IO<R, E, A>,
|
22
|
+
__tsplusTrace?: string,
|
23
|
+
): IO<R, E, A> {
|
21
24
|
return Concurrency.getWith(f);
|
22
25
|
}
|
23
26
|
|
@@ -27,7 +30,7 @@ export function concurrencyWith<R, E, A>(f: (concurrency: Maybe<number>) => IO<R
|
|
27
30
|
*
|
28
31
|
* @tsplus fluent fncts.io.IO withConcurrency
|
29
32
|
*/
|
30
|
-
export function withConcurrency_<R, E, A>(ma: IO<R, E, A>, n: number): IO<R, E, A> {
|
33
|
+
export function withConcurrency_<R, E, A>(ma: IO<R, E, A>, n: number, __tsplusTrace?: string): IO<R, E, A> {
|
31
34
|
return IO.defer(Concurrency.locally(Just(n))(ma));
|
32
35
|
}
|
33
36
|
|
@@ -37,6 +40,6 @@ export function withConcurrency_<R, E, A>(ma: IO<R, E, A>, n: number): IO<R, E,
|
|
37
40
|
*
|
38
41
|
* @tsplus getter fncts.io.IO withConcurrencyUnbounded
|
39
42
|
*/
|
40
|
-
export function withConcurrencyUnbounded<R, E, A>(ma: IO<R, E, A
|
43
|
+
export function withConcurrencyUnbounded<R, E, A>(ma: IO<R, E, A>, __tsplusTrace?: string): IO<R, E, A> {
|
41
44
|
return IO.defer(Concurrency.locally(Nothing())(ma));
|
42
45
|
}
|