effect 2.0.0-next.38 → 2.0.0-next.39
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/Bigint/dist/effect-Bigint.esm.js +346 -5
- package/Boolean/dist/effect-Boolean.esm.js +230 -5
- package/Brand/dist/effect-Brand.esm.js +204 -20
- package/Cache/dist/effect-Cache.cjs.dev.js +13 -13
- package/Cache/dist/effect-Cache.cjs.prod.js +13 -13
- package/Cache/dist/effect-Cache.esm.js +111 -74
- package/Cause/dist/effect-Cause.esm.js +668 -33
- package/Channel/dist/effect-Channel.cjs.dev.js +36 -36
- package/Channel/dist/effect-Channel.cjs.prod.js +36 -36
- package/Channel/dist/effect-Channel.esm.js +1001 -107
- package/ChannelChildExecutorDecision/dist/effect-ChannelChildExecutorDecision.esm.js +112 -3
- package/ChannelMergeDecision/dist/effect-ChannelMergeDecision.esm.js +60 -3
- package/ChannelMergeState/dist/effect-ChannelMergeState.esm.js +101 -3
- package/ChannelMergeStrategy/dist/effect-ChannelMergeStrategy.esm.js +84 -3
- package/ChannelSingleProducerAsyncInput/dist/effect-ChannelSingleProducerAsyncInput.cjs.dev.js +28 -28
- package/ChannelSingleProducerAsyncInput/dist/effect-ChannelSingleProducerAsyncInput.cjs.prod.js +28 -28
- package/ChannelSingleProducerAsyncInput/dist/effect-ChannelSingleProducerAsyncInput.esm.js +47 -91
- package/ChannelUpstreamPullRequest/dist/effect-ChannelUpstreamPullRequest.esm.js +84 -3
- package/ChannelUpstreamPullStrategy/dist/effect-ChannelUpstreamPullStrategy.esm.js +83 -3
- package/Chunk/dist/effect-Chunk.esm.js +1084 -20
- package/Clock/dist/effect-Clock.cjs.dev.js +3 -3
- package/Clock/dist/effect-Clock.cjs.prod.js +3 -3
- package/Clock/dist/effect-Clock.esm.js +78 -42
- package/Config/dist/effect-Config.esm.js +321 -37
- package/ConfigError/dist/effect-ConfigError.esm.js +185 -21
- package/ConfigProvider/dist/effect-ConfigProvider.esm.js +198 -39
- package/ConfigProviderPathPatch/dist/effect-ConfigProviderPathPatch.esm.js +70 -24
- package/ConfigSecret/dist/effect-ConfigSecret.esm.js +63 -22
- package/Console/dist/effect-Console.cjs.dev.js +22 -22
- package/Console/dist/effect-Console.cjs.prod.js +22 -22
- package/Console/dist/effect-Console.esm.js +154 -83
- package/Context/dist/effect-Context.esm.js +295 -17
- package/Data/dist/effect-Data.esm.js +163 -7
- package/DefaultServices/dist/effect-DefaultServices.cjs.dev.js +3 -3
- package/DefaultServices/dist/effect-DefaultServices.cjs.prod.js +3 -3
- package/DefaultServices/dist/effect-DefaultServices.esm.js +24 -42
- package/Deferred/dist/effect-Deferred.esm.js +206 -33
- package/Differ/dist/effect-Differ.esm.js +137 -26
- package/Duration/dist/effect-Duration.cjs.dev.js +2 -1
- package/Duration/dist/effect-Duration.cjs.mjs +1 -0
- package/Duration/dist/effect-Duration.cjs.prod.js +2 -1
- package/Duration/dist/effect-Duration.esm.js +438 -16
- package/Effect/dist/effect-Effect.cjs.dev.js +26 -26
- package/Effect/dist/effect-Effect.cjs.prod.js +26 -26
- package/Effect/dist/effect-Effect.esm.js +3093 -89
- package/Effectable/dist/effect-Effectable.esm.js +77 -10
- package/Either/dist/effect-Either.esm.js +442 -13
- package/Encoding/dist/effect-Encoding.esm.js +123 -14
- package/Equal/dist/effect-Equal.esm.js +57 -6
- package/Equivalence/dist/effect-Equivalence.esm.js +196 -2
- package/Error/dist/effect-Error.cjs.dev.js +27 -27
- package/Error/dist/effect-Error.cjs.prod.js +27 -27
- package/Error/dist/effect-Error.esm.js +47 -91
- package/ExecutionStrategy/dist/effect-ExecutionStrategy.esm.js +99 -2
- package/Exit/dist/effect-Exit.esm.js +332 -33
- package/Fiber/dist/effect-Fiber.cjs.dev.js +18 -18
- package/Fiber/dist/effect-Fiber.cjs.prod.js +18 -18
- package/Fiber/dist/effect-Fiber.esm.js +423 -77
- package/FiberId/dist/effect-FiberId.esm.js +161 -20
- package/FiberRef/dist/effect-FiberRef.cjs.dev.js +14 -14
- package/FiberRef/dist/effect-FiberRef.cjs.prod.js +14 -14
- package/FiberRef/dist/effect-FiberRef.esm.js +289 -75
- package/FiberRefs/dist/effect-FiberRefs.esm.js +107 -34
- package/FiberRefsPatch/dist/effect-FiberRefsPatch.esm.js +76 -35
- package/FiberStatus/dist/effect-FiberStatus.esm.js +89 -7
- package/Function/dist/effect-Function.esm.js +492 -1
- package/GlobalValue/dist/effect-GlobalValue.esm.js +20 -1
- package/GroupBy/dist/effect-GroupBy.cjs.dev.js +37 -37
- package/GroupBy/dist/effect-GroupBy.cjs.prod.js +37 -37
- package/GroupBy/dist/effect-GroupBy.esm.js +63 -108
- package/Hash/dist/effect-Hash.esm.js +164 -5
- package/HashMap/dist/effect-HashMap.esm.js +287 -18
- package/HashSet/dist/effect-HashSet.esm.js +227 -18
- package/Hub/dist/effect-Hub.cjs.dev.js +13 -13
- package/Hub/dist/effect-Hub.cjs.prod.js +13 -13
- package/Hub/dist/effect-Hub.esm.js +148 -74
- package/Inspectable/dist/effect-Inspectable.esm.js +38 -1
- package/KeyedPool/dist/effect-KeyedPool.cjs.dev.js +14 -14
- package/KeyedPool/dist/effect-KeyedPool.cjs.prod.js +14 -14
- package/KeyedPool/dist/effect-KeyedPool.esm.js +104 -75
- package/Layer/dist/effect-Layer.cjs.dev.js +22 -22
- package/Layer/dist/effect-Layer.cjs.prod.js +22 -22
- package/Layer/dist/effect-Layer.esm.js +557 -83
- package/List/dist/effect-List.esm.js +816 -21
- package/LogLevel/dist/effect-LogLevel.esm.js +202 -33
- package/LogSpan/dist/effect-LogSpan.esm.js +24 -1
- package/Logger/dist/effect-Logger.cjs.dev.js +24 -24
- package/Logger/dist/effect-Logger.cjs.prod.js +24 -24
- package/Logger/dist/effect-Logger.esm.js +198 -85
- package/Metric/dist/effect-Metric.cjs.dev.js +12 -12
- package/Metric/dist/effect-Metric.cjs.prod.js +12 -12
- package/Metric/dist/effect-Metric.esm.js +395 -71
- package/MetricBoundaries/dist/effect-MetricBoundaries.esm.js +52 -22
- package/MetricHook/dist/effect-MetricHook.cjs.dev.js +3 -3
- package/MetricHook/dist/effect-MetricHook.cjs.prod.js +3 -3
- package/MetricHook/dist/effect-MetricHook.esm.js +68 -27
- package/MetricKey/dist/effect-MetricKey.cjs.dev.js +4 -4
- package/MetricKey/dist/effect-MetricKey.cjs.prod.js +4 -4
- package/MetricKey/dist/effect-MetricKey.esm.js +104 -23
- package/MetricKeyType/dist/effect-MetricKeyType.cjs.dev.js +3 -3
- package/MetricKeyType/dist/effect-MetricKeyType.cjs.prod.js +3 -3
- package/MetricKeyType/dist/effect-MetricKeyType.esm.js +147 -18
- package/MetricLabel/dist/effect-MetricLabel.esm.js +41 -9
- package/MetricPair/dist/effect-MetricPair.esm.js +38 -3
- package/MetricPolling/dist/effect-MetricPolling.cjs.dev.js +18 -18
- package/MetricPolling/dist/effect-MetricPolling.cjs.prod.js +18 -18
- package/MetricPolling/dist/effect-MetricPolling.esm.js +84 -77
- package/MetricRegistry/dist/effect-MetricRegistry.cjs.dev.js +5 -5
- package/MetricRegistry/dist/effect-MetricRegistry.cjs.prod.js +5 -5
- package/MetricRegistry/dist/effect-MetricRegistry.esm.js +28 -33
- package/MetricState/dist/effect-MetricState.esm.js +151 -9
- package/MutableHashMap/dist/effect-MutableHashMap.esm.js +128 -20
- package/MutableHashSet/dist/effect-MutableHashSet.esm.js +90 -21
- package/MutableList/dist/effect-MutableList.esm.js +264 -4
- package/MutableQueue/dist/effect-MutableQueue.esm.js +187 -22
- package/MutableRef/dist/effect-MutableRef.esm.js +156 -9
- package/NonEmptyIterable/dist/effect-NonEmptyIterable.esm.js +28 -1
- package/Number/dist/effect-Number.esm.js +369 -5
- package/Option/dist/effect-Option.esm.js +1071 -15
- package/Order/dist/effect-Order.esm.js +263 -2
- package/Ordering/dist/effect-Ordering.esm.js +88 -2
- package/Pipeable/dist/effect-Pipeable.esm.js +44 -1
- package/Pool/dist/effect-Pool.cjs.dev.js +14 -14
- package/Pool/dist/effect-Pool.cjs.prod.js +14 -14
- package/Pool/dist/effect-Pool.esm.js +104 -75
- package/Predicate/dist/effect-Predicate.esm.js +634 -2
- package/Queue/dist/effect-Queue.cjs.dev.js +13 -13
- package/Queue/dist/effect-Queue.cjs.prod.js +13 -13
- package/Queue/dist/effect-Queue.esm.js +328 -74
- package/Random/dist/effect-Random.cjs.dev.js +3 -3
- package/Random/dist/effect-Random.cjs.prod.js +3 -3
- package/Random/dist/effect-Random.esm.js +83 -42
- package/ReadonlyArray/dist/effect-ReadonlyArray.esm.js +1445 -19
- package/ReadonlyRecord/dist/effect-ReadonlyRecord.esm.js +518 -17
- package/RedBlackTree/dist/effect-RedBlackTree.esm.js +314 -22
- package/Ref/dist/effect-Ref.esm.js +111 -33
- package/Reloadable/dist/effect-Reloadable.cjs.dev.js +23 -23
- package/Reloadable/dist/effect-Reloadable.cjs.prod.js +23 -23
- package/Reloadable/dist/effect-Reloadable.esm.js +88 -84
- package/Request/dist/effect-Request.cjs.dev.js +13 -13
- package/Request/dist/effect-Request.cjs.prod.js +13 -13
- package/Request/dist/effect-Request.esm.js +160 -74
- package/RequestBlock/dist/effect-RequestBlock.cjs.dev.js +28 -28
- package/RequestBlock/dist/effect-RequestBlock.cjs.prod.js +28 -28
- package/RequestBlock/dist/effect-RequestBlock.esm.js +103 -91
- package/RequestResolver/dist/effect-RequestResolver.cjs.dev.js +28 -28
- package/RequestResolver/dist/effect-RequestResolver.cjs.prod.js +28 -28
- package/RequestResolver/dist/effect-RequestResolver.esm.js +191 -91
- package/Resource/dist/effect-Resource.cjs.dev.js +19 -19
- package/Resource/dist/effect-Resource.cjs.prod.js +19 -19
- package/Resource/dist/effect-Resource.esm.js +70 -79
- package/Runtime/dist/effect-Runtime.cjs.dev.js +20 -20
- package/Runtime/dist/effect-Runtime.cjs.prod.js +20 -20
- package/Runtime/dist/effect-Runtime.esm.js +157 -79
- package/RuntimeFlags/dist/effect-RuntimeFlags.cjs.dev.js +24 -24
- package/RuntimeFlags/dist/effect-RuntimeFlags.cjs.prod.js +24 -24
- package/RuntimeFlags/dist/effect-RuntimeFlags.esm.js +305 -85
- package/RuntimeFlagsPatch/dist/effect-RuntimeFlagsPatch.esm.js +158 -27
- package/STM/dist/effect-STM.cjs.dev.js +41 -41
- package/STM/dist/effect-STM.cjs.prod.js +41 -41
- package/STM/dist/effect-STM.esm.js +1193 -112
- package/Schedule/dist/effect-Schedule.cjs.dev.js +11 -11
- package/Schedule/dist/effect-Schedule.cjs.prod.js +11 -11
- package/Schedule/dist/effect-Schedule.esm.js +957 -57
- package/ScheduleDecision/dist/effect-ScheduleDecision.cjs.dev.js +4 -4
- package/ScheduleDecision/dist/effect-ScheduleDecision.cjs.prod.js +4 -4
- package/ScheduleDecision/dist/effect-ScheduleDecision.esm.js +48 -24
- package/ScheduleInterval/dist/effect-ScheduleInterval.cjs.dev.js +2 -2
- package/ScheduleInterval/dist/effect-ScheduleInterval.cjs.prod.js +2 -2
- package/ScheduleInterval/dist/effect-ScheduleInterval.esm.js +130 -17
- package/ScheduleIntervals/dist/effect-ScheduleIntervals.cjs.dev.js +3 -3
- package/ScheduleIntervals/dist/effect-ScheduleIntervals.cjs.prod.js +3 -3
- package/ScheduleIntervals/dist/effect-ScheduleIntervals.esm.js +105 -23
- package/Scheduler/dist/effect-Scheduler.esm.js +326 -34
- package/Scope/dist/effect-Scope.cjs.dev.js +12 -12
- package/Scope/dist/effect-Scope.cjs.prod.js +12 -12
- package/Scope/dist/effect-Scope.esm.js +117 -71
- package/ScopedCache/dist/effect-ScopedCache.cjs.dev.js +14 -14
- package/ScopedCache/dist/effect-ScopedCache.cjs.prod.js +14 -14
- package/ScopedCache/dist/effect-ScopedCache.esm.js +52 -75
- package/ScopedRef/dist/effect-ScopedRef.cjs.dev.js +19 -19
- package/ScopedRef/dist/effect-ScopedRef.cjs.prod.js +19 -19
- package/ScopedRef/dist/effect-ScopedRef.esm.js +71 -79
- package/Sink/dist/effect-Sink.cjs.dev.js +32 -32
- package/Sink/dist/effect-Sink.cjs.prod.js +32 -32
- package/Sink/dist/effect-Sink.esm.js +997 -101
- package/SortedMap/dist/effect-SortedMap.esm.js +168 -23
- package/SortedSet/dist/effect-SortedSet.esm.js +263 -23
- package/Stream/dist/effect-Stream.cjs.dev.js +37 -37
- package/Stream/dist/effect-Stream.cjs.prod.js +37 -37
- package/Stream/dist/effect-Stream.esm.js +2879 -108
- package/StreamHaltStrategy/dist/effect-StreamHaltStrategy.esm.js +97 -2
- package/String/dist/effect-String.esm.js +600 -17
- package/Struct/dist/effect-Struct.esm.js +125 -4
- package/SubscriptionRef/dist/effect-SubscriptionRef.cjs.dev.js +37 -37
- package/SubscriptionRef/dist/effect-SubscriptionRef.cjs.prod.js +37 -37
- package/SubscriptionRef/dist/effect-SubscriptionRef.esm.js +160 -108
- package/Supervisor/dist/effect-Supervisor.cjs.dev.js +24 -24
- package/Supervisor/dist/effect-Supervisor.cjs.prod.js +24 -24
- package/Supervisor/dist/effect-Supervisor.esm.js +148 -85
- package/Symbol/dist/effect-Symbol.esm.js +30 -4
- package/SynchronizedRef/dist/effect-SynchronizedRef.cjs.dev.js +18 -18
- package/SynchronizedRef/dist/effect-SynchronizedRef.cjs.prod.js +18 -18
- package/SynchronizedRef/dist/effect-SynchronizedRef.esm.js +160 -78
- package/TArray/dist/effect-TArray.cjs.dev.js +43 -43
- package/TArray/dist/effect-TArray.cjs.prod.js +43 -43
- package/TArray/dist/effect-TArray.esm.js +367 -114
- package/TDeferred/dist/effect-TDeferred.cjs.dev.js +42 -42
- package/TDeferred/dist/effect-TDeferred.cjs.prod.js +42 -42
- package/TDeferred/dist/effect-TDeferred.esm.js +63 -113
- package/THub/dist/effect-THub.cjs.dev.js +44 -44
- package/THub/dist/effect-THub.cjs.prod.js +44 -44
- package/THub/dist/effect-THub.esm.js +157 -115
- package/TMap/dist/effect-TMap.cjs.dev.js +45 -45
- package/TMap/dist/effect-TMap.cjs.prod.js +45 -45
- package/TMap/dist/effect-TMap.esm.js +373 -116
- package/TPriorityQueue/dist/effect-TPriorityQueue.cjs.dev.js +41 -41
- package/TPriorityQueue/dist/effect-TPriorityQueue.cjs.prod.js +41 -41
- package/TPriorityQueue/dist/effect-TPriorityQueue.esm.js +184 -113
- package/TQueue/dist/effect-TQueue.cjs.dev.js +44 -44
- package/TQueue/dist/effect-TQueue.cjs.prod.js +44 -44
- package/TQueue/dist/effect-TQueue.esm.js +293 -115
- package/TRandom/dist/effect-TRandom.cjs.dev.js +43 -43
- package/TRandom/dist/effect-TRandom.cjs.prod.js +43 -43
- package/TRandom/dist/effect-TRandom.esm.js +93 -114
- package/TReentrantLock/dist/effect-TReentrantLock.cjs.dev.js +41 -41
- package/TReentrantLock/dist/effect-TReentrantLock.cjs.prod.js +41 -41
- package/TReentrantLock/dist/effect-TReentrantLock.esm.js +199 -112
- package/TRef/dist/effect-TRef.cjs.dev.js +41 -41
- package/TRef/dist/effect-TRef.cjs.prod.js +41 -41
- package/TRef/dist/effect-TRef.esm.js +116 -112
- package/TSemaphore/dist/effect-TSemaphore.cjs.dev.js +43 -43
- package/TSemaphore/dist/effect-TSemaphore.cjs.prod.js +43 -43
- package/TSemaphore/dist/effect-TSemaphore.esm.js +97 -114
- package/TSet/dist/effect-TSet.cjs.dev.js +45 -45
- package/TSet/dist/effect-TSet.cjs.prod.js +45 -45
- package/TSet/dist/effect-TSet.esm.js +268 -116
- package/Take/dist/effect-Take.cjs.dev.js +28 -28
- package/Take/dist/effect-Take.cjs.prod.js +28 -28
- package/Take/dist/effect-Take.esm.js +190 -91
- package/TestAnnotation/dist/effect-TestAnnotation.esm.js +111 -26
- package/TestAnnotationMap/dist/effect-TestAnnotationMap.esm.js +101 -2
- package/TestAnnotations/dist/effect-TestAnnotations.cjs.dev.js +7 -7
- package/TestAnnotations/dist/effect-TestAnnotations.cjs.prod.js +7 -7
- package/TestAnnotations/dist/effect-TestAnnotations.esm.js +83 -59
- package/TestClock/dist/effect-TestClock.cjs.dev.js +24 -24
- package/TestClock/dist/effect-TestClock.cjs.prod.js +24 -24
- package/TestClock/dist/effect-TestClock.esm.js +411 -87
- package/TestConfig/dist/effect-TestConfig.esm.js +27 -18
- package/TestContext/dist/effect-TestContext.cjs.dev.js +31 -31
- package/TestContext/dist/effect-TestContext.cjs.prod.js +31 -31
- package/TestContext/dist/effect-TestContext.esm.js +29 -98
- package/TestLive/dist/effect-TestLive.cjs.dev.js +3 -3
- package/TestLive/dist/effect-TestLive.cjs.prod.js +3 -3
- package/TestLive/dist/effect-TestLive.esm.js +48 -42
- package/TestServices/dist/effect-TestServices.cjs.dev.js +29 -29
- package/TestServices/dist/effect-TestServices.cjs.prod.js +29 -29
- package/TestServices/dist/effect-TestServices.esm.js +269 -96
- package/TestSized/dist/effect-TestSized.esm.js +50 -33
- package/Tracer/dist/effect-Tracer.cjs.dev.js +3 -3
- package/Tracer/dist/effect-Tracer.cjs.prod.js +3 -3
- package/Tracer/dist/effect-Tracer.esm.js +68 -42
- package/Tuple/dist/effect-Tuple.esm.js +173 -4
- package/Unify/dist/effect-Unify.esm.js +40 -2
- package/Utils/dist/effect-Utils.esm.js +352 -3
- package/dist/{Cache-e7468f24.cjs.dev.js → Cache-1688e584.cjs.dev.js} +1 -1
- package/dist/{Cache-65f7e875.cjs.prod.js → Cache-8f2f2b55.cjs.prod.js} +1 -1
- package/dist/{Channel-482334e0.cjs.prod.js → Channel-2ce019f1.cjs.prod.js} +2 -2
- package/dist/{Channel-4099f225.cjs.dev.js → Channel-544108d2.cjs.dev.js} +2 -2
- package/dist/{ChannelSingleProducerAsyncInput-e1260219.cjs.dev.js → ChannelSingleProducerAsyncInput-62f4749c.cjs.dev.js} +1 -1
- package/dist/{ChannelSingleProducerAsyncInput-9d23aac3.cjs.prod.js → ChannelSingleProducerAsyncInput-6e0084c3.cjs.prod.js} +1 -1
- package/dist/{Clock-0b777b1b.cjs.prod.js → Clock-09ecce0a.cjs.prod.js} +1 -1
- package/dist/{Clock-80bf3b4b.cjs.dev.js → Clock-bec722c1.cjs.dev.js} +1 -1
- package/dist/{Console-69b2fba9.cjs.prod.js → Console-150b7b40.cjs.prod.js} +3 -3
- package/dist/{Console-ff87924b.cjs.dev.js → Console-4825ee9f.cjs.dev.js} +3 -3
- package/dist/{DefaultServices-c1a6b148.cjs.dev.js → DefaultServices-d5740d37.cjs.dev.js} +1 -1
- package/dist/{DefaultServices-6a83f0aa.cjs.prod.js → DefaultServices-df7495bb.cjs.prod.js} +1 -1
- package/dist/{Duration-011e7325.cjs.prod.js → Duration-0bc08d03.cjs.prod.js} +8 -0
- package/dist/{Duration-5ac57eb4.cjs.dev.js → Duration-604874d1.cjs.dev.js} +8 -0
- package/dist/{Effect-f0659a90.cjs.prod.js → Effect-1442090f.cjs.prod.js} +9 -9
- package/dist/{Effect-8392a3cd.cjs.dev.js → Effect-6e9780e6.cjs.dev.js} +9 -9
- package/dist/{Error-5edcd83a.cjs.dev.js → Error-5ab157f2.cjs.dev.js} +1 -1
- package/dist/{Error-d7f0de14.cjs.prod.js → Error-e9d25c53.cjs.prod.js} +1 -1
- package/dist/{Fiber-c797d281.cjs.dev.js → Fiber-6432d5f7.cjs.dev.js} +3 -3
- package/dist/{Fiber-3b2a4091.cjs.prod.js → Fiber-e61b3c65.cjs.prod.js} +3 -3
- package/dist/{FiberRef-61cd9abe.cjs.dev.js → FiberRef-1db44a9b.cjs.dev.js} +2 -2
- package/dist/{FiberRef-0b332631.cjs.prod.js → FiberRef-efb4a3ac.cjs.prod.js} +2 -2
- package/dist/{GroupBy-bd212344.cjs.dev.js → GroupBy-8a8149b4.cjs.dev.js} +1 -1
- package/dist/{GroupBy-bb08aeb2.cjs.prod.js → GroupBy-b74084af.cjs.prod.js} +1 -1
- package/dist/{Hub-926961e9.cjs.prod.js → Hub-6e64debd.cjs.prod.js} +2 -2
- package/dist/{Hub-af0194fd.cjs.dev.js → Hub-74834668.cjs.dev.js} +2 -2
- package/dist/{KeyedPool-f7b4675c.cjs.dev.js → KeyedPool-b05481e9.cjs.dev.js} +3 -3
- package/dist/{KeyedPool-0ddba691.cjs.prod.js → KeyedPool-cd8abf95.cjs.prod.js} +3 -3
- package/dist/{Layer-ec0ab71c.cjs.prod.js → Layer-297269fd.cjs.prod.js} +1 -1
- package/dist/{Layer-6ad0ac38.cjs.dev.js → Layer-c69f3fdc.cjs.dev.js} +1 -1
- package/dist/{Logger-620f1fa9.cjs.dev.js → Logger-680763c7.cjs.dev.js} +2 -2
- package/dist/{Logger-3df1180d.cjs.prod.js → Logger-7a664cc3.cjs.prod.js} +2 -2
- package/dist/{Metric-ebc35919.cjs.dev.js → Metric-09d012ff.cjs.dev.js} +1 -1
- package/dist/{Metric-9607aa06.cjs.prod.js → Metric-b7563a68.cjs.prod.js} +1 -1
- package/dist/{MetricHook-fdc68e37.cjs.dev.js → MetricHook-3104e93b.cjs.dev.js} +1 -1
- package/dist/{MetricHook-a742d813.cjs.prod.js → MetricHook-efd05d72.cjs.prod.js} +1 -1
- package/dist/{MetricKey-b17b2c9a.cjs.prod.js → MetricKey-9cfcaec8.cjs.prod.js} +1 -1
- package/dist/{MetricKey-be3afc49.cjs.dev.js → MetricKey-c3ba437e.cjs.dev.js} +1 -1
- package/dist/{MetricKeyType-3dfa6802.cjs.prod.js → MetricKeyType-6d2d9036.cjs.prod.js} +1 -1
- package/dist/{MetricKeyType-fba3e0ec.cjs.dev.js → MetricKeyType-c1d7ebe8.cjs.dev.js} +1 -1
- package/dist/{MetricPolling-061de6b9.cjs.dev.js → MetricPolling-5af0ff67.cjs.dev.js} +3 -3
- package/dist/{MetricPolling-6e5e4b2e.cjs.prod.js → MetricPolling-a0a4e798.cjs.prod.js} +3 -3
- package/dist/{MetricRegistry-4df5e56b.cjs.dev.js → MetricRegistry-e4af936b.cjs.dev.js} +1 -1
- package/dist/{MetricRegistry-da2c65bd.cjs.prod.js → MetricRegistry-ff6df283.cjs.prod.js} +1 -1
- package/dist/{Pool-d8e4142e.cjs.prod.js → Pool-54389592.cjs.prod.js} +1 -1
- package/dist/{Pool-e8a79a57.cjs.dev.js → Pool-fe1b506a.cjs.dev.js} +1 -1
- package/dist/{Queue-de055f1c.cjs.prod.js → Queue-5f954287.cjs.prod.js} +1 -1
- package/dist/{Queue-55a39179.cjs.dev.js → Queue-8d082fe4.cjs.dev.js} +1 -1
- package/dist/{Random-d6a2f801.cjs.dev.js → Random-35304046.cjs.dev.js} +1 -1
- package/dist/{Random-ade126e8.cjs.prod.js → Random-b4709b6a.cjs.prod.js} +1 -1
- package/dist/{Reloadable-5f1ed95c.cjs.prod.js → Reloadable-2b8ba75d.cjs.prod.js} +5 -5
- package/dist/{Reloadable-e8bcb00e.cjs.dev.js → Reloadable-b01c9297.cjs.dev.js} +5 -5
- package/dist/{Request-45226c5f.cjs.prod.js → Request-53592fe4.cjs.prod.js} +2 -2
- package/dist/{Request-9d12c3ba.cjs.dev.js → Request-d3b63af6.cjs.dev.js} +2 -2
- package/dist/{RequestBlock-0e9f377b.cjs.dev.js → RequestBlock-1aa4c3bd.cjs.dev.js} +1 -1
- package/dist/{RequestBlock-d4c7c31d.cjs.prod.js → RequestBlock-8c3b51d1.cjs.prod.js} +1 -1
- package/dist/{RequestResolver-8764ee8c.cjs.prod.js → RequestResolver-133197d5.cjs.prod.js} +2 -2
- package/dist/{RequestResolver-b287a04a.cjs.dev.js → RequestResolver-86c21b80.cjs.dev.js} +2 -2
- package/dist/{Resource-f95cf55a.cjs.prod.js → Resource-2530fe45.cjs.prod.js} +3 -3
- package/dist/{Resource-4f2b627f.cjs.dev.js → Resource-e50b4b25.cjs.dev.js} +3 -3
- package/dist/{Runtime-969e6cb2.cjs.prod.js → Runtime-0d643f0c.cjs.prod.js} +1 -1
- package/dist/{Runtime-dc0234a0.cjs.dev.js → Runtime-c4b887ff.cjs.dev.js} +1 -1
- package/dist/{RuntimeFlags-7a400d83.cjs.prod.js → RuntimeFlags-9d8fac5a.cjs.prod.js} +1 -1
- package/dist/{RuntimeFlags-60dfc3f5.cjs.dev.js → RuntimeFlags-f67e3984.cjs.dev.js} +1 -1
- package/dist/{STM-b8d9766d.cjs.prod.js → STM-23270be2.cjs.prod.js} +2 -2
- package/dist/{STM-af9026e6.cjs.dev.js → STM-5a4c9921.cjs.dev.js} +2 -2
- package/dist/{Schedule-58648908.cjs.prod.js → Schedule-0444792d.cjs.prod.js} +1 -1
- package/dist/{Schedule-76089454.cjs.dev.js → Schedule-b6c7b49a.cjs.dev.js} +1 -1
- package/dist/{ScheduleDecision-fbd6bb79.cjs.prod.js → ScheduleDecision-369f2d2b.cjs.prod.js} +1 -1
- package/dist/{ScheduleDecision-9555a6dc.cjs.dev.js → ScheduleDecision-ba8d0e87.cjs.dev.js} +1 -1
- package/dist/{ScheduleInterval-3ca6dbb0.cjs.dev.js → ScheduleInterval-51f42533.cjs.dev.js} +1 -1
- package/dist/{ScheduleInterval-15c7da05.cjs.prod.js → ScheduleInterval-78037484.cjs.prod.js} +1 -1
- package/dist/{ScheduleIntervals-36ff45c1.cjs.dev.js → ScheduleIntervals-b0bfcf3b.cjs.dev.js} +1 -1
- package/dist/{ScheduleIntervals-a5bbdb0d.cjs.prod.js → ScheduleIntervals-db13140c.cjs.prod.js} +1 -1
- package/dist/{Scope-e3e714b4.cjs.prod.js → Scope-311c7eb9.cjs.prod.js} +1 -1
- package/dist/{Scope-820b74b2.cjs.dev.js → Scope-6ba9ec6d.cjs.dev.js} +1 -1
- package/dist/{ScopedCache-f9b2f52e.cjs.dev.js → ScopedCache-3f58b125.cjs.dev.js} +5 -5
- package/dist/{ScopedCache-467ccc2b.cjs.prod.js → ScopedCache-8f99505c.cjs.prod.js} +5 -5
- package/dist/{ScopedRef-b45fd0e8.cjs.prod.js → ScopedRef-7946d287.cjs.prod.js} +1 -1
- package/dist/{ScopedRef-735385de.cjs.dev.js → ScopedRef-b92e1633.cjs.dev.js} +1 -1
- package/dist/{Sink-dffe83ea.cjs.dev.js → Sink-9f13da17.cjs.dev.js} +1 -1
- package/dist/{Sink-cb1bba84.cjs.prod.js → Sink-9f82fc3b.cjs.prod.js} +1 -1
- package/dist/{Stream-c348a386.cjs.dev.js → Stream-14325ecb.cjs.dev.js} +2 -2
- package/dist/{Stream-39e8de11.cjs.prod.js → Stream-cf262c16.cjs.prod.js} +2 -2
- package/dist/{SubscriptionRef-62745b92.cjs.prod.js → SubscriptionRef-aa7bdc5f.cjs.prod.js} +5 -5
- package/dist/{SubscriptionRef-53e8686c.cjs.dev.js → SubscriptionRef-d3c1aa07.cjs.dev.js} +5 -5
- package/dist/{Supervisor-0ea7382b.cjs.prod.js → Supervisor-21087253.cjs.prod.js} +2 -2
- package/dist/{Supervisor-cf21fcaa.cjs.dev.js → Supervisor-40dd7ce5.cjs.dev.js} +2 -2
- package/dist/{SynchronizedRef-9e9689e9.cjs.dev.js → SynchronizedRef-3181eb0a.cjs.dev.js} +1 -1
- package/dist/{SynchronizedRef-2cc5af97.cjs.prod.js → SynchronizedRef-c6e0884b.cjs.prod.js} +1 -1
- package/dist/{TArray-6057170a.cjs.prod.js → TArray-6767b4bd.cjs.prod.js} +1 -1
- package/dist/{TArray-0b280c93.cjs.dev.js → TArray-a0a4c6e6.cjs.dev.js} +1 -1
- package/dist/{TDeferred-73b5dfc2.cjs.prod.js → TDeferred-a9839479.cjs.prod.js} +3 -3
- package/dist/{TDeferred-786b2b13.cjs.dev.js → TDeferred-ac2c4025.cjs.dev.js} +3 -3
- package/dist/{THub-810db270.cjs.prod.js → THub-25b77864.cjs.prod.js} +5 -5
- package/dist/{THub-bcd35bc0.cjs.dev.js → THub-38053ae1.cjs.dev.js} +5 -5
- package/dist/{TMap-7206da08.cjs.prod.js → TMap-91505efa.cjs.prod.js} +1 -1
- package/dist/{TMap-06e0747b.cjs.dev.js → TMap-de8ac080.cjs.dev.js} +1 -1
- package/dist/{TPriorityQueue-71490af5.cjs.prod.js → TPriorityQueue-00b65d1a.cjs.prod.js} +2 -2
- package/dist/{TPriorityQueue-0844551b.cjs.dev.js → TPriorityQueue-96ff0e15.cjs.dev.js} +2 -2
- package/dist/{TQueue-67ccf55b.cjs.prod.js → TQueue-5e242ca2.cjs.prod.js} +1 -1
- package/dist/{TQueue-5621ef6e.cjs.dev.js → TQueue-707762bf.cjs.dev.js} +1 -1
- package/dist/{TRandom-c974e739.cjs.dev.js → TRandom-5eb21d23.cjs.dev.js} +5 -5
- package/dist/{TRandom-557dc8e1.cjs.prod.js → TRandom-ec9c7bf7.cjs.prod.js} +5 -5
- package/dist/{TReentrantLock-5f7cba2d.cjs.dev.js → TReentrantLock-1b77d76f.cjs.dev.js} +3 -3
- package/dist/{TReentrantLock-e6ee830e.cjs.prod.js → TReentrantLock-c5a8401e.cjs.prod.js} +3 -3
- package/dist/{TRef-f7b2bc6f.cjs.prod.js → TRef-b87580d7.cjs.prod.js} +1 -1
- package/dist/{TRef-38eac0f0.cjs.dev.js → TRef-cf2e8ad7.cjs.dev.js} +1 -1
- package/dist/{TSemaphore-28d87428.cjs.prod.js → TSemaphore-29503416.cjs.prod.js} +4 -4
- package/dist/{TSemaphore-3cf15f77.cjs.dev.js → TSemaphore-50edec08.cjs.dev.js} +4 -4
- package/dist/{TSet-677ac73c.cjs.prod.js → TSet-3c2568e9.cjs.prod.js} +2 -2
- package/dist/{TSet-1dca2ef3.cjs.dev.js → TSet-bb4775ca.cjs.dev.js} +2 -2
- package/dist/{Take-bfdbd28d.cjs.dev.js → Take-684c9901.cjs.dev.js} +1 -1
- package/dist/{Take-e40627bd.cjs.prod.js → Take-b4c91438.cjs.prod.js} +1 -1
- package/dist/{TestAnnotations-14444032.cjs.prod.js → TestAnnotations-5db95828.cjs.prod.js} +2 -2
- package/dist/{TestAnnotations-ee0f8c79.cjs.dev.js → TestAnnotations-733b39ef.cjs.dev.js} +2 -2
- package/dist/{TestClock-30ba14e8.cjs.prod.js → TestClock-89a36b89.cjs.prod.js} +8 -8
- package/dist/{TestClock-d782f3ee.cjs.dev.js → TestClock-e2773846.cjs.dev.js} +8 -8
- package/dist/{TestContext-eebb1aad.cjs.dev.js → TestContext-3328163e.cjs.dev.js} +4 -4
- package/dist/{TestContext-f76f750e.cjs.prod.js → TestContext-917bf305.cjs.prod.js} +4 -4
- package/dist/{TestLive-dc458127.cjs.dev.js → TestLive-465ad3ef.cjs.dev.js} +1 -1
- package/dist/{TestLive-e5d614fe.cjs.prod.js → TestLive-f3232ac4.cjs.prod.js} +1 -1
- package/dist/{TestServices-b3af20a3.cjs.prod.js → TestServices-605f726e.cjs.prod.js} +6 -6
- package/dist/{TestServices-7a60d735.cjs.dev.js → TestServices-921e5c42.cjs.dev.js} +6 -6
- package/dist/{Tracer-3cd1e3bc.cjs.prod.js → Tracer-d06d0b61.cjs.prod.js} +1 -1
- package/dist/{Tracer-435e56fd.cjs.dev.js → Tracer-da182c8c.cjs.dev.js} +1 -1
- package/dist/{cache-66637407.cjs.dev.js → cache-6cdc31f7.cjs.dev.js} +3 -3
- package/dist/{cache-c88afdc0.cjs.prod.js → cache-ab7bbfbd.cjs.prod.js} +3 -3
- package/dist/{circular-d08ca815.cjs.dev.js → circular-4cb0b79d.cjs.dev.js} +5 -5
- package/dist/{circular-7eed8a92.cjs.prod.js → circular-5b3558d9.cjs.prod.js} +5 -5
- package/dist/{circular-5c436934.cjs.dev.js → circular-78011d6b.cjs.dev.js} +3 -3
- package/dist/{circular-c8f8e360.cjs.prod.js → circular-81b4c556.cjs.prod.js} +3 -3
- package/dist/{core-20a91d69.cjs.prod.js → core-4ced6e17.cjs.prod.js} +4 -4
- package/dist/{core-6e50c01f.cjs.dev.js → core-d9eea905.cjs.dev.js} +4 -4
- package/dist/{core-effect-780f9db7.cjs.dev.js → core-effect-a9b8ee08.cjs.dev.js} +4 -4
- package/dist/{core-effect-023f4abe.cjs.prod.js → core-effect-bf806dd9.cjs.prod.js} +4 -4
- package/dist/{dataSource-7ec08fa5.cjs.prod.js → dataSource-abccc876.cjs.prod.js} +2 -2
- package/dist/{dataSource-e56e2a99.cjs.dev.js → dataSource-d5f79f4e.cjs.dev.js} +2 -2
- package/dist/declarations/src/Duration.d.ts +5 -0
- package/dist/declarations/src/Duration.d.ts.map +1 -1
- package/dist/{defaultServices-452aebad.cjs.prod.js → defaultServices-4112c0c9.cjs.prod.js} +1 -1
- package/dist/{defaultServices-e9a9b935.cjs.dev.js → defaultServices-60c753dc.cjs.dev.js} +1 -1
- package/dist/effect.cjs.dev.js +93 -93
- package/dist/effect.cjs.prod.js +93 -93
- package/dist/effect.esm.js +283 -197
- package/dist/{fiber-2975db3a.cjs.prod.js → fiber-90ffaf8c.cjs.prod.js} +1 -1
- package/dist/{fiber-1132297b.cjs.dev.js → fiber-da1a207c.cjs.dev.js} +1 -1
- package/dist/{fiberRuntime-9d6d53be.cjs.prod.js → fiberRuntime-1c369a47.cjs.prod.js} +7 -7
- package/dist/{fiberRuntime-ac7fae54.cjs.dev.js → fiberRuntime-e9680313.cjs.dev.js} +7 -7
- package/dist/{groupBy-f0a83f90.cjs.prod.js → groupBy-0cc85afb.cjs.prod.js} +5 -5
- package/dist/{groupBy-e1d3c5e8.cjs.dev.js → groupBy-b204a881.cjs.dev.js} +5 -5
- package/dist/{hook-0bf192b2.cjs.prod.js → hook-6c7550dc.cjs.prod.js} +1 -1
- package/dist/{hook-9e86d119.cjs.dev.js → hook-822704ea.cjs.dev.js} +1 -1
- package/dist/{key-a79acfe7.cjs.prod.js → key-330b98b1.cjs.prod.js} +1 -1
- package/dist/{key-6ac569ca.cjs.dev.js → key-a474fc0d.cjs.dev.js} +1 -1
- package/dist/{keyType-c1e7cfc5.cjs.dev.js → keyType-1e916ae2.cjs.dev.js} +1 -1
- package/dist/{keyType-681c1c4a.cjs.prod.js → keyType-8460e792.cjs.prod.js} +1 -1
- package/dist/{layer-f0c8023d.cjs.dev.js → layer-ae8eefad.cjs.dev.js} +9 -9
- package/dist/{layer-db9c42be.cjs.prod.js → layer-ffacc2c5.cjs.prod.js} +9 -9
- package/dist/{pool-cd9f1284.cjs.dev.js → pool-3f16af61.cjs.dev.js} +4 -4
- package/dist/{pool-975b7d21.cjs.prod.js → pool-59a31f55.cjs.prod.js} +4 -4
- package/dist/{query-12e387cf.cjs.dev.js → query-193d0a89.cjs.dev.js} +3 -3
- package/dist/{query-eb8a7001.cjs.prod.js → query-fe4a82d6.cjs.prod.js} +3 -3
- package/dist/{queue-0dbc2b3f.cjs.dev.js → queue-04ae7ec7.cjs.dev.js} +1 -1
- package/dist/{queue-f70dda1a.cjs.prod.js → queue-b81aee38.cjs.prod.js} +1 -1
- package/dist/{registry-92c00ecd.cjs.prod.js → registry-29905dcc.cjs.prod.js} +2 -2
- package/dist/{registry-9e9ae2c7.cjs.dev.js → registry-c883cf52.cjs.dev.js} +2 -2
- package/dist/{runtime-f8d0f39b.cjs.dev.js → runtime-3ae98f19.cjs.dev.js} +3 -3
- package/dist/{runtime-0ada41f2.cjs.prod.js → runtime-8c3f1bd3.cjs.prod.js} +3 -3
- package/dist/{schedule-18b063cb.cjs.dev.js → schedule-479d8fcc.cjs.dev.js} +7 -7
- package/dist/{schedule-f918adf5.cjs.prod.js → schedule-7e30db2d.cjs.prod.js} +7 -7
- package/dist/{scopedRef-50091b28.cjs.dev.js → scopedRef-16d9d192.cjs.dev.js} +3 -3
- package/dist/{scopedRef-d6396f06.cjs.prod.js → scopedRef-40b5bb82.cjs.prod.js} +3 -3
- package/dist/{singleProducerAsyncInput-f3dd657f.cjs.dev.js → singleProducerAsyncInput-552122e6.cjs.dev.js} +1 -1
- package/dist/{singleProducerAsyncInput-bd600183.cjs.prod.js → singleProducerAsyncInput-c5ff73b7.cjs.prod.js} +1 -1
- package/dist/{sink-bb64c8a6.cjs.dev.js → sink-16a1a901.cjs.dev.js} +9 -9
- package/dist/{sink-6a1db2b0.cjs.prod.js → sink-c9ae7558.cjs.prod.js} +9 -9
- package/dist/{stm-2b8fa344.cjs.dev.js → stm-44f045e5.cjs.dev.js} +3 -3
- package/dist/{stm-e3401389.cjs.prod.js → stm-59af7e62.cjs.prod.js} +3 -3
- package/dist/{stream-7bc5bfac.cjs.dev.js → stream-84a13e23.cjs.dev.js} +13 -17
- package/dist/{stream-22ea5a61.cjs.prod.js → stream-8acbee57.cjs.prod.js} +13 -17
- package/dist/{tArray-a211cc29.cjs.prod.js → tArray-a690480d.cjs.prod.js} +3 -3
- package/dist/{tArray-36a6e713.cjs.dev.js → tArray-c0a3d1e2.cjs.dev.js} +3 -3
- package/dist/{tMap-fd504724.cjs.dev.js → tMap-1c1b10c4.cjs.dev.js} +5 -5
- package/dist/{tMap-9c22a2ff.cjs.prod.js → tMap-8dfc92f5.cjs.prod.js} +5 -5
- package/dist/{tQueue-4b66ca7b.cjs.prod.js → tQueue-48a29f8b.cjs.prod.js} +4 -4
- package/dist/{tQueue-565f8994.cjs.dev.js → tQueue-aaec000f.cjs.dev.js} +4 -4
- package/dist/{tRef-565db536.cjs.dev.js → tRef-1df89632.cjs.dev.js} +1 -1
- package/dist/{tRef-74dff65b.cjs.prod.js → tRef-cc473a9f.cjs.prod.js} +1 -1
- package/dist/{take-05ea3c27.cjs.prod.js → take-906e6ef4.cjs.prod.js} +1 -1
- package/dist/{take-f87477f8.cjs.dev.js → take-e1c6b82a.cjs.dev.js} +1 -1
- package/{dist/Context-149c432f.esm.js → internal/Context.esm.js} +9 -9
- package/internal/Data.esm.js +49 -0
- package/internal/Differ/ChunkPatch.esm.js +131 -0
- package/internal/Differ/ContextPatch.esm.js +158 -0
- package/internal/Differ/HashMapPatch.esm.js +133 -0
- package/internal/Differ/HashSetPatch.esm.js +107 -0
- package/internal/Differ/OrPatch.esm.js +196 -0
- package/internal/Differ.esm.js +130 -0
- package/internal/Effectable.esm.js +89 -0
- package/internal/Either.esm.js +95 -0
- package/internal/Encoding/Base64.esm.js +74 -0
- package/internal/Encoding/Base64Url.esm.js +24 -0
- package/internal/Encoding/Common.esm.js +21 -0
- package/internal/Encoding/Hex.esm.js +55 -0
- package/internal/HashMap/array.esm.js +51 -0
- package/internal/HashMap/bitwise.esm.js +34 -0
- package/internal/HashMap/config.esm.js +16 -0
- package/internal/HashMap/keySet.esm.js +8 -0
- package/internal/HashMap/node.esm.js +253 -0
- package/internal/HashMap.esm.js +366 -0
- package/internal/HashSet.esm.js +211 -0
- package/internal/Option.esm.js +75 -0
- package/{dist/ReadonlyArray-c8b1f51c.esm.js → internal/ReadonlyArray.esm.js} +1 -1
- package/internal/RedBlackTree/iterator.esm.js +204 -0
- package/internal/RedBlackTree/node.esm.js +43 -0
- package/{dist/RedBlackTree-611b3b4c.esm.js → internal/RedBlackTree.esm.js} +65 -655
- package/{dist/Stack-765c2298.esm.js → internal/Stack.esm.js} +1 -1
- package/internal/blockedRequests.esm.js +365 -0
- package/{dist/cache-d62912e6.esm.js → internal/cache.esm.js} +18 -18
- package/internal/cause.esm.js +1067 -0
- package/internal/channel/channelExecutor.esm.js +692 -0
- package/internal/channel/channelState.esm.js +78 -0
- package/{dist/childExecutorDecision-a7b466d2.esm.js → internal/channel/childExecutorDecision.esm.js} +3 -17
- package/internal/channel/continuation.esm.js +58 -0
- package/{dist/mergeDecision-d31cb28c.esm.js → internal/channel/mergeDecision.esm.js} +3 -12
- package/{dist/mergeState-1325df20.esm.js → internal/channel/mergeState.esm.js} +3 -17
- package/{dist/mergeStrategy-a88b5442.esm.js → internal/channel/mergeStrategy.esm.js} +3 -12
- package/{dist/singleProducerAsyncInput-5b2ede75.esm.js → internal/channel/singleProducerAsyncInput.esm.js} +8 -8
- package/internal/channel/subexecutor.esm.js +153 -0
- package/{dist/upstreamPullRequest-fed99e29.esm.js → internal/channel/upstreamPullRequest.esm.js} +3 -12
- package/{dist/upstreamPullStrategy-d5d1aa92.esm.js → internal/channel/upstreamPullStrategy.esm.js} +3 -12
- package/internal/channel.esm.js +648 -0
- package/internal/clock.esm.js +82 -0
- package/internal/completedRequestMap.esm.js +7 -0
- package/internal/concurrency.esm.js +47 -0
- package/{dist/config-b039b99f.esm.js → internal/config.esm.js} +12 -66
- package/{dist/configError-8b2e2999.esm.js → internal/configError.esm.js} +5 -34
- package/{dist/pathPatch-f393ab1b.esm.js → internal/configProvider/pathPatch.esm.js} +7 -7
- package/{dist/configProvider-c997961d.esm.js → internal/configProvider.esm.js} +16 -79
- package/{dist/configSecret-6e9eaf9d.esm.js → internal/configSecret.esm.js} +5 -5
- package/internal/console.esm.js +72 -0
- package/{dist/core-effect-57445976.esm.js → internal/core-effect.esm.js} +26 -53
- package/internal/core-stream.esm.js +293 -0
- package/internal/core.esm.js +1745 -0
- package/{dist/dataSource-1f41ea46.esm.js → internal/dataSource.esm.js} +9 -8
- package/internal/defaultServices/console.esm.js +96 -0
- package/internal/defaultServices.esm.js +84 -0
- package/internal/deferred.esm.js +37 -0
- package/{dist/circular-08fb0138.esm.js → internal/effect/circular.esm.js} +23 -20
- package/internal/executionStrategy.esm.js +61 -0
- package/{dist/fiber-8fb398f3.esm.js → internal/fiber.esm.js} +15 -121
- package/internal/fiberId.esm.js +243 -0
- package/internal/fiberMessage.esm.js +54 -0
- package/{dist/patch-743d675c.esm.js → internal/fiberRefs/patch.esm.js} +5 -5
- package/{dist/fiberRefs-69cce1a0.esm.js → internal/fiberRefs.esm.js} +8 -8
- package/{dist/fiberRuntime-bfcf5f49.esm.js → internal/fiberRuntime.esm.js} +152 -1006
- package/internal/fiberScope.esm.js +58 -0
- package/internal/fiberStatus.esm.js +89 -0
- package/{dist/groupBy-d11b31b1.esm.js → internal/groupBy.esm.js} +16 -14
- package/{dist/Hub-121dbf51.esm.js → internal/hub.esm.js} +34 -196
- package/internal/keyedPool.esm.js +161 -0
- package/{dist/circular-e463e1e6.esm.js → internal/layer/circular.esm.js} +10 -8
- package/{dist/layer-35828af7.esm.js → internal/layer.esm.js} +21 -65
- package/internal/logSpan.esm.js +15 -0
- package/internal/logger-circular.esm.js +21 -0
- package/internal/logger.esm.js +213 -0
- package/{dist/boundaries-52029180.esm.js → internal/metric/boundaries.esm.js} +7 -7
- package/{dist/hook-fd61107b.esm.js → internal/metric/hook.esm.js} +10 -10
- package/{dist/key-340a2bae.esm.js → internal/metric/key.esm.js} +9 -9
- package/{dist/keyType-869d90f8.esm.js → internal/metric/keyType.esm.js} +6 -6
- package/{dist/label-0cc6c9a0.esm.js → internal/metric/label.esm.js} +5 -5
- package/{dist/pair-5bb3eef4.esm.js → internal/metric/pair.esm.js} +2 -2
- package/internal/metric/polling.esm.js +74 -0
- package/{dist/registry-c59aeb06.esm.js → internal/metric/registry.esm.js} +8 -8
- package/{dist/state-2c6abdb1.esm.js → internal/metric/state.esm.js} +5 -5
- package/internal/metric.esm.js +204 -0
- package/internal/opCodes/cause.esm.js +31 -0
- package/internal/opCodes/channel.esm.js +71 -0
- package/internal/opCodes/channelChildExecutorDecision.esm.js +16 -0
- package/internal/opCodes/channelMergeDecision.esm.js +11 -0
- package/internal/opCodes/channelMergeState.esm.js +16 -0
- package/internal/opCodes/channelMergeStrategy.esm.js +11 -0
- package/internal/opCodes/channelState.esm.js +21 -0
- package/internal/opCodes/channelUpstreamPullRequest.esm.js +11 -0
- package/internal/opCodes/channelUpstreamPullStrategy.esm.js +11 -0
- package/internal/opCodes/config.esm.js +56 -0
- package/internal/opCodes/configError.esm.js +31 -0
- package/internal/opCodes/continuation.esm.js +11 -0
- package/internal/opCodes/deferred.esm.js +11 -0
- package/internal/opCodes/effect.esm.js +71 -0
- package/internal/opCodes/layer.esm.js +46 -0
- package/internal/opCodes/streamHaltStrategy.esm.js +21 -0
- package/{dist/pool-7d5c25ef.esm.js → internal/pool.esm.js} +13 -13
- package/{dist/query-242f7fda.esm.js → internal/query.esm.js} +10 -7
- package/{dist/queue-f74db567.esm.js → internal/queue.esm.js} +10 -10
- package/internal/random.esm.js +58 -0
- package/internal/ref.esm.js +121 -0
- package/internal/reloadable.esm.js +62 -0
- package/internal/request.esm.js +81 -0
- package/internal/resource.esm.js +35 -0
- package/internal/ringBuffer.esm.js +56 -0
- package/{dist/runtime-bcdd4416.esm.js → internal/runtime.esm.js} +19 -17
- package/internal/runtimeFlags.esm.js +137 -0
- package/internal/runtimeFlagsPatch.esm.js +57 -0
- package/internal/schedule/decision.esm.js +45 -0
- package/internal/schedule/interval.esm.js +85 -0
- package/internal/schedule/intervals.esm.js +135 -0
- package/{dist/schedule-566ae18c.esm.js → internal/schedule.esm.js} +26 -25
- package/{dist/ScopedCache-8fa7e96d.esm.js → internal/scopedCache.esm.js} +27 -83
- package/{dist/scopedRef-0fdefef8.esm.js → internal/scopedRef.esm.js} +10 -10
- package/internal/singleShotGen.esm.js +30 -0
- package/internal/sink.esm.js +918 -0
- package/{dist/core-f6cae6d7.esm.js → internal/stm/core.esm.js} +46 -525
- package/internal/stm/opCodes/stm.esm.js +56 -0
- package/internal/stm/opCodes/stmState.esm.js +16 -0
- package/internal/stm/opCodes/strategy.esm.js +16 -0
- package/internal/stm/opCodes/tExit.esm.js +26 -0
- package/internal/stm/opCodes/tryCommit.esm.js +11 -0
- package/internal/stm/stm/entry.esm.js +47 -0
- package/internal/stm/stm/journal.esm.js +96 -0
- package/internal/stm/stm/stmState.esm.js +104 -0
- package/internal/stm/stm/tExit.esm.js +113 -0
- package/internal/stm/stm/tryCommit.esm.js +25 -0
- package/internal/stm/stm/txnId.esm.js +15 -0
- package/internal/stm/stm/versioned.esm.js +8 -0
- package/{dist/stm-6937f6f2.esm.js → internal/stm/stm.esm.js} +16 -14
- package/{dist/tArray-79024770.esm.js → internal/stm/tArray.esm.js} +8 -8
- package/internal/stm/tDeferred.esm.js +49 -0
- package/{dist/THub-573c2fb3.esm.js → internal/stm/tHub.esm.js} +28 -200
- package/{dist/tMap-907e37f4.esm.js → internal/stm/tMap.esm.js} +13 -13
- package/internal/stm/tPriorityQueue.esm.js +156 -0
- package/{dist/tQueue-74395d76.esm.js → internal/stm/tQueue.esm.js} +10 -24
- package/internal/stm/tRandom.esm.js +89 -0
- package/internal/stm/tReentrantLock.esm.js +216 -0
- package/{dist/tRef-fc8ff438.esm.js → internal/stm/tRef.esm.js} +6 -4
- package/internal/stm/tSemaphore.esm.js +73 -0
- package/internal/stm/tSet.esm.js +113 -0
- package/internal/stream/debounceState.esm.js +39 -0
- package/internal/stream/emit.esm.js +51 -0
- package/internal/stream/haltStrategy.esm.js +74 -0
- package/internal/stream/handoff.esm.js +79 -0
- package/internal/stream/handoffSignal.esm.js +40 -0
- package/internal/stream/pull.esm.js +10 -0
- package/internal/stream/sinkEndReason.esm.js +27 -0
- package/internal/stream/zipAllState.esm.js +65 -0
- package/internal/stream/zipChunksState.esm.js +41 -0
- package/{dist/stream-e44fba40.esm.js → internal/stream.esm.js} +399 -770
- package/internal/string-utils.esm.js +66 -0
- package/internal/subscriptionRef.esm.js +65 -0
- package/internal/supervisor/patch.esm.js +156 -0
- package/internal/supervisor.esm.js +204 -0
- package/{dist/synchronizedRef-1ceb6bd3.esm.js → internal/synchronizedRef.esm.js} +4 -4
- package/{dist/take-0d5e0eab.esm.js → internal/take.esm.js} +8 -8
- package/internal/testing/suspendedWarningData.esm.js +66 -0
- package/internal/testing/warningData.esm.js +75 -0
- package/{dist/timeout-4180303d.esm.js → internal/timeout.esm.js} +1 -1
- package/internal/tracer.esm.js +61 -0
- package/package.json +700 -554
- package/dist/Bigint-bf034c1f.esm.js +0 -370
- package/dist/Boolean-bf38e241.esm.js +0 -248
- package/dist/Brand-f068009f.esm.js +0 -215
- package/dist/Cache-27cd0ab7.esm.js +0 -120
- package/dist/Cause-5946c7a3.esm.js +0 -730
- package/dist/Channel-4bba5096.esm.js +0 -1109
- package/dist/ChannelChildExecutorDecision-674b3a48.esm.js +0 -125
- package/dist/ChannelMergeDecision-e5f34de0.esm.js +0 -70
- package/dist/ChannelMergeState-ae694a7c.esm.js +0 -114
- package/dist/ChannelMergeStrategy-9ef51c54.esm.js +0 -95
- package/dist/ChannelSingleProducerAsyncInput-1d15a3ec.esm.js +0 -52
- package/dist/ChannelUpstreamPullRequest-9b3a6733.esm.js +0 -95
- package/dist/ChannelUpstreamPullStrategy-85e1042b.esm.js +0 -94
- package/dist/Chunk-4c1f4599.esm.js +0 -1167
- package/dist/Clock-f8b987d7.esm.js +0 -88
- package/dist/Config-8d8f5a9f.esm.js +0 -358
- package/dist/ConfigError-41421a53.esm.js +0 -206
- package/dist/ConfigProvider-977168f2.esm.js +0 -220
- package/dist/ConfigProviderPathPatch-881ec2b5.esm.js +0 -79
- package/dist/ConfigSecret-9d3bf471.esm.js +0 -74
- package/dist/Console-9be5cd81.esm.js +0 -247
- package/dist/Context-c41aa832.esm.js +0 -312
- package/dist/Data-dee529b9.esm.js +0 -224
- package/dist/DefaultServices-b70d7e44.esm.js +0 -30
- package/dist/Deferred-9010d2ac.esm.js +0 -230
- package/dist/Differ-a249bf4d.esm.js +0 -975
- package/dist/Duration-98bca14c.esm.js +0 -467
- package/dist/Effect-ee05a487.esm.js +0 -3417
- package/dist/Effectable-a292d920.esm.js +0 -158
- package/dist/Effectable-d9b23ee3.esm.js +0 -89
- package/dist/Either-408d23a8.esm.js +0 -163
- package/dist/Either-aa46c018.esm.js +0 -473
- package/dist/Encoding-d95012ad.esm.js +0 -295
- package/dist/Equal-2a99fde3.esm.js +0 -65
- package/dist/Equivalence-cf2752b1.esm.js +0 -218
- package/dist/Error-083b7b69.esm.js +0 -53
- package/dist/ExecutionStrategy-e3775e86.esm.js +0 -168
- package/dist/Exit-666b4f01.esm.js +0 -371
- package/dist/Fiber-ebef9c60.esm.js +0 -473
- package/dist/FiberId-17e50f05.esm.js +0 -422
- package/dist/FiberRef-ddf157fd.esm.js +0 -338
- package/dist/FiberRefs-f705c1b5.esm.js +0 -122
- package/dist/FiberRefsPatch-04e0adc7.esm.js +0 -84
- package/dist/FiberStatus-7a24d5ef.esm.js +0 -187
- package/dist/Function-12511160.esm.js +0 -516
- package/dist/GlobalValue-b5edf230.esm.js +0 -25
- package/dist/GroupBy-4c667347.esm.js +0 -72
- package/dist/HKT-1990744d.esm.js +0 -5
- package/dist/Hash-7910f34f.esm.js +0 -179
- package/dist/HashMap-6c230bde.esm.js +0 -327
- package/dist/HashSet-69824ba8.esm.js +0 -907
- package/dist/HashSet-ae2856c1.esm.js +0 -256
- package/dist/Inspectable-b0c51e90.esm.js +0 -45
- package/dist/KeyedPool-08ee3618.esm.js +0 -273
- package/dist/Layer-8586a429.esm.js +0 -623
- package/dist/List-6e58a1e9.esm.js +0 -865
- package/dist/LogLevel-5a4fa506.esm.js +0 -222
- package/dist/LogSpan-f36e9619.esm.js +0 -42
- package/dist/Logger-aafaa76b.esm.js +0 -246
- package/dist/Metric-fef02dd6.esm.js +0 -442
- package/dist/MetricBoundaries-c8610876.esm.js +0 -61
- package/dist/MetricHook-6859801b.esm.js +0 -80
- package/dist/MetricKey-d1b96e85.esm.js +0 -118
- package/dist/MetricKeyType-4ce20904.esm.js +0 -168
- package/dist/MetricLabel-123185d1.esm.js +0 -48
- package/dist/MetricPair-840a98b7.esm.js +0 -45
- package/dist/MetricPolling-538e65c8.esm.js +0 -167
- package/dist/MetricRegistry-1e32438c.esm.js +0 -34
- package/dist/MetricState-ccc2e0db.esm.js +0 -172
- package/dist/MutableHashMap-02b39969.esm.js +0 -142
- package/dist/MutableHashSet-db4f96e8.esm.js +0 -101
- package/dist/MutableList-76401868.esm.js +0 -281
- package/dist/MutableQueue-446ac662.esm.js +0 -202
- package/dist/MutableRef-2734b082.esm.js +0 -176
- package/dist/NonEmptyIterable-e78d759e.esm.js +0 -33
- package/dist/Number-4b836a09.esm.js +0 -394
- package/dist/Option-df40d2b9.esm.js +0 -1135
- package/dist/Order-a875fe30.esm.js +0 -293
- package/dist/Ordering-079176ff.esm.js +0 -97
- package/dist/Pipeable-10760a1d.esm.js +0 -49
- package/dist/Pool-f1667f78.esm.js +0 -114
- package/dist/Predicate-6b61b95b.esm.js +0 -677
- package/dist/Queue-d99be5de.esm.js +0 -362
- package/dist/Random-5ed16d23.esm.js +0 -94
- package/dist/ReadonlyArray-0a71b226.esm.js +0 -1584
- package/dist/ReadonlyRecord-c9f03980.esm.js +0 -544
- package/dist/Ref-5eefaff1.esm.js +0 -248
- package/dist/Reloadable-e2eba7eb.esm.js +0 -159
- package/dist/Request-8b0e9130.esm.js +0 -175
- package/dist/RequestBlock-88afac19.esm.js +0 -114
- package/dist/RequestResolver-f17a25be.esm.js +0 -213
- package/dist/Resource-525ecb8a.esm.js +0 -111
- package/dist/Runtime-7b6c0a8b.esm.js +0 -175
- package/dist/RuntimeFlags-60048f70.esm.js +0 -344
- package/dist/RuntimeFlagsPatch-51f77dce.esm.js +0 -365
- package/dist/STM-1ef98d11.esm.js +0 -1321
- package/dist/Schedule-8502145c.esm.js +0 -1059
- package/dist/ScheduleDecision-e0b221dc.esm.js +0 -99
- package/dist/ScheduleInterval-cc7fc624.esm.js +0 -229
- package/dist/ScheduleIntervals-c4dc0500.esm.js +0 -252
- package/dist/Scheduler-844c1a90.esm.js +0 -343
- package/dist/Scope-0253ac82.esm.js +0 -131
- package/dist/ScopedRef-d92cda3b.esm.js +0 -80
- package/dist/Sink-322b0a96.esm.js +0 -1107
- package/dist/SortedMap-e429b26f.esm.js +0 -190
- package/dist/SortedSet-ffc2cefd.esm.js +0 -288
- package/dist/Stream-a54c82e5.esm.js +0 -3175
- package/dist/StreamEmit-bd696ab0.esm.js +0 -5
- package/dist/StreamHaltStrategy-592df221.esm.js +0 -201
- package/dist/String-5d27ad4c.esm.js +0 -648
- package/dist/Struct-b95eb81c.esm.js +0 -134
- package/dist/SubscriptionRef-93d8d20b.esm.js +0 -245
- package/dist/Supervisor-802f0ad0.esm.js +0 -160
- package/dist/Symbol-81368584.esm.js +0 -36
- package/dist/SynchronizedRef-5b418159.esm.js +0 -187
- package/dist/TArray-e0699120.esm.js +0 -412
- package/dist/TDeferred-96a9e821.esm.js +0 -120
- package/dist/TMap-0b08af84.esm.js +0 -419
- package/dist/TPriorityQueue-a5eb73d4.esm.js +0 -360
- package/dist/TQueue-2c224826.esm.js +0 -324
- package/dist/TRandom-dbfd1b25.esm.js +0 -192
- package/dist/TReentrantLock-83290260.esm.js +0 -435
- package/dist/TRef-bb02383a.esm.js +0 -135
- package/dist/TSemaphore-9a746009.esm.js +0 -183
- package/dist/TSet-91c5d646.esm.js +0 -412
- package/dist/Take-880079f7.esm.js +0 -214
- package/dist/TestAnnotation-f4477615.esm.js +0 -124
- package/dist/TestAnnotationMap-11d08509.esm.js +0 -114
- package/dist/TestAnnotations-39f7e011.esm.js +0 -91
- package/dist/TestClock-ab72e391.esm.js +0 -565
- package/dist/TestConfig-0d2c885c.esm.js +0 -33
- package/dist/TestContext-61178585.esm.js +0 -36
- package/dist/TestLive-61a5e471.esm.js +0 -55
- package/dist/TestServices-310ebe14.esm.js +0 -306
- package/dist/TestSized-745ac7e5.esm.js +0 -58
- package/dist/Tracer-da65ce12.esm.js +0 -75
- package/dist/Tuple-eefd2c03.esm.js +0 -187
- package/dist/Types-be3804ad.esm.js +0 -5
- package/dist/Unify-118c2d56.esm.js +0 -45
- package/dist/Utils-80c21479.esm.js +0 -362
- package/dist/core-64ab7ff5.esm.js +0 -3225
- package/dist/defaultServices-b9ca1236.esm.js +0 -359
- package/dist/sink-637a9670.esm.js +0 -2877
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { none } from '../FiberId/dist/effect-FiberId.esm.js';
|
|
2
|
+
import { globalValue } from '../GlobalValue/dist/effect-GlobalValue.esm.js';
|
|
3
|
+
import { stateful } from './fiberMessage.esm.js';
|
|
4
|
+
|
|
5
|
+
/** @internal */
|
|
6
|
+
const FiberScopeSymbolKey = "effect/FiberScope";
|
|
7
|
+
|
|
8
|
+
/** @internal */
|
|
9
|
+
const FiberScopeTypeId = /*#__PURE__*/Symbol.for(FiberScopeSymbolKey);
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* A `FiberScope` represents the scope of a fiber lifetime. The scope of a
|
|
13
|
+
* fiber can be retrieved using `Effect.descriptor`, and when forking fibers,
|
|
14
|
+
* you can specify a custom scope to fork them on by using the `forkIn`.
|
|
15
|
+
*
|
|
16
|
+
* @since 2.0.0
|
|
17
|
+
* @category models
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
/** @internal */
|
|
21
|
+
class Global {
|
|
22
|
+
[FiberScopeTypeId] = FiberScopeTypeId;
|
|
23
|
+
fiberId = none;
|
|
24
|
+
roots = new Set();
|
|
25
|
+
add(_runtimeFlags, child) {
|
|
26
|
+
this.roots.add(child);
|
|
27
|
+
child.addObserver(() => {
|
|
28
|
+
this.roots.delete(child);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/** @internal */
|
|
34
|
+
class Local {
|
|
35
|
+
[FiberScopeTypeId] = FiberScopeTypeId;
|
|
36
|
+
constructor(fiberId, parent) {
|
|
37
|
+
this.fiberId = fiberId;
|
|
38
|
+
this.parent = parent;
|
|
39
|
+
}
|
|
40
|
+
add(_runtimeFlags, child) {
|
|
41
|
+
this.parent.tell(stateful(parentFiber => {
|
|
42
|
+
parentFiber.addChild(child);
|
|
43
|
+
child.addObserver(() => {
|
|
44
|
+
parentFiber.removeChild(child);
|
|
45
|
+
});
|
|
46
|
+
}));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/** @internal */
|
|
51
|
+
const unsafeMake = fiber => {
|
|
52
|
+
return new Local(fiber.id(), fiber);
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
/** @internal */
|
|
56
|
+
const globalScope = /*#__PURE__*/globalValue( /*#__PURE__*/Symbol.for("effect/FiberScope/Global"), () => new Global());
|
|
57
|
+
|
|
58
|
+
export { FiberScopeTypeId, globalScope, unsafeMake };
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { symbol as symbol$1, equals } from '../Equal/dist/effect-Equal.esm.js';
|
|
2
|
+
import { pipe } from '../Function/dist/effect-Function.esm.js';
|
|
3
|
+
import { symbol, combine, hash } from '../Hash/dist/effect-Hash.esm.js';
|
|
4
|
+
|
|
5
|
+
const FiberStatusSymbolKey = "effect/FiberStatus";
|
|
6
|
+
|
|
7
|
+
/** @internal */
|
|
8
|
+
const FiberStatusTypeId = /*#__PURE__*/Symbol.for(FiberStatusSymbolKey);
|
|
9
|
+
|
|
10
|
+
/** @internal */
|
|
11
|
+
const OP_DONE = "Done";
|
|
12
|
+
|
|
13
|
+
/** @internal */
|
|
14
|
+
|
|
15
|
+
/** @internal */
|
|
16
|
+
const OP_RUNNING = "Running";
|
|
17
|
+
|
|
18
|
+
/** @internal */
|
|
19
|
+
|
|
20
|
+
/** @internal */
|
|
21
|
+
const OP_SUSPENDED = "Suspended";
|
|
22
|
+
|
|
23
|
+
/** @internal */
|
|
24
|
+
|
|
25
|
+
/** @internal */
|
|
26
|
+
class Done {
|
|
27
|
+
[FiberStatusTypeId] = FiberStatusTypeId;
|
|
28
|
+
_tag = OP_DONE;
|
|
29
|
+
[symbol]() {
|
|
30
|
+
return pipe(hash(FiberStatusSymbolKey), combine(hash(this._tag)));
|
|
31
|
+
}
|
|
32
|
+
[symbol$1](that) {
|
|
33
|
+
return isFiberStatus(that) && that._tag === OP_DONE;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
/** @internal */
|
|
38
|
+
class Running {
|
|
39
|
+
[FiberStatusTypeId] = FiberStatusTypeId;
|
|
40
|
+
_tag = OP_RUNNING;
|
|
41
|
+
constructor(runtimeFlags) {
|
|
42
|
+
this.runtimeFlags = runtimeFlags;
|
|
43
|
+
}
|
|
44
|
+
[symbol]() {
|
|
45
|
+
return pipe(hash(FiberStatusSymbolKey), combine(hash(this._tag)), combine(hash(this.runtimeFlags)));
|
|
46
|
+
}
|
|
47
|
+
[symbol$1](that) {
|
|
48
|
+
return isFiberStatus(that) && that._tag === OP_RUNNING && this.runtimeFlags === that.runtimeFlags;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/** @internal */
|
|
53
|
+
class Suspended {
|
|
54
|
+
[FiberStatusTypeId] = FiberStatusTypeId;
|
|
55
|
+
_tag = OP_SUSPENDED;
|
|
56
|
+
constructor(runtimeFlags, blockingOn) {
|
|
57
|
+
this.runtimeFlags = runtimeFlags;
|
|
58
|
+
this.blockingOn = blockingOn;
|
|
59
|
+
}
|
|
60
|
+
[symbol]() {
|
|
61
|
+
return pipe(hash(FiberStatusSymbolKey), combine(hash(this._tag)), combine(hash(this.runtimeFlags)), combine(hash(this.blockingOn)));
|
|
62
|
+
}
|
|
63
|
+
[symbol$1](that) {
|
|
64
|
+
return isFiberStatus(that) && that._tag === OP_SUSPENDED && this.runtimeFlags === that.runtimeFlags && equals(this.blockingOn, that.blockingOn);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/** @internal */
|
|
69
|
+
const done = /*#__PURE__*/new Done();
|
|
70
|
+
|
|
71
|
+
/** @internal */
|
|
72
|
+
const running = runtimeFlags => new Running(runtimeFlags);
|
|
73
|
+
|
|
74
|
+
/** @internal */
|
|
75
|
+
const suspended = (runtimeFlags, blockingOn) => new Suspended(runtimeFlags, blockingOn);
|
|
76
|
+
|
|
77
|
+
/** @internal */
|
|
78
|
+
const isFiberStatus = u => typeof u === "object" && u != null && FiberStatusTypeId in u;
|
|
79
|
+
|
|
80
|
+
/** @internal */
|
|
81
|
+
const isDone = self => self._tag === OP_DONE;
|
|
82
|
+
|
|
83
|
+
/** @internal */
|
|
84
|
+
const isRunning = self => self._tag === OP_RUNNING;
|
|
85
|
+
|
|
86
|
+
/** @internal */
|
|
87
|
+
const isSuspended = self => self._tag === OP_SUSPENDED;
|
|
88
|
+
|
|
89
|
+
export { FiberStatusTypeId, OP_DONE, OP_RUNNING, OP_SUSPENDED, done, isDone, isFiberStatus, isRunning, isSuspended, running, suspended };
|
|
@@ -1,16 +1,18 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
import {
|
|
1
|
+
import { isInterruptedOnly } from '../Cause/dist/effect-Cause.esm.js';
|
|
2
|
+
import { map as map$2, of, unsafeFromArray } from '../Chunk/dist/effect-Chunk.esm.js';
|
|
3
|
+
import { make as make$1, await as _await, succeed as succeed$1 } from '../Deferred/dist/effect-Deferred.esm.js';
|
|
4
|
+
import { succeed, as, gen, acquireRelease, flatMap as flatMap$1, zipRight, map as map$1, forkScoped, sync, forEach, catchSomeCause, unit } from '../Effect/dist/effect-Effect.esm.js';
|
|
5
|
+
import { succeed as succeed$2, map as map$4 } from '../Exit/dist/effect-Exit.esm.js';
|
|
6
|
+
import { dual, pipe } from '../Function/dist/effect-Function.esm.js';
|
|
7
|
+
import { match, fromNullable, map as map$3, some, none } from '../Option/dist/effect-Option.esm.js';
|
|
8
|
+
import { pipeArguments } from '../Pipeable/dist/effect-Pipeable.esm.js';
|
|
9
|
+
import { shutdown, bounded, offer, DequeueTypeId, capacity, size, awaitShutdown, isShutdown, isFull, isEmpty, take, takeAll, takeUpTo, takeBetween, takeN, poll, unbounded } from '../Queue/dist/effect-Queue.esm.js';
|
|
10
|
+
import { make as make$2, update, get } from '../Ref/dist/effect-Ref.esm.js';
|
|
11
|
+
import { drain } from './channel.esm.js';
|
|
12
|
+
import { runScoped } from './channel/channelExecutor.esm.js';
|
|
13
|
+
import { pipeTo, readWithCause, flatMap as flatMap$2, fromEffect as fromEffect$1 } from './core-stream.esm.js';
|
|
14
|
+
import { flatMap, flattenTake, fromQueue, filterEffect, map, zipWithIndex, unwrapScoped, mapEffectSequential, distributedWithDynamicCallback, flattenExitOption, matchConcurrency, fromEffect, mapEffectPar, toChannel } from './stream.esm.js';
|
|
15
|
+
import { TakeImpl, of as of$1, chunk, failCause, end } from './take.esm.js';
|
|
14
16
|
|
|
15
17
|
/** @internal */
|
|
16
18
|
const GroupBySymbolKey = "effect/GroupBy";
|
|
@@ -203,4 +205,4 @@ const groupByIterable = /*#__PURE__*/dual(2, (iterable, f) => {
|
|
|
203
205
|
return unsafeFromArray(builder.map(tuple => [tuple[0], unsafeFromArray(tuple[1])]));
|
|
204
206
|
});
|
|
205
207
|
|
|
206
|
-
export { GroupByTypeId
|
|
208
|
+
export { GroupByTypeId, bindEffect, evaluate, filter, first, groupBy, groupByIterable, groupByKey, make, mapEffectOptions };
|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
1
|
+
import { fromIterable, unsafeGet, drop, empty, isEmpty as isEmpty$1, unsafeHead, of, prepend, filter, appendAll, append } from '../Chunk/dist/effect-Chunk.esm.js';
|
|
2
|
+
import { pipe, dual } from '../Function/dist/effect-Function.esm.js';
|
|
3
|
+
import { InvalidHubCapacityException } from './cause.esm.js';
|
|
4
|
+
import { flatMap, sync, map, deferredMake, fiberId, withFiberRuntime, unit, succeed, suspend, interrupt, deferredAwait, uninterruptible, asUnit, whenEffect, deferredSucceed, zipRight, exitInterrupt, tap, deferredUnsafeDone, deferredInterruptWith, deferredUnsafeMake, onInterrupt } from './core.esm.js';
|
|
5
|
+
import { sequential } from './executionStrategy.esm.js';
|
|
6
|
+
import { scopeMake, forEachParUnboundedDiscard, all, acquireRelease, forEachParUnbounded } from './fiberRuntime.esm.js';
|
|
7
|
+
import { EnqueueTypeId, enqueueVariance, DequeueTypeId, dequeueVariance } from './queue.esm.js';
|
|
8
|
+
import { unbounded as unbounded$1, poll, EmptyMutableQueue, offer, isEmpty as isEmpty$2, offerAll, pollUpTo } from '../MutableQueue/dist/effect-MutableQueue.esm.js';
|
|
9
|
+
import { make, get, set } from '../MutableRef/dist/effect-MutableRef.esm.js';
|
|
10
|
+
import { none, some } from '../Option/dist/effect-Option.esm.js';
|
|
11
|
+
import { pipeArguments } from '../Pipeable/dist/effect-Pipeable.esm.js';
|
|
11
12
|
|
|
12
13
|
/** @internal */
|
|
13
14
|
|
|
@@ -34,46 +35,46 @@ const removeSubscribers = (subscription, pollers) => subscribers => {
|
|
|
34
35
|
};
|
|
35
36
|
|
|
36
37
|
/** @internal */
|
|
37
|
-
const bounded
|
|
38
|
+
const bounded = requestedCapacity => pipe(sync(() => makeBoundedHub(requestedCapacity)), flatMap(atomicHub => makeHub(atomicHub, new BackPressureStrategy())));
|
|
38
39
|
|
|
39
40
|
/** @internal */
|
|
40
|
-
const dropping
|
|
41
|
+
const dropping = requestedCapacity => pipe(sync(() => makeBoundedHub(requestedCapacity)), flatMap(atomicHub => makeHub(atomicHub, new DroppingStrategy())));
|
|
41
42
|
|
|
42
43
|
/** @internal */
|
|
43
|
-
const sliding
|
|
44
|
+
const sliding = requestedCapacity => pipe(sync(() => makeBoundedHub(requestedCapacity)), flatMap(atomicHub => makeHub(atomicHub, new SlidingStrategy())));
|
|
44
45
|
|
|
45
46
|
/** @internal */
|
|
46
|
-
const unbounded
|
|
47
|
+
const unbounded = () => pipe(sync(() => makeUnboundedHub()), flatMap(atomicHub => makeHub(atomicHub, new DroppingStrategy())));
|
|
47
48
|
|
|
48
49
|
/** @internal */
|
|
49
|
-
const capacity
|
|
50
|
+
const capacity = self => self.capacity();
|
|
50
51
|
|
|
51
52
|
/** @internal */
|
|
52
|
-
const size
|
|
53
|
+
const size = self => self.size();
|
|
53
54
|
|
|
54
55
|
/** @internal */
|
|
55
|
-
const isFull
|
|
56
|
+
const isFull = self => self.isFull();
|
|
56
57
|
|
|
57
58
|
/** @internal */
|
|
58
|
-
const isEmpty
|
|
59
|
+
const isEmpty = self => self.isEmpty();
|
|
59
60
|
|
|
60
61
|
/** @internal */
|
|
61
|
-
const shutdown
|
|
62
|
+
const shutdown = self => self.shutdown();
|
|
62
63
|
|
|
63
64
|
/** @internal */
|
|
64
|
-
const isShutdown
|
|
65
|
+
const isShutdown = self => self.isShutdown();
|
|
65
66
|
|
|
66
67
|
/** @internal */
|
|
67
|
-
const awaitShutdown
|
|
68
|
+
const awaitShutdown = self => self.awaitShutdown();
|
|
68
69
|
|
|
69
70
|
/** @internal */
|
|
70
|
-
const publish
|
|
71
|
+
const publish = /*#__PURE__*/dual(2, (self, value) => self.publish(value));
|
|
71
72
|
|
|
72
73
|
/** @internal */
|
|
73
|
-
const publishAll
|
|
74
|
+
const publishAll = /*#__PURE__*/dual(2, (self, elements) => self.publishAll(elements));
|
|
74
75
|
|
|
75
76
|
/** @internal */
|
|
76
|
-
const subscribe
|
|
77
|
+
const subscribe = self => self.subscribe();
|
|
77
78
|
|
|
78
79
|
/** @internal */
|
|
79
80
|
const makeBoundedHub = requestedCapacity => {
|
|
@@ -93,7 +94,7 @@ const makeUnboundedHub = () => {
|
|
|
93
94
|
};
|
|
94
95
|
|
|
95
96
|
/** @internal */
|
|
96
|
-
const makeSubscription = (hub, subscribers, strategy) => map(deferredMake(), deferred => unsafeMakeSubscription(hub, subscribers, hub.subscribe(), unbounded$
|
|
97
|
+
const makeSubscription = (hub, subscribers, strategy) => map(deferredMake(), deferred => unsafeMakeSubscription(hub, subscribers, hub.subscribe(), unbounded$1(), deferred, make(false), strategy));
|
|
97
98
|
|
|
98
99
|
/** @internal */
|
|
99
100
|
const unsafeMakeSubscription = (hub, subscribers, subscription, pollers, shutdownHook, shutdownFlag, strategy) => {
|
|
@@ -423,7 +424,7 @@ class BoundedHubSingle {
|
|
|
423
424
|
}
|
|
424
425
|
publishAll(elements) {
|
|
425
426
|
const chunk = fromIterable(elements);
|
|
426
|
-
if (isEmpty$
|
|
427
|
+
if (isEmpty$1(chunk)) {
|
|
427
428
|
return chunk;
|
|
428
429
|
}
|
|
429
430
|
if (this.publish(unsafeHead(chunk))) {
|
|
@@ -703,7 +704,7 @@ class SubscriptionImpl {
|
|
|
703
704
|
if (get(this.shutdownFlag)) {
|
|
704
705
|
return interrupt;
|
|
705
706
|
}
|
|
706
|
-
const message = isEmpty$
|
|
707
|
+
const message = isEmpty$2(this.pollers) ? this.subscription.poll(EmptyMutableQueue) : EmptyMutableQueue;
|
|
707
708
|
if (message === EmptyMutableQueue) {
|
|
708
709
|
const deferred = deferredUnsafeMake(state.id());
|
|
709
710
|
return pipe(suspend(() => {
|
|
@@ -723,7 +724,7 @@ class SubscriptionImpl {
|
|
|
723
724
|
if (get(this.shutdownFlag)) {
|
|
724
725
|
return interrupt;
|
|
725
726
|
}
|
|
726
|
-
const as = isEmpty$
|
|
727
|
+
const as = isEmpty$2(this.pollers) ? unsafePollAllSubscription(this.subscription) : empty();
|
|
727
728
|
this.strategy.unsafeOnHubEmptySpace(this.hub, this.subscribers);
|
|
728
729
|
return succeed(as);
|
|
729
730
|
});
|
|
@@ -733,7 +734,7 @@ class SubscriptionImpl {
|
|
|
733
734
|
if (get(this.shutdownFlag)) {
|
|
734
735
|
return interrupt;
|
|
735
736
|
}
|
|
736
|
-
const as = isEmpty$
|
|
737
|
+
const as = isEmpty$2(this.pollers) ? unsafePollN(this.subscription, max) : empty();
|
|
737
738
|
this.strategy.unsafeOnHubEmptySpace(this.hub, this.subscribers);
|
|
738
739
|
return succeed(as);
|
|
739
740
|
});
|
|
@@ -833,7 +834,7 @@ class HubImpl {
|
|
|
833
834
|
}
|
|
834
835
|
const surplus = unsafePublishAll(this.hub, elements);
|
|
835
836
|
this.strategy.unsafeCompleteSubscribers(this.hub, this.subscribers);
|
|
836
|
-
if (isEmpty$
|
|
837
|
+
if (isEmpty$1(surplus)) {
|
|
837
838
|
return succeed(true);
|
|
838
839
|
}
|
|
839
840
|
return this.strategy.handleSurplus(this.hub, this.subscribers, surplus, this.shutdownFlag);
|
|
@@ -930,7 +931,7 @@ const unsafeRemove = (queue, value) => {
|
|
|
930
931
|
* @internal
|
|
931
932
|
*/
|
|
932
933
|
class BackPressureStrategy {
|
|
933
|
-
publishers = unbounded$
|
|
934
|
+
publishers = unbounded$1();
|
|
934
935
|
shutdown() {
|
|
935
936
|
return flatMap(fiberId, fiberId => flatMap(sync(() => unsafePollAllQueue(this.publishers)), publishers => forEachParUnboundedDiscard(publishers, ([_, deferred, last]) => last ? pipe(deferredInterruptWith(deferred, fiberId), asUnit) : unit, false)));
|
|
936
937
|
}
|
|
@@ -1072,7 +1073,7 @@ const unsafeStrategyCompletePollers = (strategy, hub, subscribers, subscription,
|
|
|
1072
1073
|
const poller = pipe(pollers, poll(EmptyMutableQueue));
|
|
1073
1074
|
if (poller === EmptyMutableQueue) {
|
|
1074
1075
|
pipe(subscribers, removeSubscribers(subscription, pollers));
|
|
1075
|
-
if (isEmpty$
|
|
1076
|
+
if (isEmpty$2(pollers)) {
|
|
1076
1077
|
keepPolling = false;
|
|
1077
1078
|
} else {
|
|
1078
1079
|
pipe(subscribers, addSubscribers(subscription, pollers));
|
|
@@ -1098,167 +1099,4 @@ const unsafeStrategyCompleteSubscribers = (strategy, hub, subscribers) => {
|
|
|
1098
1099
|
}
|
|
1099
1100
|
};
|
|
1100
1101
|
|
|
1101
|
-
|
|
1102
|
-
* @since 2.0.0
|
|
1103
|
-
*/
|
|
1104
|
-
|
|
1105
|
-
/**
|
|
1106
|
-
* A `Hub<A>` is an asynchronous message hub into which publishers can publish
|
|
1107
|
-
* messages of type `A` and subscribers can subscribe to take messages of type
|
|
1108
|
-
* `A`.
|
|
1109
|
-
*
|
|
1110
|
-
* @since 2.0.0
|
|
1111
|
-
* @category models
|
|
1112
|
-
*/
|
|
1113
|
-
|
|
1114
|
-
/**
|
|
1115
|
-
* Creates a bounded hub with the back pressure strategy. The hub will retain
|
|
1116
|
-
* messages until they have been taken by all subscribers, applying back
|
|
1117
|
-
* pressure to publishers if the hub is at capacity.
|
|
1118
|
-
*
|
|
1119
|
-
* For best performance use capacities that are powers of two.
|
|
1120
|
-
*
|
|
1121
|
-
* @since 2.0.0
|
|
1122
|
-
* @category constructors
|
|
1123
|
-
*/
|
|
1124
|
-
const bounded = bounded$1;
|
|
1125
|
-
|
|
1126
|
-
/**
|
|
1127
|
-
* Creates a bounded hub with the dropping strategy. The hub will drop new
|
|
1128
|
-
* messages if the hub is at capacity.
|
|
1129
|
-
*
|
|
1130
|
-
* For best performance use capacities that are powers of two.
|
|
1131
|
-
*
|
|
1132
|
-
* @since 2.0.0
|
|
1133
|
-
* @category constructors
|
|
1134
|
-
*/
|
|
1135
|
-
const dropping = dropping$1;
|
|
1136
|
-
|
|
1137
|
-
/**
|
|
1138
|
-
* Creates a bounded hub with the sliding strategy. The hub will add new
|
|
1139
|
-
* messages and drop old messages if the hub is at capacity.
|
|
1140
|
-
*
|
|
1141
|
-
* For best performance use capacities that are powers of two.
|
|
1142
|
-
*
|
|
1143
|
-
* @since 2.0.0
|
|
1144
|
-
* @category constructors
|
|
1145
|
-
*/
|
|
1146
|
-
const sliding = sliding$1;
|
|
1147
|
-
|
|
1148
|
-
/**
|
|
1149
|
-
* Creates an unbounded hub.
|
|
1150
|
-
*
|
|
1151
|
-
* @since 2.0.0
|
|
1152
|
-
* @category constructors
|
|
1153
|
-
*/
|
|
1154
|
-
const unbounded = unbounded$1;
|
|
1155
|
-
|
|
1156
|
-
/**
|
|
1157
|
-
* Returns the number of elements the queue can hold.
|
|
1158
|
-
*
|
|
1159
|
-
* @since 2.0.0
|
|
1160
|
-
* @category getters
|
|
1161
|
-
*/
|
|
1162
|
-
const capacity = capacity$1;
|
|
1163
|
-
|
|
1164
|
-
/**
|
|
1165
|
-
* Retrieves the size of the queue, which is equal to the number of elements
|
|
1166
|
-
* in the queue. This may be negative if fibers are suspended waiting for
|
|
1167
|
-
* elements to be added to the queue.
|
|
1168
|
-
*
|
|
1169
|
-
* @since 2.0.0
|
|
1170
|
-
* @category getters
|
|
1171
|
-
*/
|
|
1172
|
-
const size = size$1;
|
|
1173
|
-
|
|
1174
|
-
/**
|
|
1175
|
-
* Returns `true` if the `Queue` contains at least one element, `false`
|
|
1176
|
-
* otherwise.
|
|
1177
|
-
*
|
|
1178
|
-
* @since 2.0.0
|
|
1179
|
-
* @category getters
|
|
1180
|
-
*/
|
|
1181
|
-
const isFull = isFull$1;
|
|
1182
|
-
|
|
1183
|
-
/**
|
|
1184
|
-
* Returns `true` if the `Queue` contains zero elements, `false` otherwise.
|
|
1185
|
-
*
|
|
1186
|
-
* @since 2.0.0
|
|
1187
|
-
* @category getters
|
|
1188
|
-
*/
|
|
1189
|
-
const isEmpty = isEmpty$1;
|
|
1190
|
-
|
|
1191
|
-
/**
|
|
1192
|
-
* Interrupts any fibers that are suspended on `offer` or `take`. Future calls
|
|
1193
|
-
* to `offer*` and `take*` will be interrupted immediately.
|
|
1194
|
-
*
|
|
1195
|
-
* @since 2.0.0
|
|
1196
|
-
* @category utils
|
|
1197
|
-
*/
|
|
1198
|
-
const shutdown = shutdown$1;
|
|
1199
|
-
|
|
1200
|
-
/**
|
|
1201
|
-
* Returns `true` if `shutdown` has been called, otherwise returns `false`.
|
|
1202
|
-
*
|
|
1203
|
-
* @since 2.0.0
|
|
1204
|
-
* @category getters
|
|
1205
|
-
*/
|
|
1206
|
-
const isShutdown = isShutdown$1;
|
|
1207
|
-
|
|
1208
|
-
/**
|
|
1209
|
-
* Waits until the queue is shutdown. The `Effect` returned by this method will
|
|
1210
|
-
* not resume until the queue has been shutdown. If the queue is already
|
|
1211
|
-
* shutdown, the `Effect` will resume right away.
|
|
1212
|
-
*
|
|
1213
|
-
* @since 2.0.0
|
|
1214
|
-
* @category utils
|
|
1215
|
-
*/
|
|
1216
|
-
const awaitShutdown = awaitShutdown$1;
|
|
1217
|
-
|
|
1218
|
-
/**
|
|
1219
|
-
* Publishes a message to the hub, returning whether the message was published
|
|
1220
|
-
* to the hub.
|
|
1221
|
-
*
|
|
1222
|
-
* @since 2.0.0
|
|
1223
|
-
* @category utils
|
|
1224
|
-
*/
|
|
1225
|
-
const publish = publish$1;
|
|
1226
|
-
|
|
1227
|
-
/**
|
|
1228
|
-
* Publishes all of the specified messages to the hub, returning whether they
|
|
1229
|
-
* were published to the hub.
|
|
1230
|
-
*
|
|
1231
|
-
* @since 2.0.0
|
|
1232
|
-
* @category utils
|
|
1233
|
-
*/
|
|
1234
|
-
const publishAll = publishAll$1;
|
|
1235
|
-
|
|
1236
|
-
/**
|
|
1237
|
-
* Subscribes to receive messages from the hub. The resulting subscription can
|
|
1238
|
-
* be evaluated multiple times within the scope to take a message from the hub
|
|
1239
|
-
* each time.
|
|
1240
|
-
*
|
|
1241
|
-
* @since 2.0.0
|
|
1242
|
-
* @category utils
|
|
1243
|
-
*/
|
|
1244
|
-
const subscribe = subscribe$1;
|
|
1245
|
-
|
|
1246
|
-
var Hub = /*#__PURE__*/Object.freeze({
|
|
1247
|
-
__proto__: null,
|
|
1248
|
-
bounded: bounded,
|
|
1249
|
-
dropping: dropping,
|
|
1250
|
-
sliding: sliding,
|
|
1251
|
-
unbounded: unbounded,
|
|
1252
|
-
capacity: capacity,
|
|
1253
|
-
size: size,
|
|
1254
|
-
isFull: isFull,
|
|
1255
|
-
isEmpty: isEmpty,
|
|
1256
|
-
shutdown: shutdown,
|
|
1257
|
-
isShutdown: isShutdown,
|
|
1258
|
-
awaitShutdown: awaitShutdown,
|
|
1259
|
-
publish: publish,
|
|
1260
|
-
publishAll: publishAll,
|
|
1261
|
-
subscribe: subscribe
|
|
1262
|
-
});
|
|
1263
|
-
|
|
1264
|
-
export { Hub as H, shutdown as a, bounded as b, sliding as c, dropping as d, capacity as e, size as f, isEmpty as g, isShutdown as h, isFull as i, awaitShutdown as j, publishAll as k, publish as p, subscribe as s, unbounded as u };
|
|
1102
|
+
export { DroppingStrategy, SlidingStrategy, awaitShutdown, bounded, capacity, dropping, isEmpty, isFull, isShutdown, makeHub, publish, publishAll, shutdown, size, sliding, subscribe, unbounded, unsafeMakeHub, unsafeMakeSubscription };
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { decode, infinity } from '../Duration/dist/effect-Duration.esm.js';
|
|
2
|
+
import { equals, symbol as symbol$1 } from '../Equal/dist/effect-Equal.esm.js';
|
|
3
|
+
import { dual, pipe } from '../Function/dist/effect-Function.esm.js';
|
|
4
|
+
import { symbol, combine, hash, string } from '../Hash/dist/effect-Hash.esm.js';
|
|
5
|
+
import { empty, get as get$2, has, set, remove, values } from '../HashMap/dist/effect-HashMap.esm.js';
|
|
6
|
+
import { map, context, fiberId, sync, flatMap, forEachSequentialDiscard, suspend, uninterruptibleMask, deferredUnsafeMake, provideContext, matchCauseEffect, zipRight, deferredFailCause, failCause, as, deferredSucceed, deferredAwait, succeed, forEachSequential } from './core.esm.js';
|
|
7
|
+
import { all, scopeMake, scopeExtend } from './fiberRuntime.esm.js';
|
|
8
|
+
import { get as get$1, makeWithTTL as makeWithTTL$1 } from './pool.esm.js';
|
|
9
|
+
import { make as make$1, get as get$3, update } from '../MutableRef/dist/effect-MutableRef.esm.js';
|
|
10
|
+
import { getOrUndefined, getOrElse, none, some } from '../Option/dist/effect-Option.esm.js';
|
|
11
|
+
import { pipeArguments } from '../Pipeable/dist/effect-Pipeable.esm.js';
|
|
12
|
+
import { isTagged } from '../Predicate/dist/effect-Predicate.esm.js';
|
|
13
|
+
|
|
14
|
+
/** @internal */
|
|
15
|
+
const KeyedPoolSymbolKey = "effect/KeyedPool";
|
|
16
|
+
|
|
17
|
+
/** @internal */
|
|
18
|
+
const KeyedPoolTypeId = /*#__PURE__*/Symbol.for(KeyedPoolSymbolKey);
|
|
19
|
+
const KeyedPoolMapValueSymbol = /*#__PURE__*/Symbol.for("effect/KeyedPool/MapValue");
|
|
20
|
+
const keyedPoolVariance = {
|
|
21
|
+
_K: _ => _,
|
|
22
|
+
_E: _ => _,
|
|
23
|
+
_A: _ => _
|
|
24
|
+
};
|
|
25
|
+
class KeyedPoolImpl {
|
|
26
|
+
[KeyedPoolTypeId] = keyedPoolVariance;
|
|
27
|
+
constructor(getOrCreatePool, activePools) {
|
|
28
|
+
this.getOrCreatePool = getOrCreatePool;
|
|
29
|
+
this.activePools = activePools;
|
|
30
|
+
}
|
|
31
|
+
get(key) {
|
|
32
|
+
return flatMap(this.getOrCreatePool(key), get$1);
|
|
33
|
+
}
|
|
34
|
+
invalidate(item) {
|
|
35
|
+
return flatMap(this.activePools(), forEachSequentialDiscard(pool => pool.invalidate(item)));
|
|
36
|
+
}
|
|
37
|
+
pipe() {
|
|
38
|
+
return pipeArguments(this, arguments);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
class Complete {
|
|
42
|
+
_tag = "Complete";
|
|
43
|
+
[KeyedPoolMapValueSymbol] = KeyedPoolMapValueSymbol;
|
|
44
|
+
constructor(pool) {
|
|
45
|
+
this.pool = pool;
|
|
46
|
+
}
|
|
47
|
+
[symbol]() {
|
|
48
|
+
return pipe(string("effect/KeyedPool/Complete"), combine(hash(this.pool)));
|
|
49
|
+
}
|
|
50
|
+
[symbol$1](u) {
|
|
51
|
+
return isComplete(u) && equals(this.pool, u.pool);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
const isComplete = u => isTagged(u, "Complete") && KeyedPoolMapValueSymbol in u;
|
|
55
|
+
class Pending {
|
|
56
|
+
_tag = "Pending";
|
|
57
|
+
[KeyedPoolMapValueSymbol] = KeyedPoolMapValueSymbol;
|
|
58
|
+
constructor(deferred) {
|
|
59
|
+
this.deferred = deferred;
|
|
60
|
+
}
|
|
61
|
+
[symbol]() {
|
|
62
|
+
return pipe(string("effect/KeyedPool/Pending"), combine(hash(this.deferred)));
|
|
63
|
+
}
|
|
64
|
+
[symbol$1](u) {
|
|
65
|
+
return isPending(u) && equals(this.deferred, u.deferred);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
const isPending = u => isTagged(u, "Pending") && KeyedPoolMapValueSymbol in u;
|
|
69
|
+
const makeImpl = (get, min, max, timeToLive) => pipe(all([context(), fiberId, sync(() => make$1(empty())), scopeMake()]), map(([context, fiberId, map, scope]) => {
|
|
70
|
+
const getOrCreatePool = key => suspend(() => {
|
|
71
|
+
let value = getOrUndefined(get$2(get$3(map), key));
|
|
72
|
+
if (value === undefined) {
|
|
73
|
+
return uninterruptibleMask(restore => {
|
|
74
|
+
const deferred = deferredUnsafeMake(fiberId);
|
|
75
|
+
value = new Pending(deferred);
|
|
76
|
+
let previous = undefined;
|
|
77
|
+
if (has(get$3(map), key)) {
|
|
78
|
+
previous = getOrUndefined(get$2(get$3(map), key));
|
|
79
|
+
} else {
|
|
80
|
+
update(map, set(key, value));
|
|
81
|
+
}
|
|
82
|
+
if (previous === undefined) {
|
|
83
|
+
return pipe(restore(scopeExtend(makeWithTTL$1({
|
|
84
|
+
acquire: provideContext(get(key), context),
|
|
85
|
+
min: min(key),
|
|
86
|
+
max: max(key),
|
|
87
|
+
timeToLive: getOrElse(timeToLive(key), () => infinity)
|
|
88
|
+
}), scope)), matchCauseEffect({
|
|
89
|
+
onFailure: cause => {
|
|
90
|
+
const current = getOrUndefined(get$2(get$3(map), key));
|
|
91
|
+
if (equals(current, value)) {
|
|
92
|
+
update(map, remove(key));
|
|
93
|
+
}
|
|
94
|
+
return zipRight(deferredFailCause(deferred, cause), failCause(cause));
|
|
95
|
+
},
|
|
96
|
+
onSuccess: pool => {
|
|
97
|
+
update(map, set(key, new Complete(pool)));
|
|
98
|
+
return as(deferredSucceed(deferred, pool), pool);
|
|
99
|
+
}
|
|
100
|
+
}));
|
|
101
|
+
}
|
|
102
|
+
switch (previous._tag) {
|
|
103
|
+
case "Complete":
|
|
104
|
+
{
|
|
105
|
+
return succeed(previous.pool);
|
|
106
|
+
}
|
|
107
|
+
case "Pending":
|
|
108
|
+
{
|
|
109
|
+
return restore(deferredAwait(previous.deferred));
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
switch (value._tag) {
|
|
115
|
+
case "Complete":
|
|
116
|
+
{
|
|
117
|
+
return succeed(value.pool);
|
|
118
|
+
}
|
|
119
|
+
case "Pending":
|
|
120
|
+
{
|
|
121
|
+
return deferredAwait(value.deferred);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
const activePools = () => suspend(() => forEachSequential(Array.from(values(get$3(map))), value => {
|
|
126
|
+
switch (value._tag) {
|
|
127
|
+
case "Complete":
|
|
128
|
+
{
|
|
129
|
+
return succeed(value.pool);
|
|
130
|
+
}
|
|
131
|
+
case "Pending":
|
|
132
|
+
{
|
|
133
|
+
return deferredAwait(value.deferred);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}));
|
|
137
|
+
return new KeyedPoolImpl(getOrCreatePool, activePools);
|
|
138
|
+
}));
|
|
139
|
+
|
|
140
|
+
/** @internal */
|
|
141
|
+
const make = options => makeImpl(options.acquire, () => options.size, () => options.size, () => none());
|
|
142
|
+
|
|
143
|
+
/** @internal */
|
|
144
|
+
const makeWith = options => makeImpl(options.acquire, options.size, options.size, () => none());
|
|
145
|
+
|
|
146
|
+
/** @internal */
|
|
147
|
+
const makeWithTTL = options => {
|
|
148
|
+
const timeToLive = decode(options.timeToLive);
|
|
149
|
+
return makeImpl(options.acquire, options.min, options.max, () => some(timeToLive));
|
|
150
|
+
};
|
|
151
|
+
|
|
152
|
+
/** @internal */
|
|
153
|
+
const makeWithTTLBy = options => makeImpl(options.acquire, options.min, options.max, key => some(decode(options.timeToLive(key))));
|
|
154
|
+
|
|
155
|
+
/** @internal */
|
|
156
|
+
const get = /*#__PURE__*/dual(2, (self, key) => self.get(key));
|
|
157
|
+
|
|
158
|
+
/** @internal */
|
|
159
|
+
const invalidate = /*#__PURE__*/dual(2, (self, item) => self.invalidate(item));
|
|
160
|
+
|
|
161
|
+
export { KeyedPoolTypeId, get, invalidate, make, makeWith, makeWithTTL, makeWithTTLBy };
|