effect 2.2.5 → 2.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/RateLimiter/package.json +6 -0
- package/dist/cjs/Cause.js +14 -1
- package/dist/cjs/Cause.js.map +1 -1
- package/dist/cjs/Channel.js.map +1 -1
- package/dist/cjs/Clock.js.map +1 -1
- package/dist/cjs/Console.js.map +1 -1
- package/dist/cjs/Context.js +23 -25
- package/dist/cjs/Context.js.map +1 -1
- package/dist/cjs/Data.js +3 -3
- package/dist/cjs/Data.js.map +1 -1
- package/dist/cjs/Deferred.js +1 -1
- package/dist/cjs/Deferred.js.map +1 -1
- package/dist/cjs/Effect.js +9 -9
- package/dist/cjs/Effect.js.map +1 -1
- package/dist/cjs/Effectable.js.map +1 -1
- package/dist/cjs/Either.js.map +1 -1
- package/dist/cjs/Exit.js +2 -2
- package/dist/cjs/Exit.js.map +1 -1
- package/dist/cjs/Fiber.js.map +1 -1
- package/dist/cjs/FiberMap.js +3 -3
- package/dist/cjs/FiberRef.js.map +1 -1
- package/dist/cjs/FiberRefs.js.map +1 -1
- package/dist/cjs/FiberSet.js +3 -3
- package/dist/cjs/FiberSet.js.map +1 -1
- package/dist/cjs/GroupBy.js.map +1 -1
- package/dist/cjs/Layer.js.map +1 -1
- package/dist/cjs/LogLevel.js.map +1 -1
- package/dist/cjs/Logger.js.map +1 -1
- package/dist/cjs/Metric.js.map +1 -1
- package/dist/cjs/Number.js +20 -1
- package/dist/cjs/Number.js.map +1 -1
- package/dist/cjs/Option.js.map +1 -1
- package/dist/cjs/Pool.js.map +1 -1
- package/dist/cjs/PubSub.js.map +1 -1
- package/dist/cjs/Queue.js.map +1 -1
- package/dist/cjs/Random.js.map +1 -1
- package/dist/cjs/RateLimiter.js +38 -0
- package/dist/cjs/RateLimiter.js.map +1 -0
- package/dist/cjs/ReadonlyRecord.js +45 -9
- package/dist/cjs/ReadonlyRecord.js.map +1 -1
- package/dist/cjs/Ref.js.map +1 -1
- package/dist/cjs/Request.js.map +1 -1
- package/dist/cjs/RequestResolver.js.map +1 -1
- package/dist/cjs/Resource.js.map +1 -1
- package/dist/cjs/Runtime.js +1 -4
- package/dist/cjs/Runtime.js.map +1 -1
- package/dist/cjs/RuntimeFlags.js.map +1 -1
- package/dist/cjs/STM.js.map +1 -1
- package/dist/cjs/Schedule.js.map +1 -1
- package/dist/cjs/Scope.js.map +1 -1
- package/dist/cjs/ScopedRef.js.map +1 -1
- package/dist/cjs/SingleProducerAsyncInput.js.map +1 -1
- package/dist/cjs/Sink.js.map +1 -1
- package/dist/cjs/Stream.js.map +1 -1
- package/dist/cjs/SubscriptionRef.js.map +1 -1
- package/dist/cjs/Supervisor.js.map +1 -1
- package/dist/cjs/SynchronizedRef.js.map +1 -1
- package/dist/cjs/TArray.js.map +1 -1
- package/dist/cjs/TDeferred.js.map +1 -1
- package/dist/cjs/TMap.js.map +1 -1
- package/dist/cjs/TPriorityQueue.js.map +1 -1
- package/dist/cjs/TPubSub.js.map +1 -1
- package/dist/cjs/TQueue.js.map +1 -1
- package/dist/cjs/TRandom.js.map +1 -1
- package/dist/cjs/TReentrantLock.js.map +1 -1
- package/dist/cjs/TRef.js.map +1 -1
- package/dist/cjs/TSemaphore.js.map +1 -1
- package/dist/cjs/TSet.js.map +1 -1
- package/dist/cjs/Take.js +6 -6
- package/dist/cjs/Take.js.map +1 -1
- package/dist/cjs/TestAnnotation.js +10 -13
- package/dist/cjs/TestAnnotation.js.map +1 -1
- package/dist/cjs/TestAnnotations.js +1 -1
- package/dist/cjs/TestAnnotations.js.map +1 -1
- package/dist/cjs/TestClock.js +1 -1
- package/dist/cjs/TestClock.js.map +1 -1
- package/dist/cjs/TestConfig.js +1 -1
- package/dist/cjs/TestConfig.js.map +1 -1
- package/dist/cjs/TestContext.js.map +1 -1
- package/dist/cjs/TestLive.js +1 -1
- package/dist/cjs/TestLive.js.map +1 -1
- package/dist/cjs/TestServices.js.map +1 -1
- package/dist/cjs/TestSized.js +1 -1
- package/dist/cjs/TestSized.js.map +1 -1
- package/dist/cjs/Utils.js +0 -1
- package/dist/cjs/Utils.js.map +1 -1
- package/dist/cjs/index.js +4 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/internal/cache.js.map +1 -1
- package/dist/cjs/internal/channel/channelExecutor.js.map +1 -1
- package/dist/cjs/internal/channel/mergeDecision.js +2 -6
- package/dist/cjs/internal/channel/mergeDecision.js.map +1 -1
- package/dist/cjs/internal/channel/singleProducerAsyncInput.js.map +1 -1
- package/dist/cjs/internal/channel.js +1 -1
- package/dist/cjs/internal/channel.js.map +1 -1
- package/dist/cjs/internal/clock.js +1 -1
- package/dist/cjs/internal/clock.js.map +1 -1
- package/dist/cjs/internal/configProvider.js +2 -4
- package/dist/cjs/internal/configProvider.js.map +1 -1
- package/dist/cjs/internal/console.js.map +1 -1
- package/dist/cjs/internal/context.js +31 -22
- package/dist/cjs/internal/context.js.map +1 -1
- package/dist/cjs/internal/core-effect.js +13 -27
- package/dist/cjs/internal/core-effect.js.map +1 -1
- package/dist/cjs/internal/core-stream.js.map +1 -1
- package/dist/cjs/internal/core.js +61 -130
- package/dist/cjs/internal/core.js.map +1 -1
- package/dist/cjs/internal/data.js.map +1 -1
- package/dist/cjs/internal/defaultServices/console.js +1 -1
- package/dist/cjs/internal/defaultServices/console.js.map +1 -1
- package/dist/cjs/internal/defaultServices.js.map +1 -1
- package/dist/cjs/internal/deferred.js.map +1 -1
- package/dist/cjs/internal/differ/contextPatch.js +9 -9
- package/dist/cjs/internal/differ/contextPatch.js.map +1 -1
- package/dist/cjs/internal/effect/circular.js +7 -10
- package/dist/cjs/internal/effect/circular.js.map +1 -1
- package/dist/cjs/internal/effectable.js +4 -4
- package/dist/cjs/internal/effectable.js.map +1 -1
- package/dist/cjs/internal/fiber.js +2 -6
- package/dist/cjs/internal/fiber.js.map +1 -1
- package/dist/cjs/internal/fiberRuntime.js +10 -19
- package/dist/cjs/internal/fiberRuntime.js.map +1 -1
- package/dist/cjs/internal/groupBy.js.map +1 -1
- package/dist/cjs/internal/keyedPool.js.map +1 -1
- package/dist/cjs/internal/layer/circular.js.map +1 -1
- package/dist/cjs/internal/layer.js +3 -3
- package/dist/cjs/internal/layer.js.map +1 -1
- package/dist/cjs/internal/logSpan.js +3 -5
- package/dist/cjs/internal/logSpan.js.map +1 -1
- package/dist/cjs/internal/metric.js.map +1 -1
- package/dist/cjs/internal/pool.js.map +1 -1
- package/dist/cjs/internal/pubsub.js +2 -6
- package/dist/cjs/internal/pubsub.js.map +1 -1
- package/dist/cjs/internal/query.js.map +1 -1
- package/dist/cjs/internal/queue.js.map +1 -1
- package/dist/cjs/internal/random.js +1 -1
- package/dist/cjs/internal/random.js.map +1 -1
- package/dist/cjs/internal/rateLimiter.js +44 -0
- package/dist/cjs/internal/rateLimiter.js.map +1 -0
- package/dist/cjs/internal/ref.js.map +1 -1
- package/dist/cjs/internal/reloadable.js +1 -9
- package/dist/cjs/internal/reloadable.js.map +1 -1
- package/dist/cjs/internal/runtime.js +0 -1
- package/dist/cjs/internal/runtime.js.map +1 -1
- package/dist/cjs/internal/schedule.js.map +1 -1
- package/dist/cjs/internal/scopedCache.js.map +1 -1
- package/dist/cjs/internal/scopedRef.js.map +1 -1
- package/dist/cjs/internal/sink.js +7 -7
- package/dist/cjs/internal/sink.js.map +1 -1
- package/dist/cjs/internal/stm/core.js.map +1 -1
- package/dist/cjs/internal/stm/stm/stmState.js.map +1 -1
- package/dist/cjs/internal/stm/stm/tExit.js +2 -2
- package/dist/cjs/internal/stm/stm/tExit.js.map +1 -1
- package/dist/cjs/internal/stm/stm/tryCommit.js.map +1 -1
- package/dist/cjs/internal/stm/stm.js.map +1 -1
- package/dist/cjs/internal/stm/tArray.js.map +1 -1
- package/dist/cjs/internal/stm/tDeferred.js +4 -2
- package/dist/cjs/internal/stm/tDeferred.js.map +1 -1
- package/dist/cjs/internal/stm/tMap.js.map +1 -1
- package/dist/cjs/internal/stm/tPriorityQueue.js.map +1 -1
- package/dist/cjs/internal/stm/tPubSub.js.map +1 -1
- package/dist/cjs/internal/stm/tQueue.js.map +1 -1
- package/dist/cjs/internal/stm/tRandom.js +1 -1
- package/dist/cjs/internal/stm/tRandom.js.map +1 -1
- package/dist/cjs/internal/stm/tReentrantLock.js.map +1 -1
- package/dist/cjs/internal/stm/tRef.js.map +1 -1
- package/dist/cjs/internal/stm/tSemaphore.js.map +1 -1
- package/dist/cjs/internal/stm/tSet.js.map +1 -1
- package/dist/cjs/internal/stream/debounceState.js.map +1 -1
- package/dist/cjs/internal/stream/handoff.js.map +1 -1
- package/dist/cjs/internal/stream/handoffSignal.js.map +1 -1
- package/dist/cjs/internal/stream/pull.js.map +1 -1
- package/dist/cjs/internal/stream.js +0 -2
- package/dist/cjs/internal/stream.js.map +1 -1
- package/dist/cjs/internal/subscriptionRef.js.map +1 -1
- package/dist/cjs/internal/supervisor.js.map +1 -1
- package/dist/cjs/internal/take.js +2 -2
- package/dist/cjs/internal/take.js.map +1 -1
- package/dist/cjs/internal/testing/sleep.js.map +1 -1
- package/dist/cjs/internal/tracer.js +2 -2
- package/dist/cjs/internal/tracer.js.map +1 -1
- package/dist/cjs/internal/version.js +1 -1
- package/dist/dts/Cache.d.ts +20 -20
- package/dist/dts/Cache.d.ts.map +1 -1
- package/dist/dts/Cause.d.ts +33 -5
- package/dist/dts/Cause.d.ts.map +1 -1
- package/dist/dts/Channel.d.ts +197 -194
- package/dist/dts/Channel.d.ts.map +1 -1
- package/dist/dts/Clock.d.ts +7 -7
- package/dist/dts/Clock.d.ts.map +1 -1
- package/dist/dts/Config.d.ts +1 -1
- package/dist/dts/Config.d.ts.map +1 -1
- package/dist/dts/ConfigProvider.d.ts +6 -6
- package/dist/dts/ConfigProvider.d.ts.map +1 -1
- package/dist/dts/Console.d.ts +43 -43
- package/dist/dts/Console.d.ts.map +1 -1
- package/dist/dts/Context.d.ts +44 -29
- package/dist/dts/Context.d.ts.map +1 -1
- package/dist/dts/Data.d.ts +38 -57
- package/dist/dts/Data.d.ts.map +1 -1
- package/dist/dts/Deferred.d.ts +36 -36
- package/dist/dts/Deferred.d.ts.map +1 -1
- package/dist/dts/Effect.d.ts +732 -729
- package/dist/dts/Effect.d.ts.map +1 -1
- package/dist/dts/Effectable.d.ts +8 -8
- package/dist/dts/Effectable.d.ts.map +1 -1
- package/dist/dts/Either.d.ts +2 -3
- package/dist/dts/Either.d.ts.map +1 -1
- package/dist/dts/Exit.d.ts +74 -74
- package/dist/dts/Exit.d.ts.map +1 -1
- package/dist/dts/Fiber.d.ts +75 -75
- package/dist/dts/Fiber.d.ts.map +1 -1
- package/dist/dts/FiberMap.d.ts +22 -22
- package/dist/dts/FiberMap.d.ts.map +1 -1
- package/dist/dts/FiberRef.d.ts +28 -28
- package/dist/dts/FiberRef.d.ts.map +1 -1
- package/dist/dts/FiberRefs.d.ts +1 -1
- package/dist/dts/FiberRefs.d.ts.map +1 -1
- package/dist/dts/FiberSet.d.ts +16 -16
- package/dist/dts/FiberSet.d.ts.map +1 -1
- package/dist/dts/GroupBy.d.ts +6 -6
- package/dist/dts/GroupBy.d.ts.map +1 -1
- package/dist/dts/KeyedPool.d.ts +22 -22
- package/dist/dts/KeyedPool.d.ts.map +1 -1
- package/dist/dts/Layer.d.ts +126 -126
- package/dist/dts/Layer.d.ts.map +1 -1
- package/dist/dts/LogLevel.d.ts +2 -2
- package/dist/dts/LogLevel.d.ts.map +1 -1
- package/dist/dts/Logger.d.ts +14 -14
- package/dist/dts/Logger.d.ts.map +1 -1
- package/dist/dts/MergeDecision.d.ts +7 -7
- package/dist/dts/MergeState.d.ts +13 -13
- package/dist/dts/MergeState.d.ts.map +1 -1
- package/dist/dts/Metric.d.ts +32 -32
- package/dist/dts/Metric.d.ts.map +1 -1
- package/dist/dts/MetricPolling.d.ts +6 -6
- package/dist/dts/MetricPolling.d.ts.map +1 -1
- package/dist/dts/Number.d.ts +15 -0
- package/dist/dts/Number.d.ts.map +1 -1
- package/dist/dts/Option.d.ts +2 -3
- package/dist/dts/Option.d.ts.map +1 -1
- package/dist/dts/Pool.d.ts +15 -16
- package/dist/dts/Pool.d.ts.map +1 -1
- package/dist/dts/PubSub.d.ts +18 -18
- package/dist/dts/PubSub.d.ts.map +1 -1
- package/dist/dts/Queue.d.ts +40 -40
- package/dist/dts/Queue.d.ts.map +1 -1
- package/dist/dts/Random.d.ts +13 -13
- package/dist/dts/Random.d.ts.map +1 -1
- package/dist/dts/RateLimiter.d.ts +31 -0
- package/dist/dts/RateLimiter.d.ts.map +1 -0
- package/dist/dts/ReadonlyArray.d.ts +3 -3
- package/dist/dts/ReadonlyRecord.d.ts +37 -8
- package/dist/dts/ReadonlyRecord.d.ts.map +1 -1
- package/dist/dts/Ref.d.ts +25 -25
- package/dist/dts/Ref.d.ts.map +1 -1
- package/dist/dts/Reloadable.d.ts +9 -9
- package/dist/dts/Reloadable.d.ts.map +1 -1
- package/dist/dts/Request.d.ts +27 -28
- package/dist/dts/Request.d.ts.map +1 -1
- package/dist/dts/RequestBlock.d.ts +3 -3
- package/dist/dts/RequestBlock.d.ts.map +1 -1
- package/dist/dts/RequestResolver.d.ts +16 -16
- package/dist/dts/RequestResolver.d.ts.map +1 -1
- package/dist/dts/Resource.d.ts +7 -7
- package/dist/dts/Resource.d.ts.map +1 -1
- package/dist/dts/Runtime.d.ts +13 -16
- package/dist/dts/Runtime.d.ts.map +1 -1
- package/dist/dts/RuntimeFlags.d.ts +10 -10
- package/dist/dts/RuntimeFlags.d.ts.map +1 -1
- package/dist/dts/STM.d.ts +303 -303
- package/dist/dts/STM.d.ts.map +1 -1
- package/dist/dts/Schedule.d.ts +19 -19
- package/dist/dts/Schedule.d.ts.map +1 -1
- package/dist/dts/Scope.d.ts +10 -10
- package/dist/dts/Scope.d.ts.map +1 -1
- package/dist/dts/ScopedCache.d.ts +14 -14
- package/dist/dts/ScopedCache.d.ts.map +1 -1
- package/dist/dts/ScopedRef.d.ts +5 -5
- package/dist/dts/ScopedRef.d.ts.map +1 -1
- package/dist/dts/SingleProducerAsyncInput.d.ts +8 -8
- package/dist/dts/SingleProducerAsyncInput.d.ts.map +1 -1
- package/dist/dts/Sink.d.ts +214 -205
- package/dist/dts/Sink.d.ts.map +1 -1
- package/dist/dts/Stream.d.ts +595 -592
- package/dist/dts/Stream.d.ts.map +1 -1
- package/dist/dts/StreamEmit.d.ts +5 -5
- package/dist/dts/StreamEmit.d.ts.map +1 -1
- package/dist/dts/Streamable.d.ts +2 -2
- package/dist/dts/Streamable.d.ts.map +1 -1
- package/dist/dts/SubscriptionRef.d.ts +41 -41
- package/dist/dts/SubscriptionRef.d.ts.map +1 -1
- package/dist/dts/Supervisor.d.ts +17 -17
- package/dist/dts/Supervisor.d.ts.map +1 -1
- package/dist/dts/SynchronizedRef.d.ts +41 -41
- package/dist/dts/SynchronizedRef.d.ts.map +1 -1
- package/dist/dts/TArray.d.ts +72 -72
- package/dist/dts/TArray.d.ts.map +1 -1
- package/dist/dts/TDeferred.d.ts +12 -12
- package/dist/dts/TDeferred.d.ts.map +1 -1
- package/dist/dts/TMap.d.ts +67 -67
- package/dist/dts/TMap.d.ts.map +1 -1
- package/dist/dts/TPriorityQueue.d.ts +23 -23
- package/dist/dts/TPriorityQueue.d.ts.map +1 -1
- package/dist/dts/TPubSub.d.ts +15 -15
- package/dist/dts/TPubSub.d.ts.map +1 -1
- package/dist/dts/TQueue.d.ts +40 -40
- package/dist/dts/TQueue.d.ts.map +1 -1
- package/dist/dts/TRandom.d.ts +13 -13
- package/dist/dts/TRandom.d.ts.map +1 -1
- package/dist/dts/TReentrantLock.d.ts +21 -21
- package/dist/dts/TReentrantLock.d.ts.map +1 -1
- package/dist/dts/TRef.d.ts +25 -25
- package/dist/dts/TRef.d.ts.map +1 -1
- package/dist/dts/TSemaphore.d.ts +15 -15
- package/dist/dts/TSemaphore.d.ts.map +1 -1
- package/dist/dts/TSet.d.ts +49 -49
- package/dist/dts/TSet.d.ts.map +1 -1
- package/dist/dts/Take.d.ts +41 -41
- package/dist/dts/Take.d.ts.map +1 -1
- package/dist/dts/TestAnnotation.d.ts +1 -3
- package/dist/dts/TestAnnotation.d.ts.map +1 -1
- package/dist/dts/TestAnnotations.d.ts +3 -3
- package/dist/dts/TestAnnotations.d.ts.map +1 -1
- package/dist/dts/TestClock.d.ts +18 -18
- package/dist/dts/TestClock.d.ts.map +1 -1
- package/dist/dts/TestConfig.d.ts.map +1 -1
- package/dist/dts/TestContext.d.ts +2 -2
- package/dist/dts/TestContext.d.ts.map +1 -1
- package/dist/dts/TestLive.d.ts +1 -1
- package/dist/dts/TestLive.d.ts.map +1 -1
- package/dist/dts/TestServices.d.ts +31 -31
- package/dist/dts/TestServices.d.ts.map +1 -1
- package/dist/dts/TestSized.d.ts +2 -2
- package/dist/dts/TestSized.d.ts.map +1 -1
- package/dist/dts/Tracer.d.ts +1 -1
- package/dist/dts/Utils.d.ts.map +1 -1
- package/dist/dts/index.d.ts +12 -2
- package/dist/dts/index.d.ts.map +1 -1
- package/dist/dts/internal/channel/channelExecutor.d.ts +1 -1
- package/dist/dts/internal/channel/channelExecutor.d.ts.map +1 -1
- package/dist/dts/internal/core-stream.d.ts +1 -1
- package/dist/dts/internal/core-stream.d.ts.map +1 -1
- package/dist/dts/internal/rateLimiter.d.ts +2 -0
- package/dist/dts/internal/rateLimiter.d.ts.map +1 -0
- package/dist/dts/internal/stm/stm.d.ts +6 -6
- package/dist/dts/internal/stm/stm.d.ts.map +1 -1
- package/dist/dts/internal/version.d.ts +1 -1
- package/dist/esm/Cause.js +13 -0
- package/dist/esm/Cause.js.map +1 -1
- package/dist/esm/Channel.js.map +1 -1
- package/dist/esm/Clock.js.map +1 -1
- package/dist/esm/Console.js.map +1 -1
- package/dist/esm/Context.js +22 -24
- package/dist/esm/Context.js.map +1 -1
- package/dist/esm/Data.js +4 -5
- package/dist/esm/Data.js.map +1 -1
- package/dist/esm/Deferred.js +1 -1
- package/dist/esm/Deferred.js.map +1 -1
- package/dist/esm/Effect.js +9 -9
- package/dist/esm/Effect.js.map +1 -1
- package/dist/esm/Effectable.js.map +1 -1
- package/dist/esm/Either.js.map +1 -1
- package/dist/esm/Exit.js +2 -2
- package/dist/esm/Exit.js.map +1 -1
- package/dist/esm/Fiber.js.map +1 -1
- package/dist/esm/FiberMap.js +3 -3
- package/dist/esm/FiberRef.js.map +1 -1
- package/dist/esm/FiberRefs.js.map +1 -1
- package/dist/esm/FiberSet.js +3 -3
- package/dist/esm/FiberSet.js.map +1 -1
- package/dist/esm/GroupBy.js.map +1 -1
- package/dist/esm/Layer.js.map +1 -1
- package/dist/esm/LogLevel.js.map +1 -1
- package/dist/esm/Logger.js.map +1 -1
- package/dist/esm/Metric.js.map +1 -1
- package/dist/esm/Number.js +18 -0
- package/dist/esm/Number.js.map +1 -1
- package/dist/esm/Option.js.map +1 -1
- package/dist/esm/Pool.js.map +1 -1
- package/dist/esm/PubSub.js.map +1 -1
- package/dist/esm/Queue.js.map +1 -1
- package/dist/esm/Random.js.map +1 -1
- package/dist/esm/RateLimiter.js +7 -0
- package/dist/esm/RateLimiter.js.map +1 -0
- package/dist/esm/ReadonlyRecord.js +44 -8
- package/dist/esm/ReadonlyRecord.js.map +1 -1
- package/dist/esm/Ref.js.map +1 -1
- package/dist/esm/Request.js.map +1 -1
- package/dist/esm/RequestResolver.js.map +1 -1
- package/dist/esm/Resource.js.map +1 -1
- package/dist/esm/Runtime.js +1 -4
- package/dist/esm/Runtime.js.map +1 -1
- package/dist/esm/RuntimeFlags.js.map +1 -1
- package/dist/esm/STM.js.map +1 -1
- package/dist/esm/Schedule.js.map +1 -1
- package/dist/esm/Scope.js.map +1 -1
- package/dist/esm/ScopedRef.js.map +1 -1
- package/dist/esm/SingleProducerAsyncInput.js.map +1 -1
- package/dist/esm/Sink.js.map +1 -1
- package/dist/esm/Stream.js.map +1 -1
- package/dist/esm/SubscriptionRef.js.map +1 -1
- package/dist/esm/Supervisor.js.map +1 -1
- package/dist/esm/SynchronizedRef.js.map +1 -1
- package/dist/esm/TArray.js.map +1 -1
- package/dist/esm/TDeferred.js.map +1 -1
- package/dist/esm/TMap.js.map +1 -1
- package/dist/esm/TPriorityQueue.js.map +1 -1
- package/dist/esm/TPubSub.js.map +1 -1
- package/dist/esm/TQueue.js.map +1 -1
- package/dist/esm/TRandom.js.map +1 -1
- package/dist/esm/TReentrantLock.js.map +1 -1
- package/dist/esm/TRef.js.map +1 -1
- package/dist/esm/TSemaphore.js.map +1 -1
- package/dist/esm/TSet.js.map +1 -1
- package/dist/esm/Take.js +6 -6
- package/dist/esm/Take.js.map +1 -1
- package/dist/esm/TestAnnotation.js +10 -13
- package/dist/esm/TestAnnotation.js.map +1 -1
- package/dist/esm/TestAnnotations.js +1 -1
- package/dist/esm/TestAnnotations.js.map +1 -1
- package/dist/esm/TestClock.js +1 -1
- package/dist/esm/TestClock.js.map +1 -1
- package/dist/esm/TestConfig.js +1 -1
- package/dist/esm/TestConfig.js.map +1 -1
- package/dist/esm/TestContext.js.map +1 -1
- package/dist/esm/TestLive.js +1 -1
- package/dist/esm/TestLive.js.map +1 -1
- package/dist/esm/TestServices.js.map +1 -1
- package/dist/esm/TestSized.js +1 -1
- package/dist/esm/TestSized.js.map +1 -1
- package/dist/esm/Utils.js +1 -1
- package/dist/esm/Utils.js.map +1 -1
- package/dist/esm/index.js +12 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/internal/cache.js.map +1 -1
- package/dist/esm/internal/channel/channelExecutor.js.map +1 -1
- package/dist/esm/internal/channel/mergeDecision.js +2 -6
- package/dist/esm/internal/channel/mergeDecision.js.map +1 -1
- package/dist/esm/internal/channel/singleProducerAsyncInput.js.map +1 -1
- package/dist/esm/internal/channel.js +1 -1
- package/dist/esm/internal/channel.js.map +1 -1
- package/dist/esm/internal/clock.js +1 -1
- package/dist/esm/internal/clock.js.map +1 -1
- package/dist/esm/internal/configProvider.js +2 -4
- package/dist/esm/internal/configProvider.js.map +1 -1
- package/dist/esm/internal/console.js.map +1 -1
- package/dist/esm/internal/context.js +28 -20
- package/dist/esm/internal/context.js.map +1 -1
- package/dist/esm/internal/core-effect.js +12 -26
- package/dist/esm/internal/core-effect.js.map +1 -1
- package/dist/esm/internal/core-stream.js.map +1 -1
- package/dist/esm/internal/core.js +57 -127
- package/dist/esm/internal/core.js.map +1 -1
- package/dist/esm/internal/data.js.map +1 -1
- package/dist/esm/internal/defaultServices/console.js +1 -1
- package/dist/esm/internal/defaultServices/console.js.map +1 -1
- package/dist/esm/internal/defaultServices.js.map +1 -1
- package/dist/esm/internal/deferred.js.map +1 -1
- package/dist/esm/internal/differ/contextPatch.js +9 -9
- package/dist/esm/internal/differ/contextPatch.js.map +1 -1
- package/dist/esm/internal/effect/circular.js +5 -8
- package/dist/esm/internal/effect/circular.js.map +1 -1
- package/dist/esm/internal/effectable.js +4 -4
- package/dist/esm/internal/effectable.js.map +1 -1
- package/dist/esm/internal/fiber.js +2 -6
- package/dist/esm/internal/fiber.js.map +1 -1
- package/dist/esm/internal/fiberRuntime.js +10 -19
- package/dist/esm/internal/fiberRuntime.js.map +1 -1
- package/dist/esm/internal/groupBy.js.map +1 -1
- package/dist/esm/internal/keyedPool.js.map +1 -1
- package/dist/esm/internal/layer/circular.js.map +1 -1
- package/dist/esm/internal/layer.js +3 -3
- package/dist/esm/internal/layer.js.map +1 -1
- package/dist/esm/internal/logSpan.js +3 -5
- package/dist/esm/internal/logSpan.js.map +1 -1
- package/dist/esm/internal/metric.js.map +1 -1
- package/dist/esm/internal/pool.js.map +1 -1
- package/dist/esm/internal/pubsub.js +1 -5
- package/dist/esm/internal/pubsub.js.map +1 -1
- package/dist/esm/internal/query.js.map +1 -1
- package/dist/esm/internal/queue.js.map +1 -1
- package/dist/esm/internal/random.js +1 -1
- package/dist/esm/internal/random.js.map +1 -1
- package/dist/esm/internal/rateLimiter.js +12 -0
- package/dist/esm/internal/rateLimiter.js.map +1 -0
- package/dist/esm/internal/ref.js.map +1 -1
- package/dist/esm/internal/reloadable.js +1 -9
- package/dist/esm/internal/reloadable.js.map +1 -1
- package/dist/esm/internal/runtime.js +0 -1
- package/dist/esm/internal/runtime.js.map +1 -1
- package/dist/esm/internal/schedule.js.map +1 -1
- package/dist/esm/internal/scopedCache.js.map +1 -1
- package/dist/esm/internal/scopedRef.js.map +1 -1
- package/dist/esm/internal/sink.js +7 -7
- package/dist/esm/internal/sink.js.map +1 -1
- package/dist/esm/internal/stm/core.js.map +1 -1
- package/dist/esm/internal/stm/stm/stmState.js.map +1 -1
- package/dist/esm/internal/stm/stm/tExit.js +2 -2
- package/dist/esm/internal/stm/stm/tExit.js.map +1 -1
- package/dist/esm/internal/stm/stm/tryCommit.js.map +1 -1
- package/dist/esm/internal/stm/stm.js.map +1 -1
- package/dist/esm/internal/stm/tArray.js.map +1 -1
- package/dist/esm/internal/stm/tDeferred.js +4 -2
- package/dist/esm/internal/stm/tDeferred.js.map +1 -1
- package/dist/esm/internal/stm/tMap.js.map +1 -1
- package/dist/esm/internal/stm/tPriorityQueue.js.map +1 -1
- package/dist/esm/internal/stm/tPubSub.js.map +1 -1
- package/dist/esm/internal/stm/tQueue.js.map +1 -1
- package/dist/esm/internal/stm/tRandom.js +1 -1
- package/dist/esm/internal/stm/tRandom.js.map +1 -1
- package/dist/esm/internal/stm/tReentrantLock.js.map +1 -1
- package/dist/esm/internal/stm/tRef.js.map +1 -1
- package/dist/esm/internal/stm/tSemaphore.js.map +1 -1
- package/dist/esm/internal/stm/tSet.js.map +1 -1
- package/dist/esm/internal/stream/debounceState.js.map +1 -1
- package/dist/esm/internal/stream/handoff.js.map +1 -1
- package/dist/esm/internal/stream/handoffSignal.js.map +1 -1
- package/dist/esm/internal/stream/pull.js.map +1 -1
- package/dist/esm/internal/stream.js +0 -2
- package/dist/esm/internal/stream.js.map +1 -1
- package/dist/esm/internal/subscriptionRef.js.map +1 -1
- package/dist/esm/internal/supervisor.js.map +1 -1
- package/dist/esm/internal/take.js +2 -2
- package/dist/esm/internal/take.js.map +1 -1
- package/dist/esm/internal/testing/sleep.js.map +1 -1
- package/dist/esm/internal/tracer.js +2 -2
- package/dist/esm/internal/tracer.js.map +1 -1
- package/dist/esm/internal/version.js +1 -1
- package/package.json +9 -1
- package/src/Cache.ts +20 -20
- package/src/Cause.ts +37 -13
- package/src/Channel.ts +802 -794
- package/src/Clock.ts +7 -7
- package/src/Config.ts +1 -1
- package/src/ConfigProvider.ts +6 -6
- package/src/Console.ts +44 -48
- package/src/Context.ts +52 -30
- package/src/Data.ts +38 -61
- package/src/Deferred.ts +39 -41
- package/src/Effect.ts +1187 -1206
- package/src/Effectable.ts +8 -8
- package/src/Either.ts +2 -3
- package/src/Exit.ts +88 -105
- package/src/Fiber.ts +77 -83
- package/src/FiberMap.ts +77 -77
- package/src/FiberRef.ts +28 -28
- package/src/FiberRefs.ts +1 -1
- package/src/FiberSet.ts +61 -62
- package/src/GroupBy.ts +8 -12
- package/src/KeyedPool.ts +22 -22
- package/src/Layer.ts +187 -181
- package/src/LogLevel.ts +7 -6
- package/src/Logger.ts +18 -18
- package/src/MergeDecision.ts +7 -7
- package/src/MergeState.ts +16 -16
- package/src/Metric.ts +39 -39
- package/src/MetricPolling.ts +6 -6
- package/src/Number.ts +19 -0
- package/src/Option.ts +2 -3
- package/src/Pool.ts +15 -16
- package/src/PubSub.ts +18 -18
- package/src/Queue.ts +43 -46
- package/src/Random.ts +13 -15
- package/src/RateLimiter.ts +37 -0
- package/src/ReadonlyRecord.ts +49 -8
- package/src/Ref.ts +25 -25
- package/src/Reloadable.ts +10 -10
- package/src/Request.ts +31 -31
- package/src/RequestBlock.ts +3 -3
- package/src/RequestResolver.ts +21 -21
- package/src/Resource.ts +13 -13
- package/src/Runtime.ts +16 -19
- package/src/RuntimeFlags.ts +10 -10
- package/src/STM.ts +361 -362
- package/src/Schedule.ts +19 -19
- package/src/Scheduler.ts +2 -2
- package/src/Scope.ts +14 -15
- package/src/ScopedCache.ts +14 -14
- package/src/ScopedRef.ts +7 -7
- package/src/SingleProducerAsyncInput.ts +8 -9
- package/src/Sink.ts +357 -381
- package/src/Stream.ts +935 -1033
- package/src/StreamEmit.ts +5 -5
- package/src/Streamable.ts +2 -2
- package/src/SubscriptionRef.ts +51 -51
- package/src/Supervisor.ts +26 -26
- package/src/SynchronizedRef.ts +44 -44
- package/src/TArray.ts +74 -74
- package/src/TDeferred.ts +14 -14
- package/src/TMap.ts +72 -72
- package/src/TPriorityQueue.ts +23 -24
- package/src/TPubSub.ts +15 -15
- package/src/TQueue.ts +40 -40
- package/src/TRandom.ts +13 -13
- package/src/TReentrantLock.ts +21 -21
- package/src/TRef.ts +25 -25
- package/src/TSemaphore.ts +15 -15
- package/src/TSet.ts +49 -49
- package/src/Take.ts +51 -51
- package/src/TestAnnotation.ts +6 -17
- package/src/TestAnnotations.ts +7 -9
- package/src/TestClock.ts +39 -45
- package/src/TestConfig.ts +1 -3
- package/src/TestContext.ts +3 -3
- package/src/TestLive.ts +3 -5
- package/src/TestServices.ts +45 -47
- package/src/TestSized.ts +5 -5
- package/src/Tracer.ts +1 -1
- package/src/Utils.ts +8 -10
- package/src/index.ts +13 -2
- package/src/internal/blockedRequests.ts +2 -2
- package/src/internal/cache.ts +38 -38
- package/src/internal/channel/channelExecutor.ts +65 -73
- package/src/internal/channel/channelState.ts +11 -11
- package/src/internal/channel/continuation.ts +10 -10
- package/src/internal/channel/mergeDecision.ts +14 -16
- package/src/internal/channel/mergeState.ts +12 -12
- package/src/internal/channel/singleProducerAsyncInput.ts +15 -17
- package/src/internal/channel/subexecutor.ts +7 -7
- package/src/internal/channel.ts +901 -980
- package/src/internal/clock.ts +6 -6
- package/src/internal/concurrency.ts +9 -9
- package/src/internal/configProvider.ts +29 -36
- package/src/internal/console.ts +12 -12
- package/src/internal/context.ts +32 -23
- package/src/internal/core-effect.ts +655 -616
- package/src/internal/core-stream.ts +317 -325
- package/src/internal/core.ts +856 -790
- package/src/internal/data.ts +2 -3
- package/src/internal/dataSource.ts +14 -14
- package/src/internal/defaultServices/console.ts +3 -1
- package/src/internal/defaultServices.ts +21 -21
- package/src/internal/deferred.ts +9 -9
- package/src/internal/differ/contextPatch.ts +17 -17
- package/src/internal/effect/circular.ts +154 -159
- package/src/internal/effectable.ts +7 -7
- package/src/internal/fiber.ts +55 -59
- package/src/internal/fiberRefs.ts +1 -1
- package/src/internal/fiberRuntime.ts +426 -463
- package/src/internal/groupBy.ts +59 -62
- package/src/internal/keyedPool.ts +37 -37
- package/src/internal/layer/circular.ts +37 -37
- package/src/internal/layer.ts +235 -240
- package/src/internal/logSpan.ts +3 -5
- package/src/internal/metric/polling.ts +5 -5
- package/src/internal/metric.ts +54 -55
- package/src/internal/pool.ts +72 -72
- package/src/internal/pubsub.ts +75 -84
- package/src/internal/query.ts +25 -27
- package/src/internal/queue.ts +65 -70
- package/src/internal/random.ts +9 -9
- package/src/internal/rateLimiter.ts +30 -0
- package/src/internal/ref.ts +24 -24
- package/src/internal/reloadable.ts +11 -31
- package/src/internal/request.ts +14 -14
- package/src/internal/resource.ts +8 -8
- package/src/internal/runtime.ts +21 -22
- package/src/internal/schedule.ts +131 -134
- package/src/internal/scopedCache.ts +35 -32
- package/src/internal/scopedRef.ts +14 -14
- package/src/internal/sink.ts +507 -565
- package/src/internal/stm/core.ts +101 -102
- package/src/internal/stm/stm/stmState.ts +10 -10
- package/src/internal/stm/stm/tExit.ts +18 -18
- package/src/internal/stm/stm/tryCommit.ts +5 -5
- package/src/internal/stm/stm.ts +363 -374
- package/src/internal/stm/tArray.ts +92 -92
- package/src/internal/stm/tDeferred.ts +16 -14
- package/src/internal/stm/tMap.ts +83 -84
- package/src/internal/stm/tPriorityQueue.ts +24 -25
- package/src/internal/stm/tPubSub.ts +37 -38
- package/src/internal/stm/tQueue.ts +44 -48
- package/src/internal/stm/tRandom.ts +18 -18
- package/src/internal/stm/tReentrantLock.ts +28 -28
- package/src/internal/stm/tRef.ts +25 -25
- package/src/internal/stm/tSemaphore.ts +16 -16
- package/src/internal/stm/tSet.ts +51 -52
- package/src/internal/stream/debounceState.ts +7 -7
- package/src/internal/stream/emit.ts +4 -4
- package/src/internal/stream/handoff.ts +19 -19
- package/src/internal/stream/handoffSignal.ts +4 -4
- package/src/internal/stream/pull.ts +10 -11
- package/src/internal/stream.ts +1770 -1788
- package/src/internal/subscriptionRef.ts +17 -17
- package/src/internal/supervisor.ts +49 -56
- package/src/internal/synchronizedRef.ts +27 -27
- package/src/internal/take.ts +61 -61
- package/src/internal/testing/sleep.ts +2 -2
- package/src/internal/testing/suspendedWarningData.ts +2 -2
- package/src/internal/testing/warningData.ts +2 -2
- package/src/internal/tracer.ts +2 -6
- package/src/internal/version.ts +1 -1
package/src/internal/queue.ts
CHANGED
|
@@ -71,9 +71,9 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
71
71
|
/** @internal */
|
|
72
72
|
readonly queue: Queue.BackingQueue<A>,
|
|
73
73
|
/** @internal */
|
|
74
|
-
readonly takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
74
|
+
readonly takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>,
|
|
75
75
|
/** @internal */
|
|
76
|
-
readonly shutdownHook: Deferred.Deferred<
|
|
76
|
+
readonly shutdownHook: Deferred.Deferred<void>,
|
|
77
77
|
/** @internal */
|
|
78
78
|
readonly shutdownFlag: MutableRef.MutableRef<boolean>,
|
|
79
79
|
/** @internal */
|
|
@@ -89,7 +89,7 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
89
89
|
return this.queue.capacity()
|
|
90
90
|
}
|
|
91
91
|
|
|
92
|
-
get size(): Effect.Effect<
|
|
92
|
+
get size(): Effect.Effect<number> {
|
|
93
93
|
return core.suspend(() => core.catchAll(this.unsafeSize(), () => core.interrupt))
|
|
94
94
|
}
|
|
95
95
|
|
|
@@ -104,17 +104,17 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
104
104
|
)
|
|
105
105
|
}
|
|
106
106
|
|
|
107
|
-
get isEmpty(): Effect.Effect<
|
|
107
|
+
get isEmpty(): Effect.Effect<boolean> {
|
|
108
108
|
return core.map(this.size, (size) => size <= 0)
|
|
109
109
|
}
|
|
110
110
|
|
|
111
|
-
get isFull(): Effect.Effect<
|
|
111
|
+
get isFull(): Effect.Effect<boolean> {
|
|
112
112
|
return core.map(this.size, (size) => size >= this.capacity())
|
|
113
113
|
}
|
|
114
114
|
|
|
115
|
-
get shutdown(): Effect.Effect<
|
|
115
|
+
get shutdown(): Effect.Effect<void> {
|
|
116
116
|
return core.uninterruptible(
|
|
117
|
-
core.withFiberRuntime
|
|
117
|
+
core.withFiberRuntime((state) => {
|
|
118
118
|
pipe(this.shutdownFlag, MutableRef.set(true))
|
|
119
119
|
return pipe(
|
|
120
120
|
fiberRuntime.forEachConcurrentDiscard(
|
|
@@ -131,11 +131,11 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
131
131
|
)
|
|
132
132
|
}
|
|
133
133
|
|
|
134
|
-
get isShutdown(): Effect.Effect<
|
|
134
|
+
get isShutdown(): Effect.Effect<boolean> {
|
|
135
135
|
return core.sync(() => MutableRef.get(this.shutdownFlag))
|
|
136
136
|
}
|
|
137
137
|
|
|
138
|
-
get awaitShutdown(): Effect.Effect<
|
|
138
|
+
get awaitShutdown(): Effect.Effect<void> {
|
|
139
139
|
return core.deferredAwait(this.shutdownHook)
|
|
140
140
|
}
|
|
141
141
|
|
|
@@ -171,7 +171,7 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
171
171
|
return succeeded
|
|
172
172
|
}
|
|
173
173
|
|
|
174
|
-
offer(value: A): Effect.Effect<
|
|
174
|
+
offer(value: A): Effect.Effect<boolean> {
|
|
175
175
|
return core.suspend(() => {
|
|
176
176
|
if (MutableRef.get(this.shutdownFlag)) {
|
|
177
177
|
return core.interrupt
|
|
@@ -203,7 +203,7 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
203
203
|
})
|
|
204
204
|
}
|
|
205
205
|
|
|
206
|
-
offerAll(iterable: Iterable<A>): Effect.Effect<
|
|
206
|
+
offerAll(iterable: Iterable<A>): Effect.Effect<boolean> {
|
|
207
207
|
return core.suspend(() => {
|
|
208
208
|
if (MutableRef.get(this.shutdownFlag)) {
|
|
209
209
|
return core.interrupt
|
|
@@ -230,8 +230,8 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
230
230
|
})
|
|
231
231
|
}
|
|
232
232
|
|
|
233
|
-
get take(): Effect.Effect<
|
|
234
|
-
return core.withFiberRuntime
|
|
233
|
+
get take(): Effect.Effect<A> {
|
|
234
|
+
return core.withFiberRuntime((state) => {
|
|
235
235
|
if (MutableRef.get(this.shutdownFlag)) {
|
|
236
236
|
return core.interrupt
|
|
237
237
|
}
|
|
@@ -244,7 +244,7 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
244
244
|
// - Try to take again in case a value was added since
|
|
245
245
|
// - Wait for the deferred to be completed
|
|
246
246
|
// - Clean up resources in case of interruption
|
|
247
|
-
const deferred = core.deferredUnsafeMake<
|
|
247
|
+
const deferred = core.deferredUnsafeMake<A>(state.id())
|
|
248
248
|
return pipe(
|
|
249
249
|
core.suspend(() => {
|
|
250
250
|
pipe(this.takers, MutableQueue.offer(deferred))
|
|
@@ -261,7 +261,7 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
261
261
|
})
|
|
262
262
|
}
|
|
263
263
|
|
|
264
|
-
get takeAll(): Effect.Effect<
|
|
264
|
+
get takeAll(): Effect.Effect<Chunk.Chunk<A>> {
|
|
265
265
|
return core.suspend(() => {
|
|
266
266
|
return MutableRef.get(this.shutdownFlag)
|
|
267
267
|
? core.interrupt
|
|
@@ -273,7 +273,7 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
273
273
|
})
|
|
274
274
|
}
|
|
275
275
|
|
|
276
|
-
takeUpTo(max: number): Effect.Effect<
|
|
276
|
+
takeUpTo(max: number): Effect.Effect<Chunk.Chunk<A>> {
|
|
277
277
|
return core.suspend(() =>
|
|
278
278
|
MutableRef.get(this.shutdownFlag)
|
|
279
279
|
? core.interrupt
|
|
@@ -285,7 +285,7 @@ class QueueImpl<in out A> implements Queue.Queue<A> {
|
|
|
285
285
|
)
|
|
286
286
|
}
|
|
287
287
|
|
|
288
|
-
takeBetween(min: number, max: number): Effect.Effect<
|
|
288
|
+
takeBetween(min: number, max: number): Effect.Effect<Chunk.Chunk<A>> {
|
|
289
289
|
return core.suspend(() =>
|
|
290
290
|
takeRemainderLoop(
|
|
291
291
|
this,
|
|
@@ -303,7 +303,7 @@ const takeRemainderLoop = <A>(
|
|
|
303
303
|
min: number,
|
|
304
304
|
max: number,
|
|
305
305
|
acc: Chunk.Chunk<A>
|
|
306
|
-
): Effect.Effect<
|
|
306
|
+
): Effect.Effect<Chunk.Chunk<A>> => {
|
|
307
307
|
if (max < min) {
|
|
308
308
|
return core.succeed(acc)
|
|
309
309
|
}
|
|
@@ -345,28 +345,28 @@ export const isEnqueue = (u: unknown): u is Queue.Enqueue<unknown> => hasPropert
|
|
|
345
345
|
export const isDequeue = (u: unknown): u is Queue.Dequeue<unknown> => hasProperty(u, DequeueTypeId)
|
|
346
346
|
|
|
347
347
|
/** @internal */
|
|
348
|
-
export const bounded = <A>(requestedCapacity: number): Effect.Effect<
|
|
348
|
+
export const bounded = <A>(requestedCapacity: number): Effect.Effect<Queue.Queue<A>> =>
|
|
349
349
|
pipe(
|
|
350
350
|
core.sync(() => MutableQueue.bounded<A>(requestedCapacity)),
|
|
351
351
|
core.flatMap((queue) => make(backingQueueFromMutableQueue(queue), backPressureStrategy()))
|
|
352
352
|
)
|
|
353
353
|
|
|
354
354
|
/** @internal */
|
|
355
|
-
export const dropping = <A>(requestedCapacity: number): Effect.Effect<
|
|
355
|
+
export const dropping = <A>(requestedCapacity: number): Effect.Effect<Queue.Queue<A>> =>
|
|
356
356
|
pipe(
|
|
357
357
|
core.sync(() => MutableQueue.bounded<A>(requestedCapacity)),
|
|
358
358
|
core.flatMap((queue) => make(backingQueueFromMutableQueue(queue), droppingStrategy()))
|
|
359
359
|
)
|
|
360
360
|
|
|
361
361
|
/** @internal */
|
|
362
|
-
export const sliding = <A>(requestedCapacity: number): Effect.Effect<
|
|
362
|
+
export const sliding = <A>(requestedCapacity: number): Effect.Effect<Queue.Queue<A>> =>
|
|
363
363
|
pipe(
|
|
364
364
|
core.sync(() => MutableQueue.bounded<A>(requestedCapacity)),
|
|
365
365
|
core.flatMap((queue) => make(backingQueueFromMutableQueue(queue), slidingStrategy()))
|
|
366
366
|
)
|
|
367
367
|
|
|
368
368
|
/** @internal */
|
|
369
|
-
export const unbounded = <A>(): Effect.Effect<
|
|
369
|
+
export const unbounded = <A>(): Effect.Effect<Queue.Queue<A>> =>
|
|
370
370
|
pipe(
|
|
371
371
|
core.sync(() => MutableQueue.unbounded<A>()),
|
|
372
372
|
core.flatMap((queue) => make(backingQueueFromMutableQueue(queue), droppingStrategy()))
|
|
@@ -375,8 +375,8 @@ export const unbounded = <A>(): Effect.Effect<never, never, Queue.Queue<A>> =>
|
|
|
375
375
|
/** @internal */
|
|
376
376
|
const unsafeMake = <A>(
|
|
377
377
|
queue: Queue.BackingQueue<A>,
|
|
378
|
-
takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
379
|
-
shutdownHook: Deferred.Deferred<
|
|
378
|
+
takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>,
|
|
379
|
+
shutdownHook: Deferred.Deferred<void>,
|
|
380
380
|
shutdownFlag: MutableRef.MutableRef<boolean>,
|
|
381
381
|
strategy: Queue.Strategy<A>
|
|
382
382
|
): Queue.Queue<A> => {
|
|
@@ -387,9 +387,9 @@ const unsafeMake = <A>(
|
|
|
387
387
|
export const make = <A>(
|
|
388
388
|
queue: Queue.BackingQueue<A>,
|
|
389
389
|
strategy: Queue.Strategy<A>
|
|
390
|
-
): Effect.Effect<
|
|
390
|
+
): Effect.Effect<Queue.Queue<A>> =>
|
|
391
391
|
pipe(
|
|
392
|
-
core.deferredMake<
|
|
392
|
+
core.deferredMake<void>(),
|
|
393
393
|
core.map((deferred) =>
|
|
394
394
|
unsafeMake(
|
|
395
395
|
queue,
|
|
@@ -433,32 +433,27 @@ export const backingQueueFromMutableQueue = <A>(mutable: MutableQueue.MutableQue
|
|
|
433
433
|
export const capacity = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): number => self.capacity()
|
|
434
434
|
|
|
435
435
|
/** @internal */
|
|
436
|
-
export const size = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<
|
|
436
|
+
export const size = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<number> => self.size
|
|
437
437
|
|
|
438
438
|
/** @internal */
|
|
439
|
-
export const isFull = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<
|
|
440
|
-
self.isFull
|
|
439
|
+
export const isFull = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<boolean> => self.isFull
|
|
441
440
|
|
|
442
441
|
/** @internal */
|
|
443
|
-
export const isEmpty = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<
|
|
444
|
-
self.isEmpty
|
|
442
|
+
export const isEmpty = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<boolean> => self.isEmpty
|
|
445
443
|
|
|
446
444
|
/** @internal */
|
|
447
|
-
export const isShutdown = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<
|
|
448
|
-
self.isShutdown
|
|
445
|
+
export const isShutdown = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<boolean> => self.isShutdown
|
|
449
446
|
|
|
450
447
|
/** @internal */
|
|
451
|
-
export const awaitShutdown = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<
|
|
452
|
-
self.awaitShutdown
|
|
448
|
+
export const awaitShutdown = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<void> => self.awaitShutdown
|
|
453
449
|
|
|
454
450
|
/** @internal */
|
|
455
|
-
export const shutdown = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<
|
|
456
|
-
self.shutdown
|
|
451
|
+
export const shutdown = <A>(self: Queue.Dequeue<A> | Queue.Enqueue<A>): Effect.Effect<void> => self.shutdown
|
|
457
452
|
|
|
458
453
|
/** @internal */
|
|
459
454
|
export const offer = dual<
|
|
460
|
-
<A>(value: A) => (self: Queue.Enqueue<A>) => Effect.Effect<
|
|
461
|
-
<A>(self: Queue.Enqueue<A>, value: A) => Effect.Effect<
|
|
455
|
+
<A>(value: A) => (self: Queue.Enqueue<A>) => Effect.Effect<boolean>,
|
|
456
|
+
<A>(self: Queue.Enqueue<A>, value: A) => Effect.Effect<boolean>
|
|
462
457
|
>(2, (self, value) => self.offer(value))
|
|
463
458
|
|
|
464
459
|
/** @internal */
|
|
@@ -471,39 +466,39 @@ export const unsafeOffer = dual<
|
|
|
471
466
|
export const offerAll = dual<
|
|
472
467
|
<A>(
|
|
473
468
|
iterable: Iterable<A>
|
|
474
|
-
) => (self: Queue.Enqueue<A>) => Effect.Effect<
|
|
469
|
+
) => (self: Queue.Enqueue<A>) => Effect.Effect<boolean>,
|
|
475
470
|
<A>(
|
|
476
471
|
self: Queue.Enqueue<A>,
|
|
477
472
|
iterable: Iterable<A>
|
|
478
|
-
) => Effect.Effect<
|
|
473
|
+
) => Effect.Effect<boolean>
|
|
479
474
|
>(2, (self, iterable) => self.offerAll(iterable))
|
|
480
475
|
|
|
481
476
|
/** @internal */
|
|
482
|
-
export const poll = <A>(self: Queue.Dequeue<A>): Effect.Effect<
|
|
477
|
+
export const poll = <A>(self: Queue.Dequeue<A>): Effect.Effect<Option.Option<A>> =>
|
|
483
478
|
core.map(self.takeUpTo(1), Chunk.head)
|
|
484
479
|
|
|
485
480
|
/** @internal */
|
|
486
|
-
export const take = <A>(self: Queue.Dequeue<A>): Effect.Effect<
|
|
481
|
+
export const take = <A>(self: Queue.Dequeue<A>): Effect.Effect<A> => self.take
|
|
487
482
|
|
|
488
483
|
/** @internal */
|
|
489
|
-
export const takeAll = <A>(self: Queue.Dequeue<A>): Effect.Effect<
|
|
484
|
+
export const takeAll = <A>(self: Queue.Dequeue<A>): Effect.Effect<Chunk.Chunk<A>> => self.takeAll
|
|
490
485
|
|
|
491
486
|
/** @internal */
|
|
492
487
|
export const takeUpTo = dual<
|
|
493
|
-
(max: number) => <A>(self: Queue.Dequeue<A>) => Effect.Effect<
|
|
494
|
-
<A>(self: Queue.Dequeue<A>, max: number) => Effect.Effect<
|
|
488
|
+
(max: number) => <A>(self: Queue.Dequeue<A>) => Effect.Effect<Chunk.Chunk<A>>,
|
|
489
|
+
<A>(self: Queue.Dequeue<A>, max: number) => Effect.Effect<Chunk.Chunk<A>>
|
|
495
490
|
>(2, (self, max) => self.takeUpTo(max))
|
|
496
491
|
|
|
497
492
|
/** @internal */
|
|
498
493
|
export const takeBetween = dual<
|
|
499
|
-
(min: number, max: number) => <A>(self: Queue.Dequeue<A>) => Effect.Effect<
|
|
500
|
-
<A>(self: Queue.Dequeue<A>, min: number, max: number) => Effect.Effect<
|
|
494
|
+
(min: number, max: number) => <A>(self: Queue.Dequeue<A>) => Effect.Effect<Chunk.Chunk<A>>,
|
|
495
|
+
<A>(self: Queue.Dequeue<A>, min: number, max: number) => Effect.Effect<Chunk.Chunk<A>>
|
|
501
496
|
>(3, (self, min, max) => self.takeBetween(min, max))
|
|
502
497
|
|
|
503
498
|
/** @internal */
|
|
504
499
|
export const takeN = dual<
|
|
505
|
-
(n: number) => <A>(self: Queue.Dequeue<A>) => Effect.Effect<
|
|
506
|
-
<A>(self: Queue.Dequeue<A>, n: number) => Effect.Effect<
|
|
500
|
+
(n: number) => <A>(self: Queue.Dequeue<A>) => Effect.Effect<Chunk.Chunk<A>>,
|
|
501
|
+
<A>(self: Queue.Dequeue<A>, n: number) => Effect.Effect<Chunk.Chunk<A>>
|
|
507
502
|
>(2, (self, n) => self.takeBetween(n, n))
|
|
508
503
|
|
|
509
504
|
// -----------------------------------------------------------------------------
|
|
@@ -523,13 +518,13 @@ export const slidingStrategy = <A>(): Queue.Strategy<A> => new SlidingStrategy()
|
|
|
523
518
|
class BackPressureStrategy<in out A> implements Queue.Strategy<A> {
|
|
524
519
|
readonly [QueueStrategyTypeId] = queueStrategyVariance
|
|
525
520
|
|
|
526
|
-
readonly putters = MutableQueue.unbounded<readonly [A, Deferred.Deferred<
|
|
521
|
+
readonly putters = MutableQueue.unbounded<readonly [A, Deferred.Deferred<boolean>, boolean]>()
|
|
527
522
|
|
|
528
523
|
surplusSize(): number {
|
|
529
524
|
return MutableQueue.length(this.putters)
|
|
530
525
|
}
|
|
531
526
|
|
|
532
|
-
onCompleteTakersWithEmptyQueue(takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
527
|
+
onCompleteTakersWithEmptyQueue(takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>): void {
|
|
533
528
|
while (!MutableQueue.isEmpty(this.putters) && !MutableQueue.isEmpty(takers)) {
|
|
534
529
|
const taker = MutableQueue.poll(takers, void 0)!
|
|
535
530
|
const putter = MutableQueue.poll(this.putters, void 0)!
|
|
@@ -540,7 +535,7 @@ class BackPressureStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
540
535
|
}
|
|
541
536
|
}
|
|
542
537
|
|
|
543
|
-
get shutdown(): Effect.Effect<
|
|
538
|
+
get shutdown(): Effect.Effect<void> {
|
|
544
539
|
return pipe(
|
|
545
540
|
core.fiberId,
|
|
546
541
|
core.flatMap((fiberId) =>
|
|
@@ -568,11 +563,11 @@ class BackPressureStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
568
563
|
handleSurplus(
|
|
569
564
|
iterable: Iterable<A>,
|
|
570
565
|
queue: Queue.BackingQueue<A>,
|
|
571
|
-
takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
566
|
+
takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>,
|
|
572
567
|
isShutdown: MutableRef.MutableRef<boolean>
|
|
573
|
-
): Effect.Effect<
|
|
574
|
-
return core.withFiberRuntime
|
|
575
|
-
const deferred = core.deferredUnsafeMake<
|
|
568
|
+
): Effect.Effect<boolean> {
|
|
569
|
+
return core.withFiberRuntime((state) => {
|
|
570
|
+
const deferred = core.deferredUnsafeMake<boolean>(state.id())
|
|
576
571
|
return pipe(
|
|
577
572
|
core.suspend(() => {
|
|
578
573
|
this.unsafeOffer(iterable, deferred)
|
|
@@ -587,7 +582,7 @@ class BackPressureStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
587
582
|
|
|
588
583
|
unsafeOnQueueEmptySpace(
|
|
589
584
|
queue: Queue.BackingQueue<A>,
|
|
590
|
-
takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
585
|
+
takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>
|
|
591
586
|
): void {
|
|
592
587
|
let keepPolling = true
|
|
593
588
|
while (keepPolling && (queue.capacity() === Number.POSITIVE_INFINITY || queue.length() < queue.capacity())) {
|
|
@@ -606,7 +601,7 @@ class BackPressureStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
606
601
|
}
|
|
607
602
|
}
|
|
608
603
|
|
|
609
|
-
unsafeOffer(iterable: Iterable<A>, deferred: Deferred.Deferred<
|
|
604
|
+
unsafeOffer(iterable: Iterable<A>, deferred: Deferred.Deferred<boolean>): void {
|
|
610
605
|
const stuff = Array.from(iterable)
|
|
611
606
|
for (let i = 0; i < stuff.length; i++) {
|
|
612
607
|
const value = stuff[i]
|
|
@@ -618,7 +613,7 @@ class BackPressureStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
618
613
|
}
|
|
619
614
|
}
|
|
620
615
|
|
|
621
|
-
unsafeRemove(deferred: Deferred.Deferred<
|
|
616
|
+
unsafeRemove(deferred: Deferred.Deferred<boolean>): void {
|
|
622
617
|
unsafeOfferAll(
|
|
623
618
|
this.putters,
|
|
624
619
|
pipe(unsafePollAll(this.putters), Chunk.filter(([, _]) => _ !== deferred))
|
|
@@ -634,7 +629,7 @@ class DroppingStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
634
629
|
return 0
|
|
635
630
|
}
|
|
636
631
|
|
|
637
|
-
get shutdown(): Effect.Effect<
|
|
632
|
+
get shutdown(): Effect.Effect<void> {
|
|
638
633
|
return core.unit
|
|
639
634
|
}
|
|
640
635
|
|
|
@@ -644,15 +639,15 @@ class DroppingStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
644
639
|
handleSurplus(
|
|
645
640
|
_iterable: Iterable<A>,
|
|
646
641
|
_queue: Queue.BackingQueue<A>,
|
|
647
|
-
_takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
642
|
+
_takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>,
|
|
648
643
|
_isShutdown: MutableRef.MutableRef<boolean>
|
|
649
|
-
): Effect.Effect<
|
|
644
|
+
): Effect.Effect<boolean> {
|
|
650
645
|
return core.succeed(false)
|
|
651
646
|
}
|
|
652
647
|
|
|
653
648
|
unsafeOnQueueEmptySpace(
|
|
654
649
|
_queue: Queue.BackingQueue<A>,
|
|
655
|
-
_takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
650
|
+
_takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>
|
|
656
651
|
): void {
|
|
657
652
|
//
|
|
658
653
|
}
|
|
@@ -666,7 +661,7 @@ class SlidingStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
666
661
|
return 0
|
|
667
662
|
}
|
|
668
663
|
|
|
669
|
-
get shutdown(): Effect.Effect<
|
|
664
|
+
get shutdown(): Effect.Effect<void> {
|
|
670
665
|
return core.unit
|
|
671
666
|
}
|
|
672
667
|
|
|
@@ -676,9 +671,9 @@ class SlidingStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
676
671
|
handleSurplus(
|
|
677
672
|
iterable: Iterable<A>,
|
|
678
673
|
queue: Queue.BackingQueue<A>,
|
|
679
|
-
takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
674
|
+
takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>,
|
|
680
675
|
_isShutdown: MutableRef.MutableRef<boolean>
|
|
681
|
-
): Effect.Effect<
|
|
676
|
+
): Effect.Effect<boolean> {
|
|
682
677
|
return core.sync(() => {
|
|
683
678
|
this.unsafeOffer(queue, iterable)
|
|
684
679
|
unsafeCompleteTakers(this, queue, takers)
|
|
@@ -688,7 +683,7 @@ class SlidingStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
688
683
|
|
|
689
684
|
unsafeOnQueueEmptySpace(
|
|
690
685
|
_queue: Queue.BackingQueue<A>,
|
|
691
|
-
_takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
686
|
+
_takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>
|
|
692
687
|
): void {
|
|
693
688
|
//
|
|
694
689
|
}
|
|
@@ -709,7 +704,7 @@ class SlidingStrategy<in out A> implements Queue.Strategy<A> {
|
|
|
709
704
|
}
|
|
710
705
|
|
|
711
706
|
/** @internal */
|
|
712
|
-
const unsafeCompleteDeferred = <A>(deferred: Deferred.Deferred<
|
|
707
|
+
const unsafeCompleteDeferred = <A>(deferred: Deferred.Deferred<A>, a: A): void => {
|
|
713
708
|
return core.deferredUnsafeDone(deferred, core.succeed(a))
|
|
714
709
|
}
|
|
715
710
|
|
|
@@ -740,7 +735,7 @@ export const unsafeRemove = <A>(queue: MutableQueue.MutableQueue<A>, a: A): void
|
|
|
740
735
|
export const unsafeCompleteTakers = <A>(
|
|
741
736
|
strategy: Queue.Strategy<A>,
|
|
742
737
|
queue: Queue.BackingQueue<A>,
|
|
743
|
-
takers: MutableQueue.MutableQueue<Deferred.Deferred<
|
|
738
|
+
takers: MutableQueue.MutableQueue<Deferred.Deferred<A>>
|
|
744
739
|
): void => {
|
|
745
740
|
// Check both a taker and an item are in the queue, starting with the taker
|
|
746
741
|
let keepPolling = true
|
package/src/internal/random.ts
CHANGED
|
@@ -15,7 +15,7 @@ export const RandomTypeId: Random.RandomTypeId = Symbol.for(
|
|
|
15
15
|
) as Random.RandomTypeId
|
|
16
16
|
|
|
17
17
|
/** @internal */
|
|
18
|
-
export const randomTag: Context.Tag<Random.Random, Random.Random> = Context.
|
|
18
|
+
export const randomTag: Context.Tag<Random.Random, Random.Random> = Context.GenericTag("effect/Random")
|
|
19
19
|
/** @internal */
|
|
20
20
|
class RandomImpl implements Random.Random {
|
|
21
21
|
readonly [RandomTypeId]: Random.RandomTypeId = RandomTypeId
|
|
@@ -26,35 +26,35 @@ class RandomImpl implements Random.Random {
|
|
|
26
26
|
this.PRNG = new PCGRandom.PCGRandom(seed)
|
|
27
27
|
}
|
|
28
28
|
|
|
29
|
-
get next(): Effect.Effect<
|
|
29
|
+
get next(): Effect.Effect<number> {
|
|
30
30
|
return core.sync(() => this.PRNG.number())
|
|
31
31
|
}
|
|
32
32
|
|
|
33
|
-
get nextBoolean(): Effect.Effect<
|
|
33
|
+
get nextBoolean(): Effect.Effect<boolean> {
|
|
34
34
|
return core.map(this.next, (n) => n > 0.5)
|
|
35
35
|
}
|
|
36
36
|
|
|
37
|
-
get nextInt(): Effect.Effect<
|
|
37
|
+
get nextInt(): Effect.Effect<number> {
|
|
38
38
|
return core.sync(() => this.PRNG.integer(Number.MAX_SAFE_INTEGER))
|
|
39
39
|
}
|
|
40
40
|
|
|
41
|
-
nextRange(min: number, max: number): Effect.Effect<
|
|
41
|
+
nextRange(min: number, max: number): Effect.Effect<number> {
|
|
42
42
|
return core.map(this.next, (n) => (max - min) * n + min)
|
|
43
43
|
}
|
|
44
44
|
|
|
45
|
-
nextIntBetween(min: number, max: number): Effect.Effect<
|
|
45
|
+
nextIntBetween(min: number, max: number): Effect.Effect<number> {
|
|
46
46
|
return core.sync(() => this.PRNG.integer(max - min) + min)
|
|
47
47
|
}
|
|
48
48
|
|
|
49
|
-
shuffle<A>(elements: Iterable<A>): Effect.Effect<
|
|
49
|
+
shuffle<A>(elements: Iterable<A>): Effect.Effect<Chunk.Chunk<A>> {
|
|
50
50
|
return shuffleWith(elements, (n) => this.nextIntBetween(0, n))
|
|
51
51
|
}
|
|
52
52
|
}
|
|
53
53
|
|
|
54
54
|
const shuffleWith = <A>(
|
|
55
55
|
elements: Iterable<A>,
|
|
56
|
-
nextIntBounded: (n: number) => Effect.Effect<
|
|
57
|
-
): Effect.Effect<
|
|
56
|
+
nextIntBounded: (n: number) => Effect.Effect<number>
|
|
57
|
+
): Effect.Effect<Chunk.Chunk<A>> => {
|
|
58
58
|
return core.suspend(() =>
|
|
59
59
|
pipe(
|
|
60
60
|
core.sync(() => Array.from(elements)),
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { DurationInput } from "../Duration.js"
|
|
2
|
+
import * as Effect from "../Effect.js"
|
|
3
|
+
import type { RateLimiter } from "../RateLimiter.js"
|
|
4
|
+
import type { Scope } from "../Scope.js"
|
|
5
|
+
import * as SynchronizedRef from "../SynchronizedRef.js"
|
|
6
|
+
|
|
7
|
+
/** @internal */
|
|
8
|
+
export const make = (limit: number, window: DurationInput): Effect.Effect<
|
|
9
|
+
RateLimiter,
|
|
10
|
+
never,
|
|
11
|
+
Scope
|
|
12
|
+
> =>
|
|
13
|
+
Effect.gen(function*(_) {
|
|
14
|
+
const scope = yield* _(Effect.scope)
|
|
15
|
+
const semaphore = yield* _(Effect.makeSemaphore(limit))
|
|
16
|
+
const ref = yield* _(SynchronizedRef.make(false))
|
|
17
|
+
const reset = SynchronizedRef.updateEffect(
|
|
18
|
+
ref,
|
|
19
|
+
(running) =>
|
|
20
|
+
running ? Effect.succeed(true) : Effect.sleep(window).pipe(
|
|
21
|
+
Effect.zipRight(SynchronizedRef.set(ref, false)),
|
|
22
|
+
Effect.zipRight(semaphore.releaseAll),
|
|
23
|
+
Effect.forkIn(scope),
|
|
24
|
+
Effect.interruptible,
|
|
25
|
+
Effect.as(true)
|
|
26
|
+
)
|
|
27
|
+
)
|
|
28
|
+
const take = Effect.zipRight(semaphore.take(1), reset)
|
|
29
|
+
return (effect) => Effect.zipRight(take, effect)
|
|
30
|
+
})
|
package/src/internal/ref.ts
CHANGED
|
@@ -18,7 +18,7 @@ export const refVariance = {
|
|
|
18
18
|
class RefImpl<in out A> implements Ref.Ref<A> {
|
|
19
19
|
readonly [RefTypeId] = refVariance
|
|
20
20
|
constructor(readonly ref: MutableRef.MutableRef<A>) {}
|
|
21
|
-
modify<B>(f: (a: A) => readonly [B, A]): Effect.Effect<
|
|
21
|
+
modify<B>(f: (a: A) => readonly [B, A]): Effect.Effect<B> {
|
|
22
22
|
return core.sync(() => {
|
|
23
23
|
const current = MutableRef.get(this.ref)
|
|
24
24
|
const [b, a] = f(current)
|
|
@@ -37,33 +37,33 @@ class RefImpl<in out A> implements Ref.Ref<A> {
|
|
|
37
37
|
export const unsafeMake = <A>(value: A): Ref.Ref<A> => new RefImpl(MutableRef.make(value))
|
|
38
38
|
|
|
39
39
|
/** @internal */
|
|
40
|
-
export const make = <A>(value: A): Effect.Effect<
|
|
40
|
+
export const make = <A>(value: A): Effect.Effect<Ref.Ref<A>> => core.sync(() => unsafeMake(value))
|
|
41
41
|
|
|
42
42
|
/** @internal */
|
|
43
43
|
export const get = <A>(self: Ref.Ref<A>) => self.modify((a) => [a, a])
|
|
44
44
|
|
|
45
45
|
/** @internal */
|
|
46
46
|
export const set = dual<
|
|
47
|
-
<A>(value: A) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
48
|
-
<A>(self: Ref.Ref<A>, value: A) => Effect.Effect<
|
|
47
|
+
<A>(value: A) => (self: Ref.Ref<A>) => Effect.Effect<void>,
|
|
48
|
+
<A>(self: Ref.Ref<A>, value: A) => Effect.Effect<void>
|
|
49
49
|
>(2, <A>(self: Ref.Ref<A>, value: A) => self.modify((): [void, A] => [void 0, value]))
|
|
50
50
|
|
|
51
51
|
/** @internal */
|
|
52
52
|
export const getAndSet = dual<
|
|
53
|
-
<A>(value: A) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
54
|
-
<A>(self: Ref.Ref<A>, value: A) => Effect.Effect<
|
|
53
|
+
<A>(value: A) => (self: Ref.Ref<A>) => Effect.Effect<A>,
|
|
54
|
+
<A>(self: Ref.Ref<A>, value: A) => Effect.Effect<A>
|
|
55
55
|
>(2, <A>(self: Ref.Ref<A>, value: A) => self.modify((a): [A, A] => [a, value]))
|
|
56
56
|
|
|
57
57
|
/** @internal */
|
|
58
58
|
export const getAndUpdate = dual<
|
|
59
|
-
<A>(f: (a: A) => A) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
60
|
-
<A>(self: Ref.Ref<A>, f: (a: A) => A) => Effect.Effect<
|
|
59
|
+
<A>(f: (a: A) => A) => (self: Ref.Ref<A>) => Effect.Effect<A>,
|
|
60
|
+
<A>(self: Ref.Ref<A>, f: (a: A) => A) => Effect.Effect<A>
|
|
61
61
|
>(2, <A>(self: Ref.Ref<A>, f: (a: A) => A) => self.modify((a): [A, A] => [a, f(a)]))
|
|
62
62
|
|
|
63
63
|
/** @internal */
|
|
64
64
|
export const getAndUpdateSome = dual<
|
|
65
|
-
<A>(pf: (a: A) => Option.Option<A>) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
66
|
-
<A>(self: Ref.Ref<A>, pf: (a: A) => Option.Option<A>) => Effect.Effect<
|
|
65
|
+
<A>(pf: (a: A) => Option.Option<A>) => (self: Ref.Ref<A>) => Effect.Effect<A>,
|
|
66
|
+
<A>(self: Ref.Ref<A>, pf: (a: A) => Option.Option<A>) => Effect.Effect<A>
|
|
67
67
|
>(2, <A>(self: Ref.Ref<A>, pf: (a: A) => Option.Option<A>) =>
|
|
68
68
|
self.modify((value): [A, A] => {
|
|
69
69
|
const option = pf(value)
|
|
@@ -79,14 +79,14 @@ export const getAndUpdateSome = dual<
|
|
|
79
79
|
|
|
80
80
|
/** @internal */
|
|
81
81
|
export const setAndGet = dual<
|
|
82
|
-
<A>(value: A) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
83
|
-
<A>(self: Ref.Ref<A>, value: A) => Effect.Effect<
|
|
82
|
+
<A>(value: A) => (self: Ref.Ref<A>) => Effect.Effect<A>,
|
|
83
|
+
<A>(self: Ref.Ref<A>, value: A) => Effect.Effect<A>
|
|
84
84
|
>(2, <A>(self: Ref.Ref<A>, value: A) => self.modify((): [A, A] => [value, value]))
|
|
85
85
|
|
|
86
86
|
/** @internal */
|
|
87
87
|
export const modify = dual<
|
|
88
|
-
<A, B>(f: (a: A) => readonly [B, A]) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
89
|
-
<A, B>(self: Ref.Ref<A>, f: (a: A) => readonly [B, A]) => Effect.Effect<
|
|
88
|
+
<A, B>(f: (a: A) => readonly [B, A]) => (self: Ref.Ref<A>) => Effect.Effect<B>,
|
|
89
|
+
<A, B>(self: Ref.Ref<A>, f: (a: A) => readonly [B, A]) => Effect.Effect<B>
|
|
90
90
|
>(2, (self, f) => self.modify(f))
|
|
91
91
|
|
|
92
92
|
/** @internal */
|
|
@@ -94,12 +94,12 @@ export const modifySome = dual<
|
|
|
94
94
|
<B, A>(
|
|
95
95
|
fallback: B,
|
|
96
96
|
pf: (a: A) => Option.Option<readonly [B, A]>
|
|
97
|
-
) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
97
|
+
) => (self: Ref.Ref<A>) => Effect.Effect<B>,
|
|
98
98
|
<A, B>(
|
|
99
99
|
self: Ref.Ref<A>,
|
|
100
100
|
fallback: B,
|
|
101
101
|
pf: (a: A) => Option.Option<readonly [B, A]>
|
|
102
|
-
) => Effect.Effect<
|
|
102
|
+
) => Effect.Effect<B>
|
|
103
103
|
>(3, (self, fallback, pf) =>
|
|
104
104
|
self.modify((value) => {
|
|
105
105
|
const option = pf(value)
|
|
@@ -115,14 +115,14 @@ export const modifySome = dual<
|
|
|
115
115
|
|
|
116
116
|
/** @internal */
|
|
117
117
|
export const update = dual<
|
|
118
|
-
<A>(f: (a: A) => A) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
119
|
-
<A>(self: Ref.Ref<A>, f: (a: A) => A) => Effect.Effect<
|
|
118
|
+
<A>(f: (a: A) => A) => (self: Ref.Ref<A>) => Effect.Effect<void>,
|
|
119
|
+
<A>(self: Ref.Ref<A>, f: (a: A) => A) => Effect.Effect<void>
|
|
120
120
|
>(2, <A>(self: Ref.Ref<A>, f: (a: A) => A) => self.modify((a): [void, A] => [void 0, f(a)]))
|
|
121
121
|
|
|
122
122
|
/** @internal */
|
|
123
123
|
export const updateAndGet = dual<
|
|
124
|
-
<A>(f: (a: A) => A) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
125
|
-
<A>(self: Ref.Ref<A>, f: (a: A) => A) => Effect.Effect<
|
|
124
|
+
<A>(f: (a: A) => A) => (self: Ref.Ref<A>) => Effect.Effect<A>,
|
|
125
|
+
<A>(self: Ref.Ref<A>, f: (a: A) => A) => Effect.Effect<A>
|
|
126
126
|
>(2, <A>(self: Ref.Ref<A>, f: (a: A) => A) =>
|
|
127
127
|
self.modify((a): [A, A] => {
|
|
128
128
|
const result = f(a)
|
|
@@ -131,8 +131,8 @@ export const updateAndGet = dual<
|
|
|
131
131
|
|
|
132
132
|
/** @internal */
|
|
133
133
|
export const updateSome = dual<
|
|
134
|
-
<A>(f: (a: A) => Option.Option<A>) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
135
|
-
<A>(self: Ref.Ref<A>, f: (a: A) => Option.Option<A>) => Effect.Effect<
|
|
134
|
+
<A>(f: (a: A) => Option.Option<A>) => (self: Ref.Ref<A>) => Effect.Effect<void>,
|
|
135
|
+
<A>(self: Ref.Ref<A>, f: (a: A) => Option.Option<A>) => Effect.Effect<void>
|
|
136
136
|
>(2, <A>(self: Ref.Ref<A>, f: (a: A) => Option.Option<A>) =>
|
|
137
137
|
self.modify(
|
|
138
138
|
(a): [void, A] => [
|
|
@@ -146,8 +146,8 @@ export const updateSome = dual<
|
|
|
146
146
|
|
|
147
147
|
/** @internal */
|
|
148
148
|
export const updateSomeAndGet = dual<
|
|
149
|
-
<A>(pf: (a: A) => Option.Option<A>) => (self: Ref.Ref<A>) => Effect.Effect<
|
|
150
|
-
<A>(self: Ref.Ref<A>, pf: (a: A) => Option.Option<A>) => Effect.Effect<
|
|
149
|
+
<A>(pf: (a: A) => Option.Option<A>) => (self: Ref.Ref<A>) => Effect.Effect<A>,
|
|
150
|
+
<A>(self: Ref.Ref<A>, pf: (a: A) => Option.Option<A>) => Effect.Effect<A>
|
|
151
151
|
>(2, <A>(self: Ref.Ref<A>, pf: (a: A) => Option.Option<A>) =>
|
|
152
152
|
self.modify((value): [A, A] => {
|
|
153
153
|
const option = pf(value)
|