@fncts/io 0.0.21 → 0.0.23
Sign up to get free protection for your applications and to get access to all the features.
- package/Cached/definition.d.ts +6 -4
- package/Cached/internal.d.ts +4 -4
- package/Channel/api/mapOutConcurrentIO.d.ts +8 -0
- package/Channel/api/zipConcurrent.d.ts +16 -0
- package/Channel/api.d.ts +9 -9
- package/Channel/core-api.d.ts +4 -4
- package/Channel/definition.d.ts +35 -14
- package/Channel/internal/ChannelExecutor.d.ts +1 -0
- package/Channel/internal/MergeDecision.d.ts +10 -6
- package/Channel/internal/SingleProducerAsyncInput.d.ts +1 -1
- package/CountdownLatch.d.ts +25 -0
- package/Differ/definition.d.ts +2 -4
- package/Fiber/FiberMessage.d.ts +67 -0
- package/Fiber/FiberRuntime.d.ts +114 -0
- package/Fiber/api/interrupt.d.ts +1 -1
- package/Fiber/api/interruptAs.d.ts +8 -3
- package/Fiber/api/location.d.ts +1 -2
- package/Fiber/definition.d.ts +29 -22
- package/Fiber.d.ts +2 -4
- package/FiberDescriptor.d.ts +3 -6
- package/FiberRef/definition.d.ts +8 -4
- package/FiberRef/unsafe.d.ts +5 -0
- package/FiberRefs/api.d.ts +28 -0
- package/FiberRefs/definition.d.ts +14 -7
- package/FiberScope/constructors.d.ts +2 -2
- package/FiberScope/definition.d.ts +8 -5
- package/FiberStatus/constructors.d.ts +3 -7
- package/FiberStatus/definition.d.ts +16 -28
- package/Hub/api.d.ts +192 -0
- package/Hub/definition.d.ts +97 -35
- package/Hub/internal.d.ts +11 -4
- package/Hub.d.ts +1 -1
- package/IO/api/asyncInterrupt.d.ts +39 -0
- package/IO/api/core-scope.d.ts +6 -42
- package/IO/api/delay.d.ts +8 -0
- package/IO/api/{foreachC.d.ts → foreachConcurrent.d.ts} +8 -8
- package/IO/api/fork.d.ts +36 -0
- package/IO/api/interrupt.d.ts +23 -27
- package/IO/api/onTermination.d.ts +0 -1
- package/IO/api/race.d.ts +1 -1
- package/IO/api/sequenceT.d.ts +19 -3
- package/IO/api/supervised.d.ts +4 -6
- package/IO/api/zipConcurrent.d.ts +13 -0
- package/IO/api.d.ts +45 -130
- package/IO/definition.d.ts +137 -148
- package/IO/runtime.d.ts +19 -22
- package/IO.d.ts +5 -4
- package/Layer/MemoMap.d.ts +1 -1
- package/Layer/definition.d.ts +17 -13
- package/Logger/definition.d.ts +10 -6
- package/MVar/api.d.ts +101 -0
- package/MVar/definition.d.ts +43 -0
- package/MVar.d.ts +2 -0
- package/Push/api.d.ts +235 -0
- package/Push/definition.d.ts +41 -0
- package/Push/internal.d.ts +11 -0
- package/Push.d.ts +3 -0
- package/Queue/api/dimapIO.d.ts +102 -0
- package/Queue/api/filterInputIO.d.ts +25 -0
- package/Queue/api/filterOutputIO.d.ts +20 -0
- package/Queue/api/operations.d.ts +83 -0
- package/Queue/api/poll.d.ts +9 -0
- package/Queue/api/takeBetween.d.ts +11 -0
- package/Queue/api/zipWithIO.d.ts +27 -0
- package/Queue/api.d.ts +7 -0
- package/Queue/constructors.d.ts +1 -2
- package/Queue/definition.d.ts +178 -75
- package/Queue/internal.d.ts +4 -2
- package/Queue.d.ts +2 -0
- package/Ref/Atomic.d.ts +15 -8
- package/Ref/Derived.d.ts +18 -0
- package/Ref/DerivedAll.d.ts +18 -0
- package/Ref/Synchronized/api.d.ts +102 -0
- package/Ref/Synchronized/constructors.d.ts +13 -0
- package/Ref/Synchronized/definition.d.ts +46 -0
- package/Ref/Synchronized.d.ts +3 -72
- package/Ref/api/collect.d.ts +11 -0
- package/Ref/api/dimap.d.ts +56 -0
- package/Ref/api/filter.d.ts +21 -0
- package/Ref/api/get.d.ts +9 -0
- package/Ref/api/match.d.ts +13 -0
- package/Ref/api/matchAll.d.ts +11 -0
- package/Ref/api/modify.d.ts +79 -0
- package/Ref/api/set.d.ts +10 -0
- package/Ref/api.d.ts +23 -0
- package/Ref/constructors.d.ts +1 -8
- package/Ref/definition.d.ts +90 -55
- package/Ref.d.ts +6 -0
- package/RefSubject/Atomic.d.ts +36 -0
- package/RefSubject/Synchronized/api.d.ts +9 -0
- package/RefSubject/Synchronized/definition.d.ts +40 -0
- package/RefSubject/api.d.ts +116 -0
- package/RefSubject/definition.d.ts +51 -0
- package/RefSubject.d.ts +3 -0
- package/Reloadable/definition.d.ts +5 -1
- package/RuntimeConfig.d.ts +0 -24
- package/RuntimeFlag.d.ts +10 -0
- package/RuntimeFlags/Patch.d.ts +53 -0
- package/RuntimeFlags/RuntimeFlags.d.ts +82 -0
- package/RuntimeFlags.d.ts +2 -0
- package/STM/api/atomically.d.ts +9 -0
- package/STM/api.d.ts +12 -6
- package/STM/definition.d.ts +28 -15
- package/STM/internal/Entry.d.ts +2 -2
- package/STM/internal/TryCommit.d.ts +2 -2
- package/STM/internal/Versioned.d.ts +1 -1
- package/STM.d.ts +1 -0
- package/Schedule/api.d.ts +33 -17
- package/Schedule/definition.d.ts +7 -3
- package/Scope/ReleaseMap/definition.d.ts +1 -1
- package/Scope/definition.d.ts +1 -1
- package/ScopedRef/api.d.ts +1 -1
- package/ScopedRef/definition.d.ts +1 -1
- package/Sink/api.d.ts +12 -12
- package/State/api.d.ts +1 -1
- package/State/definition.d.ts +5 -2
- package/State/internal.d.ts +6 -2
- package/Stream/api.d.ts +20 -19
- package/Stream/definition.d.ts +26 -5
- package/Stream/internal/Handoff.d.ts +22 -16
- package/Stream/internal/Pull.d.ts +2 -2
- package/Stream/internal/SinkEndReason.d.ts +2 -2
- package/Subject/Atomic.d.ts +22 -0
- package/Subject/api.d.ts +13 -0
- package/Subject/definition.d.ts +15 -0
- package/Subject.d.ts +3 -0
- package/SubscriptionRef.d.ts +16 -7
- package/SupervisorPatch.d.ts +1 -1
- package/TExit/definition.d.ts +7 -7
- package/TFuture/definition.d.ts +2 -2
- package/TReentrantLock/definition.d.ts +3 -3
- package/TRef/api.d.ts +14 -15
- package/TRef/constructors.d.ts +6 -6
- package/TRef/definition.d.ts +54 -39
- package/TSemaphore/definition.d.ts +2 -2
- package/_cjs/Cached/api.cjs +1 -24
- package/_cjs/Cached/api.cjs.map +1 -1
- package/_cjs/Cached/definition.cjs +6 -9
- package/_cjs/Cached/definition.cjs.map +1 -1
- package/_cjs/Cached/internal.cjs +7 -9
- package/_cjs/Cached/internal.cjs.map +1 -1
- package/_cjs/Cached.cjs +0 -6
- package/_cjs/Cached.cjs.map +1 -1
- package/_cjs/CancellerState.cjs +3 -22
- package/_cjs/CancellerState.cjs.map +1 -1
- package/_cjs/Channel/ChildExecutorDecision/api.cjs +0 -3
- package/_cjs/Channel/ChildExecutorDecision/api.cjs.map +1 -1
- package/_cjs/Channel/ChildExecutorDecision/definition.cjs +0 -5
- package/_cjs/Channel/ChildExecutorDecision/definition.cjs.map +1 -1
- package/_cjs/Channel/ChildExecutorDecision.cjs +0 -4
- package/_cjs/Channel/ChildExecutorDecision.cjs.map +1 -1
- package/_cjs/Channel/UpstreamPullRequest/api.cjs +0 -7
- package/_cjs/Channel/UpstreamPullRequest/api.cjs.map +1 -1
- package/_cjs/Channel/UpstreamPullRequest/definition.cjs +0 -6
- package/_cjs/Channel/UpstreamPullRequest/definition.cjs.map +1 -1
- package/_cjs/Channel/UpstreamPullRequest.cjs +0 -4
- package/_cjs/Channel/UpstreamPullRequest.cjs.map +1 -1
- package/_cjs/Channel/UpstreamPullStrategy/definition.cjs +0 -4
- package/_cjs/Channel/UpstreamPullStrategy/definition.cjs.map +1 -1
- package/_cjs/Channel/UpstreamPullStrategy.cjs +0 -2
- package/_cjs/Channel/UpstreamPullStrategy.cjs.map +1 -1
- package/_cjs/Channel/api/interruptWhen.cjs +0 -12
- package/_cjs/Channel/api/interruptWhen.cjs.map +1 -1
- package/_cjs/Channel/api/mapOutConcurrentIO.cjs +42 -0
- package/_cjs/Channel/api/mapOutConcurrentIO.cjs.map +1 -0
- package/_cjs/Channel/api/mergeAll.cjs +0 -4
- package/_cjs/Channel/api/mergeAll.cjs.map +1 -1
- package/_cjs/Channel/api/mergeAllUnboundedWith.cjs +0 -4
- package/_cjs/Channel/api/mergeAllUnboundedWith.cjs.map +1 -1
- package/_cjs/Channel/api/mergeAllWith.cjs +39 -66
- package/_cjs/Channel/api/mergeAllWith.cjs.map +1 -1
- package/_cjs/Channel/api/mergeMap.cjs +0 -5
- package/_cjs/Channel/api/mergeMap.cjs.map +1 -1
- package/_cjs/Channel/api/mergeWith.cjs +10 -44
- package/_cjs/Channel/api/mergeWith.cjs.map +1 -1
- package/_cjs/Channel/api/run.cjs +0 -6
- package/_cjs/Channel/api/run.cjs.map +1 -1
- package/_cjs/Channel/api/runCollect.cjs +0 -5
- package/_cjs/Channel/api/runCollect.cjs.map +1 -1
- package/_cjs/Channel/api/runDrain.cjs +0 -5
- package/_cjs/Channel/api/runDrain.cjs.map +1 -1
- package/_cjs/Channel/api/runScoped.cjs +4 -26
- package/_cjs/Channel/api/runScoped.cjs.map +1 -1
- package/_cjs/Channel/api/toPull.cjs +4 -26
- package/_cjs/Channel/api/toPull.cjs.map +1 -1
- package/_cjs/Channel/api/{zipC.cjs → zipConcurrent.cjs} +16 -30
- package/_cjs/Channel/api/zipConcurrent.cjs.map +1 -0
- package/_cjs/Channel/api.cjs +85 -256
- package/_cjs/Channel/api.cjs.map +1 -1
- package/_cjs/Channel/core-api.cjs +6 -30
- package/_cjs/Channel/core-api.cjs.map +1 -1
- package/_cjs/Channel/definition.cjs +32 -108
- package/_cjs/Channel/definition.cjs.map +1 -1
- package/_cjs/Channel/internal/ChannelExecutor.cjs +117 -322
- package/_cjs/Channel/internal/ChannelExecutor.cjs.map +1 -1
- package/_cjs/Channel/internal/ChannelState.cjs +5 -37
- package/_cjs/Channel/internal/ChannelState.cjs.map +1 -1
- package/_cjs/Channel/internal/MergeDecision.cjs +11 -30
- package/_cjs/Channel/internal/MergeDecision.cjs.map +1 -1
- package/_cjs/Channel/internal/MergeState.cjs +3 -24
- package/_cjs/Channel/internal/MergeState.cjs.map +1 -1
- package/_cjs/Channel/internal/SingleProducerAsyncInput.cjs +41 -133
- package/_cjs/Channel/internal/SingleProducerAsyncInput.cjs.map +1 -1
- package/_cjs/Channel.cjs +0 -6
- package/_cjs/Channel.cjs.map +1 -1
- package/_cjs/Clock/api.cjs +0 -7
- package/_cjs/Clock/api.cjs.map +1 -1
- package/_cjs/Clock/definition.cjs +0 -6
- package/_cjs/Clock/definition.cjs.map +1 -1
- package/_cjs/Clock/live.cjs +2 -12
- package/_cjs/Clock/live.cjs.map +1 -1
- package/_cjs/Clock.cjs +0 -6
- package/_cjs/Clock.cjs.map +1 -1
- package/_cjs/Console/api.cjs +0 -7
- package/_cjs/Console/api.cjs.map +1 -1
- package/_cjs/Console/definition.cjs +0 -6
- package/_cjs/Console/definition.cjs.map +1 -1
- package/_cjs/Console/live.cjs +0 -11
- package/_cjs/Console/live.cjs.map +1 -1
- package/_cjs/Console.cjs +0 -6
- package/_cjs/Console.cjs.map +1 -1
- package/_cjs/CountdownLatch.cjs +52 -0
- package/_cjs/CountdownLatch.cjs.map +1 -0
- package/_cjs/Differ/api.cjs +0 -23
- package/_cjs/Differ/api.cjs.map +1 -1
- package/_cjs/Differ/definition.cjs +3 -5
- package/_cjs/Differ/definition.cjs.map +1 -1
- package/_cjs/Fiber/FiberMessage.cjs +72 -0
- package/_cjs/Fiber/FiberMessage.cjs.map +1 -0
- package/_cjs/Fiber/FiberRuntime.cjs +742 -0
- package/_cjs/Fiber/FiberRuntime.cjs.map +1 -0
- package/_cjs/Fiber/api/await.cjs +0 -1
- package/_cjs/Fiber/api/await.cjs.map +1 -1
- package/_cjs/Fiber/api/awaitAll.cjs +2 -8
- package/_cjs/Fiber/api/awaitAll.cjs.map +1 -1
- package/_cjs/Fiber/api/children.cjs +0 -1
- package/_cjs/Fiber/api/children.cjs.map +1 -1
- package/_cjs/Fiber/api/collectAll.cjs +3 -25
- package/_cjs/Fiber/api/collectAll.cjs.map +1 -1
- package/_cjs/Fiber/api/fromIO.cjs +0 -5
- package/_cjs/Fiber/api/fromIO.cjs.map +1 -1
- package/_cjs/Fiber/api/id.cjs +0 -1
- package/_cjs/Fiber/api/id.cjs.map +1 -1
- package/_cjs/Fiber/api/inheritRefs.cjs +1 -2
- package/_cjs/Fiber/api/inheritRefs.cjs.map +1 -1
- package/_cjs/Fiber/api/interrupt.cjs +3 -8
- package/_cjs/Fiber/api/interrupt.cjs.map +1 -1
- package/_cjs/Fiber/api/interruptAll.cjs +2 -12
- package/_cjs/Fiber/api/interruptAll.cjs.map +1 -1
- package/_cjs/Fiber/api/interruptAs.cjs +16 -11
- package/_cjs/Fiber/api/interruptAs.cjs.map +1 -1
- package/_cjs/Fiber/api/interruptFork.cjs +2 -9
- package/_cjs/Fiber/api/interruptFork.cjs.map +1 -1
- package/_cjs/Fiber/api/join.cjs +3 -6
- package/_cjs/Fiber/api/join.cjs.map +1 -1
- package/_cjs/Fiber/api/joinAll.cjs +0 -6
- package/_cjs/Fiber/api/joinAll.cjs.map +1 -1
- package/_cjs/Fiber/api/location.cjs +1 -8
- package/_cjs/Fiber/api/location.cjs.map +1 -1
- package/_cjs/Fiber/api/mapFiber.cjs +0 -7
- package/_cjs/Fiber/api/mapFiber.cjs.map +1 -1
- package/_cjs/Fiber/api/mapIO.cjs +1 -18
- package/_cjs/Fiber/api/mapIO.cjs.map +1 -1
- package/_cjs/Fiber/api/poll.cjs +0 -1
- package/_cjs/Fiber/api/poll.cjs.map +1 -1
- package/_cjs/Fiber/api/zipWith.cjs +2 -18
- package/_cjs/Fiber/api/zipWith.cjs.map +1 -1
- package/_cjs/Fiber/constructors.cjs +0 -18
- package/_cjs/Fiber/constructors.cjs.map +1 -1
- package/_cjs/Fiber/definition.cjs +18 -17
- package/_cjs/Fiber/definition.cjs.map +1 -1
- package/_cjs/Fiber.cjs +15 -85
- package/_cjs/Fiber.cjs.map +1 -1
- package/_cjs/FiberDescriptor.cjs +1 -6
- package/_cjs/FiberDescriptor.cjs.map +1 -1
- package/_cjs/FiberRef/api/locallyScoped.cjs +0 -6
- package/_cjs/FiberRef/api/locallyScoped.cjs.map +1 -1
- package/_cjs/FiberRef/api/locallyScopedWith.cjs +0 -5
- package/_cjs/FiberRef/api/locallyScopedWith.cjs.map +1 -1
- package/_cjs/FiberRef/api.cjs +18 -54
- package/_cjs/FiberRef/api.cjs.map +1 -1
- package/_cjs/FiberRef/constructors.cjs +0 -10
- package/_cjs/FiberRef/constructors.cjs.map +1 -1
- package/_cjs/FiberRef/definition.cjs +13 -27
- package/_cjs/FiberRef/definition.cjs.map +1 -1
- package/_cjs/FiberRef/unsafe.cjs +20 -48
- package/_cjs/FiberRef/unsafe.cjs.map +1 -1
- package/_cjs/FiberRef.cjs +0 -12
- package/_cjs/FiberRef.cjs.map +1 -1
- package/_cjs/FiberRefs/api.cjs +62 -22
- package/_cjs/FiberRefs/api.cjs.map +1 -1
- package/_cjs/FiberRefs/definition.cjs +5 -17
- package/_cjs/FiberRefs/definition.cjs.map +1 -1
- package/_cjs/FiberRefs/join.cjs +34 -56
- package/_cjs/FiberRefs/join.cjs.map +1 -1
- package/_cjs/FiberRefs.cjs +0 -6
- package/_cjs/FiberRefs.cjs.map +1 -1
- package/_cjs/FiberScope/constructors.cjs +0 -4
- package/_cjs/FiberScope/constructors.cjs.map +1 -1
- package/_cjs/FiberScope/definition.cjs +15 -20
- package/_cjs/FiberScope/definition.cjs.map +1 -1
- package/_cjs/FiberScope.cjs +0 -4
- package/_cjs/FiberScope.cjs.map +1 -1
- package/_cjs/FiberStatus/constructors.cjs +5 -20
- package/_cjs/FiberStatus/constructors.cjs.map +1 -1
- package/_cjs/FiberStatus/definition.cjs +18 -77
- package/_cjs/FiberStatus/definition.cjs.map +1 -1
- package/_cjs/FiberStatus.cjs +0 -4
- package/_cjs/FiberStatus.cjs.map +1 -1
- package/_cjs/Future/api.cjs +28 -77
- package/_cjs/Future/api.cjs.map +1 -1
- package/_cjs/Future/constructors.cjs +0 -11
- package/_cjs/Future/constructors.cjs.map +1 -1
- package/_cjs/Future/definition.cjs +2 -15
- package/_cjs/Future/definition.cjs.map +1 -1
- package/_cjs/Future.cjs +0 -6
- package/_cjs/Future.cjs.map +1 -1
- package/_cjs/Hub/api.cjs +396 -0
- package/_cjs/Hub/api.cjs.map +1 -0
- package/_cjs/Hub/definition.cjs +22 -104
- package/_cjs/Hub/definition.cjs.map +1 -1
- package/_cjs/Hub/internal.cjs +103 -170
- package/_cjs/Hub/internal.cjs.map +1 -1
- package/_cjs/Hub.cjs +4 -8
- package/_cjs/Hub.cjs.map +1 -1
- package/_cjs/IO/api/acquireRelease.cjs +0 -4
- package/_cjs/IO/api/acquireRelease.cjs.map +1 -1
- package/_cjs/IO/api/acquireReleaseExit.cjs +0 -6
- package/_cjs/IO/api/acquireReleaseExit.cjs.map +1 -1
- package/_cjs/IO/api/acquireReleaseInterruptible.cjs +0 -4
- package/_cjs/IO/api/acquireReleaseInterruptible.cjs.map +1 -1
- package/_cjs/IO/api/acquireReleaseInterruptibleExit.cjs +2 -6
- package/_cjs/IO/api/acquireReleaseInterruptibleExit.cjs.map +1 -1
- package/_cjs/IO/api/addFinalizer.cjs +0 -4
- package/_cjs/IO/api/addFinalizer.cjs.map +1 -1
- package/_cjs/IO/api/addFinalizerExit.cjs +0 -7
- package/_cjs/IO/api/addFinalizerExit.cjs.map +1 -1
- package/_cjs/IO/api/asyncIO.cjs +7 -15
- package/_cjs/IO/api/asyncIO.cjs.map +1 -1
- package/_cjs/IO/api/asyncInterrupt.cjs +77 -0
- package/_cjs/IO/api/asyncInterrupt.cjs.map +1 -0
- package/_cjs/IO/api/bracket.cjs +0 -4
- package/_cjs/IO/api/bracket.cjs.map +1 -1
- package/_cjs/IO/api/bracketExit.cjs +1 -8
- package/_cjs/IO/api/bracketExit.cjs.map +1 -1
- package/_cjs/IO/api/clockWith.cjs +0 -12
- package/_cjs/IO/api/clockWith.cjs.map +1 -1
- package/_cjs/IO/api/concurrency.cjs +0 -15
- package/_cjs/IO/api/concurrency.cjs.map +1 -1
- package/_cjs/IO/api/concurrentFinalizers.cjs +0 -7
- package/_cjs/IO/api/concurrentFinalizers.cjs.map +1 -1
- package/_cjs/IO/api/consoleWith.cjs +0 -12
- package/_cjs/IO/api/consoleWith.cjs.map +1 -1
- package/_cjs/IO/api/core-scope.cjs +49 -119
- package/_cjs/IO/api/core-scope.cjs.map +1 -1
- package/_cjs/IO/api/{onExit.cjs → delay.cjs} +8 -12
- package/_cjs/IO/api/delay.cjs.map +1 -0
- package/_cjs/IO/api/ensuringChildren.cjs +3 -8
- package/_cjs/IO/api/ensuringChildren.cjs.map +1 -1
- package/_cjs/IO/api/environment.cjs +0 -29
- package/_cjs/IO/api/environment.cjs.map +1 -1
- package/_cjs/IO/api/{foreachC.cjs → foreachConcurrent.cjs} +32 -65
- package/_cjs/IO/api/foreachConcurrent.cjs.map +1 -0
- package/_cjs/IO/api/foreachExec.cjs +2 -9
- package/_cjs/IO/api/foreachExec.cjs.map +1 -1
- package/_cjs/IO/api/fork.cjs +75 -0
- package/_cjs/IO/api/fork.cjs.map +1 -0
- package/_cjs/IO/api/forkAll.cjs +3 -7
- package/_cjs/IO/api/forkAll.cjs.map +1 -1
- package/_cjs/IO/api/forkIn.cjs +1 -9
- package/_cjs/IO/api/forkIn.cjs.map +1 -1
- package/_cjs/IO/api/forkScoped.cjs +1 -9
- package/_cjs/IO/api/forkScoped.cjs.map +1 -1
- package/_cjs/IO/api/fulfill.cjs +1 -7
- package/_cjs/IO/api/fulfill.cjs.map +1 -1
- package/_cjs/IO/api/interrupt.cjs +78 -101
- package/_cjs/IO/api/interrupt.cjs.map +1 -1
- package/_cjs/IO/api/memoize.cjs +1 -8
- package/_cjs/IO/api/memoize.cjs.map +1 -1
- package/_cjs/IO/api/onTermination.cjs +7 -14
- package/_cjs/IO/api/onTermination.cjs.map +1 -1
- package/_cjs/IO/api/once.cjs +4 -8
- package/_cjs/IO/api/once.cjs.map +1 -1
- package/_cjs/IO/api/provideLayer.cjs +0 -8
- package/_cjs/IO/api/provideLayer.cjs.map +1 -1
- package/_cjs/IO/api/provideSomeLayer.cjs +0 -5
- package/_cjs/IO/api/provideSomeLayer.cjs.map +1 -1
- package/_cjs/IO/api/race.cjs +4 -15
- package/_cjs/IO/api/race.cjs.map +1 -1
- package/_cjs/IO/api/raceFirst.cjs +1 -6
- package/_cjs/IO/api/raceFirst.cjs.map +1 -1
- package/_cjs/IO/api/randomWith.cjs +0 -12
- package/_cjs/IO/api/randomWith.cjs.map +1 -1
- package/_cjs/IO/api/repeat.cjs +0 -15
- package/_cjs/IO/api/repeat.cjs.map +1 -1
- package/_cjs/IO/api/retry.cjs +0 -15
- package/_cjs/IO/api/retry.cjs.map +1 -1
- package/_cjs/IO/api/schedule.cjs +0 -10
- package/_cjs/IO/api/schedule.cjs.map +1 -1
- package/_cjs/IO/api/scope.cjs +0 -6
- package/_cjs/IO/api/scope.cjs.map +1 -1
- package/_cjs/IO/api/scopeWith.cjs +0 -5
- package/_cjs/IO/api/scopeWith.cjs.map +1 -1
- package/_cjs/IO/api/scoped.cjs +0 -9
- package/_cjs/IO/api/scoped.cjs.map +1 -1
- package/_cjs/IO/api/sequenceT.cjs +1 -7
- package/_cjs/IO/api/sequenceT.cjs.map +1 -1
- package/_cjs/IO/api/sleep.cjs +0 -4
- package/_cjs/IO/api/sleep.cjs.map +1 -1
- package/_cjs/IO/api/stateful.cjs +0 -6
- package/_cjs/IO/api/stateful.cjs.map +1 -1
- package/_cjs/IO/api/supervised.cjs +6 -16
- package/_cjs/IO/api/supervised.cjs.map +1 -1
- package/_cjs/IO/api/timeout.cjs +0 -12
- package/_cjs/IO/api/timeout.cjs.map +1 -1
- package/_cjs/IO/api/withChildren.cjs +2 -10
- package/_cjs/IO/api/withChildren.cjs.map +1 -1
- package/_cjs/IO/api/withEarlyRelease.cjs +0 -7
- package/_cjs/IO/api/withEarlyRelease.cjs.map +1 -1
- package/_cjs/IO/api/withFinalizer.cjs +0 -4
- package/_cjs/IO/api/withFinalizer.cjs.map +1 -1
- package/_cjs/IO/api/withFinalizerExit.cjs +0 -4
- package/_cjs/IO/api/withFinalizerExit.cjs.map +1 -1
- package/_cjs/IO/api/{zipC.cjs → zipConcurrent.cjs} +21 -41
- package/_cjs/IO/api/zipConcurrent.cjs.map +1 -0
- package/_cjs/IO/api.cjs +180 -667
- package/_cjs/IO/api.cjs.map +1 -1
- package/_cjs/IO/definition.cjs +131 -218
- package/_cjs/IO/definition.cjs.map +1 -1
- package/_cjs/IO/runtime.cjs +51 -119
- package/_cjs/IO/runtime.cjs.map +1 -1
- package/_cjs/IO.cjs +41 -134
- package/_cjs/IO.cjs.map +1 -1
- package/_cjs/IOEnv/definition.cjs +0 -11
- package/_cjs/IOEnv/definition.cjs.map +1 -1
- package/_cjs/IOEnv/live.cjs +0 -11
- package/_cjs/IOEnv/live.cjs.map +1 -1
- package/_cjs/IOEnv/services.cjs +0 -5
- package/_cjs/IOEnv/services.cjs.map +1 -1
- package/_cjs/IOEnv.cjs +0 -6
- package/_cjs/IOEnv.cjs.map +1 -1
- package/_cjs/InterruptStatus/constructors.cjs +0 -5
- package/_cjs/InterruptStatus/constructors.cjs.map +1 -1
- package/_cjs/InterruptStatus/definition.cjs +0 -5
- package/_cjs/InterruptStatus/definition.cjs.map +1 -1
- package/_cjs/InterruptStatus.cjs +0 -4
- package/_cjs/InterruptStatus.cjs.map +1 -1
- package/_cjs/Layer/MemoMap.cjs +40 -92
- package/_cjs/Layer/MemoMap.cjs.map +1 -1
- package/_cjs/Layer/api.cjs +5 -106
- package/_cjs/Layer/api.cjs.map +1 -1
- package/_cjs/Layer/definition.cjs +14 -54
- package/_cjs/Layer/definition.cjs.map +1 -1
- package/_cjs/Layer.cjs +0 -6
- package/_cjs/Layer.cjs.map +1 -1
- package/_cjs/LogLevel.cjs +0 -20
- package/_cjs/LogLevel.cjs.map +1 -1
- package/_cjs/LogSpan.cjs +0 -7
- package/_cjs/LogSpan.cjs.map +1 -1
- package/_cjs/Logger/api.cjs +0 -7
- package/_cjs/Logger/api.cjs.map +1 -1
- package/_cjs/Logger/constructors.cjs +2 -17
- package/_cjs/Logger/constructors.cjs.map +1 -1
- package/_cjs/Logger/definition.cjs +3 -4
- package/_cjs/Logger/definition.cjs.map +1 -1
- package/_cjs/Logger.cjs +0 -6
- package/_cjs/Logger.cjs.map +1 -1
- package/_cjs/MVar/api.cjs +170 -0
- package/_cjs/MVar/api.cjs.map +1 -0
- package/_cjs/MVar/definition.cjs +28 -0
- package/_cjs/MVar/definition.cjs.map +1 -0
- package/_cjs/MVar.cjs +28 -0
- package/_cjs/MVar.cjs.map +1 -0
- package/_cjs/Push/api.cjs +477 -0
- package/_cjs/Push/api.cjs.map +1 -0
- package/_cjs/Push/definition.cjs +50 -0
- package/_cjs/Push/definition.cjs.map +1 -0
- package/_cjs/Push/internal.cjs +42 -0
- package/_cjs/Push/internal.cjs.map +1 -0
- package/_cjs/Push.cjs +39 -0
- package/_cjs/Push.cjs.map +1 -0
- package/_cjs/Queue/api/dimapIO.cjs +174 -0
- package/_cjs/Queue/api/dimapIO.cjs.map +1 -0
- package/_cjs/Queue/api/filterInputIO.cjs +109 -0
- package/_cjs/Queue/api/filterInputIO.cjs.map +1 -0
- package/_cjs/Queue/api/filterOutputIO.cjs +117 -0
- package/_cjs/Queue/api/filterOutputIO.cjs.map +1 -0
- package/_cjs/Queue/api/operations.cjs +133 -0
- package/_cjs/Queue/api/operations.cjs.map +1 -0
- package/_cjs/{Fiber/api/evalOn.cjs → Queue/api/poll.cjs} +11 -20
- package/_cjs/Queue/api/poll.cjs.map +1 -0
- package/_cjs/Queue/api/takeBetween.cjs +47 -0
- package/_cjs/Queue/api/takeBetween.cjs.map +1 -0
- package/_cjs/Queue/api/zipWithIO.cjs +82 -0
- package/_cjs/Queue/api/zipWithIO.cjs.map +1 -0
- package/_cjs/Queue/api.cjs +83 -0
- package/_cjs/Queue/api.cjs.map +1 -0
- package/_cjs/Queue/constructors.cjs +5 -32
- package/_cjs/Queue/constructors.cjs.map +1 -1
- package/_cjs/Queue/definition.cjs +26 -192
- package/_cjs/Queue/definition.cjs.map +1 -1
- package/_cjs/Queue/internal.cjs +142 -42
- package/_cjs/Queue/internal.cjs.map +1 -1
- package/_cjs/Queue/strategy.cjs +12 -53
- package/_cjs/Queue/strategy.cjs.map +1 -1
- package/_cjs/Queue.cjs +22 -6
- package/_cjs/Queue.cjs.map +1 -1
- package/_cjs/Random/api.cjs +0 -17
- package/_cjs/Random/api.cjs.map +1 -1
- package/_cjs/Random/definition.cjs +0 -7
- package/_cjs/Random/definition.cjs.map +1 -1
- package/_cjs/Random/live.cjs +0 -14
- package/_cjs/Random/live.cjs.map +1 -1
- package/_cjs/Random.cjs +0 -6
- package/_cjs/Random.cjs.map +1 -1
- package/_cjs/Ref/Atomic.cjs +26 -21
- package/_cjs/Ref/Atomic.cjs.map +1 -1
- package/_cjs/Ref/Derived.cjs +50 -0
- package/_cjs/Ref/Derived.cjs.map +1 -0
- package/_cjs/Ref/DerivedAll.cjs +49 -0
- package/_cjs/Ref/DerivedAll.cjs.map +1 -0
- package/_cjs/Ref/Synchronized/api.cjs +192 -0
- package/_cjs/Ref/Synchronized/api.cjs.map +1 -0
- package/_cjs/Ref/Synchronized/constructors.cjs +31 -0
- package/_cjs/Ref/Synchronized/constructors.cjs.map +1 -0
- package/_cjs/Ref/Synchronized/definition.cjs +69 -0
- package/_cjs/Ref/Synchronized/definition.cjs.map +1 -0
- package/_cjs/Ref/Synchronized.cjs +33 -134
- package/_cjs/Ref/Synchronized.cjs.map +1 -1
- package/_cjs/{FiberState/constructors.cjs → Ref/api/collect.cjs} +16 -34
- package/_cjs/Ref/api/collect.cjs.map +1 -0
- package/_cjs/Ref/api/dimap.cjs +105 -0
- package/_cjs/Ref/api/dimap.cjs.map +1 -0
- package/_cjs/Ref/api/filter.cjs +40 -0
- package/_cjs/Ref/api/filter.cjs.map +1 -0
- package/_cjs/Ref/api/get.cjs +18 -0
- package/_cjs/Ref/api/get.cjs.map +1 -0
- package/_cjs/Ref/api/match.cjs +24 -0
- package/_cjs/Ref/api/match.cjs.map +1 -0
- package/_cjs/Ref/api/matchAll.cjs +22 -0
- package/_cjs/Ref/api/matchAll.cjs.map +1 -0
- package/_cjs/Ref/api/modify.cjs +141 -0
- package/_cjs/Ref/api/modify.cjs.map +1 -0
- package/_cjs/Ref/api/set.cjs +21 -0
- package/_cjs/Ref/api/set.cjs.map +1 -0
- package/_cjs/Ref/api.cjs +134 -0
- package/_cjs/Ref/api.cjs.map +1 -0
- package/_cjs/Ref/constructors.cjs +4 -30
- package/_cjs/Ref/constructors.cjs.map +1 -1
- package/_cjs/Ref/definition.cjs +17 -107
- package/_cjs/Ref/definition.cjs.map +1 -1
- package/_cjs/Ref.cjs +66 -8
- package/_cjs/Ref.cjs.map +1 -1
- package/_cjs/RefSubject/Atomic.cjs +109 -0
- package/_cjs/RefSubject/Atomic.cjs.map +1 -0
- package/_cjs/{Fiber/api/evalOnIO.cjs → RefSubject/Synchronized/api.cjs} +13 -23
- package/_cjs/RefSubject/Synchronized/api.cjs.map +1 -0
- package/_cjs/RefSubject/Synchronized/definition.cjs +56 -0
- package/_cjs/RefSubject/Synchronized/definition.cjs.map +1 -0
- package/_cjs/RefSubject/api.cjs +245 -0
- package/_cjs/RefSubject/api.cjs.map +1 -0
- package/_cjs/RefSubject/definition.cjs +26 -0
- package/_cjs/RefSubject/definition.cjs.map +1 -0
- package/_cjs/{FiberState.cjs → RefSubject.cjs} +7 -13
- package/_cjs/RefSubject.cjs.map +1 -0
- package/_cjs/Reloadable/api.cjs +3 -18
- package/_cjs/Reloadable/api.cjs.map +1 -1
- package/_cjs/Reloadable/constructors.cjs +5 -32
- package/_cjs/Reloadable/constructors.cjs.map +1 -1
- package/_cjs/Reloadable/definition.cjs +4 -16
- package/_cjs/Reloadable/definition.cjs.map +1 -1
- package/_cjs/Reloadable.cjs +0 -6
- package/_cjs/Reloadable.cjs.map +1 -1
- package/_cjs/RuntimeConfig.cjs +1 -44
- package/_cjs/RuntimeConfig.cjs.map +1 -1
- package/_cjs/RuntimeFlag.cjs +6 -0
- package/_cjs/RuntimeFlag.cjs.map +1 -0
- package/_cjs/RuntimeFlags/Patch.cjs +76 -0
- package/_cjs/RuntimeFlags/Patch.cjs.map +1 -0
- package/_cjs/RuntimeFlags/RuntimeFlags.cjs +107 -0
- package/_cjs/RuntimeFlags/RuntimeFlags.cjs.map +1 -0
- package/_cjs/RuntimeFlags.cjs +28 -0
- package/_cjs/RuntimeFlags.cjs.map +1 -0
- package/_cjs/STM/api/atomically.cjs +55 -0
- package/_cjs/STM/api/atomically.cjs.map +1 -0
- package/_cjs/STM/api/core-api.cjs +0 -16
- package/_cjs/STM/api/core-api.cjs.map +1 -1
- package/_cjs/STM/api/core-constructors.cjs +0 -15
- package/_cjs/STM/api/core-constructors.cjs.map +1 -1
- package/_cjs/STM/api.cjs +65 -229
- package/_cjs/STM/api.cjs.map +1 -1
- package/_cjs/STM/definition.cjs +34 -84
- package/_cjs/STM/definition.cjs.map +1 -1
- package/_cjs/STM/driver.cjs +10 -63
- package/_cjs/STM/driver.cjs.map +1 -1
- package/_cjs/STM/internal/CommitState.cjs +5 -32
- package/_cjs/STM/internal/CommitState.cjs.map +1 -1
- package/_cjs/STM/internal/Entry.cjs +6 -23
- package/_cjs/STM/internal/Entry.cjs.map +1 -1
- package/_cjs/STM/internal/Journal.cjs +17 -113
- package/_cjs/STM/internal/Journal.cjs.map +1 -1
- package/_cjs/STM/internal/TryCommit.cjs +7 -14
- package/_cjs/STM/internal/TryCommit.cjs.map +1 -1
- package/_cjs/STM/internal/Versioned.cjs +3 -4
- package/_cjs/STM/internal/Versioned.cjs.map +1 -1
- package/_cjs/STM.cjs +11 -10
- package/_cjs/STM.cjs.map +1 -1
- package/_cjs/Schedule/Decision.cjs +4 -30
- package/_cjs/Schedule/Decision.cjs.map +1 -1
- package/_cjs/Schedule/Driver.cjs +0 -5
- package/_cjs/Schedule/Driver.cjs.map +1 -1
- package/_cjs/Schedule/api/driver.cjs +16 -28
- package/_cjs/Schedule/api/driver.cjs.map +1 -1
- package/_cjs/Schedule/api.cjs +109 -252
- package/_cjs/Schedule/api.cjs.map +1 -1
- package/_cjs/Schedule/definition.cjs +3 -3
- package/_cjs/Schedule/definition.cjs.map +1 -1
- package/_cjs/Schedule.cjs +0 -8
- package/_cjs/Schedule.cjs.map +1 -1
- package/_cjs/Scope/Finalizer/definition.cjs +0 -6
- package/_cjs/Scope/Finalizer/definition.cjs.map +1 -1
- package/_cjs/Scope/Finalizer.cjs +0 -2
- package/_cjs/Scope/Finalizer.cjs.map +1 -1
- package/_cjs/Scope/ReleaseMap/api/releaseAll.cjs +4 -15
- package/_cjs/Scope/ReleaseMap/api/releaseAll.cjs.map +1 -1
- package/_cjs/Scope/ReleaseMap/api.cjs +12 -33
- package/_cjs/Scope/ReleaseMap/api.cjs.map +1 -1
- package/_cjs/Scope/ReleaseMap/constructors.cjs +1 -12
- package/_cjs/Scope/ReleaseMap/constructors.cjs.map +1 -1
- package/_cjs/Scope/ReleaseMap/definition.cjs +0 -9
- package/_cjs/Scope/ReleaseMap/definition.cjs.map +1 -1
- package/_cjs/Scope/ReleaseMap.cjs +0 -6
- package/_cjs/Scope/ReleaseMap.cjs.map +1 -1
- package/_cjs/Scope/api.cjs +1 -44
- package/_cjs/Scope/api.cjs.map +1 -1
- package/_cjs/Scope/definition.cjs +5 -15
- package/_cjs/Scope/definition.cjs.map +1 -1
- package/_cjs/Scope.cjs +0 -4
- package/_cjs/Scope.cjs.map +1 -1
- package/_cjs/ScopedRef/api.cjs +9 -24
- package/_cjs/ScopedRef/api.cjs.map +1 -1
- package/_cjs/ScopedRef/definition.cjs +3 -5
- package/_cjs/ScopedRef/definition.cjs.map +1 -1
- package/_cjs/ScopedRef.cjs +0 -4
- package/_cjs/ScopedRef.cjs.map +1 -1
- package/_cjs/Sink/api.cjs +134 -384
- package/_cjs/Sink/api.cjs.map +1 -1
- package/_cjs/Sink/definition.cjs +0 -3
- package/_cjs/Sink/definition.cjs.map +1 -1
- package/_cjs/Sink.cjs +0 -4
- package/_cjs/Sink.cjs.map +1 -1
- package/_cjs/State/api.cjs +2 -20
- package/_cjs/State/api.cjs.map +1 -1
- package/_cjs/State/definition.cjs +6 -9
- package/_cjs/State/definition.cjs.map +1 -1
- package/_cjs/State/internal.cjs +7 -6
- package/_cjs/State/internal.cjs.map +1 -1
- package/_cjs/State.cjs +0 -4
- package/_cjs/State.cjs.map +1 -1
- package/_cjs/Stream/api/zipAllWith.cjs +2 -31
- package/_cjs/Stream/api/zipAllWith.cjs.map +1 -1
- package/_cjs/Stream/api/zipWith.cjs +0 -5
- package/_cjs/Stream/api/zipWith.cjs.map +1 -1
- package/_cjs/Stream/api/zipWithChunks.cjs +2 -22
- package/_cjs/Stream/api/zipWithChunks.cjs.map +1 -1
- package/_cjs/Stream/api.cjs +237 -685
- package/_cjs/Stream/api.cjs.map +1 -1
- package/_cjs/Stream/definition.cjs +4 -10
- package/_cjs/Stream/definition.cjs.map +1 -1
- package/_cjs/Stream/internal/DebounceState.cjs +6 -36
- package/_cjs/Stream/internal/DebounceState.cjs.map +1 -1
- package/_cjs/Stream/internal/Handoff.cjs +42 -90
- package/_cjs/Stream/internal/Handoff.cjs.map +1 -1
- package/_cjs/Stream/internal/Pull.cjs +10 -31
- package/_cjs/Stream/internal/Pull.cjs.map +1 -1
- package/_cjs/Stream/internal/SinkEndReason.cjs +10 -24
- package/_cjs/Stream/internal/SinkEndReason.cjs.map +1 -1
- package/_cjs/Stream/internal/Take.cjs +0 -51
- package/_cjs/Stream/internal/Take.cjs.map +1 -1
- package/_cjs/Stream/internal/util.cjs +0 -10
- package/_cjs/Stream/internal/util.cjs.map +1 -1
- package/_cjs/Stream.cjs +0 -4
- package/_cjs/Stream.cjs.map +1 -1
- package/_cjs/{IO/api/withRuntimeConfig.cjs → Subject/Atomic.cjs} +25 -19
- package/_cjs/Subject/Atomic.cjs.map +1 -0
- package/_cjs/{FiberState → Subject}/api.cjs +17 -15
- package/_cjs/Subject/api.cjs.map +1 -0
- package/_cjs/Subject/definition.cjs +11 -0
- package/_cjs/Subject/definition.cjs.map +1 -0
- package/_cjs/Subject.cjs +39 -0
- package/_cjs/Subject.cjs.map +1 -0
- package/_cjs/SubscriptionRef.cjs +22 -36
- package/_cjs/SubscriptionRef.cjs.map +1 -1
- package/_cjs/Supervisor/api.cjs +4 -21
- package/_cjs/Supervisor/api.cjs.map +1 -1
- package/_cjs/Supervisor/constructors.cjs +0 -24
- package/_cjs/Supervisor/constructors.cjs.map +1 -1
- package/_cjs/Supervisor/definition.cjs +5 -43
- package/_cjs/Supervisor/definition.cjs.map +1 -1
- package/_cjs/Supervisor.cjs +0 -6
- package/_cjs/Supervisor.cjs.map +1 -1
- package/_cjs/SupervisorPatch.cjs +13 -65
- package/_cjs/SupervisorPatch.cjs.map +1 -1
- package/_cjs/TExit/constructors.cjs +0 -12
- package/_cjs/TExit/constructors.cjs.map +1 -1
- package/_cjs/TExit/definition.cjs +36 -97
- package/_cjs/TExit/definition.cjs.map +1 -1
- package/_cjs/TExit.cjs +0 -4
- package/_cjs/TExit.cjs.map +1 -1
- package/_cjs/TFuture/api.cjs +0 -22
- package/_cjs/TFuture/api.cjs.map +1 -1
- package/_cjs/TFuture/constructors.cjs +1 -13
- package/_cjs/TFuture/constructors.cjs.map +1 -1
- package/_cjs/TFuture/definition.cjs +0 -4
- package/_cjs/TFuture/definition.cjs.map +1 -1
- package/_cjs/TFuture.cjs +0 -6
- package/_cjs/TFuture.cjs.map +1 -1
- package/_cjs/TReentrantLock/api.cjs +17 -90
- package/_cjs/TReentrantLock/api.cjs.map +1 -1
- package/_cjs/TReentrantLock/definition.cjs +3 -34
- package/_cjs/TReentrantLock/definition.cjs.map +1 -1
- package/_cjs/TReentrantLock.cjs +0 -4
- package/_cjs/TReentrantLock.cjs.map +1 -1
- package/_cjs/TRef/api.cjs +23 -248
- package/_cjs/TRef/api.cjs.map +1 -1
- package/_cjs/TRef/constructors.cjs +1 -20
- package/_cjs/TRef/constructors.cjs.map +1 -1
- package/_cjs/TRef/definition.cjs +85 -35
- package/_cjs/TRef/definition.cjs.map +1 -1
- package/_cjs/TRef.cjs +0 -6
- package/_cjs/TRef.cjs.map +1 -1
- package/_cjs/TSemaphore/api.cjs +5 -28
- package/_cjs/TSemaphore/api.cjs.map +1 -1
- package/_cjs/TSemaphore/constructors.cjs +1 -14
- package/_cjs/TSemaphore/constructors.cjs.map +1 -1
- package/_cjs/TSemaphore/definition.cjs +0 -4
- package/_cjs/TSemaphore/definition.cjs.map +1 -1
- package/_cjs/TSemaphore.cjs +0 -6
- package/_cjs/TSemaphore.cjs.map +1 -1
- package/_cjs/TxnId.cjs +0 -3
- package/_cjs/TxnId.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/dropUntilIO.cjs +0 -7
- package/_cjs/collection/immutable/Conc/dropUntilIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/dropWhileIO.cjs +0 -7
- package/_cjs/collection/immutable/Conc/dropWhileIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/filterIO.cjs +0 -7
- package/_cjs/collection/immutable/Conc/filterIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/findIO.cjs +0 -12
- package/_cjs/collection/immutable/Conc/findIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/mapIO.cjs +0 -5
- package/_cjs/collection/immutable/Conc/mapIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/takeWhileIO.cjs +0 -9
- package/_cjs/collection/immutable/Conc/takeWhileIO.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc.cjs +0 -12
- package/_cjs/collection/immutable/Conc.cjs.map +1 -1
- package/_cjs/data/Exit/foreachIO.cjs +0 -6
- package/_cjs/data/Exit/foreachIO.cjs.map +1 -1
- package/_cjs/internal/HashedPair.cjs +4 -15
- package/_cjs/internal/HashedPair.cjs.map +1 -1
- package/_cjs/internal/Hub.cjs +0 -164
- package/_cjs/internal/Hub.cjs.map +1 -1
- package/_cjs/internal/IsFatal.cjs +13 -53
- package/_cjs/internal/IsFatal.cjs.map +1 -1
- package/_cjs/internal/MutableQueue.cjs +0 -68
- package/_cjs/internal/MutableQueue.cjs.map +1 -1
- package/_cjs/internal/Scheduler.cjs +0 -18
- package/_cjs/internal/Scheduler.cjs.map +1 -1
- package/_cjs/internal/StackTraceBuilder.cjs +0 -9
- package/_cjs/internal/StackTraceBuilder.cjs.map +1 -1
- package/_mjs/Cached/api.mjs +1 -8
- package/_mjs/Cached/api.mjs.map +1 -1
- package/_mjs/Cached/definition.mjs +6 -6
- package/_mjs/Cached/definition.mjs.map +1 -1
- package/_mjs/Cached/internal.mjs +3 -6
- package/_mjs/Cached/internal.mjs.map +1 -1
- package/_mjs/Cached.mjs.map +1 -1
- package/_mjs/CancellerState.mjs +6 -15
- package/_mjs/CancellerState.mjs.map +1 -1
- package/_mjs/Channel/ChildExecutorDecision/api.mjs +0 -2
- package/_mjs/Channel/ChildExecutorDecision/api.mjs.map +1 -1
- package/_mjs/Channel/ChildExecutorDecision/definition.mjs +0 -2
- package/_mjs/Channel/ChildExecutorDecision/definition.mjs.map +1 -1
- package/_mjs/Channel/ChildExecutorDecision.mjs.map +1 -1
- package/_mjs/Channel/UpstreamPullRequest/api.mjs +0 -4
- package/_mjs/Channel/UpstreamPullRequest/api.mjs.map +1 -1
- package/_mjs/Channel/UpstreamPullRequest/definition.mjs +0 -2
- package/_mjs/Channel/UpstreamPullRequest/definition.mjs.map +1 -1
- package/_mjs/Channel/UpstreamPullRequest.mjs.map +1 -1
- package/_mjs/Channel/UpstreamPullStrategy/definition.mjs +0 -1
- package/_mjs/Channel/UpstreamPullStrategy/definition.mjs.map +1 -1
- package/_mjs/Channel/UpstreamPullStrategy.mjs.map +1 -1
- package/_mjs/Channel/api/interruptWhen.mjs +0 -3
- package/_mjs/Channel/api/interruptWhen.mjs.map +1 -1
- package/_mjs/Channel/api/mapOutConcurrentIO.mjs +34 -0
- package/_mjs/Channel/api/mapOutConcurrentIO.mjs.map +1 -0
- package/_mjs/Channel/api/mergeAll.mjs +0 -1
- package/_mjs/Channel/api/mergeAll.mjs.map +1 -1
- package/_mjs/Channel/api/mergeAllUnboundedWith.mjs +0 -1
- package/_mjs/Channel/api/mergeAllUnboundedWith.mjs.map +1 -1
- package/_mjs/Channel/api/mergeAllWith.mjs +39 -38
- package/_mjs/Channel/api/mergeAllWith.mjs.map +1 -1
- package/_mjs/Channel/api/mergeMap.mjs +0 -1
- package/_mjs/Channel/api/mergeMap.mjs.map +1 -1
- package/_mjs/Channel/api/mergeWith.mjs +10 -28
- package/_mjs/Channel/api/mergeWith.mjs.map +1 -1
- package/_mjs/Channel/api/run.mjs +0 -1
- package/_mjs/Channel/api/run.mjs.map +1 -1
- package/_mjs/Channel/api/runCollect.mjs +0 -1
- package/_mjs/Channel/api/runCollect.mjs.map +1 -1
- package/_mjs/Channel/api/runDrain.mjs +0 -1
- package/_mjs/Channel/api/runDrain.mjs.map +1 -1
- package/_mjs/Channel/api/runScoped.mjs +4 -19
- package/_mjs/Channel/api/runScoped.mjs.map +1 -1
- package/_mjs/Channel/api/toPull.mjs +4 -17
- package/_mjs/Channel/api/toPull.mjs.map +1 -1
- package/_mjs/Channel/api/zipConcurrent.mjs +32 -0
- package/_mjs/Channel/api/zipConcurrent.mjs.map +1 -0
- package/_mjs/Channel/api.mjs +79 -195
- package/_mjs/Channel/api.mjs.map +1 -1
- package/_mjs/Channel/core-api.mjs +4 -21
- package/_mjs/Channel/core-api.mjs.map +1 -1
- package/_mjs/Channel/definition.mjs +40 -67
- package/_mjs/Channel/definition.mjs.map +1 -1
- package/_mjs/Channel/internal/ChannelExecutor.mjs +117 -291
- package/_mjs/Channel/internal/ChannelExecutor.mjs.map +1 -1
- package/_mjs/Channel/internal/ChannelState.mjs +5 -20
- package/_mjs/Channel/internal/ChannelState.mjs.map +1 -1
- package/_mjs/Channel/internal/MergeDecision.mjs +9 -17
- package/_mjs/Channel/internal/MergeDecision.mjs.map +1 -1
- package/_mjs/Channel/internal/MergeState.mjs +6 -15
- package/_mjs/Channel/internal/MergeState.mjs.map +1 -1
- package/_mjs/Channel/internal/SingleProducerAsyncInput.mjs +44 -106
- package/_mjs/Channel/internal/SingleProducerAsyncInput.mjs.map +1 -1
- package/_mjs/Channel.mjs.map +1 -1
- package/_mjs/Clock/api.mjs +0 -2
- package/_mjs/Clock/api.mjs.map +1 -1
- package/_mjs/Clock/definition.mjs +0 -2
- package/_mjs/Clock/definition.mjs.map +1 -1
- package/_mjs/Clock/live.mjs +2 -6
- package/_mjs/Clock/live.mjs.map +1 -1
- package/_mjs/Clock.mjs.map +1 -1
- package/_mjs/Console/api.mjs +0 -2
- package/_mjs/Console/api.mjs.map +1 -1
- package/_mjs/Console/definition.mjs +0 -2
- package/_mjs/Console/definition.mjs.map +1 -1
- package/_mjs/Console/live.mjs +0 -4
- package/_mjs/Console/live.mjs.map +1 -1
- package/_mjs/Console.mjs.map +1 -1
- package/_mjs/CountdownLatch.mjs +41 -0
- package/_mjs/CountdownLatch.mjs.map +1 -0
- package/_mjs/Differ/api.mjs +0 -15
- package/_mjs/Differ/api.mjs.map +1 -1
- package/_mjs/Differ/definition.mjs +3 -3
- package/_mjs/Differ/definition.mjs.map +1 -1
- package/_mjs/Fiber/FiberMessage.mjs +56 -0
- package/_mjs/Fiber/FiberMessage.mjs.map +1 -0
- package/_mjs/Fiber/FiberRuntime.mjs +735 -0
- package/_mjs/Fiber/FiberRuntime.mjs.map +1 -0
- 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.map +1 -1
- package/_mjs/Fiber/api/collectAll.mjs +3 -4
- package/_mjs/Fiber/api/collectAll.mjs.map +1 -1
- package/_mjs/Fiber/api/fromIO.mjs +0 -1
- package/_mjs/Fiber/api/fromIO.mjs.map +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 +3 -4
- package/_mjs/Fiber/api/interrupt.mjs.map +1 -1
- package/_mjs/Fiber/api/interruptAll.mjs +2 -5
- package/_mjs/Fiber/api/interruptAll.mjs.map +1 -1
- package/_mjs/Fiber/api/interruptAs.mjs +14 -8
- package/_mjs/Fiber/api/interruptAs.mjs.map +1 -1
- package/_mjs/Fiber/api/interruptFork.mjs +2 -5
- package/_mjs/Fiber/api/interruptFork.mjs.map +1 -1
- package/_mjs/Fiber/api/join.mjs +3 -3
- package/_mjs/Fiber/api/join.mjs.map +1 -1
- package/_mjs/Fiber/api/joinAll.mjs +0 -1
- package/_mjs/Fiber/api/joinAll.mjs.map +1 -1
- package/_mjs/Fiber/api/location.mjs +1 -3
- package/_mjs/Fiber/api/location.mjs.map +1 -1
- package/_mjs/Fiber/api/mapFiber.mjs +0 -1
- package/_mjs/Fiber/api/mapFiber.mjs.map +1 -1
- package/_mjs/Fiber/api/mapIO.mjs +1 -4
- package/_mjs/Fiber/api/mapIO.mjs.map +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 +0 -6
- package/_mjs/Fiber/constructors.mjs.map +1 -1
- package/_mjs/Fiber/definition.mjs +14 -7
- package/_mjs/Fiber/definition.mjs.map +1 -1
- package/_mjs/Fiber.mjs +3 -5
- package/_mjs/Fiber.mjs.map +1 -1
- package/_mjs/FiberDescriptor.mjs +1 -4
- package/_mjs/FiberDescriptor.mjs.map +1 -1
- package/_mjs/FiberRef/api/locallyScoped.mjs +0 -1
- package/_mjs/FiberRef/api/locallyScoped.mjs.map +1 -1
- package/_mjs/FiberRef/api/locallyScopedWith.mjs +0 -1
- package/_mjs/FiberRef/api/locallyScopedWith.mjs.map +1 -1
- package/_mjs/FiberRef/api.mjs +16 -34
- package/_mjs/FiberRef/api.mjs.map +1 -1
- package/_mjs/FiberRef/constructors.mjs +0 -3
- package/_mjs/FiberRef/constructors.mjs.map +1 -1
- package/_mjs/FiberRef/definition.mjs +11 -13
- package/_mjs/FiberRef/definition.mjs.map +1 -1
- package/_mjs/FiberRef/unsafe.mjs +17 -30
- package/_mjs/FiberRef/unsafe.mjs.map +1 -1
- package/_mjs/FiberRef.mjs +2 -2
- package/_mjs/FiberRef.mjs.map +1 -1
- package/_mjs/FiberRefs/api.mjs +55 -11
- package/_mjs/FiberRefs/api.mjs.map +1 -1
- package/_mjs/FiberRefs/definition.mjs +2 -13
- package/_mjs/FiberRefs/definition.mjs.map +1 -1
- package/_mjs/FiberRefs/join.mjs +34 -46
- package/_mjs/FiberRefs/join.mjs.map +1 -1
- package/_mjs/FiberRefs.mjs.map +1 -1
- package/_mjs/FiberScope/constructors.mjs +0 -2
- package/_mjs/FiberScope/constructors.mjs.map +1 -1
- package/_mjs/FiberScope/definition.mjs +15 -12
- package/_mjs/FiberScope/definition.mjs.map +1 -1
- package/_mjs/FiberScope.mjs.map +1 -1
- package/_mjs/FiberStatus/constructors.mjs +5 -15
- package/_mjs/FiberStatus/constructors.mjs.map +1 -1
- package/_mjs/FiberStatus/definition.mjs +14 -66
- package/_mjs/FiberStatus/definition.mjs.map +1 -1
- package/_mjs/FiberStatus.mjs.map +1 -1
- package/_mjs/Future/api.mjs +28 -58
- package/_mjs/Future/api.mjs.map +1 -1
- package/_mjs/Future/constructors.mjs +0 -4
- package/_mjs/Future/constructors.mjs.map +1 -1
- package/_mjs/Future/definition.mjs +3 -9
- package/_mjs/Future/definition.mjs.map +1 -1
- package/_mjs/Future.mjs.map +1 -1
- package/_mjs/Hub/api.mjs +359 -0
- package/_mjs/Hub/api.mjs.map +1 -0
- package/_mjs/Hub/definition.mjs +17 -85
- package/_mjs/Hub/definition.mjs.map +1 -1
- package/_mjs/Hub/internal.mjs +102 -145
- package/_mjs/Hub/internal.mjs.map +1 -1
- package/_mjs/Hub.mjs +1 -1
- package/_mjs/Hub.mjs.map +1 -1
- package/_mjs/IO/api/acquireRelease.mjs +0 -1
- package/_mjs/IO/api/acquireRelease.mjs.map +1 -1
- package/_mjs/IO/api/acquireReleaseExit.mjs +0 -1
- package/_mjs/IO/api/acquireReleaseExit.mjs.map +1 -1
- package/_mjs/IO/api/acquireReleaseInterruptible.mjs +0 -1
- package/_mjs/IO/api/acquireReleaseInterruptible.mjs.map +1 -1
- package/_mjs/IO/api/acquireReleaseInterruptibleExit.mjs +2 -2
- package/_mjs/IO/api/acquireReleaseInterruptibleExit.mjs.map +1 -1
- package/_mjs/IO/api/addFinalizer.mjs +0 -1
- package/_mjs/IO/api/addFinalizer.mjs.map +1 -1
- package/_mjs/IO/api/addFinalizerExit.mjs +0 -1
- package/_mjs/IO/api/addFinalizerExit.mjs.map +1 -1
- package/_mjs/IO/api/asyncIO.mjs +7 -7
- package/_mjs/IO/api/asyncIO.mjs.map +1 -1
- package/_mjs/IO/api/asyncInterrupt.mjs +65 -0
- package/_mjs/IO/api/asyncInterrupt.mjs.map +1 -0
- package/_mjs/IO/api/bracket.mjs +0 -1
- package/_mjs/IO/api/bracket.mjs.map +1 -1
- package/_mjs/IO/api/bracketExit.mjs +1 -2
- package/_mjs/IO/api/bracketExit.mjs.map +1 -1
- package/_mjs/IO/api/clockWith.mjs +0 -3
- package/_mjs/IO/api/clockWith.mjs.map +1 -1
- package/_mjs/IO/api/concurrency.mjs +0 -5
- package/_mjs/IO/api/concurrency.mjs.map +1 -1
- package/_mjs/IO/api/concurrentFinalizers.mjs +0 -1
- package/_mjs/IO/api/concurrentFinalizers.mjs.map +1 -1
- package/_mjs/IO/api/consoleWith.mjs +0 -3
- package/_mjs/IO/api/consoleWith.mjs.map +1 -1
- package/_mjs/IO/api/core-scope.mjs +46 -88
- package/_mjs/IO/api/core-scope.mjs.map +1 -1
- package/_mjs/IO/api/delay.mjs +12 -0
- package/_mjs/IO/api/delay.mjs.map +1 -0
- package/_mjs/IO/api/ensuringChildren.mjs +3 -3
- package/_mjs/IO/api/ensuringChildren.mjs.map +1 -1
- package/_mjs/IO/api/environment.mjs +0 -15
- package/_mjs/IO/api/environment.mjs.map +1 -1
- package/_mjs/IO/api/{foreachC.mjs → foreachConcurrent.mjs} +30 -42
- package/_mjs/IO/api/foreachConcurrent.mjs.map +1 -0
- package/_mjs/IO/api/foreachExec.mjs +2 -3
- package/_mjs/IO/api/foreachExec.mjs.map +1 -1
- package/_mjs/IO/api/fork.mjs +64 -0
- package/_mjs/IO/api/fork.mjs.map +1 -0
- package/_mjs/IO/api/forkAll.mjs +3 -3
- package/_mjs/IO/api/forkAll.mjs.map +1 -1
- package/_mjs/IO/api/forkIn.mjs +1 -2
- package/_mjs/IO/api/forkIn.mjs.map +1 -1
- package/_mjs/IO/api/forkScoped.mjs +1 -2
- package/_mjs/IO/api/forkScoped.mjs.map +1 -1
- package/_mjs/IO/api/fulfill.mjs +1 -2
- package/_mjs/IO/api/fulfill.mjs.map +1 -1
- package/_mjs/IO/api/interrupt.mjs +68 -79
- package/_mjs/IO/api/interrupt.mjs.map +1 -1
- package/_mjs/IO/api/memoize.mjs +1 -2
- package/_mjs/IO/api/memoize.mjs.map +1 -1
- package/_mjs/IO/api/onTermination.mjs +7 -7
- package/_mjs/IO/api/onTermination.mjs.map +1 -1
- package/_mjs/IO/api/once.mjs +4 -4
- package/_mjs/IO/api/once.mjs.map +1 -1
- package/_mjs/IO/api/provideLayer.mjs +0 -1
- package/_mjs/IO/api/provideLayer.mjs.map +1 -1
- package/_mjs/IO/api/provideSomeLayer.mjs +0 -1
- package/_mjs/IO/api/provideSomeLayer.mjs.map +1 -1
- package/_mjs/IO/api/race.mjs +4 -6
- package/_mjs/IO/api/race.mjs.map +1 -1
- package/_mjs/IO/api/raceFirst.mjs +1 -2
- package/_mjs/IO/api/raceFirst.mjs.map +1 -1
- package/_mjs/IO/api/randomWith.mjs +0 -3
- package/_mjs/IO/api/randomWith.mjs.map +1 -1
- package/_mjs/IO/api/repeat.mjs +0 -5
- package/_mjs/IO/api/repeat.mjs.map +1 -1
- package/_mjs/IO/api/retry.mjs +0 -6
- package/_mjs/IO/api/retry.mjs.map +1 -1
- package/_mjs/IO/api/schedule.mjs +0 -4
- package/_mjs/IO/api/schedule.mjs.map +1 -1
- package/_mjs/IO/api/scope.mjs +0 -1
- package/_mjs/IO/api/scope.mjs.map +1 -1
- package/_mjs/IO/api/scopeWith.mjs +0 -1
- package/_mjs/IO/api/scopeWith.mjs.map +1 -1
- package/_mjs/IO/api/scoped.mjs +0 -3
- package/_mjs/IO/api/scoped.mjs.map +1 -1
- package/_mjs/IO/api/sequenceT.mjs +1 -2
- package/_mjs/IO/api/sequenceT.mjs.map +1 -1
- package/_mjs/IO/api/sleep.mjs +0 -1
- package/_mjs/IO/api/sleep.mjs.map +1 -1
- package/_mjs/IO/api/stateful.mjs +0 -1
- package/_mjs/IO/api/stateful.mjs.map +1 -1
- package/_mjs/IO/api/supervised.mjs +6 -12
- package/_mjs/IO/api/supervised.mjs.map +1 -1
- package/_mjs/IO/api/timeout.mjs +0 -3
- package/_mjs/IO/api/timeout.mjs.map +1 -1
- package/_mjs/IO/api/withChildren.mjs +2 -4
- package/_mjs/IO/api/withChildren.mjs.map +1 -1
- package/_mjs/IO/api/withEarlyRelease.mjs +0 -1
- package/_mjs/IO/api/withEarlyRelease.mjs.map +1 -1
- package/_mjs/IO/api/withFinalizer.mjs +0 -1
- package/_mjs/IO/api/withFinalizer.mjs.map +1 -1
- package/_mjs/IO/api/withFinalizerExit.mjs +0 -1
- package/_mjs/IO/api/withFinalizerExit.mjs.map +1 -1
- package/_mjs/IO/api/zipConcurrent.mjs +41 -0
- package/_mjs/IO/api/zipConcurrent.mjs.map +1 -0
- package/_mjs/IO/api.mjs +164 -517
- package/_mjs/IO/api.mjs.map +1 -1
- package/_mjs/IO/definition.mjs +115 -154
- package/_mjs/IO/definition.mjs.map +1 -1
- package/_mjs/IO/runtime.mjs +51 -86
- package/_mjs/IO/runtime.mjs.map +1 -1
- package/_mjs/IO.mjs +7 -6
- package/_mjs/IO.mjs.map +1 -1
- package/_mjs/IOEnv/definition.mjs +0 -1
- package/_mjs/IOEnv/definition.mjs.map +1 -1
- package/_mjs/IOEnv/live.mjs +0 -1
- package/_mjs/IOEnv/live.mjs.map +1 -1
- package/_mjs/IOEnv/services.mjs +0 -1
- package/_mjs/IOEnv/services.mjs.map +1 -1
- package/_mjs/IOEnv.mjs.map +1 -1
- package/_mjs/InterruptStatus/constructors.mjs +0 -3
- package/_mjs/InterruptStatus/constructors.mjs.map +1 -1
- package/_mjs/InterruptStatus/definition.mjs +0 -3
- package/_mjs/InterruptStatus/definition.mjs.map +1 -1
- package/_mjs/InterruptStatus.mjs.map +1 -1
- package/_mjs/Layer/MemoMap.mjs +38 -66
- package/_mjs/Layer/MemoMap.mjs.map +1 -1
- package/_mjs/Layer/api.mjs +6 -71
- package/_mjs/Layer/api.mjs.map +1 -1
- package/_mjs/Layer/definition.mjs +17 -35
- package/_mjs/Layer/definition.mjs.map +1 -1
- package/_mjs/Layer.mjs.map +1 -1
- package/_mjs/LogLevel.mjs +0 -13
- package/_mjs/LogLevel.mjs.map +1 -1
- package/_mjs/LogSpan.mjs +0 -4
- package/_mjs/LogSpan.mjs.map +1 -1
- package/_mjs/Logger/api.mjs +0 -2
- package/_mjs/Logger/api.mjs.map +1 -1
- package/_mjs/Logger/constructors.mjs +2 -10
- package/_mjs/Logger/constructors.mjs.map +1 -1
- package/_mjs/Logger/definition.mjs +1 -1
- package/_mjs/Logger/definition.mjs.map +1 -1
- package/_mjs/Logger.mjs.map +1 -1
- package/_mjs/MVar/api.mjs +150 -0
- package/_mjs/MVar/api.mjs.map +1 -0
- package/_mjs/MVar/definition.mjs +18 -0
- package/_mjs/MVar/definition.mjs.map +1 -0
- package/_mjs/MVar.mjs +4 -0
- package/_mjs/MVar.mjs.map +1 -0
- package/_mjs/Push/api.mjs +420 -0
- package/_mjs/Push/api.mjs.map +1 -0
- package/_mjs/Push/definition.mjs +38 -0
- package/_mjs/Push/definition.mjs.map +1 -0
- package/_mjs/Push/internal.mjs +28 -0
- package/_mjs/Push/internal.mjs.map +1 -0
- package/_mjs/Push.mjs +5 -0
- package/_mjs/Push.mjs.map +1 -0
- package/_mjs/Queue/api/dimapIO.mjs +156 -0
- package/_mjs/Queue/api/dimapIO.mjs.map +1 -0
- package/_mjs/Queue/api/filterInputIO.mjs +98 -0
- package/_mjs/Queue/api/filterInputIO.mjs.map +1 -0
- package/_mjs/Queue/api/filterOutputIO.mjs +106 -0
- package/_mjs/Queue/api/filterOutputIO.mjs.map +1 -0
- package/_mjs/Queue/api/operations.mjs +118 -0
- package/_mjs/Queue/api/operations.mjs.map +1 -0
- package/_mjs/Queue/api/poll.mjs +13 -0
- package/_mjs/Queue/api/poll.mjs.map +1 -0
- package/_mjs/Queue/api/takeBetween.mjs +39 -0
- package/_mjs/Queue/api/takeBetween.mjs.map +1 -0
- package/_mjs/Queue/api/zipWithIO.mjs +71 -0
- package/_mjs/Queue/api/zipWithIO.mjs.map +1 -0
- package/_mjs/Queue/api.mjs +9 -0
- package/_mjs/Queue/api.mjs.map +1 -0
- package/_mjs/Queue/constructors.mjs +5 -20
- package/_mjs/Queue/constructors.mjs.map +1 -1
- package/_mjs/Queue/definition.mjs +18 -172
- package/_mjs/Queue/definition.mjs.map +1 -1
- package/_mjs/Queue/internal.mjs +141 -28
- package/_mjs/Queue/internal.mjs.map +1 -1
- package/_mjs/Queue/strategy.mjs +12 -36
- package/_mjs/Queue/strategy.mjs.map +1 -1
- package/_mjs/Queue.mjs +3 -1
- package/_mjs/Queue.mjs.map +1 -1
- package/_mjs/Random/api.mjs +0 -8
- package/_mjs/Random/api.mjs.map +1 -1
- package/_mjs/Random/definition.mjs +0 -2
- package/_mjs/Random/definition.mjs.map +1 -1
- package/_mjs/Random/live.mjs +0 -7
- package/_mjs/Random/live.mjs.map +1 -1
- package/_mjs/Random.mjs.map +1 -1
- package/_mjs/Ref/Atomic.mjs +25 -15
- package/_mjs/Ref/Atomic.mjs.map +1 -1
- package/_mjs/Ref/Derived.mjs +40 -0
- package/_mjs/Ref/Derived.mjs.map +1 -0
- package/_mjs/Ref/DerivedAll.mjs +39 -0
- package/_mjs/Ref/DerivedAll.mjs.map +1 -0
- package/_mjs/Ref/Synchronized/api.mjs +168 -0
- package/_mjs/Ref/Synchronized/api.mjs.map +1 -0
- package/_mjs/Ref/Synchronized/constructors.mjs +22 -0
- package/_mjs/Ref/Synchronized/constructors.mjs.map +1 -0
- package/_mjs/Ref/Synchronized/definition.mjs +57 -0
- package/_mjs/Ref/Synchronized/definition.mjs.map +1 -0
- package/_mjs/Ref/Synchronized.mjs +4 -122
- package/_mjs/Ref/Synchronized.mjs.map +1 -1
- package/_mjs/Ref/api/collect.mjs +18 -0
- package/_mjs/Ref/api/collect.mjs.map +1 -0
- package/_mjs/Ref/api/dimap.mjs +88 -0
- package/_mjs/Ref/api/dimap.mjs.map +1 -0
- package/_mjs/Ref/api/filter.mjs +31 -0
- package/_mjs/Ref/api/filter.mjs.map +1 -0
- package/_mjs/Ref/api/get.mjs +12 -0
- package/_mjs/Ref/api/get.mjs.map +1 -0
- package/_mjs/Ref/api/match.mjs +18 -0
- package/_mjs/Ref/api/match.mjs.map +1 -0
- package/_mjs/Ref/api/matchAll.mjs +16 -0
- package/_mjs/Ref/api/matchAll.mjs.map +1 -0
- package/_mjs/Ref/api/modify.mjs +124 -0
- package/_mjs/Ref/api/modify.mjs.map +1 -0
- package/_mjs/Ref/api/set.mjs +15 -0
- package/_mjs/Ref/api/set.mjs.map +1 -0
- package/_mjs/Ref/api.mjs +32 -0
- package/_mjs/Ref/api.mjs.map +1 -0
- package/_mjs/Ref/constructors.mjs +3 -18
- package/_mjs/Ref/constructors.mjs.map +1 -1
- package/_mjs/Ref/definition.mjs +12 -97
- package/_mjs/Ref/definition.mjs.map +1 -1
- package/_mjs/Ref.mjs +8 -0
- package/_mjs/Ref.mjs.map +1 -1
- package/_mjs/RefSubject/Atomic.mjs +100 -0
- package/_mjs/RefSubject/Atomic.mjs.map +1 -0
- package/_mjs/RefSubject/Synchronized/api.mjs +15 -0
- package/_mjs/RefSubject/Synchronized/api.mjs.map +1 -0
- package/_mjs/RefSubject/Synchronized/definition.mjs +45 -0
- package/_mjs/RefSubject/Synchronized/definition.mjs.map +1 -0
- package/_mjs/RefSubject/api.mjs +220 -0
- package/_mjs/RefSubject/api.mjs.map +1 -0
- package/_mjs/RefSubject/definition.mjs +18 -0
- package/_mjs/RefSubject/definition.mjs.map +1 -0
- package/_mjs/RefSubject.mjs +5 -0
- package/_mjs/RefSubject.mjs.map +1 -0
- package/_mjs/Reloadable/api.mjs +3 -12
- package/_mjs/Reloadable/api.mjs.map +1 -1
- package/_mjs/Reloadable/constructors.mjs +5 -17
- package/_mjs/Reloadable/constructors.mjs.map +1 -1
- package/_mjs/Reloadable/definition.mjs +2 -7
- package/_mjs/Reloadable/definition.mjs.map +1 -1
- package/_mjs/Reloadable.mjs.map +1 -1
- package/_mjs/RuntimeConfig.mjs +0 -31
- package/_mjs/RuntimeConfig.mjs.map +1 -1
- package/_mjs/RuntimeFlag.mjs +2 -0
- package/_mjs/RuntimeFlag.mjs.map +1 -0
- package/_mjs/RuntimeFlags/Patch.mjs +58 -0
- package/_mjs/RuntimeFlags/Patch.mjs.map +1 -0
- package/_mjs/RuntimeFlags/RuntimeFlags.mjs +82 -0
- package/_mjs/RuntimeFlags/RuntimeFlags.mjs.map +1 -0
- package/_mjs/RuntimeFlags.mjs +4 -0
- package/_mjs/RuntimeFlags.mjs.map +1 -0
- package/_mjs/STM/api/atomically.mjs +47 -0
- package/_mjs/STM/api/atomically.mjs.map +1 -0
- package/_mjs/STM/api/core-api.mjs +0 -8
- package/_mjs/STM/api/core-api.mjs.map +1 -1
- package/_mjs/STM/api/core-constructors.mjs +0 -8
- package/_mjs/STM/api/core-constructors.mjs.map +1 -1
- package/_mjs/STM/api.mjs +61 -171
- package/_mjs/STM/api.mjs.map +1 -1
- package/_mjs/STM/definition.mjs +34 -46
- package/_mjs/STM/definition.mjs.map +1 -1
- package/_mjs/STM/driver.mjs +10 -52
- package/_mjs/STM/driver.mjs.map +1 -1
- package/_mjs/STM/internal/CommitState.mjs +5 -25
- package/_mjs/STM/internal/CommitState.mjs.map +1 -1
- package/_mjs/STM/internal/Entry.mjs +5 -14
- package/_mjs/STM/internal/Entry.mjs.map +1 -1
- package/_mjs/STM/internal/Journal.mjs +17 -99
- package/_mjs/STM/internal/Journal.mjs.map +1 -1
- package/_mjs/STM/internal/TryCommit.mjs +9 -10
- package/_mjs/STM/internal/TryCommit.mjs.map +1 -1
- package/_mjs/STM/internal/Versioned.mjs +3 -2
- package/_mjs/STM/internal/Versioned.mjs.map +1 -1
- package/_mjs/STM.mjs +3 -2
- package/_mjs/STM.mjs.map +1 -1
- package/_mjs/Schedule/Decision.mjs +6 -19
- package/_mjs/Schedule/Decision.mjs.map +1 -1
- package/_mjs/Schedule/Driver.mjs +0 -2
- package/_mjs/Schedule/Driver.mjs.map +1 -1
- package/_mjs/Schedule/api/driver.mjs +16 -16
- package/_mjs/Schedule/api/driver.mjs.map +1 -1
- package/_mjs/Schedule/api.mjs +100 -187
- package/_mjs/Schedule/api.mjs.map +1 -1
- package/_mjs/Schedule/definition.mjs +1 -0
- package/_mjs/Schedule/definition.mjs.map +1 -1
- package/_mjs/Schedule.mjs.map +1 -1
- package/_mjs/Scope/Finalizer/definition.mjs +0 -1
- package/_mjs/Scope/Finalizer/definition.mjs.map +1 -1
- package/_mjs/Scope/Finalizer.mjs.map +1 -1
- package/_mjs/Scope/ReleaseMap/api/releaseAll.mjs +4 -5
- package/_mjs/Scope/ReleaseMap/api/releaseAll.mjs.map +1 -1
- package/_mjs/Scope/ReleaseMap/api.mjs +12 -22
- package/_mjs/Scope/ReleaseMap/api.mjs.map +1 -1
- package/_mjs/Scope/ReleaseMap/constructors.mjs +1 -4
- package/_mjs/Scope/ReleaseMap/constructors.mjs.map +1 -1
- package/_mjs/Scope/ReleaseMap/definition.mjs +0 -2
- package/_mjs/Scope/ReleaseMap/definition.mjs.map +1 -1
- package/_mjs/Scope/ReleaseMap.mjs.map +1 -1
- package/_mjs/Scope/api.mjs +1 -25
- package/_mjs/Scope/api.mjs.map +1 -1
- package/_mjs/Scope/definition.mjs +4 -6
- package/_mjs/Scope/definition.mjs.map +1 -1
- package/_mjs/Scope.mjs.map +1 -1
- package/_mjs/ScopedRef/api.mjs +9 -11
- package/_mjs/ScopedRef/api.mjs.map +1 -1
- package/_mjs/ScopedRef/definition.mjs +3 -3
- package/_mjs/ScopedRef/definition.mjs.map +1 -1
- package/_mjs/ScopedRef.mjs.map +1 -1
- package/_mjs/Sink/api.mjs +130 -292
- package/_mjs/Sink/api.mjs.map +1 -1
- package/_mjs/Sink/definition.mjs +0 -1
- package/_mjs/Sink/definition.mjs.map +1 -1
- package/_mjs/Sink.mjs.map +1 -1
- package/_mjs/State/api.mjs +1 -8
- package/_mjs/State/api.mjs.map +1 -1
- package/_mjs/State/definition.mjs +6 -5
- package/_mjs/State/definition.mjs.map +1 -1
- package/_mjs/State/internal.mjs +5 -3
- package/_mjs/State/internal.mjs.map +1 -1
- package/_mjs/State.mjs.map +1 -1
- package/_mjs/Stream/api/zipAllWith.mjs +2 -19
- package/_mjs/Stream/api/zipAllWith.mjs.map +1 -1
- package/_mjs/Stream/api/zipWith.mjs +0 -1
- package/_mjs/Stream/api/zipWith.mjs.map +1 -1
- package/_mjs/Stream/api/zipWithChunks.mjs +2 -14
- package/_mjs/Stream/api/zipWithChunks.mjs.map +1 -1
- package/_mjs/Stream/api.mjs +232 -544
- package/_mjs/Stream/api.mjs.map +1 -1
- package/_mjs/Stream/definition.mjs +2 -5
- package/_mjs/Stream/definition.mjs.map +1 -1
- package/_mjs/Stream/internal/DebounceState.mjs +9 -27
- package/_mjs/Stream/internal/DebounceState.mjs.map +1 -1
- package/_mjs/Stream/internal/Handoff.mjs +45 -58
- package/_mjs/Stream/internal/Handoff.mjs.map +1 -1
- package/_mjs/Stream/internal/Pull.mjs +10 -16
- package/_mjs/Stream/internal/Pull.mjs.map +1 -1
- package/_mjs/Stream/internal/SinkEndReason.mjs +11 -18
- package/_mjs/Stream/internal/SinkEndReason.mjs.map +1 -1
- package/_mjs/Stream/internal/Take.mjs +0 -22
- package/_mjs/Stream/internal/Take.mjs.map +1 -1
- package/_mjs/Stream/internal/util.mjs +0 -3
- package/_mjs/Stream/internal/util.mjs.map +1 -1
- package/_mjs/Stream.mjs.map +1 -1
- package/_mjs/Subject/Atomic.mjs +24 -0
- package/_mjs/Subject/Atomic.mjs.map +1 -0
- package/_mjs/Subject/api.mjs +18 -0
- package/_mjs/Subject/api.mjs.map +1 -0
- package/_mjs/Subject/definition.mjs +3 -0
- package/_mjs/Subject/definition.mjs.map +1 -0
- package/_mjs/Subject.mjs +5 -0
- package/_mjs/Subject.mjs.map +1 -0
- package/_mjs/SubscriptionRef.mjs +19 -23
- package/_mjs/SubscriptionRef.mjs.map +1 -1
- package/_mjs/Supervisor/api.mjs +4 -15
- package/_mjs/Supervisor/api.mjs.map +1 -1
- package/_mjs/Supervisor/constructors.mjs +0 -12
- package/_mjs/Supervisor/constructors.mjs.map +1 -1
- package/_mjs/Supervisor/definition.mjs +5 -31
- package/_mjs/Supervisor/definition.mjs.map +1 -1
- package/_mjs/Supervisor.mjs.map +1 -1
- package/_mjs/SupervisorPatch.mjs +16 -45
- package/_mjs/SupervisorPatch.mjs.map +1 -1
- package/_mjs/TExit/constructors.mjs +0 -6
- package/_mjs/TExit/constructors.mjs.map +1 -1
- package/_mjs/TExit/definition.mjs +36 -78
- package/_mjs/TExit/definition.mjs.map +1 -1
- package/_mjs/TExit.mjs.map +1 -1
- package/_mjs/TFuture/api.mjs +0 -6
- package/_mjs/TFuture/api.mjs.map +1 -1
- package/_mjs/TFuture/constructors.mjs +1 -4
- package/_mjs/TFuture/constructors.mjs.map +1 -1
- package/_mjs/TFuture/definition.mjs.map +1 -1
- package/_mjs/TFuture.mjs.map +1 -1
- package/_mjs/TReentrantLock/api.mjs +17 -64
- package/_mjs/TReentrantLock/api.mjs.map +1 -1
- package/_mjs/TReentrantLock/definition.mjs +3 -22
- package/_mjs/TReentrantLock/definition.mjs.map +1 -1
- package/_mjs/TReentrantLock.mjs.map +1 -1
- package/_mjs/TRef/api.mjs +20 -222
- package/_mjs/TRef/api.mjs.map +1 -1
- package/_mjs/TRef/constructors.mjs +1 -8
- package/_mjs/TRef/constructors.mjs.map +1 -1
- package/_mjs/TRef/definition.mjs +83 -19
- package/_mjs/TRef/definition.mjs.map +1 -1
- package/_mjs/TRef.mjs.map +1 -1
- package/_mjs/TSemaphore/api.mjs +5 -15
- package/_mjs/TSemaphore/api.mjs.map +1 -1
- package/_mjs/TSemaphore/constructors.mjs +1 -5
- package/_mjs/TSemaphore/constructors.mjs.map +1 -1
- package/_mjs/TSemaphore/definition.mjs.map +1 -1
- package/_mjs/TSemaphore.mjs.map +1 -1
- package/_mjs/TxnId.mjs +0 -1
- package/_mjs/TxnId.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/dropUntilIO.mjs +0 -3
- package/_mjs/collection/immutable/Conc/dropUntilIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/dropWhileIO.mjs +0 -3
- package/_mjs/collection/immutable/Conc/dropWhileIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/filterIO.mjs +0 -3
- package/_mjs/collection/immutable/Conc/filterIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/findIO.mjs +0 -7
- package/_mjs/collection/immutable/Conc/findIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/mapIO.mjs +0 -1
- package/_mjs/collection/immutable/Conc/mapIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/takeWhileIO.mjs +0 -4
- package/_mjs/collection/immutable/Conc/takeWhileIO.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc.mjs.map +1 -1
- package/_mjs/data/Exit/foreachIO.mjs +0 -1
- package/_mjs/data/Exit/foreachIO.mjs.map +1 -1
- package/_mjs/internal/HashedPair.mjs +4 -7
- package/_mjs/internal/HashedPair.mjs.map +1 -1
- package/_mjs/internal/Hub.mjs +0 -147
- package/_mjs/internal/Hub.mjs.map +1 -1
- package/_mjs/internal/IsFatal.mjs +15 -42
- package/_mjs/internal/IsFatal.mjs.map +1 -1
- package/_mjs/internal/MutableQueue.mjs +0 -49
- package/_mjs/internal/MutableQueue.mjs.map +1 -1
- package/_mjs/internal/Scheduler.mjs +0 -11
- package/_mjs/internal/Scheduler.mjs.map +1 -1
- package/_mjs/internal/StackTraceBuilder.mjs +0 -3
- package/_mjs/internal/StackTraceBuilder.mjs.map +1 -1
- package/_src/Cached/definition.ts +6 -4
- package/_src/Cached/internal.ts +4 -4
- package/_src/Channel/api/{mapOutIOC.ts → mapOutConcurrentIO.ts} +8 -5
- package/_src/Channel/api/mergeAllWith.ts +6 -6
- package/_src/Channel/api/mergeWith.ts +5 -5
- package/_src/Channel/api/{zipC.ts → zipConcurrent.ts} +10 -10
- package/_src/Channel/api.ts +31 -32
- package/_src/Channel/core-api.ts +4 -4
- package/_src/Channel/definition.ts +37 -14
- package/_src/Channel/internal/ChannelExecutor.ts +25 -14
- package/_src/Channel/internal/MergeDecision.ts +11 -6
- package/_src/Channel/internal/SingleProducerAsyncInput.ts +1 -1
- package/_src/CountdownLatch.ts +39 -0
- package/_src/Differ/definition.ts +2 -4
- package/_src/Fiber/FiberMessage.ts +78 -0
- package/_src/Fiber/FiberRuntime.ts +826 -0
- package/_src/Fiber/api/awaitAll.ts +1 -1
- package/_src/Fiber/api/collectAll.ts +3 -2
- package/_src/Fiber/api/inheritRefs.ts +1 -1
- package/_src/Fiber/api/interrupt.ts +1 -2
- package/_src/Fiber/api/interruptAs.ts +11 -6
- package/_src/Fiber/api/interruptFork.ts +1 -1
- package/_src/Fiber/api/location.ts +2 -2
- package/_src/Fiber/api/zipWith.ts +1 -1
- package/_src/Fiber/definition.ts +44 -22
- package/_src/Fiber.ts +2 -4
- package/_src/FiberDescriptor.ts +1 -8
- package/_src/FiberRef/api.ts +13 -17
- package/_src/FiberRef/definition.ts +9 -4
- package/_src/FiberRef/unsafe.ts +6 -1
- package/_src/FiberRefs/api.ts +56 -3
- package/_src/FiberRefs/definition.ts +15 -7
- package/_src/FiberRefs/join.ts +5 -5
- package/_src/FiberScope/constructors.ts +2 -2
- package/_src/FiberScope/definition.ts +21 -9
- package/_src/FiberStatus/constructors.ts +6 -18
- package/_src/FiberStatus/definition.ts +13 -54
- package/_src/Future/api.ts +14 -5
- package/_src/Hub/api.ts +451 -0
- package/_src/Hub/definition.ts +117 -93
- package/_src/Hub/internal.ts +165 -115
- package/_src/Hub.ts +1 -1
- package/_src/IO/api/asyncInterrupt.ts +77 -0
- package/_src/IO/api/core-scope.ts +70 -89
- package/_src/IO/api/delay.ts +8 -0
- package/_src/IO/api/{foreachC.ts → foreachConcurrent.ts} +8 -8
- package/_src/IO/api/foreachExec.ts +2 -2
- package/_src/IO/api/fork.ts +83 -0
- package/_src/IO/api/interrupt.ts +106 -69
- package/_src/IO/api/onTermination.ts +8 -7
- package/_src/IO/api/race.ts +4 -4
- package/_src/IO/api/sequenceT.ts +4 -6
- package/_src/IO/api/supervised.ts +7 -9
- package/_src/IO/api/withChildren.ts +2 -4
- package/_src/IO/api/{zipC.ts → zipConcurrent.ts} +9 -9
- package/_src/IO/api.ts +99 -256
- package/_src/IO/definition.ts +171 -161
- package/_src/IO/runtime.ts +62 -61
- package/_src/IO.ts +6 -4
- package/_src/Layer/MemoMap.ts +3 -3
- package/_src/Layer/api.ts +2 -2
- package/_src/Layer/definition.ts +18 -13
- package/_src/Logger/definition.ts +9 -4
- package/_src/MVar/api.ts +185 -0
- package/_src/MVar/definition.ts +45 -0
- package/_src/MVar.ts +4 -0
- package/_src/Push/api.ts +705 -0
- package/_src/Push/definition.ts +51 -0
- package/_src/Push/internal.ts +39 -0
- package/_src/Push.ts +5 -0
- package/_src/Queue/api/dimapIO.ts +218 -0
- package/_src/Queue/api/filterInputIO.ts +122 -0
- package/_src/Queue/api/filterOutputIO.ts +138 -0
- package/_src/Queue/api/operations.ts +141 -0
- package/_src/Queue/api/poll.ts +16 -0
- package/_src/Queue/api/takeBetween.ts +44 -0
- package/_src/Queue/api/zipWithIO.ts +110 -0
- package/_src/Queue/api.ts +9 -0
- package/_src/Queue/constructors.ts +6 -22
- package/_src/Queue/definition.ts +196 -215
- package/_src/Queue/internal.ts +159 -2
- package/_src/Queue/strategy.ts +3 -3
- package/_src/Queue.ts +3 -1
- package/_src/Ref/Atomic.ts +43 -10
- package/_src/Ref/Derived.ts +95 -0
- package/_src/Ref/DerivedAll.ts +99 -0
- package/_src/Ref/Synchronized/api.ts +248 -0
- package/_src/Ref/Synchronized/constructors.ts +21 -0
- package/_src/Ref/Synchronized/definition.ts +136 -0
- package/_src/Ref/Synchronized.ts +5 -107
- package/_src/Ref/api/collect.ts +17 -0
- package/_src/Ref/api/dimap.ts +102 -0
- package/_src/Ref/api/filter.ts +31 -0
- package/_src/Ref/api/get.ts +14 -0
- package/_src/Ref/api/match.ts +25 -0
- package/_src/Ref/api/matchAll.ts +24 -0
- package/_src/Ref/api/modify.ts +133 -0
- package/_src/Ref/api/set.ts +17 -0
- package/_src/Ref/api.ts +39 -0
- package/_src/Ref/constructors.ts +2 -15
- package/_src/Ref/definition.ts +124 -81
- package/_src/Ref.ts +9 -0
- package/_src/RefSubject/Atomic.ts +120 -0
- package/_src/RefSubject/Synchronized/api.ts +14 -0
- package/_src/RefSubject/Synchronized/definition.ts +72 -0
- package/_src/RefSubject/api.ts +240 -0
- package/_src/RefSubject/definition.ts +69 -0
- package/_src/RefSubject.ts +5 -0
- package/_src/Reloadable/definition.ts +6 -1
- package/_src/RuntimeConfig.ts +0 -29
- package/_src/RuntimeFlag.ts +10 -0
- package/_src/RuntimeFlags/Patch.ts +79 -0
- package/_src/RuntimeFlags/RuntimeFlags.ts +112 -0
- package/_src/RuntimeFlags.ts +4 -0
- package/_src/STM/api/atomically.ts +43 -0
- package/_src/STM/api.ts +20 -38
- package/_src/STM/definition.ts +33 -20
- package/_src/STM/driver.ts +3 -3
- package/_src/STM/internal/Entry.ts +2 -2
- package/_src/STM/internal/Journal.ts +1 -1
- package/_src/STM/internal/TryCommit.ts +4 -4
- package/_src/STM/internal/Versioned.ts +1 -1
- package/_src/STM.ts +1 -0
- package/_src/Schedule/api/driver.ts +2 -2
- package/_src/Schedule/api.ts +60 -38
- package/_src/Schedule/definition.ts +8 -3
- package/_src/Scope/ReleaseMap/api/releaseAll.ts +4 -3
- package/_src/Scope/ReleaseMap/constructors.ts +1 -1
- package/_src/Scope/definition.ts +2 -2
- package/_src/ScopedRef/definition.ts +1 -1
- package/_src/Sink/api.ts +15 -12
- package/_src/State/api.ts +1 -1
- package/_src/State/definition.ts +6 -3
- package/_src/State/internal.ts +8 -3
- package/_src/Stream/api/zipAllWith.ts +1 -1
- package/_src/Stream/api/zipWithChunks.ts +1 -1
- package/_src/Stream/api.ts +91 -81
- package/_src/Stream/definition.ts +17 -5
- package/_src/Stream/internal/Handoff.ts +34 -27
- package/_src/Stream/internal/Pull.ts +2 -1
- package/_src/Stream/internal/SinkEndReason.ts +2 -2
- package/_src/Subject/Atomic.ts +32 -0
- package/_src/Subject/api.ts +18 -0
- package/_src/Subject/definition.ts +18 -0
- package/_src/Subject.ts +5 -0
- package/_src/SubscriptionRef.ts +21 -7
- package/_src/Supervisor/api.ts +2 -2
- package/_src/SupervisorPatch.ts +1 -1
- package/_src/TExit/definition.ts +11 -12
- package/_src/TFuture/definition.ts +2 -2
- package/_src/TReentrantLock/api.ts +4 -4
- package/_src/TReentrantLock/definition.ts +1 -1
- package/_src/TRef/api.ts +32 -200
- package/_src/TRef/constructors.ts +6 -6
- package/_src/TRef/definition.ts +171 -39
- package/_src/TSemaphore/api.ts +1 -1
- package/_src/TSemaphore/definition.ts +1 -1
- package/_src/global.ts +13 -5
- package/_src/index.ts +7 -1
- package/_src/internal/IsFatal.ts +1 -1
- package/global.d.ts +13 -5
- package/index.d.ts +7 -1
- package/internal/HashedPair.d.ts +2 -2
- package/internal/IsFatal.d.ts +1 -1
- package/package.json +4 -4
- package/Channel/api/mapOutIOC.d.ts +0 -8
- package/Channel/api/zipC.d.ts +0 -16
- package/Fiber/FiberContext.d.ts +0 -153
- package/Fiber/api/evalOn.d.ts +0 -7
- package/Fiber/api/evalOnIO.d.ts +0 -9
- package/Fiber/api/interruptAsFork.d.ts +0 -8
- package/FiberState/api.d.ts +0 -7
- package/FiberState/constructors.d.ts +0 -22
- package/FiberState/definition.d.ts +0 -38
- package/FiberState.d.ts +0 -3
- package/Hub/constructors.d.ts +0 -49
- package/IO/api/onExit.d.ts +0 -7
- package/IO/api/withRuntimeConfig.d.ts +0 -10
- package/IO/api/zipC.d.ts +0 -13
- package/_cjs/Channel/api/mapOutIOC.cjs +0 -63
- package/_cjs/Channel/api/mapOutIOC.cjs.map +0 -1
- package/_cjs/Channel/api/zipC.cjs.map +0 -1
- package/_cjs/Fiber/FiberContext.cjs +0 -1088
- package/_cjs/Fiber/FiberContext.cjs.map +0 -1
- package/_cjs/Fiber/api/evalOn.cjs.map +0 -1
- package/_cjs/Fiber/api/evalOnIO.cjs.map +0 -1
- package/_cjs/Fiber/api/interruptAsFork.cjs +0 -17
- package/_cjs/Fiber/api/interruptAsFork.cjs.map +0 -1
- package/_cjs/FiberState/api.cjs.map +0 -1
- package/_cjs/FiberState/constructors.cjs.map +0 -1
- package/_cjs/FiberState/definition.cjs +0 -46
- package/_cjs/FiberState/definition.cjs.map +0 -1
- package/_cjs/FiberState.cjs.map +0 -1
- package/_cjs/Hub/constructors.cjs +0 -93
- package/_cjs/Hub/constructors.cjs.map +0 -1
- package/_cjs/IO/api/foreachC.cjs.map +0 -1
- package/_cjs/IO/api/onExit.cjs.map +0 -1
- package/_cjs/IO/api/withRuntimeConfig.cjs.map +0 -1
- package/_cjs/IO/api/zipC.cjs.map +0 -1
- package/_mjs/Channel/api/mapOutIOC.mjs +0 -33
- package/_mjs/Channel/api/mapOutIOC.mjs.map +0 -1
- package/_mjs/Channel/api/zipC.mjs +0 -36
- package/_mjs/Channel/api/zipC.mjs.map +0 -1
- package/_mjs/Fiber/FiberContext.mjs +0 -1013
- package/_mjs/Fiber/FiberContext.mjs.map +0 -1
- package/_mjs/Fiber/api/evalOn.mjs +0 -19
- package/_mjs/Fiber/api/evalOn.mjs.map +0 -1
- package/_mjs/Fiber/api/evalOnIO.mjs +0 -18
- package/_mjs/Fiber/api/evalOnIO.mjs.map +0 -1
- package/_mjs/Fiber/api/interruptAsFork.mjs +0 -10
- package/_mjs/Fiber/api/interruptAsFork.mjs.map +0 -1
- package/_mjs/FiberState/api.mjs +0 -15
- package/_mjs/FiberState/api.mjs.map +0 -1
- package/_mjs/FiberState/constructors.mjs +0 -26
- package/_mjs/FiberState/constructors.mjs.map +0 -1
- package/_mjs/FiberState/definition.mjs +0 -26
- package/_mjs/FiberState/definition.mjs.map +0 -1
- package/_mjs/FiberState.mjs +0 -5
- package/_mjs/FiberState.mjs.map +0 -1
- package/_mjs/Hub/constructors.mjs +0 -66
- package/_mjs/Hub/constructors.mjs.map +0 -1
- package/_mjs/IO/api/foreachC.mjs.map +0 -1
- package/_mjs/IO/api/onExit.mjs +0 -12
- package/_mjs/IO/api/onExit.mjs.map +0 -1
- package/_mjs/IO/api/withRuntimeConfig.mjs +0 -15
- package/_mjs/IO/api/withRuntimeConfig.mjs.map +0 -1
- package/_mjs/IO/api/zipC.mjs +0 -43
- package/_mjs/IO/api/zipC.mjs.map +0 -1
- package/_src/Fiber/FiberContext.ts +0 -999
- package/_src/Fiber/api/evalOn.ts +0 -14
- package/_src/Fiber/api/evalOnIO.ts +0 -16
- package/_src/Fiber/api/interruptAsFork.ts +0 -9
- package/_src/FiberState/api.ts +0 -12
- package/_src/FiberState/constructors.ts +0 -33
- package/_src/FiberState/definition.ts +0 -43
- package/_src/FiberState.ts +0 -5
- package/_src/Hub/constructors.ts +0 -80
- package/_src/IO/api/onExit.ts +0 -11
- package/_src/IO/api/withRuntimeConfig.ts +0 -18
package/_src/Hub/definition.ts
CHANGED
@@ -1,108 +1,132 @@
|
|
1
|
-
import type {
|
2
|
-
import type {
|
3
|
-
|
4
|
-
import
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
import type { Hub as HubInternal } from "@fncts/io/internal/Hub";
|
9
|
-
|
10
|
-
import { QueueTypeId } from "../Queue/definition.js";
|
11
|
-
import { makeSubscription } from "./internal.js";
|
1
|
+
import type { IO } from "@fncts/io/IO";
|
2
|
+
import type { PDequeue, PEnqueue, PEnqueueInternal } from "@fncts/io/Queue";
|
3
|
+
|
4
|
+
import { EnqueueTypeId, QueueTypeId, QueueVariance } from "@fncts/io/Queue/definition";
|
5
|
+
|
6
|
+
export const HubVariance = Symbol.for("fncts.io.Hub.Variance");
|
7
|
+
export type HubVariance = typeof HubVariance;
|
12
8
|
|
13
9
|
export const HubTypeId = Symbol.for("fncts.io.Hub");
|
14
10
|
export type HubTypeId = typeof HubTypeId;
|
15
11
|
|
16
12
|
/**
|
13
|
+
* A `Hub<RA, RB, EA, EB, A, B>` is an asynchronous message hub. Publishers
|
14
|
+
* can publish messages of type `A` to the hub and subscribers can subscribe to
|
15
|
+
* take messages of type `B` from the hub. Publishing messages can require an
|
16
|
+
* environment of type `RA` and fail with an error of type `EA`. Taking
|
17
|
+
* messages can require an environment of type `RB` and fail with an error of
|
18
|
+
* type `EB`.
|
19
|
+
*
|
17
20
|
* @tsplus type fncts.io.Hub
|
18
|
-
* @tsplus companion fncts.io.HubOps
|
19
21
|
*/
|
20
|
-
export
|
21
|
-
readonly [
|
22
|
-
readonly [
|
23
|
-
|
24
|
-
|
25
|
-
readonly
|
26
|
-
readonly
|
27
|
-
readonly
|
28
|
-
readonly
|
29
|
-
|
30
|
-
|
31
|
-
) {}
|
32
|
-
|
33
|
-
awaitShutdown: UIO<void> = this.shutdownHook.await;
|
34
|
-
|
35
|
-
get capacity(): number {
|
36
|
-
return this.hub.capacity;
|
37
|
-
}
|
38
|
-
|
39
|
-
isShutdown: UIO<boolean> = IO(this.shutdownFlag.get);
|
40
|
-
|
41
|
-
publish(this: this, a: A, __tsplusTrace?: string): UIO<boolean> {
|
42
|
-
return IO.defer(() => {
|
43
|
-
if (this.shutdownFlag.get) {
|
44
|
-
return IO.interrupt;
|
45
|
-
}
|
46
|
-
|
47
|
-
if (this.hub.publish(a)) {
|
48
|
-
this.strategy.unsafeCompleteSubscribers(this.hub, this.subscribers);
|
49
|
-
return IO.succeedNow(true);
|
50
|
-
}
|
51
|
-
|
52
|
-
return this.strategy.handleSurplus(this.hub, this.subscribers, Conc.single(a), this.shutdownFlag);
|
53
|
-
});
|
54
|
-
}
|
55
|
-
|
56
|
-
publishAll(this: this, as: Iterable<A>, __tsplusTrace?: string): UIO<boolean> {
|
57
|
-
return IO.defer(() => {
|
58
|
-
if (this.shutdownFlag.get) {
|
59
|
-
return IO.interrupt;
|
60
|
-
}
|
61
|
-
|
62
|
-
const surplus = this.hub.publishAll(as);
|
63
|
-
|
64
|
-
this.strategy.unsafeCompleteSubscribers(this.hub, this.subscribers);
|
65
|
-
|
66
|
-
if (surplus.isEmpty) {
|
67
|
-
return IO.succeedNow(true);
|
68
|
-
}
|
69
|
-
|
70
|
-
return this.strategy.handleSurplus(this.hub, this.subscribers, surplus, this.shutdownFlag);
|
71
|
-
});
|
72
|
-
}
|
73
|
-
|
74
|
-
shutdown: UIO<void> = IO.deferWith((_, fiberId) => {
|
75
|
-
this.shutdownFlag.set(true);
|
76
|
-
return this.scope
|
77
|
-
.close(Exit.interrupt(fiberId))
|
78
|
-
.apSecond(this.strategy.shutdown)
|
79
|
-
.whenIO(this.shutdownHook.succeed(undefined));
|
80
|
-
}).uninterruptible;
|
81
|
-
|
82
|
-
size: UIO<number> = IO.defer(() => {
|
83
|
-
if (this.shutdownFlag.get) {
|
84
|
-
return IO.interrupt;
|
85
|
-
}
|
86
|
-
|
87
|
-
return IO.succeed(this.hub.size());
|
88
|
-
});
|
89
|
-
|
90
|
-
subscribe: IO<Scope, never, Dequeue<A>> = IO.acquireRelease(
|
91
|
-
makeSubscription(this.hub, this.subscribers, this.strategy).tap((dequeue) =>
|
92
|
-
this.scope.addFinalizer(dequeue.shutdown),
|
93
|
-
),
|
94
|
-
(dequeue) => dequeue.shutdown,
|
95
|
-
);
|
96
|
-
|
97
|
-
isEmpty: UIO<boolean> = this.size.map((size) => size === 0);
|
22
|
+
export interface PHub<RA, RB, EA, EB, A, B> extends PEnqueue<RA, RB, EA, EB, A, B> {
|
23
|
+
readonly [HubTypeId]: HubTypeId;
|
24
|
+
readonly [HubVariance]: {
|
25
|
+
readonly _RA: (_: never) => RA;
|
26
|
+
readonly _RB: (_: never) => RB;
|
27
|
+
readonly _EA: (_: never) => EA;
|
28
|
+
readonly _EB: (_: never) => EB;
|
29
|
+
readonly _A: (_: A) => void;
|
30
|
+
readonly _B: (_: never) => B;
|
31
|
+
};
|
32
|
+
}
|
98
33
|
|
99
|
-
|
34
|
+
/**
|
35
|
+
* @tsplus type fncts.io.Hub
|
36
|
+
*/
|
37
|
+
export interface Hub<A> extends PHub<never, never, never, never, A, A> {}
|
100
38
|
|
101
|
-
|
39
|
+
/**
|
40
|
+
* @tsplus type fncts.io.HubOps
|
41
|
+
*/
|
42
|
+
export interface HubOps {}
|
43
|
+
|
44
|
+
export const Hub: HubOps = {};
|
45
|
+
|
46
|
+
export declare namespace PHub {}
|
47
|
+
export declare namespace Hub {}
|
48
|
+
|
49
|
+
export abstract class PHubInternal<RA, RB, EA, EB, A, B>
|
50
|
+
implements PHub<RA, RB, EA, EB, A, B>, PEnqueueInternal<RA, RB, EA, EB, A, B>
|
51
|
+
{
|
52
|
+
readonly [QueueTypeId]: QueueTypeId = QueueTypeId;
|
53
|
+
readonly [EnqueueTypeId]: EnqueueTypeId = EnqueueTypeId;
|
54
|
+
readonly [HubTypeId]: HubTypeId = HubTypeId;
|
55
|
+
declare [HubVariance]: {
|
56
|
+
readonly _RA: (_: never) => RA;
|
57
|
+
readonly _RB: (_: never) => RB;
|
58
|
+
readonly _EA: (_: never) => EA;
|
59
|
+
readonly _EB: (_: never) => EB;
|
60
|
+
readonly _A: (_: A) => void;
|
61
|
+
readonly _B: (_: never) => B;
|
62
|
+
};
|
63
|
+
declare [QueueVariance]: {
|
64
|
+
readonly _RA: (_: never) => RA;
|
65
|
+
readonly _RB: (_: never) => RB;
|
66
|
+
readonly _EA: (_: never) => EA;
|
67
|
+
readonly _EB: (_: never) => EB;
|
68
|
+
readonly _A: (_: A) => void;
|
69
|
+
readonly _B: (_: never) => B;
|
70
|
+
};
|
71
|
+
|
72
|
+
/**
|
73
|
+
* Waits for the hub to be shut down.
|
74
|
+
*/
|
75
|
+
abstract awaitShutdown: UIO<void>;
|
76
|
+
|
77
|
+
/**
|
78
|
+
* The maximum capacity of the hub.
|
79
|
+
*/
|
80
|
+
abstract capacity: number;
|
81
|
+
|
82
|
+
/**
|
83
|
+
* Checks whether the hub is shut down.
|
84
|
+
*/
|
85
|
+
abstract isShutdown: UIO<boolean>;
|
86
|
+
|
87
|
+
/**
|
88
|
+
* Publishes a message to the hub, returning whether the message was
|
89
|
+
* published to the hub.
|
90
|
+
*/
|
91
|
+
abstract publish(a: A): IO<RA, EA, boolean>;
|
92
|
+
|
93
|
+
/**
|
94
|
+
* Publishes all of the specified messages to the hub, returning whether
|
95
|
+
* they were published to the hub.
|
96
|
+
*/
|
97
|
+
abstract publishAll(as: Iterable<A>): IO<RA, EA, boolean>;
|
98
|
+
|
99
|
+
/**
|
100
|
+
* Shuts down the hub.
|
101
|
+
*/
|
102
|
+
abstract shutdown: UIO<void>;
|
103
|
+
|
104
|
+
/**
|
105
|
+
* The current number of messages in the hub.
|
106
|
+
*/
|
107
|
+
abstract size: UIO<number>;
|
108
|
+
|
109
|
+
/**
|
110
|
+
* Subscribes to receive messages from the hub. The resulting subscription
|
111
|
+
* can be evaluated multiple times within the scope of the managed to take a
|
112
|
+
* message from the hub each time.
|
113
|
+
*/
|
114
|
+
abstract subscribe: IO<Scope, never, PDequeue<RA, RB, EA, EB, A, B>>;
|
115
|
+
|
116
|
+
offer(a: A, __tsplusTrace?: string): IO<RA, EA, boolean> {
|
102
117
|
return this.publish(a);
|
103
118
|
}
|
104
119
|
|
105
|
-
offerAll(
|
120
|
+
offerAll(as: Iterable<A>, __tsplusTrace?: string): IO<RA, EA, boolean> {
|
106
121
|
return this.publishAll(as);
|
107
122
|
}
|
108
123
|
}
|
124
|
+
|
125
|
+
/**
|
126
|
+
* @tsplus macro remove
|
127
|
+
*/
|
128
|
+
export function concrete<RA, RB, EA, EB, A, B>(
|
129
|
+
_: PHub<RA, RB, EA, EB, A, B>,
|
130
|
+
): asserts _ is PHubInternal<RA, RB, EA, EB, A, B> {
|
131
|
+
//
|
132
|
+
}
|
package/_src/Hub/internal.ts
CHANGED
@@ -1,11 +1,11 @@
|
|
1
1
|
import type { Hub as HubInternal } from "@fncts/io/internal/Hub";
|
2
|
-
import type { Dequeue } from "@fncts/io/Queue";
|
3
2
|
|
4
3
|
import { HashSet } from "@fncts/base/collection/mutable/HashSet";
|
5
4
|
import { AtomicBoolean } from "@fncts/base/internal/AtomicBoolean";
|
5
|
+
import { PHubInternal } from "@fncts/io/Hub/definition";
|
6
6
|
import { HashedPair } from "@fncts/io/internal/HashedPair";
|
7
7
|
import { MutableQueue } from "@fncts/io/internal/MutableQueue";
|
8
|
-
import {
|
8
|
+
import { QueueInternal } from "@fncts/io/Queue";
|
9
9
|
|
10
10
|
/**
|
11
11
|
* A `Strategy<A>` describes the protocol for how publishers and subscribers
|
@@ -128,7 +128,7 @@ export class BackPressure<A> extends Strategy<A> {
|
|
128
128
|
return Do((_) => {
|
129
129
|
const fiberId = _(IO.fiberId);
|
130
130
|
const publishers = _(IO.succeed(self.publishers.unsafeDequeueAll));
|
131
|
-
_(publishers.
|
131
|
+
_(publishers.traverseIOConcurrentDiscard(([_, future, last]) => (last ? future.interruptAs(fiberId) : IO.unit)));
|
132
132
|
});
|
133
133
|
}
|
134
134
|
|
@@ -254,9 +254,7 @@ export class Sliding<A> extends Strategy<A> {
|
|
254
254
|
}
|
255
255
|
}
|
256
256
|
|
257
|
-
class UnsafeSubscription<A>
|
258
|
-
readonly [QueueTypeId]: QueueTypeId = QueueTypeId;
|
259
|
-
declare _Out: (_: never) => A;
|
257
|
+
class UnsafeSubscription<A> extends QueueInternal<never, never, never, never, A, A> {
|
260
258
|
constructor(
|
261
259
|
readonly hub: HubInternal<A>,
|
262
260
|
readonly subscribers: HashSet<HashedPair<HubInternal.Subscription<A>, MutableQueue<Future<never, A>>>>,
|
@@ -265,92 +263,83 @@ class UnsafeSubscription<A> implements Dequeue<A> {
|
|
265
263
|
readonly shutdownHook: Future<never, void>,
|
266
264
|
readonly shutdownFlag: AtomicBoolean,
|
267
265
|
readonly strategy: Strategy<A>,
|
268
|
-
) {
|
269
|
-
|
270
|
-
get awaitShutdown(): UIO<void> {
|
271
|
-
return this.shutdownHook.await;
|
266
|
+
) {
|
267
|
+
super();
|
272
268
|
}
|
273
269
|
|
274
|
-
|
275
|
-
return this.hub.capacity;
|
276
|
-
}
|
270
|
+
awaitShutdown: UIO<void> = this.shutdownHook.await;
|
277
271
|
|
278
|
-
|
279
|
-
return IO.succeed(() => this.shutdownFlag.get);
|
280
|
-
}
|
272
|
+
capacity: number = this.hub.capacity;
|
281
273
|
|
282
|
-
|
283
|
-
return IO.fiberId.flatMap((fiberId) =>
|
284
|
-
IO.defer(() => {
|
285
|
-
this.shutdownFlag.set(true);
|
286
|
-
return this.pollers.unsafeDequeueAll
|
287
|
-
.traverseIOC((fiber) => fiber.interruptAs(fiberId))
|
288
|
-
.apSecond(IO.succeed(this.subscription.unsubscribe()))
|
289
|
-
.whenIO(this.shutdownHook.succeed(undefined));
|
290
|
-
}),
|
291
|
-
);
|
292
|
-
}
|
274
|
+
isShutdown: UIO<boolean> = IO.succeed(() => this.shutdownFlag.get);
|
293
275
|
|
294
|
-
|
295
|
-
|
296
|
-
|
297
|
-
|
298
|
-
|
276
|
+
shutdown: UIO<void> = IO.fiberId.flatMap((fiberId) =>
|
277
|
+
IO.defer(() => {
|
278
|
+
this.shutdownFlag.set(true);
|
279
|
+
return IO.foreachConcurrent(this.pollers.unsafeDequeueAll, (fiber) => fiber.interruptAs(fiberId))
|
280
|
+
.zipRight(IO.succeed(this.subscription.unsubscribe()))
|
281
|
+
.whenIO(this.shutdownHook.succeed(undefined));
|
282
|
+
}),
|
283
|
+
);
|
299
284
|
|
300
|
-
|
301
|
-
|
302
|
-
|
285
|
+
size: UIO<number> = IO.defer(() => {
|
286
|
+
if (this.shutdownFlag.get) {
|
287
|
+
return IO.interrupt;
|
288
|
+
}
|
303
289
|
|
304
|
-
|
305
|
-
|
306
|
-
IO.defer(() => {
|
307
|
-
if (this.shutdownFlag.get) {
|
308
|
-
return IO.interrupt;
|
309
|
-
}
|
290
|
+
return IO.succeed(this.subscription.size());
|
291
|
+
});
|
310
292
|
|
311
|
-
|
312
|
-
const message = this.pollers.isEmpty ? this.subscription.poll(empty) : empty;
|
313
|
-
|
314
|
-
if (message == null) {
|
315
|
-
const future = Future.unsafeMake<never, A>(fiberId);
|
316
|
-
|
317
|
-
return IO.defer(() => {
|
318
|
-
this.pollers.enqueue(future);
|
319
|
-
this.subscribers.add(new HashedPair(this.subscription, this.pollers));
|
320
|
-
this.strategy.unsafeCompletePollers(this.hub, this.subscribers, this.subscription, this.pollers);
|
321
|
-
if (this.shutdownFlag.get) {
|
322
|
-
return IO.interrupt;
|
323
|
-
} else {
|
324
|
-
return future.await;
|
325
|
-
}
|
326
|
-
}).onInterrupt(() =>
|
327
|
-
IO.succeed(() => {
|
328
|
-
this.pollers.unsafeRemove(future);
|
329
|
-
}),
|
330
|
-
);
|
331
|
-
} else {
|
332
|
-
this.strategy.unsafeOnHubEmptySpace(this.hub, this.subscribers);
|
333
|
-
return IO.succeedNow(message);
|
334
|
-
}
|
335
|
-
}),
|
336
|
-
);
|
337
|
-
}
|
293
|
+
offer = (_: never): IO<never, never, boolean> => IO.succeedNow(false);
|
338
294
|
|
339
|
-
|
340
|
-
|
295
|
+
offerAll = (_: Iterable<never>): IO<never, never, boolean> => IO.succeedNow(false);
|
296
|
+
|
297
|
+
take: IO<never, never, A> = IO.fiberId.flatMap((fiberId) =>
|
298
|
+
IO.defer(() => {
|
341
299
|
if (this.shutdownFlag.get) {
|
342
300
|
return IO.interrupt;
|
343
301
|
}
|
344
302
|
|
345
|
-
const
|
303
|
+
const empty = null as unknown as A;
|
304
|
+
const message = this.pollers.isEmpty ? this.subscription.poll(empty) : empty;
|
346
305
|
|
347
|
-
|
306
|
+
if (message == null) {
|
307
|
+
const future = Future.unsafeMake<never, A>(fiberId);
|
348
308
|
|
349
|
-
|
350
|
-
|
351
|
-
|
309
|
+
return IO.defer(() => {
|
310
|
+
this.pollers.enqueue(future);
|
311
|
+
this.subscribers.add(new HashedPair(this.subscription, this.pollers));
|
312
|
+
this.strategy.unsafeCompletePollers(this.hub, this.subscribers, this.subscription, this.pollers);
|
313
|
+
if (this.shutdownFlag.get) {
|
314
|
+
return IO.interrupt;
|
315
|
+
} else {
|
316
|
+
return future.await;
|
317
|
+
}
|
318
|
+
}).onInterrupt(() =>
|
319
|
+
IO.succeed(() => {
|
320
|
+
this.pollers.unsafeRemove(future);
|
321
|
+
}),
|
322
|
+
);
|
323
|
+
} else {
|
324
|
+
this.strategy.unsafeOnHubEmptySpace(this.hub, this.subscribers);
|
325
|
+
return IO.succeedNow(message);
|
326
|
+
}
|
327
|
+
}),
|
328
|
+
);
|
329
|
+
|
330
|
+
takeAll: IO<never, never, Conc<A>> = IO.defer(() => {
|
331
|
+
if (this.shutdownFlag.get) {
|
332
|
+
return IO.interrupt;
|
333
|
+
}
|
334
|
+
|
335
|
+
const as = this.pollers.isEmpty ? this.subscription.unsafePollAll : Conc.empty<A>();
|
336
|
+
|
337
|
+
this.strategy.unsafeOnHubEmptySpace(this.hub, this.subscribers);
|
338
|
+
|
339
|
+
return IO.succeedNow(as);
|
340
|
+
});
|
352
341
|
|
353
|
-
takeUpTo
|
342
|
+
takeUpTo = (n: number): IO<never, never, Conc<A>> => {
|
354
343
|
return IO.defer(() => {
|
355
344
|
if (this.shutdownFlag.get) {
|
356
345
|
return IO.interrupt;
|
@@ -361,43 +350,7 @@ class UnsafeSubscription<A> implements Dequeue<A> {
|
|
361
350
|
this.strategy.unsafeOnHubEmptySpace(this.hub, this.subscribers);
|
362
351
|
return IO.succeedNow(as);
|
363
352
|
});
|
364
|
-
}
|
365
|
-
|
366
|
-
private takeRemainder(min: number, max: number, acc: Conc<A>, __tsplusTrace?: string): UIO<Conc<A>> {
|
367
|
-
if (max < min) return IO.succeedNow(acc);
|
368
|
-
else {
|
369
|
-
return this.takeUpTo(max).flatMap((bs) => {
|
370
|
-
const remaining = min - bs.length;
|
371
|
-
if (remaining === 1) {
|
372
|
-
return this.take.map((b) => acc.concat(bs).append(b));
|
373
|
-
} else if (remaining > 1) {
|
374
|
-
return this.take.flatMap((b) => this.takeRemainder(remaining - 1, max - bs.length, acc.concat(bs).append(b)));
|
375
|
-
} else {
|
376
|
-
return IO.succeedNow(acc.concat(bs));
|
377
|
-
}
|
378
|
-
});
|
379
|
-
}
|
380
|
-
}
|
381
|
-
|
382
|
-
takeBetween(this: this, min: number, max: number, __tsplusTrace?: string): UIO<Conc<A>> {
|
383
|
-
return this.takeRemainder(min, max, Conc());
|
384
|
-
}
|
385
|
-
|
386
|
-
takeN(this: this, n: number, __tsplusTrace?: string): UIO<Conc<A>> {
|
387
|
-
return this.takeBetween(n, n);
|
388
|
-
}
|
389
|
-
|
390
|
-
get poll(): UIO<Maybe<A>> {
|
391
|
-
return this.takeUpTo(1).map((_) => _.head);
|
392
|
-
}
|
393
|
-
|
394
|
-
get isFull(): UIO<boolean> {
|
395
|
-
return this.size.map((size) => size === this.capacity);
|
396
|
-
}
|
397
|
-
|
398
|
-
get isEmpty(): UIO<boolean> {
|
399
|
-
return this.size.map((size) => size === 0);
|
400
|
-
}
|
353
|
+
};
|
401
354
|
}
|
402
355
|
|
403
356
|
/**
|
@@ -407,7 +360,7 @@ export function makeSubscription<A>(
|
|
407
360
|
hub: HubInternal<A>,
|
408
361
|
subscribers: HashSet<HashedPair<HubInternal.Subscription<A>, MutableQueue<Future<never, A>>>>,
|
409
362
|
strategy: Strategy<A>,
|
410
|
-
): UIO<Dequeue<A>> {
|
363
|
+
): UIO<Queue.Dequeue<A>> {
|
411
364
|
return Future.make<never, void>().map((future) => {
|
412
365
|
return unsafeMakeSubscription(
|
413
366
|
hub,
|
@@ -432,7 +385,7 @@ export function unsafeMakeSubscription<A>(
|
|
432
385
|
shutdownHook: Future<never, void>,
|
433
386
|
shutdownFlag: AtomicBoolean,
|
434
387
|
strategy: Strategy<A>,
|
435
|
-
): Dequeue<A> {
|
388
|
+
): Queue.Dequeue<A> {
|
436
389
|
return new UnsafeSubscription(hub, subscribers, subscription, pollers, shutdownHook, shutdownFlag, strategy);
|
437
390
|
}
|
438
391
|
|
@@ -441,3 +394,100 @@ export function subscribersHashSet<A>(): HashSet<
|
|
441
394
|
> {
|
442
395
|
return HashSet.empty<HashedPair<HubInternal.Subscription<A>, MutableQueue<Future<never, A>>>>();
|
443
396
|
}
|
397
|
+
|
398
|
+
class UnsafeHub<A> extends PHubInternal<never, never, never, never, A, A> {
|
399
|
+
constructor(
|
400
|
+
readonly hub: HubInternal<A>,
|
401
|
+
readonly subscribers: HashSet<HashedPair<HubInternal.Subscription<A>, MutableQueue<Future<never, A>>>>,
|
402
|
+
readonly scope: Scope.Closeable,
|
403
|
+
readonly shutdownHook: Future<never, void>,
|
404
|
+
readonly shutdownFlag: AtomicBoolean,
|
405
|
+
readonly strategy: Strategy<A>,
|
406
|
+
) {
|
407
|
+
super();
|
408
|
+
}
|
409
|
+
|
410
|
+
awaitShutdown = this.shutdownHook.await;
|
411
|
+
|
412
|
+
capacity = this.hub.capacity;
|
413
|
+
|
414
|
+
isShutdown = IO.succeed(this.shutdownFlag.get);
|
415
|
+
|
416
|
+
shutdown = IO.fiberId.flatMap((fiberId) =>
|
417
|
+
IO.defer(() => {
|
418
|
+
this.shutdownFlag.set(true);
|
419
|
+
return this.scope
|
420
|
+
.close(Exit.interrupt(fiberId))
|
421
|
+
.zipRight(this.strategy.shutdown)
|
422
|
+
.whenIO(this.shutdownHook.succeed(undefined));
|
423
|
+
}),
|
424
|
+
).uninterruptible;
|
425
|
+
|
426
|
+
size = IO.defer(() => {
|
427
|
+
if (this.shutdownFlag.get) {
|
428
|
+
return IO.interrupt;
|
429
|
+
}
|
430
|
+
|
431
|
+
return IO.succeed(this.hub.size());
|
432
|
+
});
|
433
|
+
|
434
|
+
subscribe: IO<Scope, never, Queue.Dequeue<A>> = IO.acquireRelease(
|
435
|
+
makeSubscription(this.hub, this.subscribers, this.strategy).tap((dequeue) =>
|
436
|
+
this.scope.addFinalizer(dequeue.shutdown),
|
437
|
+
),
|
438
|
+
(dequeue) => dequeue.shutdown,
|
439
|
+
);
|
440
|
+
|
441
|
+
publish = (a: A): IO<never, never, boolean> =>
|
442
|
+
IO.defer(() => {
|
443
|
+
if (this.shutdownFlag.get) {
|
444
|
+
return IO.interrupt;
|
445
|
+
}
|
446
|
+
|
447
|
+
if (this.hub.publish(a)) {
|
448
|
+
this.strategy.unsafeCompleteSubscribers(this.hub, this.subscribers);
|
449
|
+
return IO.succeedNow(true);
|
450
|
+
}
|
451
|
+
|
452
|
+
return this.strategy.handleSurplus(this.hub, this.subscribers, Conc.single(a), this.shutdownFlag);
|
453
|
+
});
|
454
|
+
|
455
|
+
publishAll = (as: Iterable<A>): IO<never, never, boolean> =>
|
456
|
+
IO.defer(() => {
|
457
|
+
if (this.shutdownFlag.get) {
|
458
|
+
return IO.interrupt;
|
459
|
+
}
|
460
|
+
|
461
|
+
const surplus = this.hub.publishAll(as);
|
462
|
+
|
463
|
+
this.strategy.unsafeCompleteSubscribers(this.hub, this.subscribers);
|
464
|
+
|
465
|
+
if (surplus.isEmpty) {
|
466
|
+
return IO.succeedNow(true);
|
467
|
+
}
|
468
|
+
|
469
|
+
return this.strategy.handleSurplus(this.hub, this.subscribers, surplus, this.shutdownFlag);
|
470
|
+
});
|
471
|
+
}
|
472
|
+
|
473
|
+
/**
|
474
|
+
* Unsafely creates a hub with the specified strategy.
|
475
|
+
*/
|
476
|
+
export function unsafeMakeHub<A>(
|
477
|
+
hub: HubInternal<A>,
|
478
|
+
subscribers: HashSet<HashedPair<HubInternal.Subscription<A>, MutableQueue<Future<never, A>>>>,
|
479
|
+
scope: Scope.Closeable,
|
480
|
+
shutdownHook: Future<never, void>,
|
481
|
+
shutdownFlag: AtomicBoolean,
|
482
|
+
strategy: Strategy<A>,
|
483
|
+
): Hub<A> {
|
484
|
+
return new UnsafeHub(hub, subscribers, scope, shutdownHook, shutdownFlag, strategy).unsafeCoerce();
|
485
|
+
}
|
486
|
+
|
487
|
+
export function makeHubInternal<A>(hub: HubInternal<A>, strategy: Strategy<A>): UIO<Hub<A>> {
|
488
|
+
return Do((_) => {
|
489
|
+
const scope = _(Scope.make);
|
490
|
+
const future = _(Future.make<never, void>());
|
491
|
+
return unsafeMakeHub(hub, subscribersHashSet(), scope, future, new AtomicBoolean(false), strategy);
|
492
|
+
});
|
493
|
+
}
|
package/_src/Hub.ts
CHANGED
@@ -0,0 +1,77 @@
|
|
1
|
+
/**
|
2
|
+
* Imports an asynchronous side-effect into an IO. The side-effect
|
3
|
+
* has the option of returning the value synchronously, which is useful in
|
4
|
+
* cases where it cannot be determined if the effect is synchronous or
|
5
|
+
* asynchronous until the side-effect is actually executed. The effect also
|
6
|
+
* has the option of returning a canceler, which will be used by the runtime
|
7
|
+
* to cancel the asynchronous effect if the fiber executing the effect is
|
8
|
+
* interrupted.
|
9
|
+
*
|
10
|
+
* If the register function returns a value synchronously, then the callback
|
11
|
+
* function must not be called. Otherwise the callback function must be called
|
12
|
+
* at most once.
|
13
|
+
*
|
14
|
+
* The list of fibers, that may complete the async callback, is used to
|
15
|
+
* provide better diagnostics.
|
16
|
+
*
|
17
|
+
* @tsplus static fncts.io.IOOps asyncInterrupt
|
18
|
+
*/
|
19
|
+
export function asyncInterrupt<R, E, A>(
|
20
|
+
register: (cb: (resolve: IO<R, E, A>) => void) => Either<URIO<R, any>, IO<R, E, A>>,
|
21
|
+
blockingOn: FiberId = FiberId.none,
|
22
|
+
__tsplusTrace?: string,
|
23
|
+
): IO<R, E, A> {
|
24
|
+
return IO.defer(() => {
|
25
|
+
let cancelerRef: URIO<R, any> = IO.unit!;
|
26
|
+
return IO.async<R, E, A>((k) => {
|
27
|
+
const result = register(k);
|
28
|
+
result.match(
|
29
|
+
(canceler) => {
|
30
|
+
cancelerRef = canceler;
|
31
|
+
},
|
32
|
+
(done) => {
|
33
|
+
k(done);
|
34
|
+
},
|
35
|
+
);
|
36
|
+
}, blockingOn).onInterrupt(() => cancelerRef);
|
37
|
+
});
|
38
|
+
}
|
39
|
+
|
40
|
+
/**
|
41
|
+
* Imports an asynchronous effect into a pure `IO`, possibly returning the value synchronously.
|
42
|
+
*
|
43
|
+
* If the register function returns a value synchronously, then the callback
|
44
|
+
* function must not be called. Otherwise the callback function must be called at most once.
|
45
|
+
*
|
46
|
+
* @tsplus static fncts.io.IOOps asyncMaybe
|
47
|
+
*/
|
48
|
+
export function asyncMaybe<R, E, A>(
|
49
|
+
register: (resolve: (_: IO<R, E, A>) => void) => Maybe<IO<R, E, A>>,
|
50
|
+
blockingOn: FiberId = FiberId.none,
|
51
|
+
__tsplusTrace?: string,
|
52
|
+
): IO<R, E, A> {
|
53
|
+
return asyncInterrupt(
|
54
|
+
(cb) => register(cb).match(() => Either.left(IO.unit), Either.right),
|
55
|
+
blockingOn,
|
56
|
+
__tsplusTrace,
|
57
|
+
);
|
58
|
+
}
|
59
|
+
|
60
|
+
/**
|
61
|
+
* Returns a `IO` that will never produce anything. The moral equivalent of
|
62
|
+
* `while(true) {}`, only without the wasted CPU cycles.
|
63
|
+
*
|
64
|
+
* @tsplus static fncts.io.IOOps never
|
65
|
+
*/
|
66
|
+
export const never: UIO<never> = IO.defer(() =>
|
67
|
+
asyncInterrupt<never, never, never>(() => {
|
68
|
+
const interval = setInterval(() => {
|
69
|
+
//
|
70
|
+
}, 60000);
|
71
|
+
return Either.left(
|
72
|
+
IO.succeed(() => {
|
73
|
+
clearInterval(interval);
|
74
|
+
}),
|
75
|
+
);
|
76
|
+
}),
|
77
|
+
);
|