@fncts/io 0.0.21 → 0.0.22
Sign up to get free protection for your applications and to get access to all the features.
- package/Channel/api/mapOutConcurrentIO.d.ts +8 -0
- package/Channel/api/zipConcurrent.d.ts +16 -0
- package/Channel/api.d.ts +5 -5
- package/Channel/core-api.d.ts +4 -4
- package/Channel/internal/SingleProducerAsyncInput.d.ts +1 -1
- package/CountdownLatch.d.ts +25 -0
- package/Fiber/FiberMessage.d.ts +67 -0
- package/Fiber/FiberRuntime.d.ts +116 -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 +17 -16
- package/Fiber.d.ts +2 -4
- package/FiberDescriptor.d.ts +3 -6
- package/FiberRef/definition.d.ts +2 -2
- 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 +84 -36
- 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 +13 -17
- package/IO/api/race.d.ts +1 -1
- package/IO/api/supervised.d.ts +4 -6
- package/IO/api/zipConcurrent.d.ts +13 -0
- package/IO/api.d.ts +36 -137
- package/IO/definition.d.ts +120 -145
- package/IO/runtime.d.ts +19 -22
- package/IO.d.ts +5 -3
- package/Layer/MemoMap.d.ts +1 -1
- package/Push/api.d.ts +232 -0
- package/Push/definition.d.ts +34 -0
- package/Push/internal.d.ts +11 -0
- package/Push.d.ts +3 -0
- package/Queue/api/dimapIO.d.ts +98 -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 +170 -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 +16 -0
- package/Ref/DerivedAll.d.ts +18 -0
- package/Ref/Synchronized/api.d.ts +102 -0
- package/Ref/Synchronized/constructors.d.ts +8 -0
- package/Ref/Synchronized/definition.d.ts +44 -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 +79 -55
- package/Ref/symbols.d.ts +30 -0
- package/Ref.d.ts +7 -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 +45 -0
- package/RefSubject.d.ts +3 -0
- 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/Schedule/api.d.ts +33 -17
- package/Scope/ReleaseMap/definition.d.ts +1 -1
- package/ScopedRef/api.d.ts +1 -1
- package/Sink/api.d.ts +12 -12
- package/Stream/api.d.ts +20 -19
- package/Stream/internal/Handoff.d.ts +1 -1
- package/Stream/internal/Pull.d.ts +2 -2
- package/Subject/Atomic.d.ts +18 -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/TExit/definition.d.ts +2 -2
- 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 +47 -34
- package/TRef/symbols.d.ts +20 -0
- package/TRef.d.ts +1 -0
- 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 +2 -7
- package/_cjs/Cached/definition.cjs.map +1 -1
- package/_cjs/Cached/internal.cjs +0 -3
- 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 +70 -241
- 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 +19 -105
- package/_cjs/Channel/definition.cjs.map +1 -1
- package/_cjs/Channel/internal/ChannelExecutor.cjs +107 -317
- 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 +4 -27
- 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 +50 -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 +0 -4
- 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 +735 -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 +11 -14
- 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 +5 -23
- 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 +13 -73
- 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 +20 -104
- package/_cjs/Hub/definition.cjs.map +1 -1
- package/_cjs/Hub/internal.cjs +105 -172
- 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/{Fiber/api/evalOn.cjs → IO/api/delay.cjs} +9 -19
- 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} +31 -64
- 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 +59 -91
- 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/onExit.cjs +0 -5
- package/_cjs/IO/api/onExit.cjs.map +1 -1
- package/_cjs/IO/api/onTermination.cjs +0 -8
- 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 +0 -6
- 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 +152 -665
- package/_cjs/IO/api.cjs.map +1 -1
- package/_cjs/IO/definition.cjs +121 -213
- 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 -123
- 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 -91
- package/_cjs/Layer/MemoMap.cjs.map +1 -1
- package/_cjs/Layer/api.cjs +4 -105
- package/_cjs/Layer/api.cjs.map +1 -1
- package/_cjs/Layer/definition.cjs +9 -51
- 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 +0 -3
- package/_cjs/Logger/definition.cjs.map +1 -1
- package/_cjs/Logger.cjs +0 -6
- package/_cjs/Logger.cjs.map +1 -1
- package/_cjs/Push/api.cjs +474 -0
- package/_cjs/Push/api.cjs.map +1 -0
- package/_cjs/Push/definition.cjs +43 -0
- package/_cjs/Push/definition.cjs.map +1 -0
- package/_cjs/Push/internal.cjs +40 -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/{IO/api/withRuntimeConfig.cjs → Queue/api/poll.cjs} +10 -16
- 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 +24 -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 +13 -54
- 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 +46 -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/{Fiber/api/evalOnIO.cjs → Ref/Synchronized/constructors.cjs} +12 -23
- package/_cjs/Ref/Synchronized/constructors.cjs.map +1 -0
- package/_cjs/Ref/Synchronized/definition.cjs +65 -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 +16 -107
- package/_cjs/Ref/definition.cjs.map +1 -1
- package/_cjs/Ref/symbols.cjs +37 -0
- package/_cjs/Ref/symbols.cjs.map +1 -0
- package/_cjs/Ref.cjs +77 -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/RefSubject/Synchronized/api.cjs +23 -0
- 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/{FiberState/api.cjs → RefSubject/definition.cjs} +12 -16
- 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 +0 -14
- 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/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 +5 -143
- package/_cjs/STM/api.cjs.map +1 -1
- package/_cjs/STM/definition.cjs +9 -72
- package/_cjs/STM/definition.cjs.map +1 -1
- package/_cjs/STM/driver.cjs +9 -62
- 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 +0 -20
- 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 +2 -12
- package/_cjs/STM/internal/TryCommit.cjs.map +1 -1
- package/_cjs/STM/internal/Versioned.cjs +0 -3
- package/_cjs/STM/internal/Versioned.cjs.map +1 -1
- package/_cjs/STM.cjs +0 -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 +0 -2
- 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 +0 -42
- package/_cjs/Scope/api.cjs.map +1 -1
- package/_cjs/Scope/definition.cjs +0 -12
- 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 +0 -4
- 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 +0 -18
- package/_cjs/State/api.cjs.map +1 -1
- package/_cjs/State/definition.cjs +2 -7
- package/_cjs/State/definition.cjs.map +1 -1
- package/_cjs/State/internal.cjs +0 -3
- 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 +0 -8
- 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 +13 -61
- 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 +4 -21
- 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/{FiberState/definition.cjs → Subject/Atomic.cjs} +21 -36
- package/_cjs/Subject/Atomic.cjs.map +1 -0
- package/_cjs/Subject/api.cjs +28 -0
- 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 +10 -64
- 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 +14 -76
- 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 +0 -12
- 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 +16 -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 +0 -19
- package/_cjs/TRef/constructors.cjs.map +1 -1
- package/_cjs/TRef/definition.cjs +80 -30
- package/_cjs/TRef/definition.cjs.map +1 -1
- package/_cjs/TRef/symbols.cjs +27 -0
- package/_cjs/TRef/symbols.cjs.map +1 -0
- package/_cjs/TRef.cjs +11 -6
- package/_cjs/TRef.cjs.map +1 -1
- package/_cjs/TSemaphore/api.cjs +4 -27
- package/_cjs/TSemaphore/api.cjs.map +1 -1
- package/_cjs/TSemaphore/constructors.cjs +0 -13
- 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 +10 -52
- 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 +2 -4
- package/_mjs/Cached/definition.mjs.map +1 -1
- package/_mjs/Cached/internal.mjs +0 -1
- 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 +69 -186
- 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 +31 -66
- package/_mjs/Channel/definition.mjs.map +1 -1
- package/_mjs/Channel/internal/ChannelExecutor.mjs +107 -286
- 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 +5 -16
- 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 +39 -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 +0 -2
- 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 +728 -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 +9 -5
- 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 +5 -10
- 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 +13 -54
- 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 +15 -84
- package/_mjs/Hub/definition.mjs.map +1 -1
- package/_mjs/Hub/internal.mjs +104 -147
- 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} +29 -41
- 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 +53 -72
- 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/onExit.mjs +0 -1
- package/_mjs/IO/api/onExit.mjs.map +1 -1
- package/_mjs/IO/api/onTermination.mjs +0 -1
- 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 +0 -1
- 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 +140 -516
- package/_mjs/IO/api.mjs.map +1 -1
- package/_mjs/IO/definition.mjs +107 -150
- 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 -5
- 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 -65
- package/_mjs/Layer/MemoMap.mjs.map +1 -1
- package/_mjs/Layer/api.mjs +4 -69
- package/_mjs/Layer/api.mjs.map +1 -1
- package/_mjs/Layer/definition.mjs +15 -34
- 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 +0 -1
- package/_mjs/Logger/definition.mjs.map +1 -1
- package/_mjs/Logger.mjs.map +1 -1
- package/_mjs/Push/api.mjs +417 -0
- package/_mjs/Push/api.mjs.map +1 -0
- package/_mjs/Push/definition.mjs +33 -0
- package/_mjs/Push/definition.mjs.map +1 -0
- package/_mjs/Push/internal.mjs +26 -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 +17 -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 +13 -37
- 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 +37 -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 +14 -0
- package/_mjs/Ref/Synchronized/constructors.mjs.map +1 -0
- package/_mjs/Ref/Synchronized/definition.mjs +54 -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/symbols.mjs +25 -0
- package/_mjs/Ref/symbols.mjs.map +1 -0
- package/_mjs/Ref.mjs +9 -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 +11 -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 +0 -6
- 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/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 +5 -88
- package/_mjs/STM/api.mjs.map +1 -1
- package/_mjs/STM/definition.mjs +14 -36
- package/_mjs/STM/definition.mjs.map +1 -1
- package/_mjs/STM/driver.mjs +9 -51
- 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 +0 -12
- 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 +3 -8
- package/_mjs/STM/internal/TryCommit.mjs.map +1 -1
- package/_mjs/STM/internal/Versioned.mjs +0 -1
- package/_mjs/STM/internal/Versioned.mjs.map +1 -1
- package/_mjs/STM.mjs +2 -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.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 +0 -23
- package/_mjs/Scope/api.mjs.map +1 -1
- package/_mjs/Scope/definition.mjs +0 -4
- 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 +0 -2
- 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 +0 -7
- package/_mjs/State/api.mjs.map +1 -1
- package/_mjs/State/definition.mjs +2 -4
- package/_mjs/State/definition.mjs.map +1 -1
- package/_mjs/State/internal.mjs +0 -1
- 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 +0 -4
- 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 +13 -34
- 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 +5 -16
- 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 +22 -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 +13 -44
- 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 +14 -57
- 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 +0 -3
- 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 +16 -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 +0 -7
- package/_mjs/TRef/constructors.mjs.map +1 -1
- package/_mjs/TRef/definition.mjs +80 -15
- package/_mjs/TRef/definition.mjs.map +1 -1
- package/_mjs/TRef/symbols.mjs +17 -0
- package/_mjs/TRef/symbols.mjs.map +1 -0
- package/_mjs/TRef.mjs +1 -0
- package/_mjs/TRef.mjs.map +1 -1
- package/_mjs/TSemaphore/api.mjs +4 -14
- package/_mjs/TSemaphore/api.mjs.map +1 -1
- package/_mjs/TSemaphore/constructors.mjs +0 -4
- 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 +12 -41
- 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/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 +17 -17
- package/_src/Channel/core-api.ts +4 -4
- package/_src/Channel/internal/ChannelExecutor.ts +11 -11
- package/_src/Channel/internal/SingleProducerAsyncInput.ts +1 -1
- package/_src/CountdownLatch.ts +39 -0
- package/_src/Fiber/FiberMessage.ts +78 -0
- package/_src/Fiber/FiberRuntime.ts +822 -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 +30 -15
- package/_src/Fiber.ts +2 -4
- package/_src/FiberDescriptor.ts +1 -8
- package/_src/FiberRef/api.ts +13 -17
- 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/Hub/api.ts +449 -0
- package/_src/Hub/definition.ts +102 -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 +74 -54
- package/_src/IO/api/race.ts +4 -4
- 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 +86 -265
- package/_src/IO/definition.ts +153 -152
- package/_src/IO/runtime.ts +62 -61
- package/_src/IO.ts +6 -3
- package/_src/Layer/MemoMap.ts +2 -2
- package/_src/Push/api.ts +702 -0
- package/_src/Push/definition.ts +42 -0
- package/_src/Push/internal.ts +39 -0
- package/_src/Push.ts +5 -0
- package/_src/Queue/api/dimapIO.ts +207 -0
- package/_src/Queue/api/filterInputIO.ts +120 -0
- package/_src/Queue/api/filterOutputIO.ts +136 -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 +188 -216
- 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 +92 -0
- package/_src/Ref/DerivedAll.ts +99 -0
- package/_src/Ref/Synchronized/api.ts +248 -0
- package/_src/Ref/Synchronized/constructors.ts +12 -0
- package/_src/Ref/Synchronized/definition.ts +133 -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 +113 -81
- package/_src/Ref/symbols.ts +29 -0
- package/_src/Ref.ts +10 -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 +62 -0
- package/_src/RefSubject.ts +5 -0
- 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.ts +1 -1
- package/_src/STM/internal/Journal.ts +1 -1
- package/_src/Schedule/api/driver.ts +2 -2
- package/_src/Schedule/api.ts +60 -38
- package/_src/Scope/ReleaseMap/api/releaseAll.ts +4 -3
- package/_src/Scope/ReleaseMap/constructors.ts +1 -1
- package/_src/Sink/api.ts +15 -12
- 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/internal/Handoff.ts +3 -3
- package/_src/Stream/internal/Pull.ts +2 -1
- package/_src/Subject/Atomic.ts +28 -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/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 +162 -34
- package/_src/TRef/symbols.ts +19 -0
- package/_src/TRef.ts +1 -0
- package/_src/TSemaphore/api.ts +1 -1
- package/_src/TSemaphore/definition.ts +1 -1
- package/_src/global.ts +9 -5
- package/_src/index.ts +7 -1
- package/global.d.ts +9 -5
- package/index.d.ts +7 -1
- package/internal/HashedPair.d.ts +2 -2
- 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/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.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/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/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/withRuntimeConfig.ts +0 -18
@@ -1,999 +0,0 @@
|
|
1
|
-
import type { Instruction, Match, Race } from "@fncts/io/IO/definition";
|
2
|
-
|
3
|
-
import { ExitTag } from "@fncts/base/data/Exit";
|
4
|
-
import { TraceElement } from "@fncts/base/data/TraceElement";
|
5
|
-
import { AtomicReference } from "@fncts/base/internal/AtomicReference";
|
6
|
-
import { Stack } from "@fncts/base/internal/Stack";
|
7
|
-
import { CancellerState } from "@fncts/io/CancellerState";
|
8
|
-
import { FiberTypeId, isFiber } from "@fncts/io/Fiber/definition";
|
9
|
-
import { FiberState } from "@fncts/io/FiberState";
|
10
|
-
import { FiberStatus, FiberStatusTag } from "@fncts/io/FiberStatus";
|
11
|
-
import { StackTraceBuilder } from "@fncts/io/internal/StackTraceBuilder";
|
12
|
-
import { concrete, IOTag, isIOError } from "@fncts/io/IO/definition";
|
13
|
-
|
14
|
-
export type FiberRefLocals = HashMap<FiberRef<unknown>, Cons<readonly [FiberId.Runtime, unknown]>>;
|
15
|
-
|
16
|
-
type Erased = IO<any, any, any>;
|
17
|
-
type ErasedCont = (a: any) => Erased;
|
18
|
-
|
19
|
-
export class InterruptExit {
|
20
|
-
readonly _tag = "InterruptExit";
|
21
|
-
constructor(readonly apply: ErasedCont, readonly trace?: string) {}
|
22
|
-
}
|
23
|
-
|
24
|
-
export class HandlerFrame {
|
25
|
-
readonly _tag = "HandlerFrame";
|
26
|
-
constructor(readonly apply: ErasedCont, readonly trace?: string) {}
|
27
|
-
}
|
28
|
-
|
29
|
-
export class TracedCont {
|
30
|
-
readonly _tag = "TracedCont";
|
31
|
-
constructor(readonly apply: ErasedCont, readonly trace?: string) {}
|
32
|
-
}
|
33
|
-
|
34
|
-
export class Finalizer {
|
35
|
-
readonly _tag = "Finalizer";
|
36
|
-
constructor(readonly finalizer: IO<any, never, any>, readonly apply: ErasedCont, readonly trace?: string) {}
|
37
|
-
}
|
38
|
-
|
39
|
-
export type Frame =
|
40
|
-
| InterruptExit
|
41
|
-
| Match<any, any, any, any, any, any, any, any, any>
|
42
|
-
| HandlerFrame
|
43
|
-
| TracedCont
|
44
|
-
| Finalizer;
|
45
|
-
|
46
|
-
export const currentFiber = new AtomicReference<FiberContext<any, any> | null>(null);
|
47
|
-
|
48
|
-
export function unsafeCurrentFiber(): Maybe<FiberContext<any, any>> {
|
49
|
-
return Maybe.fromNullable(currentFiber.get);
|
50
|
-
}
|
51
|
-
|
52
|
-
/**
|
53
|
-
* `FiberContext` provides all of the context and facilities required to run a `IO`
|
54
|
-
*
|
55
|
-
* @tsplus type fncts.io.Fiber
|
56
|
-
*/
|
57
|
-
export class FiberContext<E, A> implements Fiber.Runtime<E, A>, Hashable, Equatable {
|
58
|
-
readonly _typeId: FiberTypeId = FiberTypeId;
|
59
|
-
readonly _tag = "RuntimeFiber";
|
60
|
-
readonly _E!: () => E;
|
61
|
-
readonly _A!: () => A;
|
62
|
-
|
63
|
-
get [Symbol.hash](): number {
|
64
|
-
return Hashable.string(this.id.threadName);
|
65
|
-
}
|
66
|
-
|
67
|
-
[Symbol.equals](that: unknown) {
|
68
|
-
return isFiber(that) && this.id == that.id;
|
69
|
-
}
|
70
|
-
|
71
|
-
private state = FiberState.initial<E, A>();
|
72
|
-
private asyncEpoch = 0 | 0;
|
73
|
-
private stack = Stack<Frame>();
|
74
|
-
nextIO: Instruction | null = null;
|
75
|
-
|
76
|
-
constructor(
|
77
|
-
readonly fiberId: FiberId.Runtime,
|
78
|
-
public runtimeConfig: RuntimeConfig,
|
79
|
-
public interruptStatus: Stack<boolean>,
|
80
|
-
public fiberRefLocals: FiberRefLocals,
|
81
|
-
private readonly _children: Set<FiberContext<unknown, unknown>>,
|
82
|
-
) {
|
83
|
-
this.unsafeSetRef(FiberRef.currentSupervisor, this.runtimeConfig.supervisor);
|
84
|
-
}
|
85
|
-
|
86
|
-
get poll() {
|
87
|
-
return IO.succeed(() => this.unsafePoll());
|
88
|
-
}
|
89
|
-
|
90
|
-
get inheritRefs(): UIO<void> {
|
91
|
-
return IO.defer(() => {
|
92
|
-
const childFiberRefLocals = this.fiberRefLocals;
|
93
|
-
if (childFiberRefLocals.isEmpty) {
|
94
|
-
return IO.unit;
|
95
|
-
} else {
|
96
|
-
return IO.updateFiberRefs((parentFiberId, parentFiberRefs) =>
|
97
|
-
parentFiberRefs.join(parentFiberId, FiberRefs(childFiberRefLocals)),
|
98
|
-
);
|
99
|
-
}
|
100
|
-
});
|
101
|
-
}
|
102
|
-
|
103
|
-
get id() {
|
104
|
-
return this.fiberId;
|
105
|
-
}
|
106
|
-
|
107
|
-
awaitAsync(k: FiberState.Callback<E, A>) {
|
108
|
-
const exit = this.unsafeAddObserver((exit) => k(exit.flatten));
|
109
|
-
|
110
|
-
if (exit != null) {
|
111
|
-
k(exit);
|
112
|
-
}
|
113
|
-
}
|
114
|
-
|
115
|
-
get children(): UIO<Conc<Fiber.Runtime<any, any>>> {
|
116
|
-
return this.evalOnIO(
|
117
|
-
IO.succeed(() => {
|
118
|
-
const concBuilder = new ConcBuilder<Fiber.Runtime<any, any>>(Conc.empty());
|
119
|
-
|
120
|
-
for (const child of this._children) {
|
121
|
-
concBuilder.append(child);
|
122
|
-
}
|
123
|
-
|
124
|
-
return concBuilder.result();
|
125
|
-
}),
|
126
|
-
IO.succeed(Conc.empty()),
|
127
|
-
);
|
128
|
-
}
|
129
|
-
|
130
|
-
evalOnIO<R1, E1, B, R2, E2, C>(
|
131
|
-
effect: IO<R1, E1, B>,
|
132
|
-
orElse: IO<R2, E2, C>,
|
133
|
-
__tsplusTrace?: string,
|
134
|
-
): IO<R1 & R2, E1 | E2, B | C> {
|
135
|
-
return Do((Δ) => {
|
136
|
-
const r = Δ(IO.environment<R1 & R2>());
|
137
|
-
const p = Δ(Future.make<E1 | E2, B | C>());
|
138
|
-
Δ(this.evalOn(effect.provideEnvironment(r).fulfill(p), orElse.provideEnvironment(r).fulfill(p)));
|
139
|
-
return Δ(p.await);
|
140
|
-
});
|
141
|
-
}
|
142
|
-
|
143
|
-
get fiberRefs(): FiberRefs {
|
144
|
-
return FiberRefs(this.fiberRefLocals);
|
145
|
-
}
|
146
|
-
|
147
|
-
get await(): UIO<Exit<E, A>> {
|
148
|
-
return IO.asyncInterrupt((k): Either<UIO<void>, UIO<Exit<E, A>>> => {
|
149
|
-
const cb: FiberState.Callback<never, Exit<E, A>> = (x) => k(IO.fromExit(x));
|
150
|
-
const result = this.unsafeAddObserver(cb);
|
151
|
-
if (result == null) {
|
152
|
-
return Either.left(IO.succeed(() => this.unsafeRemoveObserver(cb)));
|
153
|
-
} else {
|
154
|
-
return Either.right(IO.succeedNow(result));
|
155
|
-
}
|
156
|
-
}, this.fiberId);
|
157
|
-
}
|
158
|
-
|
159
|
-
run(): void {
|
160
|
-
this.runUntil(this.runtimeConfig.yieldOpCount);
|
161
|
-
}
|
162
|
-
|
163
|
-
get scope(): FiberScope {
|
164
|
-
return FiberScope.unsafeMake(this);
|
165
|
-
}
|
166
|
-
|
167
|
-
get status(): UIO<FiberStatus> {
|
168
|
-
return IO.succeedNow(this.state.status);
|
169
|
-
}
|
170
|
-
|
171
|
-
get trace(): UIO<Trace> {
|
172
|
-
return IO.succeed(() => this.unsafeCaptureTrace(List.empty()));
|
173
|
-
}
|
174
|
-
|
175
|
-
interruptAs(fiberId: FiberId): UIO<Exit<E, A>> {
|
176
|
-
return this.interruptAsFork(fiberId).apSecond(this.await);
|
177
|
-
}
|
178
|
-
|
179
|
-
evalOn(effect: UIO<any>, orElse: UIO<any>): UIO<void> {
|
180
|
-
return IO.defer(() => this.unsafeEvalOn(effect, orElse));
|
181
|
-
}
|
182
|
-
|
183
|
-
get location() {
|
184
|
-
return this.fiberId.location;
|
185
|
-
}
|
186
|
-
|
187
|
-
/**
|
188
|
-
* The main evaluator loop for the fiber. For purely synchronous effects, this will run either
|
189
|
-
* to completion, or for the specified maximum operation count. For effects with asynchronous
|
190
|
-
* callbacks, the loop will proceed no further than the first asynchronous boundary.
|
191
|
-
*/
|
192
|
-
runUntil(maxOpCount: number): void {
|
193
|
-
try {
|
194
|
-
let current: Instruction | null = this.nextIO;
|
195
|
-
this.nextIO = null;
|
196
|
-
let extraTrace: string | undefined = undefined;
|
197
|
-
const flags = this.runtimeConfig.flags;
|
198
|
-
const superviseOps =
|
199
|
-
flags.isEnabled(RuntimeConfigFlag.SuperviseOperations) && this.currentSupervisor !== Supervisor.none;
|
200
|
-
|
201
|
-
this.runtimeConfig.flags.isEnabled(RuntimeConfigFlag.EnableCurrentFiber) && currentFiber.set(this);
|
202
|
-
|
203
|
-
this.currentSupervisor !== Supervisor.none && this.currentSupervisor.unsafeOnResume(this);
|
204
|
-
|
205
|
-
while (current !== null) {
|
206
|
-
try {
|
207
|
-
let opCount = 0;
|
208
|
-
while (current !== null) {
|
209
|
-
if (!this.unsafeShouldInterrupt) {
|
210
|
-
const message = this.unsafeDrainMailbox();
|
211
|
-
if (message !== null) {
|
212
|
-
const oldIO = current;
|
213
|
-
current = concrete(message.flatMap(() => oldIO));
|
214
|
-
} else if (opCount === maxOpCount) {
|
215
|
-
this.unsafeRunLater(current);
|
216
|
-
current = null;
|
217
|
-
} else {
|
218
|
-
superviseOps && this.currentSupervisor.unsafeOnEffect(this, current);
|
219
|
-
switch (current._tag) {
|
220
|
-
case IOTag.Chain: {
|
221
|
-
const nested = concrete(current.io);
|
222
|
-
const k = current.f;
|
223
|
-
|
224
|
-
switch (nested._tag) {
|
225
|
-
case IOTag.SucceedNow: {
|
226
|
-
current = concrete(k(nested.value));
|
227
|
-
break;
|
228
|
-
}
|
229
|
-
case IOTag.Succeed: {
|
230
|
-
extraTrace = nested.trace;
|
231
|
-
const value = nested.effect();
|
232
|
-
extraTrace = undefined;
|
233
|
-
current = concrete(k(value));
|
234
|
-
break;
|
235
|
-
}
|
236
|
-
case IOTag.SucceedWith: {
|
237
|
-
extraTrace = current.trace;
|
238
|
-
const value = nested.effect(this.runtimeConfig, this.fiberId);
|
239
|
-
extraTrace = undefined;
|
240
|
-
current = concrete(k(value));
|
241
|
-
break;
|
242
|
-
}
|
243
|
-
case IOTag.Yield: {
|
244
|
-
extraTrace = current.trace;
|
245
|
-
this.unsafeRunLater(concrete(IO.unit));
|
246
|
-
extraTrace = undefined;
|
247
|
-
current = null;
|
248
|
-
break;
|
249
|
-
}
|
250
|
-
default: {
|
251
|
-
this.stack.push(new TracedCont(current.f, current.trace));
|
252
|
-
current = concrete(current.io);
|
253
|
-
break;
|
254
|
-
}
|
255
|
-
}
|
256
|
-
break;
|
257
|
-
}
|
258
|
-
case IOTag.Trace: {
|
259
|
-
current = this.unsafeNextEffect(this.unsafeCaptureTrace(Cons(current.trace, Nil())));
|
260
|
-
break;
|
261
|
-
}
|
262
|
-
case IOTag.SucceedNow: {
|
263
|
-
current = this.unsafeNextEffect(current.value);
|
264
|
-
break;
|
265
|
-
}
|
266
|
-
case IOTag.Succeed: {
|
267
|
-
current = this.unsafeNextEffect(current.effect());
|
268
|
-
break;
|
269
|
-
}
|
270
|
-
case IOTag.SucceedWith: {
|
271
|
-
current = this.unsafeNextEffect(current.effect(this.runtimeConfig, this.fiberId));
|
272
|
-
break;
|
273
|
-
}
|
274
|
-
case IOTag.Fail: {
|
275
|
-
const fastPathTrace: List<string> = extraTrace === undefined ? Nil() : Cons(extraTrace, Nil());
|
276
|
-
extraTrace = undefined;
|
277
|
-
const cause = current.cause();
|
278
|
-
const tracedCause = cause.isTraced
|
279
|
-
? cause
|
280
|
-
: Cause.traced(cause, this.unsafeCaptureTrace(Cons(current.trace, fastPathTrace)));
|
281
|
-
|
282
|
-
const discardedFolds = this.unsafeUnwindStack();
|
283
|
-
const strippedCause: Cause<any> = discardedFolds
|
284
|
-
? // We threw away some error handlers while unwinding the stack because
|
285
|
-
// we got interrupted during this instruction. So it's not safe to return
|
286
|
-
// typed failures from cause0, because they might not be typed correctly.
|
287
|
-
// Instead, we strip the typed failures, and return the remainders and
|
288
|
-
// the interruption
|
289
|
-
tracedCause.stripFailures
|
290
|
-
: tracedCause;
|
291
|
-
const suppressed = this.unsafeClearSuppressedCause();
|
292
|
-
const fullCause = strippedCause.contains(suppressed)
|
293
|
-
? strippedCause
|
294
|
-
: Cause.then(strippedCause, suppressed);
|
295
|
-
|
296
|
-
if (!this.stack.hasNext) {
|
297
|
-
// Error not caught, stack is empty:
|
298
|
-
this.unsafeSetInterrupting(true);
|
299
|
-
|
300
|
-
current = this.unsafeTryDone(Exit.failCause(fullCause), current.trace);
|
301
|
-
} else {
|
302
|
-
this.unsafeSetInterrupting(false);
|
303
|
-
|
304
|
-
// Error caught, next continuation on the stack will deal
|
305
|
-
// with it, so we just have to compute it here
|
306
|
-
current = this.unsafeNextEffect(fullCause);
|
307
|
-
}
|
308
|
-
break;
|
309
|
-
}
|
310
|
-
|
311
|
-
case IOTag.Match: {
|
312
|
-
this.stack.push(current);
|
313
|
-
current = concrete(current.io);
|
314
|
-
break;
|
315
|
-
}
|
316
|
-
|
317
|
-
case IOTag.Async: {
|
318
|
-
const trace = current.trace;
|
319
|
-
const epoch = this.asyncEpoch;
|
320
|
-
this.asyncEpoch = epoch + 1;
|
321
|
-
|
322
|
-
this.unsafeEnterAsync(epoch, current.blockingOn, trace);
|
323
|
-
|
324
|
-
const r = current.register(this.unsafeCreateAsyncResume(epoch));
|
325
|
-
|
326
|
-
Either.concrete(r);
|
327
|
-
switch (r._tag) {
|
328
|
-
case "Left": {
|
329
|
-
this.unsafeSetAsyncCanceller(epoch, r.left);
|
330
|
-
if (this.unsafeShouldInterrupt) {
|
331
|
-
if (this.unsafeExitAsync(epoch)) {
|
332
|
-
this.unsafeSetInterrupting(true);
|
333
|
-
current = concrete(
|
334
|
-
r.left.flatMap(() => IO.failCauseNow(this.unsafeClearSuppressedCause())),
|
335
|
-
);
|
336
|
-
} else {
|
337
|
-
current = null;
|
338
|
-
}
|
339
|
-
} else {
|
340
|
-
current = null;
|
341
|
-
}
|
342
|
-
break;
|
343
|
-
}
|
344
|
-
case "Right": {
|
345
|
-
if (!this.unsafeExitAsync(epoch)) {
|
346
|
-
current = null;
|
347
|
-
} else {
|
348
|
-
current = concrete(r.right);
|
349
|
-
}
|
350
|
-
}
|
351
|
-
}
|
352
|
-
break;
|
353
|
-
}
|
354
|
-
case IOTag.Fork: {
|
355
|
-
current = this.unsafeNextEffect(
|
356
|
-
this.unsafeFork(concrete(current.io), current.scope, current.trace),
|
357
|
-
);
|
358
|
-
break;
|
359
|
-
}
|
360
|
-
case IOTag.Yield: {
|
361
|
-
current = null;
|
362
|
-
this.unsafeRunLater(concrete(IO.unit));
|
363
|
-
break;
|
364
|
-
}
|
365
|
-
case IOTag.Defer: {
|
366
|
-
current = concrete(current.make());
|
367
|
-
break;
|
368
|
-
}
|
369
|
-
case IOTag.DeferWith: {
|
370
|
-
current = concrete(current.make(this.runtimeConfig, this.fiberId));
|
371
|
-
break;
|
372
|
-
}
|
373
|
-
case IOTag.Stateful: {
|
374
|
-
current = concrete(current.onState(this, this.state.status));
|
375
|
-
break;
|
376
|
-
}
|
377
|
-
case IOTag.Race: {
|
378
|
-
current = concrete(this.unsafeRace(current));
|
379
|
-
break;
|
380
|
-
}
|
381
|
-
case IOTag.Logged: {
|
382
|
-
this.unsafeLogWith(
|
383
|
-
current.message,
|
384
|
-
current.cause,
|
385
|
-
current.overrideLogLevel,
|
386
|
-
current.overrideRef1,
|
387
|
-
current.overrideValue1,
|
388
|
-
current.trace,
|
389
|
-
);
|
390
|
-
|
391
|
-
current = this.unsafeNextEffect(undefined);
|
392
|
-
break;
|
393
|
-
}
|
394
|
-
default: {
|
395
|
-
console.log("Unrecognized Instruction", current);
|
396
|
-
throw new Error("Unrecognized Instruction");
|
397
|
-
}
|
398
|
-
}
|
399
|
-
}
|
400
|
-
} else {
|
401
|
-
const trace = current.trace;
|
402
|
-
current = concrete(IO.failCauseNow(this.unsafeClearSuppressedCause(), trace));
|
403
|
-
this.unsafeSetInterrupting(true);
|
404
|
-
}
|
405
|
-
opCount++;
|
406
|
-
}
|
407
|
-
} catch (e) {
|
408
|
-
if (isInterruptedException(e)) {
|
409
|
-
const trace = current ? current.trace : undefined;
|
410
|
-
current = concrete(IO.interruptAs(FiberId.none, trace));
|
411
|
-
this.unsafeSetInterrupting(true);
|
412
|
-
} else if (isIOError(e)) {
|
413
|
-
switch (e.exit._tag) {
|
414
|
-
case "Success": {
|
415
|
-
current = this.unsafeNextEffect(e.exit.value);
|
416
|
-
break;
|
417
|
-
}
|
418
|
-
case "Failure": {
|
419
|
-
const trace = current ? current.trace : undefined;
|
420
|
-
current = concrete(IO.failCauseNow(e.exit.cause, trace));
|
421
|
-
}
|
422
|
-
}
|
423
|
-
} else if (this.unsafeIsFatal(e)) {
|
424
|
-
this.unsafeHandleFatalError(e);
|
425
|
-
} else {
|
426
|
-
this.unsafeSetInterrupting(true);
|
427
|
-
current = concrete(IO.haltNow(e));
|
428
|
-
}
|
429
|
-
}
|
430
|
-
}
|
431
|
-
} finally {
|
432
|
-
currentFiber.set(null);
|
433
|
-
this.currentSupervisor.unsafeOnSuspend(this);
|
434
|
-
}
|
435
|
-
}
|
436
|
-
|
437
|
-
unsafeRunLater(i0: Instruction) {
|
438
|
-
this.unsafeGetRef(FiberRef.currentScheduler).scheduleTask(() => {
|
439
|
-
this.nextIO = i0;
|
440
|
-
this.runUntil(this.runtimeConfig.yieldOpCount);
|
441
|
-
});
|
442
|
-
}
|
443
|
-
|
444
|
-
unsafeGetRef<A>(ref: FiberRef<A>): A {
|
445
|
-
return this.fiberRefLocals
|
446
|
-
.get(ref)
|
447
|
-
.map((_) => _.head[1])
|
448
|
-
.getOrElse(ref.initial) as A;
|
449
|
-
}
|
450
|
-
|
451
|
-
private unsafeGetRefs(fiberRefLocals: FiberRefLocals): HashMap<FiberRef<unknown>, unknown> {
|
452
|
-
return fiberRefLocals.map((stack) => stack.head[1]);
|
453
|
-
}
|
454
|
-
|
455
|
-
unsafeSetRef<A>(ref: FiberRef<A>, value: A): void {
|
456
|
-
const oldState = this.fiberRefLocals;
|
457
|
-
const oldStack = oldState.get(ref).getOrElse(List.empty<readonly [FiberId.Runtime, unknown]>());
|
458
|
-
let newStack: Cons<readonly [FiberId.Runtime, unknown]>;
|
459
|
-
if (oldStack.isEmpty()) {
|
460
|
-
newStack = Cons([this.fiberId, value]);
|
461
|
-
} else if (oldStack.head[0] == this.fiberId) {
|
462
|
-
newStack = Cons([this.fiberId, value], oldStack.tail);
|
463
|
-
} else {
|
464
|
-
newStack = Cons([this.fiberId, value], oldStack);
|
465
|
-
}
|
466
|
-
const newState = oldState.set(ref, newStack);
|
467
|
-
this.fiberRefLocals = newState;
|
468
|
-
}
|
469
|
-
|
470
|
-
unsafeDeleteRef<A>(ref: FiberRef<A>): void {
|
471
|
-
this.fiberRefLocals = this.fiberRefLocals.remove(ref);
|
472
|
-
}
|
473
|
-
|
474
|
-
unsafePoll() {
|
475
|
-
switch (this.state._tag) {
|
476
|
-
case "Executing": {
|
477
|
-
return Nothing();
|
478
|
-
}
|
479
|
-
case "Done": {
|
480
|
-
return Just(this.state.value);
|
481
|
-
}
|
482
|
-
}
|
483
|
-
}
|
484
|
-
|
485
|
-
private interruptExit = new InterruptExit((v: any) => {
|
486
|
-
if (this.unsafeIsInterruptible) {
|
487
|
-
this.interruptStatus.pop();
|
488
|
-
return IO.succeedNow(v);
|
489
|
-
} else {
|
490
|
-
return IO.succeed(() => {
|
491
|
-
this.interruptStatus.pop();
|
492
|
-
return v;
|
493
|
-
});
|
494
|
-
}
|
495
|
-
});
|
496
|
-
|
497
|
-
unsafeAddFinalizer(finalizer: IO<any, never, any>): void {
|
498
|
-
this.stack.push(
|
499
|
-
new Finalizer(finalizer, (v) => {
|
500
|
-
this.unsafeDisableInterruption();
|
501
|
-
this.unsafeRestoreInterruptStatus();
|
502
|
-
return finalizer.map(() => v);
|
503
|
-
}),
|
504
|
-
);
|
505
|
-
}
|
506
|
-
|
507
|
-
get unsafeIsInterruptible() {
|
508
|
-
return this.interruptStatus.hasNext ? this.interruptStatus.peek()! : true;
|
509
|
-
}
|
510
|
-
|
511
|
-
private get unsafeIsInterrupted() {
|
512
|
-
return this.state.interruptors.size > 0;
|
513
|
-
}
|
514
|
-
|
515
|
-
private get unsafeIsInterrupting() {
|
516
|
-
return this.state.status.isInterrupting;
|
517
|
-
}
|
518
|
-
|
519
|
-
private get unsafeShouldInterrupt() {
|
520
|
-
return this.unsafeIsInterrupted && this.unsafeIsInterruptible && !this.unsafeIsInterrupting;
|
521
|
-
}
|
522
|
-
|
523
|
-
private unsafeDisableInterruption(): void {
|
524
|
-
this.interruptStatus.push(false);
|
525
|
-
}
|
526
|
-
|
527
|
-
unsafeRestoreInterruptStatus(): void {
|
528
|
-
this.stack.push(this.interruptExit);
|
529
|
-
}
|
530
|
-
|
531
|
-
private unsafeAddSuppressedCause(cause: Cause<never>): void {
|
532
|
-
if (!cause.isEmpty) {
|
533
|
-
if (this.state._tag === "Executing") {
|
534
|
-
this.state.suppressed = Cause.then(this.state.suppressed, cause);
|
535
|
-
}
|
536
|
-
}
|
537
|
-
}
|
538
|
-
|
539
|
-
/**
|
540
|
-
* Unwinds the stack, looking for the first error handler, and exiting
|
541
|
-
* interruptible / uninterruptible regions.
|
542
|
-
*/
|
543
|
-
private unsafeUnwindStack() {
|
544
|
-
let unwinding = true;
|
545
|
-
let discardedFolds = false;
|
546
|
-
|
547
|
-
// Unwind the stack, looking for an error handler:
|
548
|
-
while (unwinding && this.stack.hasNext) {
|
549
|
-
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
550
|
-
const frame = this.stack.pop()!;
|
551
|
-
|
552
|
-
switch (frame._tag) {
|
553
|
-
case "InterruptExit": {
|
554
|
-
this.interruptStatus.pop();
|
555
|
-
break;
|
556
|
-
}
|
557
|
-
case "Finalizer": {
|
558
|
-
this.unsafeDisableInterruption();
|
559
|
-
this.stack.push(
|
560
|
-
new TracedCont(
|
561
|
-
(cause) =>
|
562
|
-
frame.finalizer.matchCauseIO(
|
563
|
-
(finalizerCause) => {
|
564
|
-
this.interruptStatus.pop();
|
565
|
-
this.unsafeAddSuppressedCause(finalizerCause);
|
566
|
-
return IO.failCauseNow(cause);
|
567
|
-
},
|
568
|
-
() => {
|
569
|
-
this.interruptStatus.pop();
|
570
|
-
return IO.failCauseNow(cause);
|
571
|
-
},
|
572
|
-
),
|
573
|
-
frame.trace,
|
574
|
-
),
|
575
|
-
);
|
576
|
-
unwinding = false;
|
577
|
-
break;
|
578
|
-
}
|
579
|
-
case IOTag.Match: {
|
580
|
-
if (!this.unsafeShouldInterrupt) {
|
581
|
-
// Push error handler back onto the stack and halt iteration:
|
582
|
-
this.stack.push(new HandlerFrame(frame.onFailure, frame.trace));
|
583
|
-
unwinding = false;
|
584
|
-
} else {
|
585
|
-
discardedFolds = true;
|
586
|
-
}
|
587
|
-
break;
|
588
|
-
}
|
589
|
-
}
|
590
|
-
}
|
591
|
-
|
592
|
-
return discardedFolds;
|
593
|
-
}
|
594
|
-
|
595
|
-
private unsafeAddObserver(k: FiberState.Callback<never, Exit<E, A>>): Exit<E, A> | null {
|
596
|
-
switch (this.state._tag) {
|
597
|
-
case "Done": {
|
598
|
-
return this.state.value;
|
599
|
-
}
|
600
|
-
case "Executing": {
|
601
|
-
this.state.observers.add(k);
|
602
|
-
return null;
|
603
|
-
}
|
604
|
-
}
|
605
|
-
}
|
606
|
-
|
607
|
-
private unsafeNextEffect(value: any): Instruction | null {
|
608
|
-
if (this.stack.hasNext) {
|
609
|
-
const k = this.stack.pop()!;
|
610
|
-
return concrete(k.apply(value));
|
611
|
-
} else {
|
612
|
-
return this.unsafeTryDone(Exit.succeed(value));
|
613
|
-
}
|
614
|
-
}
|
615
|
-
|
616
|
-
private unsafeNotifyObservers(v: Exit<E, A>, observers: Set<FiberState.Callback<never, Exit<E, A>>>) {
|
617
|
-
if (observers.size > 0) {
|
618
|
-
const result = Exit.succeed(v);
|
619
|
-
observers.forEach((k) => k(result));
|
620
|
-
}
|
621
|
-
}
|
622
|
-
|
623
|
-
private unsafeRemoveObserver(k: FiberState.Callback<never, Exit<E, A>>) {
|
624
|
-
if (this.state._tag === "Executing") {
|
625
|
-
this.state.observers.delete(k);
|
626
|
-
}
|
627
|
-
}
|
628
|
-
|
629
|
-
interruptAsFork(fiberId: FiberId): UIO<void> {
|
630
|
-
const interruptedCause = Cause.interrupt(fiberId);
|
631
|
-
return IO(() => {
|
632
|
-
const oldState = this.state;
|
633
|
-
if (
|
634
|
-
this.state._tag === "Executing" &&
|
635
|
-
this.state.status._tag === "Suspended" &&
|
636
|
-
this.state.status.interruptible &&
|
637
|
-
this.state.asyncCanceller._tag === "Registered"
|
638
|
-
) {
|
639
|
-
const asyncCanceller = this.state.asyncCanceller.asyncCanceller;
|
640
|
-
const interrupt = IO.failCauseNow(interruptedCause);
|
641
|
-
this.state.status = FiberStatus.running(true);
|
642
|
-
this.state.interruptors = new Set(oldState.interruptors).add(fiberId);
|
643
|
-
this.state.asyncCanceller = CancellerState.empty;
|
644
|
-
this.unsafeRunLater(concrete(asyncCanceller.flatMap(() => interrupt)));
|
645
|
-
} else if (this.state._tag === "Executing") {
|
646
|
-
const newCause = Cause.then(this.state.suppressed, interruptedCause);
|
647
|
-
this.state.interruptors.add(fiberId);
|
648
|
-
this.state.suppressed = newCause;
|
649
|
-
}
|
650
|
-
});
|
651
|
-
}
|
652
|
-
|
653
|
-
private unsafeTryDone(exit: Exit<E, A>, trace?: string): Instruction | null {
|
654
|
-
switch (this.state._tag) {
|
655
|
-
case "Done": {
|
656
|
-
// Already done
|
657
|
-
return null;
|
658
|
-
}
|
659
|
-
case "Executing": {
|
660
|
-
if (this.state.mailbox !== null) {
|
661
|
-
// Not done because the mailbox isn't empty
|
662
|
-
const mailbox = this.state.mailbox;
|
663
|
-
this.state.mailbox = null;
|
664
|
-
this.unsafeSetInterrupting(true);
|
665
|
-
return concrete(mailbox.flatMap(() => IO.fromExit(exit)));
|
666
|
-
} else if (this._children.size === 0) {
|
667
|
-
// We are truly "done" because all the children of this fiber have terminated,
|
668
|
-
// and there are no more pending effects that we have to execute on the fiber.
|
669
|
-
const interruptorsCause = this.state.interruptorsCause;
|
670
|
-
const newExit = interruptorsCause.isEmpty
|
671
|
-
? exit
|
672
|
-
: exit.mapErrorCause((cause) => {
|
673
|
-
if (cause.contains(interruptorsCause)) {
|
674
|
-
return cause;
|
675
|
-
} else {
|
676
|
-
return Cause.then(cause, interruptorsCause);
|
677
|
-
}
|
678
|
-
});
|
679
|
-
|
680
|
-
const observers = this.state.observers;
|
681
|
-
this.state = FiberState.done(newExit);
|
682
|
-
this.unsafeReportUnhandled(newExit);
|
683
|
-
|
684
|
-
this.unsafeNotifyObservers(newExit, observers);
|
685
|
-
|
686
|
-
return null;
|
687
|
-
} else {
|
688
|
-
// not done because there are children left to close
|
689
|
-
this.unsafeSetInterrupting(true);
|
690
|
-
|
691
|
-
let interruptChildren = IO.unit;
|
692
|
-
|
693
|
-
this._children.forEach((child) => {
|
694
|
-
interruptChildren = interruptChildren.flatMap(() => child.interruptAs(this.fiberId));
|
695
|
-
});
|
696
|
-
this._children.clear();
|
697
|
-
|
698
|
-
return concrete(interruptChildren.flatMap(() => IO.fromExit(exit)));
|
699
|
-
}
|
700
|
-
}
|
701
|
-
}
|
702
|
-
}
|
703
|
-
|
704
|
-
private unsafeSetAsyncCanceller(epoch: number, asyncCanceller0: Erased | null): void {
|
705
|
-
const asyncCanceller = !asyncCanceller0 ? IO.unit : asyncCanceller0;
|
706
|
-
if (this.state._tag === "Executing") {
|
707
|
-
if (
|
708
|
-
this.state.status._tag === "Suspended" &&
|
709
|
-
this.state.asyncCanceller._tag === "Pending" &&
|
710
|
-
this.state.status.epoch === epoch
|
711
|
-
) {
|
712
|
-
this.state.asyncCanceller = CancellerState.registered(asyncCanceller);
|
713
|
-
} else if (
|
714
|
-
this.state.status._tag === "Suspended" &&
|
715
|
-
this.state.asyncCanceller._tag === "Registered" &&
|
716
|
-
this.state.status.epoch === epoch
|
717
|
-
) {
|
718
|
-
throw new Error("inconsistent state in setAsyncCanceller");
|
719
|
-
}
|
720
|
-
} else {
|
721
|
-
return;
|
722
|
-
}
|
723
|
-
}
|
724
|
-
|
725
|
-
private unsafeReportUnhandled(exit: Exit<E, A>, trace?: string): void {
|
726
|
-
if (exit._tag === ExitTag.Failure) {
|
727
|
-
this.runtimeConfig.reportFailure(exit.cause);
|
728
|
-
}
|
729
|
-
}
|
730
|
-
|
731
|
-
private unsafeSetInterrupting(value: boolean): void {
|
732
|
-
switch (this.state._tag) {
|
733
|
-
case "Executing": {
|
734
|
-
this.state.status = this.state.status.withInterrupting(value);
|
735
|
-
return;
|
736
|
-
}
|
737
|
-
case "Done": {
|
738
|
-
return;
|
739
|
-
}
|
740
|
-
}
|
741
|
-
}
|
742
|
-
|
743
|
-
private unsafeEnterAsync(epoch: number, blockingOn: FiberId, trace?: string): void {
|
744
|
-
if (
|
745
|
-
this.state._tag === "Executing" &&
|
746
|
-
this.state.status._tag === FiberStatusTag.Running &&
|
747
|
-
this.state.asyncCanceller._tag === "Empty"
|
748
|
-
) {
|
749
|
-
const newStatus = FiberStatus.suspended(
|
750
|
-
this.state.status.interrupting,
|
751
|
-
this.unsafeIsInterruptible && !this.unsafeIsInterrupting,
|
752
|
-
epoch,
|
753
|
-
blockingOn,
|
754
|
-
trace,
|
755
|
-
);
|
756
|
-
this.state.status = newStatus;
|
757
|
-
this.state.asyncCanceller = CancellerState.pending;
|
758
|
-
} else {
|
759
|
-
throw new IllegalStateError(`Fiber ${this.fiberId.threadName} is not running`);
|
760
|
-
}
|
761
|
-
}
|
762
|
-
|
763
|
-
private unsafeExitAsync(epoch: number): boolean {
|
764
|
-
if (
|
765
|
-
this.state._tag === "Executing" &&
|
766
|
-
this.state.status._tag === "Suspended" &&
|
767
|
-
this.state.status.epoch === epoch
|
768
|
-
) {
|
769
|
-
this.state.status = FiberStatus.running(this.state.status.interrupting);
|
770
|
-
this.state.asyncCanceller = CancellerState.empty;
|
771
|
-
return true;
|
772
|
-
}
|
773
|
-
return false;
|
774
|
-
}
|
775
|
-
|
776
|
-
private unsafeCreateAsyncResume(epoch: number) {
|
777
|
-
return (_: Erased) => {
|
778
|
-
if (this.unsafeExitAsync(epoch)) {
|
779
|
-
this.unsafeRunLater(concrete(_));
|
780
|
-
}
|
781
|
-
};
|
782
|
-
}
|
783
|
-
|
784
|
-
private unsafeFork(
|
785
|
-
io: Instruction,
|
786
|
-
forkScope: Maybe<FiberScope> = Nothing(),
|
787
|
-
trace?: string,
|
788
|
-
): FiberContext<any, any> {
|
789
|
-
const childId = FiberId.unsafeMake(TraceElement.parse(trace));
|
790
|
-
const childFiberRefLocals = this.fiberRefs.forkAs(childId).fiberRefLocals;
|
791
|
-
const parentScope: FiberScope = forkScope
|
792
|
-
.orElse(this.unsafeGetRef(FiberRef.forkScopeOverride))
|
793
|
-
.getOrElse(this.scope);
|
794
|
-
|
795
|
-
const grandChildren = new Set<FiberContext<any, any>>();
|
796
|
-
const childContext = new FiberContext<any, any>(
|
797
|
-
childId,
|
798
|
-
this.runtimeConfig,
|
799
|
-
Stack.single(this.unsafeIsInterruptible),
|
800
|
-
childFiberRefLocals,
|
801
|
-
grandChildren,
|
802
|
-
);
|
803
|
-
|
804
|
-
if (this.currentSupervisor !== Supervisor.none) {
|
805
|
-
this.currentSupervisor.unsafeOnStart(
|
806
|
-
this.unsafeGetRef(FiberRef.currentEnvironment),
|
807
|
-
io,
|
808
|
-
Just(this),
|
809
|
-
childContext,
|
810
|
-
);
|
811
|
-
childContext.unsafeOnDone((exit) => {
|
812
|
-
this.currentSupervisor.unsafeOnEnd(exit.flatten, childContext);
|
813
|
-
});
|
814
|
-
}
|
815
|
-
const childIO = !parentScope.unsafeAdd(childContext) ? IO.interruptAs(parentScope.fiberId) : io;
|
816
|
-
childContext.nextIO = concrete(childIO);
|
817
|
-
this.unsafeGetRef(FiberRef.currentScheduler).scheduleTask(() =>
|
818
|
-
childContext.runUntil(this.runtimeConfig.yieldOpCount),
|
819
|
-
);
|
820
|
-
|
821
|
-
return childContext;
|
822
|
-
}
|
823
|
-
|
824
|
-
unsafeOnDone(k: FiberState.Callback<never, Exit<E, A>>): void {
|
825
|
-
const exit = this.unsafeAddObserver(k);
|
826
|
-
if (exit == null) {
|
827
|
-
return;
|
828
|
-
} else {
|
829
|
-
k(Exit.succeed(exit));
|
830
|
-
}
|
831
|
-
}
|
832
|
-
|
833
|
-
private unsafeClearSuppressedCause(): Cause<never> {
|
834
|
-
switch (this.state._tag) {
|
835
|
-
case "Executing": {
|
836
|
-
const suppressed = this.state.suppressed;
|
837
|
-
this.state.suppressed = Cause.empty();
|
838
|
-
return suppressed;
|
839
|
-
}
|
840
|
-
case "Done": {
|
841
|
-
return Cause.empty();
|
842
|
-
}
|
843
|
-
}
|
844
|
-
}
|
845
|
-
|
846
|
-
unsafeGetDescriptor() {
|
847
|
-
return new FiberDescriptor(
|
848
|
-
this.fiberId,
|
849
|
-
this.state.status,
|
850
|
-
this.state.interruptors,
|
851
|
-
InterruptStatus.fromBoolean(this.unsafeIsInterruptible),
|
852
|
-
this.scope,
|
853
|
-
);
|
854
|
-
}
|
855
|
-
|
856
|
-
private unsafeRace<R, E, A, R1, E1, A1, R2, E2, A2, R3, E3, A3>(
|
857
|
-
race: Race<R, E, A, R1, E1, A1, R2, E2, A2, R3, E3, A3>,
|
858
|
-
): IO<R | R1 | R2 | R3, E2 | E3, A2 | A3> {
|
859
|
-
const raceIndicator = new AtomicReference(true);
|
860
|
-
const left = this.unsafeFork(concrete(race.left), Nothing(), race.trace);
|
861
|
-
const right = this.unsafeFork(concrete(race.right), Nothing(), race.trace);
|
862
|
-
|
863
|
-
return IO.async<R | R1 | R2 | R3, E2 | E3, A2 | A3>((cb) => {
|
864
|
-
const leftRegister = left.unsafeAddObserver(() => {
|
865
|
-
this.unsafeCompleteRace(left, right, race.leftWins, raceIndicator, cb);
|
866
|
-
});
|
867
|
-
if (leftRegister != null) {
|
868
|
-
this.unsafeCompleteRace(left, right, race.leftWins, raceIndicator, cb);
|
869
|
-
} else {
|
870
|
-
const rightRegister = right.unsafeAddObserver(() => {
|
871
|
-
this.unsafeCompleteRace(right, left, race.rightWins, raceIndicator, cb);
|
872
|
-
});
|
873
|
-
if (rightRegister != null) {
|
874
|
-
this.unsafeCompleteRace(right, left, race.rightWins, raceIndicator, cb);
|
875
|
-
}
|
876
|
-
}
|
877
|
-
}, left.fiberId.combine(right.fiberId));
|
878
|
-
}
|
879
|
-
|
880
|
-
private unsafeCompleteRace<R, R1, R2, E2, A2, R3, E3, A3>(
|
881
|
-
winner: Fiber<any, any>,
|
882
|
-
loser: Fiber<any, any>,
|
883
|
-
cont: (fiber0: Fiber<any, any>, fiber1: Fiber<any, any>) => Erased,
|
884
|
-
ab: AtomicReference<boolean>,
|
885
|
-
cb: (_: IO<R | R1 | R2 | R3, E2 | E3, A2 | A3>) => void,
|
886
|
-
): void {
|
887
|
-
if (ab.compareAndSet(true, false)) {
|
888
|
-
cb(cont(winner, loser));
|
889
|
-
}
|
890
|
-
}
|
891
|
-
|
892
|
-
private unsafeCaptureTrace(prefix: List<string | undefined>): Trace {
|
893
|
-
const builder = new StackTraceBuilder();
|
894
|
-
|
895
|
-
prefix.forEach((element) => builder.append(TraceElement.parse(element)));
|
896
|
-
|
897
|
-
const stack = this.stack.clone();
|
898
|
-
while (stack.hasNext) {
|
899
|
-
builder.append(TraceElement.parse(stack.pop()!.trace));
|
900
|
-
}
|
901
|
-
|
902
|
-
return new Trace(this.fiberId, builder.result());
|
903
|
-
}
|
904
|
-
|
905
|
-
private unsafeEvalOn(effect: UIO<any>, orElse: UIO<any>): UIO<void> {
|
906
|
-
if (this.state._tag === "Executing") {
|
907
|
-
const newMailbox = this.state.mailbox == null ? effect : this.state.mailbox.flatMap(() => effect);
|
908
|
-
this.state.mailbox = newMailbox;
|
909
|
-
return IO.unit;
|
910
|
-
} else {
|
911
|
-
return orElse.asUnit;
|
912
|
-
}
|
913
|
-
}
|
914
|
-
|
915
|
-
private unsafeDrainMailbox(): UIO<any> | null {
|
916
|
-
if (this.state._tag === "Executing") {
|
917
|
-
const mailbox = this.state.mailbox;
|
918
|
-
this.state.mailbox = null;
|
919
|
-
return mailbox;
|
920
|
-
} else {
|
921
|
-
return null;
|
922
|
-
}
|
923
|
-
}
|
924
|
-
|
925
|
-
unsafeAddChild(child: FiberContext<unknown, unknown>): void {
|
926
|
-
this.unsafeEvalOn(
|
927
|
-
IO.succeed(() => {
|
928
|
-
this._children.add(child);
|
929
|
-
}),
|
930
|
-
IO.unit,
|
931
|
-
);
|
932
|
-
}
|
933
|
-
|
934
|
-
private unsafeLog(message: () => string, trace?: string): void {
|
935
|
-
const logLevel = this.unsafeGetRef(FiberRef.currentLogLevel);
|
936
|
-
const spans = this.unsafeGetRef(FiberRef.currentLogSpan);
|
937
|
-
const annotations = this.unsafeGetRef(FiberRef.currentLogAnnotations);
|
938
|
-
this.runtimeConfig.logger.log(
|
939
|
-
TraceElement.parse(trace),
|
940
|
-
this.fiberId,
|
941
|
-
logLevel,
|
942
|
-
message,
|
943
|
-
Cause.empty(),
|
944
|
-
this.fiberRefLocals,
|
945
|
-
spans,
|
946
|
-
annotations,
|
947
|
-
);
|
948
|
-
}
|
949
|
-
|
950
|
-
private unsafeLogWith(
|
951
|
-
message: () => string,
|
952
|
-
cause: Cause<any>,
|
953
|
-
overrideLogLevel: Maybe<LogLevel>,
|
954
|
-
overrideRef1: FiberRef<unknown> | null = null,
|
955
|
-
overrideValue1: unknown | null = null,
|
956
|
-
trace?: string,
|
957
|
-
): void {
|
958
|
-
const logLevel = overrideLogLevel.getOrElse(this.unsafeGetRef(FiberRef.currentLogLevel));
|
959
|
-
const spans = this.unsafeGetRef(FiberRef.currentLogSpan);
|
960
|
-
const annotations = this.unsafeGetRef(FiberRef.currentLogAnnotations);
|
961
|
-
|
962
|
-
let contextMap;
|
963
|
-
|
964
|
-
if (overrideRef1 !== null) {
|
965
|
-
const map = this.unsafeGetRefs(this.fiberRefLocals);
|
966
|
-
if (overrideValue1 === null) {
|
967
|
-
map.remove(overrideRef1);
|
968
|
-
} else {
|
969
|
-
map.set(overrideRef1, overrideValue1);
|
970
|
-
}
|
971
|
-
contextMap = map;
|
972
|
-
} else {
|
973
|
-
contextMap = this.fiberRefLocals;
|
974
|
-
}
|
975
|
-
|
976
|
-
this.runtimeConfig.logger.log(
|
977
|
-
TraceElement.parse(trace),
|
978
|
-
this.fiberId,
|
979
|
-
logLevel,
|
980
|
-
message,
|
981
|
-
cause,
|
982
|
-
contextMap,
|
983
|
-
spans,
|
984
|
-
annotations,
|
985
|
-
);
|
986
|
-
}
|
987
|
-
|
988
|
-
private unsafeIsFatal(t: unknown): boolean {
|
989
|
-
return this.unsafeGetRef(FiberRef.currentIsFatal).apply(t);
|
990
|
-
}
|
991
|
-
|
992
|
-
private unsafeHandleFatalError(t: unknown): never {
|
993
|
-
return this.unsafeGetRef(FiberRef.currentReportFatal)(t);
|
994
|
-
}
|
995
|
-
|
996
|
-
get currentSupervisor(): Supervisor<any> {
|
997
|
-
return this.unsafeGetRef(FiberRef.currentSupervisor);
|
998
|
-
}
|
999
|
-
}
|