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/LogLevel.ts
CHANGED
|
@@ -178,12 +178,13 @@ export const allLevels = core.allLogLevels
|
|
|
178
178
|
* @category utils
|
|
179
179
|
*/
|
|
180
180
|
export const locally: {
|
|
181
|
-
(self: LogLevel): <
|
|
182
|
-
<
|
|
183
|
-
} = dual
|
|
184
|
-
|
|
185
|
-
<
|
|
186
|
-
|
|
181
|
+
(self: LogLevel): <A, E, R>(use: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
182
|
+
<A, E, R>(use: Effect.Effect<A, E, R>, self: LogLevel): Effect.Effect<A, E, R>
|
|
183
|
+
} = dual(
|
|
184
|
+
2,
|
|
185
|
+
<A, E, R>(use: Effect.Effect<A, E, R>, self: LogLevel): Effect.Effect<A, E, R> =>
|
|
186
|
+
core.fiberRefLocally(use, core.currentLogLevel, self)
|
|
187
|
+
)
|
|
187
188
|
|
|
188
189
|
/**
|
|
189
190
|
* @since 2.0.0
|
package/src/Logger.ts
CHANGED
|
@@ -82,22 +82,22 @@ export const make: <Message, Output>(log: (options: Logger.Options<Message>) =>
|
|
|
82
82
|
* @since 2.0.0
|
|
83
83
|
* @category context
|
|
84
84
|
*/
|
|
85
|
-
export const add: <B>(logger: Logger<unknown, B>) => Layer.Layer<never
|
|
85
|
+
export const add: <B>(logger: Logger<unknown, B>) => Layer.Layer<never> = circular.addLogger
|
|
86
86
|
|
|
87
87
|
/**
|
|
88
88
|
* @since 2.0.0
|
|
89
89
|
* @category context
|
|
90
90
|
*/
|
|
91
|
-
export const addEffect: <
|
|
91
|
+
export const addEffect: <A, E, R>(effect: Effect<Logger<unknown, A>, E, R>) => Layer.Layer<never, E, R> =
|
|
92
92
|
circular.addLoggerEffect
|
|
93
93
|
|
|
94
94
|
/**
|
|
95
95
|
* @since 2.0.0
|
|
96
96
|
* @category context
|
|
97
97
|
*/
|
|
98
|
-
export const addScoped: <
|
|
99
|
-
effect: Effect<
|
|
100
|
-
) => Layer.Layer<Exclude<R, Scope
|
|
98
|
+
export const addScoped: <A, E, R>(
|
|
99
|
+
effect: Effect<Logger<unknown, A>, E, R>
|
|
100
|
+
) => Layer.Layer<never, E, Exclude<R, Scope>> = circular.addLoggerScoped
|
|
101
101
|
|
|
102
102
|
/**
|
|
103
103
|
* @since 2.0.0
|
|
@@ -170,15 +170,15 @@ export const none: Logger<unknown, void> = internal.none
|
|
|
170
170
|
* @since 2.0.0
|
|
171
171
|
* @category context
|
|
172
172
|
*/
|
|
173
|
-
export const remove: <A>(logger: Logger<unknown, A>) => Layer.Layer<never
|
|
173
|
+
export const remove: <A>(logger: Logger<unknown, A>) => Layer.Layer<never> = circular.removeLogger
|
|
174
174
|
|
|
175
175
|
/**
|
|
176
176
|
* @since 2.0.0
|
|
177
177
|
* @category context
|
|
178
178
|
*/
|
|
179
179
|
export const replace: {
|
|
180
|
-
<B>(that: Logger<unknown, B>): <A>(self: Logger<unknown, A>) => Layer.Layer<never
|
|
181
|
-
<A, B>(self: Logger<unknown, A>, that: Logger<unknown, B>): Layer.Layer<never
|
|
180
|
+
<B>(that: Logger<unknown, B>): <A>(self: Logger<unknown, A>) => Layer.Layer<never>
|
|
181
|
+
<A, B>(self: Logger<unknown, A>, that: Logger<unknown, B>): Layer.Layer<never>
|
|
182
182
|
} = circular.replaceLogger
|
|
183
183
|
|
|
184
184
|
/**
|
|
@@ -186,8 +186,8 @@ export const replace: {
|
|
|
186
186
|
* @category context
|
|
187
187
|
*/
|
|
188
188
|
export const replaceEffect: {
|
|
189
|
-
<R, E, B>(that: Effect<
|
|
190
|
-
<A, R, E, B>(self: Logger<unknown, A>, that: Effect<
|
|
189
|
+
<R, E, B>(that: Effect<Logger<unknown, B>, E, R>): <A>(self: Logger<unknown, A>) => Layer.Layer<never, E, R>
|
|
190
|
+
<A, R, E, B>(self: Logger<unknown, A>, that: Effect<Logger<unknown, B>, E, R>): Layer.Layer<never, E, R>
|
|
191
191
|
} = circular.replaceLoggerEffect
|
|
192
192
|
|
|
193
193
|
/**
|
|
@@ -196,12 +196,12 @@ export const replaceEffect: {
|
|
|
196
196
|
*/
|
|
197
197
|
export const replaceScoped: {
|
|
198
198
|
<R, E, B>(
|
|
199
|
-
that: Effect<
|
|
200
|
-
): <A>(self: Logger<unknown, A>) => Layer.Layer<Exclude<R, Scope
|
|
199
|
+
that: Effect<Logger<unknown, B>, E, R>
|
|
200
|
+
): <A>(self: Logger<unknown, A>) => Layer.Layer<never, E, Exclude<R, Scope>>
|
|
201
201
|
<A, R, E, B>(
|
|
202
202
|
self: Logger<unknown, A>,
|
|
203
|
-
that: Effect<
|
|
204
|
-
): Layer.Layer<Exclude<R, Scope
|
|
203
|
+
that: Effect<Logger<unknown, B>, E, R>
|
|
204
|
+
): Layer.Layer<never, E, Exclude<R, Scope>>
|
|
205
205
|
} = circular.replaceLoggerScoped
|
|
206
206
|
|
|
207
207
|
/**
|
|
@@ -236,8 +236,8 @@ export const test: {
|
|
|
236
236
|
* @category context
|
|
237
237
|
*/
|
|
238
238
|
export const withMinimumLogLevel: {
|
|
239
|
-
(level: LogLevel.LogLevel): <
|
|
240
|
-
<
|
|
239
|
+
(level: LogLevel.LogLevel): <A, E, R>(self: Effect<A, E, R>) => Effect<A, E, R>
|
|
240
|
+
<A, E, R>(self: Effect<A, E, R>, level: LogLevel.LogLevel): Effect<A, E, R>
|
|
241
241
|
} = circular.withMinimumLogLevel
|
|
242
242
|
|
|
243
243
|
/**
|
|
@@ -320,10 +320,10 @@ export const tracerLogger: Logger<unknown, void> = fiberRuntime.tracerLogger
|
|
|
320
320
|
* @since 2.0.0
|
|
321
321
|
* @category constructors
|
|
322
322
|
*/
|
|
323
|
-
export const logFmt: Layer.Layer<never
|
|
323
|
+
export const logFmt: Layer.Layer<never> = replace(fiberRuntime.defaultLogger, fiberRuntime.logFmtLogger)
|
|
324
324
|
|
|
325
325
|
/**
|
|
326
326
|
* @since 2.0.0
|
|
327
327
|
* @category context
|
|
328
328
|
*/
|
|
329
|
-
export const minimumLogLevel: (level: LogLevel.LogLevel) => Layer.Layer<never
|
|
329
|
+
export const minimumLogLevel: (level: LogLevel.LogLevel) => Layer.Layer<never> = circular.minimumLogLevel
|
package/src/MergeDecision.ts
CHANGED
|
@@ -47,21 +47,21 @@ export declare namespace MergeDecision {
|
|
|
47
47
|
* @since 2.0.0
|
|
48
48
|
* @category constructors
|
|
49
49
|
*/
|
|
50
|
-
export const Done: <
|
|
50
|
+
export const Done: <Z, E, R>(effect: Effect.Effect<Z, E, R>) => MergeDecision<R, unknown, unknown, E, Z> = internal.Done
|
|
51
51
|
|
|
52
52
|
/**
|
|
53
53
|
* @since 2.0.0
|
|
54
54
|
* @category constructors
|
|
55
55
|
*/
|
|
56
56
|
export const Await: <R, E0, Z0, E, Z>(
|
|
57
|
-
f: (exit: Exit.Exit<
|
|
57
|
+
f: (exit: Exit.Exit<Z0, E0>) => Effect.Effect<Z, E, R>
|
|
58
58
|
) => MergeDecision<R, E0, Z0, E, Z> = internal.Await
|
|
59
59
|
|
|
60
60
|
/**
|
|
61
61
|
* @since 2.0.0
|
|
62
62
|
* @category constructors
|
|
63
63
|
*/
|
|
64
|
-
export const AwaitConst: <R, E, Z>(effect: Effect.Effect<
|
|
64
|
+
export const AwaitConst: <R, E, Z>(effect: Effect.Effect<Z, E, R>) => MergeDecision<R, unknown, unknown, E, Z> =
|
|
65
65
|
internal.AwaitConst
|
|
66
66
|
|
|
67
67
|
/**
|
|
@@ -81,15 +81,15 @@ export const isMergeDecision: (u: unknown) => u is MergeDecision<unknown, unknow
|
|
|
81
81
|
export const match: {
|
|
82
82
|
<R, E0, Z0, E, Z, Z2>(
|
|
83
83
|
options: {
|
|
84
|
-
readonly onDone: (effect: Effect.Effect<
|
|
85
|
-
readonly onAwait: (f: (exit: Exit.Exit<
|
|
84
|
+
readonly onDone: (effect: Effect.Effect<Z, E, R>) => Z2
|
|
85
|
+
readonly onAwait: (f: (exit: Exit.Exit<Z0, E0>) => Effect.Effect<Z, E, R>) => Z2
|
|
86
86
|
}
|
|
87
87
|
): (self: MergeDecision<R, E0, Z0, E, Z>) => Z2
|
|
88
88
|
<R, E0, Z0, E, Z, Z2>(
|
|
89
89
|
self: MergeDecision<R, E0, Z0, E, Z>,
|
|
90
90
|
options: {
|
|
91
|
-
readonly onDone: (effect: Effect.Effect<
|
|
92
|
-
readonly onAwait: (f: (exit: Exit.Exit<
|
|
91
|
+
readonly onDone: (effect: Effect.Effect<Z, E, R>) => Z2
|
|
92
|
+
readonly onAwait: (f: (exit: Exit.Exit<Z0, E0>) => Effect.Effect<Z, E, R>) => Z2
|
|
93
93
|
}
|
|
94
94
|
): Z2
|
|
95
95
|
} = internal.match
|
package/src/MergeState.ts
CHANGED
|
@@ -49,8 +49,8 @@ export interface BothRunning<_Env, out Err, out Err1, _Err2, out Elem, out Done,
|
|
|
49
49
|
extends MergeState.Proto
|
|
50
50
|
{
|
|
51
51
|
readonly _tag: "BothRunning"
|
|
52
|
-
readonly left: Fiber.Fiber<
|
|
53
|
-
readonly right: Fiber.Fiber<
|
|
52
|
+
readonly left: Fiber.Fiber<Either.Either<Done, Elem>, Err>
|
|
53
|
+
readonly right: Fiber.Fiber<Either.Either<Done1, Elem>, Err1>
|
|
54
54
|
}
|
|
55
55
|
|
|
56
56
|
/**
|
|
@@ -61,7 +61,7 @@ export interface LeftDone<out Env, _Err, in Err1, out Err2, _Elem, _Done, in Don
|
|
|
61
61
|
extends MergeState.Proto
|
|
62
62
|
{
|
|
63
63
|
readonly _tag: "LeftDone"
|
|
64
|
-
f(exit: Exit.Exit<
|
|
64
|
+
f(exit: Exit.Exit<Done1, Err1>): Effect.Effect<Done2, Err2, Env>
|
|
65
65
|
}
|
|
66
66
|
|
|
67
67
|
/**
|
|
@@ -72,7 +72,7 @@ export interface RightDone<out Env, in Err, _Err1, out Err2, _Elem, in Done, _Do
|
|
|
72
72
|
extends MergeState.Proto
|
|
73
73
|
{
|
|
74
74
|
readonly _tag: "RightDone"
|
|
75
|
-
f(exit: Exit.Exit<
|
|
75
|
+
f(exit: Exit.Exit<Done, Err>): Effect.Effect<Done2, Err2, Env>
|
|
76
76
|
}
|
|
77
77
|
|
|
78
78
|
/**
|
|
@@ -80,8 +80,8 @@ export interface RightDone<out Env, in Err, _Err1, out Err2, _Elem, in Done, _Do
|
|
|
80
80
|
* @category constructors
|
|
81
81
|
*/
|
|
82
82
|
export const BothRunning: <Env, Err, Err1, Err2, Elem, Done, Done1, Done2>(
|
|
83
|
-
left: Fiber.Fiber<
|
|
84
|
-
right: Fiber.Fiber<
|
|
83
|
+
left: Fiber.Fiber<Either.Either<Done, Elem>, Err>,
|
|
84
|
+
right: Fiber.Fiber<Either.Either<Done1, Elem>, Err1>
|
|
85
85
|
) => MergeState<Env, Err, Err1, Err2, Elem, Done, Done1, Done2> = internal.BothRunning
|
|
86
86
|
|
|
87
87
|
/**
|
|
@@ -89,7 +89,7 @@ export const BothRunning: <Env, Err, Err1, Err2, Elem, Done, Done1, Done2>(
|
|
|
89
89
|
* @category constructors
|
|
90
90
|
*/
|
|
91
91
|
export const LeftDone: <Env, Err, Err1, Err2, Elem, Done, Done1, Done2>(
|
|
92
|
-
f: (exit: Exit.Exit<
|
|
92
|
+
f: (exit: Exit.Exit<Done1, Err1>) => Effect.Effect<Done2, Err2, Env>
|
|
93
93
|
) => MergeState<Env, Err, Err1, Err2, Elem, Done, Done1, Done2> = internal.LeftDone
|
|
94
94
|
|
|
95
95
|
/**
|
|
@@ -97,7 +97,7 @@ export const LeftDone: <Env, Err, Err1, Err2, Elem, Done, Done1, Done2>(
|
|
|
97
97
|
* @category constructors
|
|
98
98
|
*/
|
|
99
99
|
export const RightDone: <Env, Err, Err1, Err2, Elem, Done, Done1, Done2>(
|
|
100
|
-
f: (exit: Exit.Exit<
|
|
100
|
+
f: (exit: Exit.Exit<Done, Err>) => Effect.Effect<Done2, Err2, Env>
|
|
101
101
|
) => MergeState<Env, Err, Err1, Err2, Elem, Done, Done1, Done2> = internal.RightDone
|
|
102
102
|
|
|
103
103
|
/**
|
|
@@ -151,22 +151,22 @@ export const match: {
|
|
|
151
151
|
<Env, Err, Err1, Err2, Elem, Done, Done1, Done2, Z>(
|
|
152
152
|
options: {
|
|
153
153
|
readonly onBothRunning: (
|
|
154
|
-
left: Fiber.Fiber<
|
|
155
|
-
right: Fiber.Fiber<
|
|
154
|
+
left: Fiber.Fiber<Either.Either<Done, Elem>, Err>,
|
|
155
|
+
right: Fiber.Fiber<Either.Either<Done1, Elem>, Err1>
|
|
156
156
|
) => Z
|
|
157
|
-
readonly onLeftDone: (f: (exit: Exit.Exit<
|
|
158
|
-
readonly onRightDone: (f: (exit: Exit.Exit<
|
|
157
|
+
readonly onLeftDone: (f: (exit: Exit.Exit<Done1, Err1>) => Effect.Effect<Done2, Err2, Env>) => Z
|
|
158
|
+
readonly onRightDone: (f: (exit: Exit.Exit<Done, Err>) => Effect.Effect<Done2, Err2, Env>) => Z
|
|
159
159
|
}
|
|
160
160
|
): (self: MergeState<Env, Err, Err1, Err2, Elem, Done, Done1, Done2>) => Z
|
|
161
161
|
<Env, Err, Err1, Err2, Elem, Done, Done1, Done2, Z>(
|
|
162
162
|
self: MergeState<Env, Err, Err1, Err2, Elem, Done, Done1, Done2>,
|
|
163
163
|
options: {
|
|
164
164
|
readonly onBothRunning: (
|
|
165
|
-
left: Fiber.Fiber<
|
|
166
|
-
right: Fiber.Fiber<
|
|
165
|
+
left: Fiber.Fiber<Either.Either<Done, Elem>, Err>,
|
|
166
|
+
right: Fiber.Fiber<Either.Either<Done1, Elem>, Err1>
|
|
167
167
|
) => Z
|
|
168
|
-
readonly onLeftDone: (f: (exit: Exit.Exit<
|
|
169
|
-
readonly onRightDone: (f: (exit: Exit.Exit<
|
|
168
|
+
readonly onLeftDone: (f: (exit: Exit.Exit<Done1, Err1>) => Effect.Effect<Done2, Err2, Env>) => Z
|
|
169
|
+
readonly onRightDone: (f: (exit: Exit.Exit<Done, Err>) => Effect.Effect<Done2, Err2, Env>) => Z
|
|
170
170
|
}
|
|
171
171
|
): Z
|
|
172
172
|
} = internal.match
|
package/src/Metric.ts
CHANGED
|
@@ -57,7 +57,7 @@ export interface Metric<in out Type, in In, out Out> extends Metric.Variance<Typ
|
|
|
57
57
|
unsafeUpdate(input: In, extraTags: ReadonlyArray<MetricLabel.MetricLabel>): void
|
|
58
58
|
unsafeValue(extraTags: ReadonlyArray<MetricLabel.MetricLabel>): Out
|
|
59
59
|
register(): this
|
|
60
|
-
<R, E, A extends In>(effect: Effect.Effect<
|
|
60
|
+
<R, E, A extends In>(effect: Effect.Effect<A, E, R>): Effect.Effect<A, E, R>
|
|
61
61
|
}
|
|
62
62
|
|
|
63
63
|
/**
|
|
@@ -302,7 +302,7 @@ export const histogram: (
|
|
|
302
302
|
* @since 2.0.0
|
|
303
303
|
* @category aspects
|
|
304
304
|
*/
|
|
305
|
-
export const increment: (self: Metric.Counter<number> | Metric.Counter<bigint>) => Effect.Effect<
|
|
305
|
+
export const increment: (self: Metric.Counter<number> | Metric.Counter<bigint>) => Effect.Effect<void> =
|
|
306
306
|
internal.increment
|
|
307
307
|
|
|
308
308
|
/**
|
|
@@ -310,10 +310,10 @@ export const increment: (self: Metric.Counter<number> | Metric.Counter<bigint>)
|
|
|
310
310
|
* @category aspects
|
|
311
311
|
*/
|
|
312
312
|
export const incrementBy: {
|
|
313
|
-
(amount: number): (self: Metric.Counter<number>) => Effect.Effect<
|
|
314
|
-
(amount: bigint): (self: Metric.Counter<bigint>) => Effect.Effect<
|
|
315
|
-
(self: Metric.Counter<number>, amount: number): Effect.Effect<
|
|
316
|
-
(self: Metric.Counter<bigint>, amount: bigint): Effect.Effect<
|
|
313
|
+
(amount: number): (self: Metric.Counter<number>) => Effect.Effect<void>
|
|
314
|
+
(amount: bigint): (self: Metric.Counter<bigint>) => Effect.Effect<void>
|
|
315
|
+
(self: Metric.Counter<number>, amount: number): Effect.Effect<void>
|
|
316
|
+
(self: Metric.Counter<bigint>, amount: bigint): Effect.Effect<void>
|
|
317
317
|
} = internal.incrementBy
|
|
318
318
|
|
|
319
319
|
/**
|
|
@@ -343,10 +343,10 @@ export const mapType: {
|
|
|
343
343
|
* @category aspects
|
|
344
344
|
*/
|
|
345
345
|
export const set: {
|
|
346
|
-
(value: number): (self: Metric.Gauge<number>) => Effect.Effect<
|
|
347
|
-
(value: bigint): (self: Metric.Gauge<bigint>) => Effect.Effect<
|
|
348
|
-
(self: Metric.Gauge<number>, value: number): Effect.Effect<
|
|
349
|
-
(self: Metric.Gauge<bigint>, value: bigint): Effect.Effect<
|
|
346
|
+
(value: number): (self: Metric.Gauge<number>) => Effect.Effect<void>
|
|
347
|
+
(value: bigint): (self: Metric.Gauge<bigint>) => Effect.Effect<void>
|
|
348
|
+
(self: Metric.Gauge<number>, value: number): Effect.Effect<void>
|
|
349
|
+
(self: Metric.Gauge<bigint>, value: bigint): Effect.Effect<void>
|
|
350
350
|
} = internal.set
|
|
351
351
|
|
|
352
352
|
/**
|
|
@@ -355,7 +355,7 @@ export const set: {
|
|
|
355
355
|
* @since 2.0.0
|
|
356
356
|
* @category getters
|
|
357
357
|
*/
|
|
358
|
-
export const snapshot: Effect.Effect<
|
|
358
|
+
export const snapshot: Effect.Effect<ReadonlyArray<MetricPair.MetricPair.Untyped>> = internal.snapshot
|
|
359
359
|
|
|
360
360
|
/**
|
|
361
361
|
* Creates a metric that ignores input and produces constant output.
|
|
@@ -512,11 +512,11 @@ export const timerWithBoundaries: (
|
|
|
512
512
|
export const trackAll: {
|
|
513
513
|
<In>(
|
|
514
514
|
input: In
|
|
515
|
-
): <Type, Out>(self: Metric<Type, In, Out>) => <
|
|
515
|
+
): <Type, Out>(self: Metric<Type, In, Out>) => <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
516
516
|
<Type, In, Out>(
|
|
517
517
|
self: Metric<Type, In, Out>,
|
|
518
518
|
input: In
|
|
519
|
-
): <
|
|
519
|
+
): <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
520
520
|
} = internal.trackAll
|
|
521
521
|
|
|
522
522
|
/**
|
|
@@ -527,8 +527,8 @@ export const trackAll: {
|
|
|
527
527
|
* @category aspects
|
|
528
528
|
*/
|
|
529
529
|
export const trackDefect: {
|
|
530
|
-
<Type, Out>(metric: Metric<Type, unknown, Out>): <
|
|
531
|
-
<R, E, A, Type, Out>(self: Effect.Effect<
|
|
530
|
+
<Type, Out>(metric: Metric<Type, unknown, Out>): <A, E, R>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
531
|
+
<R, E, A, Type, Out>(self: Effect.Effect<A, E, R>, metric: Metric<Type, unknown, Out>): Effect.Effect<A, E, R>
|
|
532
532
|
} = internal.trackDefect
|
|
533
533
|
|
|
534
534
|
/**
|
|
@@ -543,12 +543,12 @@ export const trackDefectWith: {
|
|
|
543
543
|
<Type, In, Out>(
|
|
544
544
|
metric: Metric<Type, In, Out>,
|
|
545
545
|
f: (defect: unknown) => In
|
|
546
|
-
): <
|
|
546
|
+
): <A, E, R>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
547
547
|
<R, E, A, Type, In, Out>(
|
|
548
|
-
self: Effect.Effect<
|
|
548
|
+
self: Effect.Effect<A, E, R>,
|
|
549
549
|
metric: Metric<Type, In, Out>,
|
|
550
550
|
f: (defect: unknown) => In
|
|
551
|
-
): Effect.Effect<
|
|
551
|
+
): Effect.Effect<A, E, R>
|
|
552
552
|
} = internal.trackDefectWith
|
|
553
553
|
|
|
554
554
|
/**
|
|
@@ -562,11 +562,11 @@ export const trackDefectWith: {
|
|
|
562
562
|
export const trackDuration: {
|
|
563
563
|
<Type, Out>(
|
|
564
564
|
metric: Metric<Type, Duration.Duration, Out>
|
|
565
|
-
): <
|
|
565
|
+
): <A, E, R>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
566
566
|
<R, E, A, Type, Out>(
|
|
567
|
-
self: Effect.Effect<
|
|
567
|
+
self: Effect.Effect<A, E, R>,
|
|
568
568
|
metric: Metric<Type, Duration.Duration, Out>
|
|
569
|
-
): Effect.Effect<
|
|
569
|
+
): Effect.Effect<A, E, R>
|
|
570
570
|
} = internal.trackDuration
|
|
571
571
|
|
|
572
572
|
/**
|
|
@@ -581,12 +581,12 @@ export const trackDurationWith: {
|
|
|
581
581
|
<Type, In, Out>(
|
|
582
582
|
metric: Metric<Type, In, Out>,
|
|
583
583
|
f: (duration: Duration.Duration) => In
|
|
584
|
-
): <
|
|
584
|
+
): <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
585
585
|
<R, E, A, Type, In, Out>(
|
|
586
|
-
self: Effect.Effect<
|
|
586
|
+
self: Effect.Effect<A, E, R>,
|
|
587
587
|
metric: Metric<Type, In, Out>,
|
|
588
588
|
f: (duration: Duration.Duration) => In
|
|
589
|
-
): Effect.Effect<
|
|
589
|
+
): Effect.Effect<A, E, R>
|
|
590
590
|
} = internal.trackDurationWith
|
|
591
591
|
|
|
592
592
|
/**
|
|
@@ -599,11 +599,11 @@ export const trackDurationWith: {
|
|
|
599
599
|
export const trackError: {
|
|
600
600
|
<Type, In, Out>(
|
|
601
601
|
metric: Metric<Type, In, Out>
|
|
602
|
-
): <R, E extends In, A>(self: Effect.Effect<
|
|
602
|
+
): <R, E extends In, A>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
603
603
|
<R, E extends In, A, Type, In, Out>(
|
|
604
|
-
self: Effect.Effect<
|
|
604
|
+
self: Effect.Effect<A, E, R>,
|
|
605
605
|
metric: Metric<Type, In, Out>
|
|
606
|
-
): Effect.Effect<
|
|
606
|
+
): Effect.Effect<A, E, R>
|
|
607
607
|
} = internal.trackError
|
|
608
608
|
|
|
609
609
|
/**
|
|
@@ -618,12 +618,12 @@ export const trackErrorWith: {
|
|
|
618
618
|
<Type, In, Out, In2>(
|
|
619
619
|
metric: Metric<Type, In, Out>,
|
|
620
620
|
f: (error: In2) => In
|
|
621
|
-
): <R, E extends In2, A>(effect: Effect.Effect<
|
|
621
|
+
): <R, E extends In2, A>(effect: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
622
622
|
<R, E extends In2, A, Type, In, Out, In2>(
|
|
623
|
-
self: Effect.Effect<
|
|
623
|
+
self: Effect.Effect<A, E, R>,
|
|
624
624
|
metric: Metric<Type, In, Out>,
|
|
625
625
|
f: (error: In2) => In
|
|
626
|
-
): Effect.Effect<
|
|
626
|
+
): Effect.Effect<A, E, R>
|
|
627
627
|
} = internal.trackErrorWith
|
|
628
628
|
|
|
629
629
|
/**
|
|
@@ -636,11 +636,11 @@ export const trackErrorWith: {
|
|
|
636
636
|
export const trackSuccess: {
|
|
637
637
|
<Type, In, Out>(
|
|
638
638
|
metric: Metric<Type, In, Out>
|
|
639
|
-
): <R, E, A extends In>(self: Effect.Effect<
|
|
639
|
+
): <R, E, A extends In>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
640
640
|
<R, E, A extends In, Type, In, Out>(
|
|
641
|
-
self: Effect.Effect<
|
|
641
|
+
self: Effect.Effect<A, E, R>,
|
|
642
642
|
metric: Metric<Type, In, Out>
|
|
643
|
-
): Effect.Effect<
|
|
643
|
+
): Effect.Effect<A, E, R>
|
|
644
644
|
} = internal.trackSuccess
|
|
645
645
|
|
|
646
646
|
/**
|
|
@@ -655,12 +655,12 @@ export const trackSuccessWith: {
|
|
|
655
655
|
<Type, In, Out, In2>(
|
|
656
656
|
metric: Metric<Type, In, Out>,
|
|
657
657
|
f: (value: In2) => In
|
|
658
|
-
): <R, E, A extends In2>(self: Effect.Effect<
|
|
658
|
+
): <R, E, A extends In2>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>
|
|
659
659
|
<R, E, A extends In2, Type, In, Out, In2>(
|
|
660
|
-
self: Effect.Effect<
|
|
660
|
+
self: Effect.Effect<A, E, R>,
|
|
661
661
|
metric: Metric<Type, In, Out>,
|
|
662
662
|
f: (value: In2) => In
|
|
663
|
-
): Effect.Effect<
|
|
663
|
+
): Effect.Effect<A, E, R>
|
|
664
664
|
} = internal.trackSuccessWith
|
|
665
665
|
|
|
666
666
|
/**
|
|
@@ -672,8 +672,8 @@ export const trackSuccessWith: {
|
|
|
672
672
|
* @category utils
|
|
673
673
|
*/
|
|
674
674
|
export const update: {
|
|
675
|
-
<In>(input: In): <Type, Out>(self: Metric<Type, In, Out>) => Effect.Effect<
|
|
676
|
-
<Type, In, Out>(self: Metric<Type, In, Out>, input: In): Effect.Effect<
|
|
675
|
+
<In>(input: In): <Type, Out>(self: Metric<Type, In, Out>) => Effect.Effect<void>
|
|
676
|
+
<Type, In, Out>(self: Metric<Type, In, Out>, input: In): Effect.Effect<void>
|
|
677
677
|
} = internal.update
|
|
678
678
|
|
|
679
679
|
/**
|
|
@@ -682,7 +682,7 @@ export const update: {
|
|
|
682
682
|
* @since 2.0.0
|
|
683
683
|
* @category getters
|
|
684
684
|
*/
|
|
685
|
-
export const value: <Type, In, Out>(self: Metric<Type, In, Out>) => Effect.Effect<
|
|
685
|
+
export const value: <Type, In, Out>(self: Metric<Type, In, Out>) => Effect.Effect<Out> = internal.value
|
|
686
686
|
|
|
687
687
|
/**
|
|
688
688
|
* @since 2.0.0
|
package/src/MetricPolling.ts
CHANGED
|
@@ -37,7 +37,7 @@ export interface MetricPolling<in out Type, in out In, out R, out E, out Out> ex
|
|
|
37
37
|
/**
|
|
38
38
|
* An effect that polls a value that may be fed to the metric.
|
|
39
39
|
*/
|
|
40
|
-
readonly poll: Effect.Effect<
|
|
40
|
+
readonly poll: Effect.Effect<In, E, R>
|
|
41
41
|
}
|
|
42
42
|
|
|
43
43
|
/**
|
|
@@ -48,7 +48,7 @@ export interface MetricPolling<in out Type, in out In, out R, out E, out Out> ex
|
|
|
48
48
|
*/
|
|
49
49
|
export const make: <Type, In, Out, R, E>(
|
|
50
50
|
metric: Metric.Metric<Type, In, Out>,
|
|
51
|
-
poll: Effect.Effect<
|
|
51
|
+
poll: Effect.Effect<In, E, R>
|
|
52
52
|
) => MetricPolling<Type, In, R, E, Out> = internal.make
|
|
53
53
|
|
|
54
54
|
/**
|
|
@@ -74,11 +74,11 @@ export const launch: {
|
|
|
74
74
|
schedule: Schedule.Schedule<R2, unknown, A2>
|
|
75
75
|
): <Type, In, R, E, Out>(
|
|
76
76
|
self: MetricPolling<Type, In, R, E, Out>
|
|
77
|
-
) => Effect.Effect<
|
|
77
|
+
) => Effect.Effect<Fiber.Fiber<A2, E>, never, Scope.Scope | R2 | R>
|
|
78
78
|
<Type, In, R, E, Out, R2, A2>(
|
|
79
79
|
self: MetricPolling<Type, In, R, E, Out>,
|
|
80
80
|
schedule: Schedule.Schedule<R2, unknown, A2>
|
|
81
|
-
): Effect.Effect<Scope.Scope | R | R2
|
|
81
|
+
): Effect.Effect<Fiber.Fiber<A2, E>, never, Scope.Scope | R | R2>
|
|
82
82
|
} = internal.launch
|
|
83
83
|
|
|
84
84
|
/**
|
|
@@ -87,7 +87,7 @@ export const launch: {
|
|
|
87
87
|
* @since 2.0.0
|
|
88
88
|
* @category utils
|
|
89
89
|
*/
|
|
90
|
-
export const poll: <Type, In, R, E, Out>(self: MetricPolling<Type, In, R, E, Out>) => Effect.Effect<
|
|
90
|
+
export const poll: <Type, In, R, E, Out>(self: MetricPolling<Type, In, R, E, Out>) => Effect.Effect<In, E, R> =
|
|
91
91
|
internal.poll
|
|
92
92
|
|
|
93
93
|
/**
|
|
@@ -98,7 +98,7 @@ export const poll: <Type, In, R, E, Out>(self: MetricPolling<Type, In, R, E, Out
|
|
|
98
98
|
*/
|
|
99
99
|
export const pollAndUpdate: <Type, In, R, E, Out>(
|
|
100
100
|
self: MetricPolling<Type, In, R, E, Out>
|
|
101
|
-
) => Effect.Effect<
|
|
101
|
+
) => Effect.Effect<void, E, R> = internal.pollAndUpdate
|
|
102
102
|
|
|
103
103
|
/**
|
|
104
104
|
* Returns a new polling metric whose poll function will be retried with the
|
package/src/Number.ts
CHANGED
|
@@ -448,3 +448,22 @@ export const remainder: {
|
|
|
448
448
|
const divisorInt = parseInt(divisor.toFixed(decCount).replace(".", ""))
|
|
449
449
|
return (selfInt % divisorInt) / Math.pow(10, decCount)
|
|
450
450
|
})
|
|
451
|
+
|
|
452
|
+
/**
|
|
453
|
+
* Returns the next power of 2 from the given number.
|
|
454
|
+
*
|
|
455
|
+
* @param self - The number to find the next power of 2 from.
|
|
456
|
+
*
|
|
457
|
+
* @example
|
|
458
|
+
* import { nextPow2 } from "effect/Number"
|
|
459
|
+
*
|
|
460
|
+
* assert.deepStrictEqual(nextPow2(5), 8)
|
|
461
|
+
* assert.deepStrictEqual(nextPow2(17), 32)
|
|
462
|
+
*
|
|
463
|
+
* @category math
|
|
464
|
+
* @since 2.0.0
|
|
465
|
+
*/
|
|
466
|
+
export const nextPow2 = (n: number): number => {
|
|
467
|
+
const nextPow = Math.ceil(Math.log(n) / Math.log(2))
|
|
468
|
+
return Math.max(Math.pow(2, nextPow), 2)
|
|
469
|
+
}
|
package/src/Option.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* @since 2.0.0
|
|
3
3
|
*/
|
|
4
|
-
import type * as Data from "./Data.js"
|
|
5
4
|
import type { Either } from "./Either.js"
|
|
6
5
|
import * as Equal from "./Equal.js"
|
|
7
6
|
import * as Equivalence from "./Equivalence.js"
|
|
@@ -41,7 +40,7 @@ export type TypeId = typeof TypeId
|
|
|
41
40
|
* @category models
|
|
42
41
|
* @since 2.0.0
|
|
43
42
|
*/
|
|
44
|
-
export interface None<out A> extends
|
|
43
|
+
export interface None<out A> extends Pipeable, Inspectable {
|
|
45
44
|
readonly _tag: "None"
|
|
46
45
|
readonly _op: "None"
|
|
47
46
|
readonly [TypeId]: {
|
|
@@ -56,7 +55,7 @@ export interface None<out A> extends Data.Case, Pipeable, Inspectable {
|
|
|
56
55
|
* @category models
|
|
57
56
|
* @since 2.0.0
|
|
58
57
|
*/
|
|
59
|
-
export interface Some<out A> extends
|
|
58
|
+
export interface Some<out A> extends Pipeable, Inspectable {
|
|
60
59
|
readonly _tag: "Some"
|
|
61
60
|
readonly _op: "Some"
|
|
62
61
|
readonly value: A
|