effect 2.2.5 → 2.3.1
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 +47 -47
- 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 +47 -47
- 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/groupBy.ts
CHANGED
|
@@ -46,27 +46,27 @@ export const isGroupBy = (u: unknown): u is GroupBy.GroupBy<unknown, unknown, un
|
|
|
46
46
|
/** @internal */
|
|
47
47
|
export const evaluate = dual<
|
|
48
48
|
<K, E, V, R2, E2, A>(
|
|
49
|
-
f: (key: K, stream: Stream.Stream<
|
|
49
|
+
f: (key: K, stream: Stream.Stream<V, E>) => Stream.Stream<A, E2, R2>,
|
|
50
50
|
options?: {
|
|
51
51
|
readonly bufferSize?: number | undefined
|
|
52
52
|
}
|
|
53
|
-
) => <R>(self: GroupBy.GroupBy<R, E, K, V>) => Stream.Stream<
|
|
53
|
+
) => <R>(self: GroupBy.GroupBy<R, E, K, V>) => Stream.Stream<A, E | E2, R2 | R>,
|
|
54
54
|
<R, K, E, V, R2, E2, A>(
|
|
55
55
|
self: GroupBy.GroupBy<R, E, K, V>,
|
|
56
|
-
f: (key: K, stream: Stream.Stream<
|
|
56
|
+
f: (key: K, stream: Stream.Stream<V, E>) => Stream.Stream<A, E2, R2>,
|
|
57
57
|
options?: {
|
|
58
58
|
readonly bufferSize?: number | undefined
|
|
59
59
|
}
|
|
60
|
-
) => Stream.Stream<
|
|
60
|
+
) => Stream.Stream<A, E | E2, R2 | R>
|
|
61
61
|
>(
|
|
62
62
|
(args) => isGroupBy(args[0]),
|
|
63
63
|
<R, K, E, V, R2, E2, A>(
|
|
64
64
|
self: GroupBy.GroupBy<R, E, K, V>,
|
|
65
|
-
f: (key: K, stream: Stream.Stream<
|
|
65
|
+
f: (key: K, stream: Stream.Stream<V, E>) => Stream.Stream<A, E2, R2>,
|
|
66
66
|
options?: {
|
|
67
67
|
readonly bufferSize?: number | undefined
|
|
68
68
|
}
|
|
69
|
-
): Stream.Stream<
|
|
69
|
+
): Stream.Stream<A, E | E2, R2 | R> =>
|
|
70
70
|
stream.flatMap(
|
|
71
71
|
self.grouped,
|
|
72
72
|
([key, queue]) => f(key, stream.flattenTake(stream.fromQueue(queue, { shutdown: true }))),
|
|
@@ -113,7 +113,7 @@ export const first = dual<
|
|
|
113
113
|
|
|
114
114
|
/** @internal */
|
|
115
115
|
export const make = <R, E, K, V>(
|
|
116
|
-
grouped: Stream.Stream<
|
|
116
|
+
grouped: Stream.Stream<readonly [K, Queue.Dequeue<Take.Take<V, E>>], E, R>
|
|
117
117
|
): GroupBy.GroupBy<R, E, K, V> => ({
|
|
118
118
|
[GroupByTypeId]: groupByVariance,
|
|
119
119
|
pipe() {
|
|
@@ -127,14 +127,14 @@ export const make = <R, E, K, V>(
|
|
|
127
127
|
/** @internal */
|
|
128
128
|
export const groupBy = dual<
|
|
129
129
|
<A, R2, E2, K, V>(
|
|
130
|
-
f: (a: A) => Effect.Effect<
|
|
130
|
+
f: (a: A) => Effect.Effect<readonly [K, V], E2, R2>,
|
|
131
131
|
options?: {
|
|
132
132
|
readonly bufferSize?: number | undefined
|
|
133
133
|
}
|
|
134
|
-
) => <R, E>(self: Stream.Stream<
|
|
134
|
+
) => <R, E>(self: Stream.Stream<A, E, R>) => GroupBy.GroupBy<R2 | R, E2 | E, K, V>,
|
|
135
135
|
<R, E, A, R2, E2, K, V>(
|
|
136
|
-
self: Stream.Stream<
|
|
137
|
-
f: (a: A) => Effect.Effect<
|
|
136
|
+
self: Stream.Stream<A, E, R>,
|
|
137
|
+
f: (a: A) => Effect.Effect<readonly [K, V], E2, R2>,
|
|
138
138
|
options?: {
|
|
139
139
|
readonly bufferSize?: number | undefined
|
|
140
140
|
}
|
|
@@ -142,8 +142,8 @@ export const groupBy = dual<
|
|
|
142
142
|
>(
|
|
143
143
|
(args) => stream.isStream(args[0]),
|
|
144
144
|
<R, E, A, R2, E2, K, V>(
|
|
145
|
-
self: Stream.Stream<
|
|
146
|
-
f: (a: A) => Effect.Effect<
|
|
145
|
+
self: Stream.Stream<A, E, R>,
|
|
146
|
+
f: (a: A) => Effect.Effect<readonly [K, V], E2, R2>,
|
|
147
147
|
options?: {
|
|
148
148
|
readonly bufferSize?: number | undefined
|
|
149
149
|
}
|
|
@@ -152,13 +152,10 @@ export const groupBy = dual<
|
|
|
152
152
|
stream.unwrapScoped(
|
|
153
153
|
Effect.gen(function*($) {
|
|
154
154
|
const decider = yield* $(
|
|
155
|
-
Deferred.make<
|
|
156
|
-
never,
|
|
157
|
-
(key: K, value: V) => Effect.Effect<never, never, Predicate<number>>
|
|
158
|
-
>()
|
|
155
|
+
Deferred.make<(key: K, value: V) => Effect.Effect<Predicate<number>>>()
|
|
159
156
|
)
|
|
160
157
|
const output = yield* $(Effect.acquireRelease(
|
|
161
|
-
Queue.bounded<Exit.Exit<
|
|
158
|
+
Queue.bounded<Exit.Exit<readonly [K, Queue.Dequeue<Take.Take<V, E | E2>>], Option.Option<E | E2>>>(
|
|
162
159
|
options?.bufferSize ?? 16
|
|
163
160
|
),
|
|
164
161
|
(queue) => Queue.shutdown(queue)
|
|
@@ -213,50 +210,50 @@ export const groupBy = dual<
|
|
|
213
210
|
export const mapEffectOptions = dual<
|
|
214
211
|
{
|
|
215
212
|
<A, R2, E2, A2>(
|
|
216
|
-
f: (a: A) => Effect.Effect<
|
|
213
|
+
f: (a: A) => Effect.Effect<A2, E2, R2>,
|
|
217
214
|
options?: {
|
|
218
215
|
readonly concurrency?: number | "unbounded" | undefined
|
|
219
216
|
readonly unordered?: boolean | undefined
|
|
220
217
|
}
|
|
221
|
-
): <R, E>(self: Stream.Stream<
|
|
218
|
+
): <R, E>(self: Stream.Stream<A, E, R>) => Stream.Stream<A2, E2 | E, R2 | R>
|
|
222
219
|
<A, R2, E2, A2, K>(
|
|
223
|
-
f: (a: A) => Effect.Effect<
|
|
220
|
+
f: (a: A) => Effect.Effect<A2, E2, R2>,
|
|
224
221
|
options: {
|
|
225
222
|
readonly key: (a: A) => K
|
|
226
223
|
readonly bufferSize?: number | undefined
|
|
227
224
|
}
|
|
228
|
-
): <R, E>(self: Stream.Stream<
|
|
225
|
+
): <R, E>(self: Stream.Stream<A, E, R>) => Stream.Stream<A2, E2 | E, R2 | R>
|
|
229
226
|
},
|
|
230
227
|
{
|
|
231
228
|
<R, E, A, R2, E2, A2>(
|
|
232
|
-
self: Stream.Stream<
|
|
233
|
-
f: (a: A) => Effect.Effect<
|
|
229
|
+
self: Stream.Stream<A, E, R>,
|
|
230
|
+
f: (a: A) => Effect.Effect<A2, E2, R2>,
|
|
234
231
|
options?: {
|
|
235
232
|
readonly concurrency?: number | "unbounded" | undefined
|
|
236
233
|
readonly unordered?: boolean | undefined
|
|
237
234
|
}
|
|
238
|
-
): Stream.Stream<
|
|
235
|
+
): Stream.Stream<A2, E2 | E, R2 | R>
|
|
239
236
|
<R, E, A, R2, E2, A2, K>(
|
|
240
|
-
self: Stream.Stream<
|
|
241
|
-
f: (a: A) => Effect.Effect<
|
|
237
|
+
self: Stream.Stream<A, E, R>,
|
|
238
|
+
f: (a: A) => Effect.Effect<A2, E2, R2>,
|
|
242
239
|
options: {
|
|
243
240
|
readonly key: (a: A) => K
|
|
244
241
|
readonly bufferSize?: number | undefined
|
|
245
242
|
}
|
|
246
|
-
): Stream.Stream<
|
|
243
|
+
): Stream.Stream<A2, E2 | E, R2 | R>
|
|
247
244
|
}
|
|
248
245
|
>(
|
|
249
246
|
(args) => typeof args[0] !== "function",
|
|
250
247
|
(<R, E, A, R2, E2, A2, K>(
|
|
251
|
-
self: Stream.Stream<
|
|
252
|
-
f: (a: A) => Effect.Effect<
|
|
248
|
+
self: Stream.Stream<A, E, R>,
|
|
249
|
+
f: (a: A) => Effect.Effect<A2, E2, R2>,
|
|
253
250
|
options?: {
|
|
254
251
|
readonly key?: ((a: A) => K) | undefined
|
|
255
252
|
readonly concurrency?: number | "unbounded" | undefined
|
|
256
253
|
readonly unordered?: boolean | undefined
|
|
257
254
|
readonly bufferSize?: number | undefined
|
|
258
255
|
}
|
|
259
|
-
): Stream.Stream<
|
|
256
|
+
): Stream.Stream<A2, E2 | E, R2 | R> => {
|
|
260
257
|
if (options?.key) {
|
|
261
258
|
return evaluate(
|
|
262
259
|
groupByKey(self, options.key, { bufferSize: options.bufferSize }),
|
|
@@ -279,33 +276,33 @@ export const mapEffectOptions = dual<
|
|
|
279
276
|
export const bindEffect = dual<
|
|
280
277
|
<N extends string, K, R2, E2, A>(
|
|
281
278
|
tag: Exclude<N, keyof K>,
|
|
282
|
-
f: (_: K) => Effect.Effect<
|
|
279
|
+
f: (_: K) => Effect.Effect<A, E2, R2>,
|
|
283
280
|
options?: {
|
|
284
281
|
readonly concurrency?: number | "unbounded" | undefined
|
|
285
282
|
readonly bufferSize?: number | undefined
|
|
286
283
|
}
|
|
287
|
-
) => <R, E>(self: Stream.Stream<
|
|
288
|
-
|
|
284
|
+
) => <R, E>(self: Stream.Stream<K, E, R>) => Stream.Stream<
|
|
285
|
+
Effect.MergeRecord<K, { [k in N]: A }>,
|
|
289
286
|
E | E2,
|
|
290
|
-
|
|
287
|
+
R | R2
|
|
291
288
|
>,
|
|
292
289
|
<R, E, N extends string, K, R2, E2, A>(
|
|
293
|
-
self: Stream.Stream<
|
|
290
|
+
self: Stream.Stream<K, E, R>,
|
|
294
291
|
tag: Exclude<N, keyof K>,
|
|
295
|
-
f: (_: K) => Effect.Effect<
|
|
292
|
+
f: (_: K) => Effect.Effect<A, E2, R2>,
|
|
296
293
|
options?: {
|
|
297
294
|
readonly concurrency?: number | "unbounded" | undefined
|
|
298
295
|
readonly unordered?: boolean | undefined
|
|
299
296
|
}
|
|
300
297
|
) => Stream.Stream<
|
|
301
|
-
|
|
298
|
+
Effect.MergeRecord<K, { [k in N]: A }>,
|
|
302
299
|
E | E2,
|
|
303
|
-
|
|
300
|
+
R | R2
|
|
304
301
|
>
|
|
305
302
|
>((args) => typeof args[0] !== "string", <R, E, N extends string, K, R2, E2, A>(
|
|
306
|
-
self: Stream.Stream<
|
|
303
|
+
self: Stream.Stream<K, E, R>,
|
|
307
304
|
tag: Exclude<N, keyof K>,
|
|
308
|
-
f: (_: K) => Effect.Effect<
|
|
305
|
+
f: (_: K) => Effect.Effect<A, E2, R2>,
|
|
309
306
|
options?: {
|
|
310
307
|
readonly concurrency?: number | "unbounded" | undefined
|
|
311
308
|
readonly unordered?: boolean | undefined
|
|
@@ -334,7 +331,7 @@ class MapDequeue<in out A, out B> implements Queue.Dequeue<B> {
|
|
|
334
331
|
return Queue.capacity(this.dequeue)
|
|
335
332
|
}
|
|
336
333
|
|
|
337
|
-
get size(): Effect.Effect<
|
|
334
|
+
get size(): Effect.Effect<number> {
|
|
338
335
|
return Queue.size(this.dequeue)
|
|
339
336
|
}
|
|
340
337
|
|
|
@@ -342,7 +339,7 @@ class MapDequeue<in out A, out B> implements Queue.Dequeue<B> {
|
|
|
342
339
|
return this.dequeue.unsafeSize()
|
|
343
340
|
}
|
|
344
341
|
|
|
345
|
-
get awaitShutdown(): Effect.Effect<
|
|
342
|
+
get awaitShutdown(): Effect.Effect<void> {
|
|
346
343
|
return Queue.awaitShutdown(this.dequeue)
|
|
347
344
|
}
|
|
348
345
|
|
|
@@ -350,43 +347,43 @@ class MapDequeue<in out A, out B> implements Queue.Dequeue<B> {
|
|
|
350
347
|
return this.dequeue.isActive()
|
|
351
348
|
}
|
|
352
349
|
|
|
353
|
-
get isShutdown(): Effect.Effect<
|
|
350
|
+
get isShutdown(): Effect.Effect<boolean> {
|
|
354
351
|
return Queue.isShutdown(this.dequeue)
|
|
355
352
|
}
|
|
356
353
|
|
|
357
|
-
get shutdown(): Effect.Effect<
|
|
354
|
+
get shutdown(): Effect.Effect<void> {
|
|
358
355
|
return Queue.shutdown(this.dequeue)
|
|
359
356
|
}
|
|
360
357
|
|
|
361
|
-
get isFull(): Effect.Effect<
|
|
358
|
+
get isFull(): Effect.Effect<boolean> {
|
|
362
359
|
return Queue.isFull(this.dequeue)
|
|
363
360
|
}
|
|
364
361
|
|
|
365
|
-
get isEmpty(): Effect.Effect<
|
|
362
|
+
get isEmpty(): Effect.Effect<boolean> {
|
|
366
363
|
return Queue.isEmpty(this.dequeue)
|
|
367
364
|
}
|
|
368
365
|
|
|
369
|
-
get take(): Effect.Effect<
|
|
366
|
+
get take(): Effect.Effect<B> {
|
|
370
367
|
return pipe(Queue.take(this.dequeue), Effect.map((a) => this.f(a)))
|
|
371
368
|
}
|
|
372
369
|
|
|
373
|
-
get takeAll(): Effect.Effect<
|
|
370
|
+
get takeAll(): Effect.Effect<Chunk.Chunk<B>> {
|
|
374
371
|
return pipe(Queue.takeAll(this.dequeue), Effect.map(Chunk.map((a) => this.f(a))))
|
|
375
372
|
}
|
|
376
373
|
|
|
377
|
-
takeUpTo(max: number): Effect.Effect<
|
|
374
|
+
takeUpTo(max: number): Effect.Effect<Chunk.Chunk<B>> {
|
|
378
375
|
return pipe(Queue.takeUpTo(this.dequeue, max), Effect.map(Chunk.map((a) => this.f(a))))
|
|
379
376
|
}
|
|
380
377
|
|
|
381
|
-
takeBetween(min: number, max: number): Effect.Effect<
|
|
378
|
+
takeBetween(min: number, max: number): Effect.Effect<Chunk.Chunk<B>> {
|
|
382
379
|
return pipe(Queue.takeBetween(this.dequeue, min, max), Effect.map(Chunk.map((a) => this.f(a))))
|
|
383
380
|
}
|
|
384
381
|
|
|
385
|
-
takeN(n: number): Effect.Effect<
|
|
382
|
+
takeN(n: number): Effect.Effect<Chunk.Chunk<B>> {
|
|
386
383
|
return pipe(Queue.takeN(this.dequeue, n), Effect.map(Chunk.map((a) => this.f(a))))
|
|
387
384
|
}
|
|
388
385
|
|
|
389
|
-
poll(): Effect.Effect<
|
|
386
|
+
poll(): Effect.Effect<Option.Option<B>> {
|
|
390
387
|
return pipe(Queue.poll(this.dequeue), Effect.map(Option.map((a) => this.f(a))))
|
|
391
388
|
}
|
|
392
389
|
|
|
@@ -402,9 +399,9 @@ export const groupByKey = dual<
|
|
|
402
399
|
options?: {
|
|
403
400
|
readonly bufferSize?: number | undefined
|
|
404
401
|
}
|
|
405
|
-
) => <R, E>(self: Stream.Stream<
|
|
402
|
+
) => <R, E>(self: Stream.Stream<A, E, R>) => GroupBy.GroupBy<R, E, K, A>,
|
|
406
403
|
<R, E, A, K>(
|
|
407
|
-
self: Stream.Stream<
|
|
404
|
+
self: Stream.Stream<A, E, R>,
|
|
408
405
|
f: (a: A) => K,
|
|
409
406
|
options?: {
|
|
410
407
|
readonly bufferSize?: number | undefined
|
|
@@ -413,16 +410,16 @@ export const groupByKey = dual<
|
|
|
413
410
|
>(
|
|
414
411
|
(args) => typeof args[0] !== "function",
|
|
415
412
|
<R, E, A, K>(
|
|
416
|
-
self: Stream.Stream<
|
|
413
|
+
self: Stream.Stream<A, E, R>,
|
|
417
414
|
f: (a: A) => K,
|
|
418
415
|
options?: {
|
|
419
416
|
readonly bufferSize?: number | undefined
|
|
420
417
|
}
|
|
421
418
|
): GroupBy.GroupBy<R, E, K, A> => {
|
|
422
419
|
const loop = (
|
|
423
|
-
map: Map<K, Queue.Queue<Take.Take<
|
|
424
|
-
outerQueue: Queue.Queue<Take.Take<
|
|
425
|
-
): Channel.Channel<
|
|
420
|
+
map: Map<K, Queue.Queue<Take.Take<A, E>>>,
|
|
421
|
+
outerQueue: Queue.Queue<Take.Take<readonly [K, Queue.Queue<Take.Take<A, E>>], E>>
|
|
422
|
+
): Channel.Channel<never, Chunk.Chunk<A>, E, E, unknown, unknown, R> =>
|
|
426
423
|
core.readWithCause({
|
|
427
424
|
onInput: (input: Chunk.Chunk<A>) =>
|
|
428
425
|
core.flatMap(
|
|
@@ -431,7 +428,7 @@ export const groupByKey = dual<
|
|
|
431
428
|
const innerQueue = map.get(key)
|
|
432
429
|
if (innerQueue === undefined) {
|
|
433
430
|
return pipe(
|
|
434
|
-
Queue.bounded<Take.Take<
|
|
431
|
+
Queue.bounded<Take.Take<A, E>>(options?.bufferSize ?? 16),
|
|
435
432
|
Effect.flatMap((innerQueue) =>
|
|
436
433
|
pipe(
|
|
437
434
|
Effect.sync(() => {
|
|
@@ -486,11 +483,11 @@ export const groupByKey = dual<
|
|
|
486
483
|
})
|
|
487
484
|
return make(stream.unwrapScoped(
|
|
488
485
|
pipe(
|
|
489
|
-
Effect.sync(() => new Map<K, Queue.Queue<Take.Take<
|
|
486
|
+
Effect.sync(() => new Map<K, Queue.Queue<Take.Take<A, E>>>()),
|
|
490
487
|
Effect.flatMap((map) =>
|
|
491
488
|
pipe(
|
|
492
489
|
Effect.acquireRelease(
|
|
493
|
-
Queue.unbounded<Take.Take<
|
|
490
|
+
Queue.unbounded<Take.Take<readonly [K, Queue.Queue<Take.Take<A, E>>], E>>(),
|
|
494
491
|
(queue) => Queue.shutdown(queue)
|
|
495
492
|
),
|
|
496
493
|
Effect.flatMap((queue) =>
|
|
@@ -36,16 +36,16 @@ const keyedPoolVariance = {
|
|
|
36
36
|
_A: (_: any) => _
|
|
37
37
|
}
|
|
38
38
|
|
|
39
|
-
class KeyedPoolImpl<in K, out
|
|
39
|
+
class KeyedPoolImpl<in K, in out A, out E = never> implements KeyedPool.KeyedPool<K, A, E> {
|
|
40
40
|
readonly [KeyedPoolTypeId] = keyedPoolVariance
|
|
41
41
|
constructor(
|
|
42
|
-
readonly getOrCreatePool: (key: K) => Effect.Effect<
|
|
43
|
-
readonly activePools: Effect.Effect<
|
|
42
|
+
readonly getOrCreatePool: (key: K) => Effect.Effect<Pool.Pool<A, E>>,
|
|
43
|
+
readonly activePools: Effect.Effect<Array<Pool.Pool<A, E>>>
|
|
44
44
|
) {}
|
|
45
|
-
get(key: K): Effect.Effect<
|
|
45
|
+
get(key: K): Effect.Effect<A, E, Scope.Scope> {
|
|
46
46
|
return core.flatMap(this.getOrCreatePool(key), pool.get)
|
|
47
47
|
}
|
|
48
|
-
invalidate(item: A): Effect.Effect<
|
|
48
|
+
invalidate(item: A): Effect.Effect<void> {
|
|
49
49
|
return core.flatMap(this.activePools, core.forEachSequentialDiscard((pool) => pool.invalidate(item)))
|
|
50
50
|
}
|
|
51
51
|
pipe() {
|
|
@@ -53,12 +53,12 @@ class KeyedPoolImpl<in K, out E, in out A> implements KeyedPool.KeyedPool<K, E,
|
|
|
53
53
|
}
|
|
54
54
|
}
|
|
55
55
|
|
|
56
|
-
type MapValue<
|
|
56
|
+
type MapValue<A, E> = Complete<A, E> | Pending<A, E>
|
|
57
57
|
|
|
58
|
-
class Complete<out
|
|
58
|
+
class Complete<in out A, out E> implements Equal.Equal {
|
|
59
59
|
readonly _tag = "Complete"
|
|
60
60
|
readonly [KeyedPoolMapValueSymbol]: KeyedPoolMapValueSymbol = KeyedPoolMapValueSymbol
|
|
61
|
-
constructor(readonly pool: Pool.Pool<
|
|
61
|
+
constructor(readonly pool: Pool.Pool<A, E>) {}
|
|
62
62
|
[Hash.symbol](): number {
|
|
63
63
|
return pipe(
|
|
64
64
|
Hash.string("effect/KeyedPool/Complete"),
|
|
@@ -73,10 +73,10 @@ class Complete<out E, in out A> implements Equal.Equal {
|
|
|
73
73
|
const isComplete = (u: unknown): u is Complete<unknown, unknown> =>
|
|
74
74
|
Predicate.isTagged(u, "Complete") && KeyedPoolMapValueSymbol in u
|
|
75
75
|
|
|
76
|
-
class Pending<in out
|
|
76
|
+
class Pending<in out A, in out E> implements Equal.Equal {
|
|
77
77
|
readonly _tag = "Pending"
|
|
78
78
|
readonly [KeyedPoolMapValueSymbol]: KeyedPoolMapValueSymbol = KeyedPoolMapValueSymbol
|
|
79
|
-
constructor(readonly deferred: Deferred.Deferred<
|
|
79
|
+
constructor(readonly deferred: Deferred.Deferred<Pool.Pool<A, E>>) {}
|
|
80
80
|
[Hash.symbol](): number {
|
|
81
81
|
return pipe(
|
|
82
82
|
Hash.string("effect/KeyedPool/Pending"),
|
|
@@ -91,32 +91,32 @@ class Pending<in out E, in out A> implements Equal.Equal {
|
|
|
91
91
|
const isPending = (u: unknown): u is Pending<unknown, unknown> =>
|
|
92
92
|
Predicate.isTagged(u, "Pending") && KeyedPoolMapValueSymbol in u
|
|
93
93
|
|
|
94
|
-
const makeImpl = <K,
|
|
95
|
-
get: (key: K) => Effect.Effect<
|
|
94
|
+
const makeImpl = <K, A, E, R>(
|
|
95
|
+
get: (key: K) => Effect.Effect<A, E, R>,
|
|
96
96
|
min: (key: K) => number,
|
|
97
97
|
max: (key: K) => number,
|
|
98
98
|
timeToLive: (key: K) => Option.Option<Duration.Duration>
|
|
99
|
-
): Effect.Effect<
|
|
99
|
+
): Effect.Effect<KeyedPool.KeyedPool<K, A, E>, never, R | Scope.Scope> =>
|
|
100
100
|
pipe(
|
|
101
101
|
fiberRuntime.all([
|
|
102
102
|
core.context<R>(),
|
|
103
103
|
core.fiberId,
|
|
104
|
-
core.sync(() => MutableRef.make(HashMap.empty<K, MapValue<
|
|
104
|
+
core.sync(() => MutableRef.make(HashMap.empty<K, MapValue<A, E>>())),
|
|
105
105
|
fiberRuntime.scopeMake()
|
|
106
106
|
]),
|
|
107
107
|
core.map(([context, fiberId, map, scope]) => {
|
|
108
|
-
const getOrCreatePool = (key: K): Effect.Effect<
|
|
108
|
+
const getOrCreatePool = (key: K): Effect.Effect<Pool.Pool<A, E>> =>
|
|
109
109
|
core.suspend(() => {
|
|
110
|
-
let value: MapValue<
|
|
110
|
+
let value: MapValue<A, E> | undefined = Option.getOrUndefined(HashMap.get(MutableRef.get(map), key))
|
|
111
111
|
if (value === undefined) {
|
|
112
112
|
return core.uninterruptibleMask((restore) => {
|
|
113
|
-
const deferred = core.deferredUnsafeMake<
|
|
113
|
+
const deferred = core.deferredUnsafeMake<Pool.Pool<A, E>>(fiberId)
|
|
114
114
|
value = new Pending(deferred)
|
|
115
|
-
let previous: MapValue<
|
|
115
|
+
let previous: MapValue<A, E> | undefined = undefined
|
|
116
116
|
if (HashMap.has(MutableRef.get(map), key)) {
|
|
117
117
|
previous = Option.getOrUndefined(HashMap.get(MutableRef.get(map), key))
|
|
118
118
|
} else {
|
|
119
|
-
MutableRef.update(map, HashMap.set(key, value as MapValue<
|
|
119
|
+
MutableRef.update(map, HashMap.set(key, value as MapValue<A, E>))
|
|
120
120
|
}
|
|
121
121
|
if (previous === undefined) {
|
|
122
122
|
return pipe(
|
|
@@ -143,7 +143,7 @@ const makeImpl = <K, R, E, A>(
|
|
|
143
143
|
)
|
|
144
144
|
},
|
|
145
145
|
onSuccess: (pool) => {
|
|
146
|
-
MutableRef.update(map, HashMap.set(key, new Complete(pool) as MapValue<
|
|
146
|
+
MutableRef.update(map, HashMap.set(key, new Complete(pool) as MapValue<A, E>))
|
|
147
147
|
return core.as(
|
|
148
148
|
core.deferredSucceed(deferred, pool),
|
|
149
149
|
pool
|
|
@@ -171,7 +171,7 @@ const makeImpl = <K, R, E, A>(
|
|
|
171
171
|
}
|
|
172
172
|
}
|
|
173
173
|
})
|
|
174
|
-
const activePools: Effect.Effect<
|
|
174
|
+
const activePools: Effect.Effect<Array<Pool.Pool<A, E>>> = core.suspend(() =>
|
|
175
175
|
core.forEachSequential(Array.from(HashMap.values(MutableRef.get(map))), (value) => {
|
|
176
176
|
switch (value._tag) {
|
|
177
177
|
case "Complete": {
|
|
@@ -188,55 +188,55 @@ const makeImpl = <K, R, E, A>(
|
|
|
188
188
|
)
|
|
189
189
|
|
|
190
190
|
/** @internal */
|
|
191
|
-
export const make = <K,
|
|
191
|
+
export const make = <K, A, E, R>(
|
|
192
192
|
options: {
|
|
193
|
-
readonly acquire: (key: K) => Effect.Effect<
|
|
193
|
+
readonly acquire: (key: K) => Effect.Effect<A, E, R>
|
|
194
194
|
readonly size: number
|
|
195
195
|
}
|
|
196
|
-
): Effect.Effect<
|
|
196
|
+
): Effect.Effect<KeyedPool.KeyedPool<K, A, E>, never, R | Scope.Scope> =>
|
|
197
197
|
makeImpl(options.acquire, () => options.size, () => options.size, () => Option.none())
|
|
198
198
|
|
|
199
199
|
/** @internal */
|
|
200
|
-
export const makeWith = <K,
|
|
200
|
+
export const makeWith = <K, A, E, R>(
|
|
201
201
|
options: {
|
|
202
|
-
readonly acquire: (key: K) => Effect.Effect<
|
|
202
|
+
readonly acquire: (key: K) => Effect.Effect<A, E, R>
|
|
203
203
|
readonly size: (key: K) => number
|
|
204
204
|
}
|
|
205
|
-
): Effect.Effect<
|
|
205
|
+
): Effect.Effect<KeyedPool.KeyedPool<K, A, E>, never, R | Scope.Scope> =>
|
|
206
206
|
makeImpl(options.acquire, options.size, options.size, () => Option.none())
|
|
207
207
|
|
|
208
208
|
/** @internal */
|
|
209
|
-
export const makeWithTTL = <K,
|
|
209
|
+
export const makeWithTTL = <K, A, E, R>(
|
|
210
210
|
options: {
|
|
211
|
-
readonly acquire: (key: K) => Effect.Effect<
|
|
211
|
+
readonly acquire: (key: K) => Effect.Effect<A, E, R>
|
|
212
212
|
readonly min: (key: K) => number
|
|
213
213
|
readonly max: (key: K) => number
|
|
214
214
|
readonly timeToLive: Duration.DurationInput
|
|
215
215
|
}
|
|
216
|
-
): Effect.Effect<
|
|
216
|
+
): Effect.Effect<KeyedPool.KeyedPool<K, A, E>, never, R | Scope.Scope> => {
|
|
217
217
|
const timeToLive = Duration.decode(options.timeToLive)
|
|
218
218
|
return makeImpl(options.acquire, options.min, options.max, () => Option.some(timeToLive))
|
|
219
219
|
}
|
|
220
220
|
|
|
221
221
|
/** @internal */
|
|
222
|
-
export const makeWithTTLBy = <K,
|
|
222
|
+
export const makeWithTTLBy = <K, A, E, R>(
|
|
223
223
|
options: {
|
|
224
|
-
readonly acquire: (key: K) => Effect.Effect<
|
|
224
|
+
readonly acquire: (key: K) => Effect.Effect<A, E, R>
|
|
225
225
|
readonly min: (key: K) => number
|
|
226
226
|
readonly max: (key: K) => number
|
|
227
227
|
readonly timeToLive: (key: K) => Duration.DurationInput
|
|
228
228
|
}
|
|
229
|
-
): Effect.Effect<
|
|
229
|
+
): Effect.Effect<KeyedPool.KeyedPool<K, A, E>, never, R | Scope.Scope> =>
|
|
230
230
|
makeImpl(options.acquire, options.min, options.max, (key) => Option.some(Duration.decode(options.timeToLive(key))))
|
|
231
231
|
|
|
232
232
|
/** @internal */
|
|
233
233
|
export const get = dual<
|
|
234
|
-
<K>(key: K) => <
|
|
235
|
-
<K,
|
|
234
|
+
<K>(key: K) => <A, E>(self: KeyedPool.KeyedPool<K, A, E>) => Effect.Effect<A, E, Scope.Scope>,
|
|
235
|
+
<K, A, E>(self: KeyedPool.KeyedPool<K, A, E>, key: K) => Effect.Effect<A, E, Scope.Scope>
|
|
236
236
|
>(2, (self, key) => self.get(key))
|
|
237
237
|
|
|
238
238
|
/** @internal */
|
|
239
239
|
export const invalidate = dual<
|
|
240
|
-
<A>(item: A) => <K, E>(self: KeyedPool.KeyedPool<K,
|
|
241
|
-
<K,
|
|
240
|
+
<A>(item: A) => <K, E>(self: KeyedPool.KeyedPool<K, A, E>) => Effect.Effect<void>,
|
|
241
|
+
<K, A, E>(self: KeyedPool.KeyedPool<K, A, E>, item: A) => Effect.Effect<void>
|
|
242
242
|
>(2, (self, item) => self.invalidate(item))
|