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
|
@@ -1,15 +1,1071 @@
|
|
|
1
|
-
import '../../dist/Equal
|
|
2
|
-
import '../../dist/Equivalence
|
|
3
|
-
import '../../dist/Function
|
|
4
|
-
import '../../
|
|
5
|
-
import '../../
|
|
6
|
-
import '../../dist/
|
|
7
|
-
import '../../dist/
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
1
|
+
import { equivalence } from '../../Equal/dist/effect-Equal.esm.js';
|
|
2
|
+
import { make } from '../../Equivalence/dist/effect-Equivalence.esm.js';
|
|
3
|
+
import { dual, constNull, constUndefined, identity } from '../../Function/dist/effect-Function.esm.js';
|
|
4
|
+
import { getRight as getRight$1, getLeft as getLeft$1, right, left, isLeft } from '../../internal/Either.esm.js';
|
|
5
|
+
import { none as none$1, some as some$1, isOption as isOption$1, isNone as isNone$1, isSome as isSome$1 } from '../../internal/Option.esm.js';
|
|
6
|
+
import { sum as sum$1, multiply as multiply$1, subtract as subtract$1, divide as divide$1 } from '../../Number/dist/effect-Number.esm.js';
|
|
7
|
+
import { make as make$1 } from '../../Order/dist/effect-Order.esm.js';
|
|
8
|
+
import { adapter as adapter$1 } from '../../Utils/dist/effect-Utils.esm.js';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* @since 2.0.0
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* @category models
|
|
16
|
+
* @since 2.0.0
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* @category symbols
|
|
21
|
+
* @since 2.0.0
|
|
22
|
+
*/
|
|
23
|
+
const TypeId = /*#__PURE__*/Symbol.for("effect/Option");
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* @category symbols
|
|
27
|
+
* @since 2.0.0
|
|
28
|
+
*/
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* @category models
|
|
32
|
+
* @since 2.0.0
|
|
33
|
+
*/
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* @category models
|
|
37
|
+
* @since 2.0.0
|
|
38
|
+
*/
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* @category models
|
|
42
|
+
* @since 2.0.0
|
|
43
|
+
*/
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* @category models
|
|
47
|
+
* @since 2.0.0
|
|
48
|
+
*/
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* @category type lambdas
|
|
52
|
+
* @since 2.0.0
|
|
53
|
+
*/
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Creates a new `Option` that represents the absence of a value.
|
|
57
|
+
*
|
|
58
|
+
* @category constructors
|
|
59
|
+
* @since 2.0.0
|
|
60
|
+
*/
|
|
61
|
+
const none = () => none$1;
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Creates a new `Option` that wraps the given value.
|
|
65
|
+
*
|
|
66
|
+
* @param value - The value to wrap.
|
|
67
|
+
*
|
|
68
|
+
* @category constructors
|
|
69
|
+
* @since 2.0.0
|
|
70
|
+
*/
|
|
71
|
+
const some = some$1;
|
|
72
|
+
|
|
73
|
+
/**
|
|
74
|
+
* Tests if a value is a `Option`.
|
|
75
|
+
*
|
|
76
|
+
* @param input - The value to check.
|
|
77
|
+
*
|
|
78
|
+
* @example
|
|
79
|
+
* import { some, none, isOption } from 'effect/Option'
|
|
80
|
+
*
|
|
81
|
+
* assert.deepStrictEqual(isOption(some(1)), true)
|
|
82
|
+
* assert.deepStrictEqual(isOption(none()), true)
|
|
83
|
+
* assert.deepStrictEqual(isOption({}), false)
|
|
84
|
+
*
|
|
85
|
+
* @category guards
|
|
86
|
+
* @since 2.0.0
|
|
87
|
+
*/
|
|
88
|
+
const isOption = isOption$1;
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* Determine if a `Option` is a `None`.
|
|
92
|
+
*
|
|
93
|
+
* @param self - The `Option` to check.
|
|
94
|
+
*
|
|
95
|
+
* @example
|
|
96
|
+
* import { some, none, isNone } from 'effect/Option'
|
|
97
|
+
*
|
|
98
|
+
* assert.deepStrictEqual(isNone(some(1)), false)
|
|
99
|
+
* assert.deepStrictEqual(isNone(none()), true)
|
|
100
|
+
*
|
|
101
|
+
* @category guards
|
|
102
|
+
* @since 2.0.0
|
|
103
|
+
*/
|
|
104
|
+
const isNone = isNone$1;
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* Determine if a `Option` is a `Some`.
|
|
108
|
+
*
|
|
109
|
+
* @param self - The `Option` to check.
|
|
110
|
+
*
|
|
111
|
+
* @example
|
|
112
|
+
* import { some, none, isSome } from 'effect/Option'
|
|
113
|
+
*
|
|
114
|
+
* assert.deepStrictEqual(isSome(some(1)), true)
|
|
115
|
+
* assert.deepStrictEqual(isSome(none()), false)
|
|
116
|
+
*
|
|
117
|
+
* @category guards
|
|
118
|
+
* @since 2.0.0
|
|
119
|
+
*/
|
|
120
|
+
const isSome = isSome$1;
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* Matches the given `Option` and returns either the provided `onNone` value or the result of the provided `onSome`
|
|
124
|
+
* function when passed the `Option`'s value.
|
|
125
|
+
*
|
|
126
|
+
* @param self - The `Option` to match
|
|
127
|
+
* @param onNone - The value to be returned if the `Option` is `None`
|
|
128
|
+
* @param onSome - The function to be called if the `Option` is `Some`, it will be passed the `Option`'s value and its result will be returned
|
|
129
|
+
*
|
|
130
|
+
* @example
|
|
131
|
+
* import { some, none, match } from 'effect/Option'
|
|
132
|
+
* import { pipe } from "effect/Function"
|
|
133
|
+
*
|
|
134
|
+
* assert.deepStrictEqual(
|
|
135
|
+
* pipe(some(1), match({ onNone: () => 'a none', onSome: (a) => `a some containing ${a}` })),
|
|
136
|
+
* 'a some containing 1'
|
|
137
|
+
* )
|
|
138
|
+
*
|
|
139
|
+
* assert.deepStrictEqual(
|
|
140
|
+
* pipe(none(), match({ onNone: () => 'a none', onSome: (a) => `a some containing ${a}` })),
|
|
141
|
+
* 'a none'
|
|
142
|
+
* )
|
|
143
|
+
*
|
|
144
|
+
* @category pattern matching
|
|
145
|
+
* @since 2.0.0
|
|
146
|
+
*/
|
|
147
|
+
const match = /*#__PURE__*/dual(2, (self, {
|
|
148
|
+
onNone,
|
|
149
|
+
onSome
|
|
150
|
+
}) => isNone(self) ? onNone() : onSome(self.value));
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
* Returns a type guard from a `Option` returning function.
|
|
154
|
+
* This function ensures that a type guard definition is type-safe.
|
|
155
|
+
*
|
|
156
|
+
* @example
|
|
157
|
+
* import * as O from "effect/Option"
|
|
158
|
+
*
|
|
159
|
+
* const parsePositive = (n: number): O.Option<number> =>
|
|
160
|
+
* n > 0 ? O.some(n) : O.none()
|
|
161
|
+
*
|
|
162
|
+
* const isPositive = O.toRefinement(parsePositive)
|
|
163
|
+
*
|
|
164
|
+
* assert.deepStrictEqual(isPositive(1), true)
|
|
165
|
+
* assert.deepStrictEqual(isPositive(-1), false)
|
|
166
|
+
*
|
|
167
|
+
* @category conversions
|
|
168
|
+
* @since 2.0.0
|
|
169
|
+
*/
|
|
170
|
+
const toRefinement = f => a => isSome(f(a));
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* Converts an `Iterable` of values into an `Option`. Returns the first value of the `Iterable` wrapped in a `Some`
|
|
174
|
+
* if the `Iterable` is not empty, otherwise returns `None`.
|
|
175
|
+
*
|
|
176
|
+
* @param collection - The `Iterable` to be converted to an `Option`.
|
|
177
|
+
*
|
|
178
|
+
* @example
|
|
179
|
+
* import { fromIterable, some, none } from 'effect/Option'
|
|
180
|
+
*
|
|
181
|
+
* assert.deepStrictEqual(fromIterable([1, 2, 3]), some(1))
|
|
182
|
+
* assert.deepStrictEqual(fromIterable([]), none())
|
|
183
|
+
*
|
|
184
|
+
* @category conversions
|
|
185
|
+
* @since 2.0.0
|
|
186
|
+
*/
|
|
187
|
+
const fromIterable = collection => {
|
|
188
|
+
for (const a of collection) {
|
|
189
|
+
return some(a);
|
|
190
|
+
}
|
|
191
|
+
return none();
|
|
192
|
+
};
|
|
193
|
+
|
|
194
|
+
/**
|
|
195
|
+
* Converts a `Either` to an `Option` discarding the error.
|
|
196
|
+
*
|
|
197
|
+
* Alias of {@link fromEither}.
|
|
198
|
+
*
|
|
199
|
+
* @example
|
|
200
|
+
* import * as O from "effect/Option"
|
|
201
|
+
* import * as E from "effect/Either"
|
|
202
|
+
*
|
|
203
|
+
* assert.deepStrictEqual(O.getRight(E.right('ok')), O.some('ok'))
|
|
204
|
+
* assert.deepStrictEqual(O.getRight(E.left('err')), O.none())
|
|
205
|
+
*
|
|
206
|
+
* @category conversions
|
|
207
|
+
* @since 2.0.0
|
|
208
|
+
*/
|
|
209
|
+
const getRight = getRight$1;
|
|
210
|
+
|
|
211
|
+
/**
|
|
212
|
+
* Converts a `Either` to an `Option` discarding the value.
|
|
213
|
+
*
|
|
214
|
+
* @example
|
|
215
|
+
* import * as O from "effect/Option"
|
|
216
|
+
* import * as E from "effect/Either"
|
|
217
|
+
*
|
|
218
|
+
* assert.deepStrictEqual(O.getLeft(E.right("ok")), O.none())
|
|
219
|
+
* assert.deepStrictEqual(O.getLeft(E.left("a")), O.some("a"))
|
|
220
|
+
*
|
|
221
|
+
* @category conversions
|
|
222
|
+
* @since 2.0.0
|
|
223
|
+
*/
|
|
224
|
+
const getLeft = getLeft$1;
|
|
225
|
+
|
|
226
|
+
/**
|
|
227
|
+
* Returns the value of the `Option` if it is `Some`, otherwise returns `onNone`
|
|
228
|
+
*
|
|
229
|
+
* @param self - The `Option` to get the value of.
|
|
230
|
+
* @param onNone - Function that returns the default value to return if the `Option` is `None`.
|
|
231
|
+
*
|
|
232
|
+
* @example
|
|
233
|
+
* import { some, none, getOrElse } from 'effect/Option'
|
|
234
|
+
* import { pipe } from "effect/Function"
|
|
235
|
+
*
|
|
236
|
+
* assert.deepStrictEqual(pipe(some(1), getOrElse(() => 0)), 1)
|
|
237
|
+
* assert.deepStrictEqual(pipe(none(), getOrElse(() => 0)), 0)
|
|
238
|
+
*
|
|
239
|
+
* @category getters
|
|
240
|
+
* @since 2.0.0
|
|
241
|
+
*/
|
|
242
|
+
const getOrElse = /*#__PURE__*/dual(2, (self, onNone) => isNone(self) ? onNone() : self.value);
|
|
243
|
+
|
|
244
|
+
/**
|
|
245
|
+
* Returns the provided `Option` `that` if `self` is `None`, otherwise returns `self`.
|
|
246
|
+
*
|
|
247
|
+
* @param self - The first `Option` to be checked.
|
|
248
|
+
* @param that - The `Option` to return if `self` is `None`.
|
|
249
|
+
*
|
|
250
|
+
* @example
|
|
251
|
+
* import * as O from "effect/Option"
|
|
252
|
+
* import { pipe } from "effect/Function"
|
|
253
|
+
*
|
|
254
|
+
* assert.deepStrictEqual(
|
|
255
|
+
* pipe(
|
|
256
|
+
* O.none(),
|
|
257
|
+
* O.orElse(() => O.none())
|
|
258
|
+
* ),
|
|
259
|
+
* O.none()
|
|
260
|
+
* )
|
|
261
|
+
* assert.deepStrictEqual(
|
|
262
|
+
* pipe(
|
|
263
|
+
* O.some('a'),
|
|
264
|
+
* O.orElse(() => O.none())
|
|
265
|
+
* ),
|
|
266
|
+
* O.some('a')
|
|
267
|
+
* )
|
|
268
|
+
* assert.deepStrictEqual(
|
|
269
|
+
* pipe(
|
|
270
|
+
* O.none(),
|
|
271
|
+
* O.orElse(() => O.some('b'))
|
|
272
|
+
* ),
|
|
273
|
+
* O.some('b')
|
|
274
|
+
* )
|
|
275
|
+
* assert.deepStrictEqual(
|
|
276
|
+
* pipe(
|
|
277
|
+
* O.some('a'),
|
|
278
|
+
* O.orElse(() => O.some('b'))
|
|
279
|
+
* ),
|
|
280
|
+
* O.some('a')
|
|
281
|
+
* )
|
|
282
|
+
*
|
|
283
|
+
* @category error handling
|
|
284
|
+
* @since 2.0.0
|
|
285
|
+
*/
|
|
286
|
+
const orElse = /*#__PURE__*/dual(2, (self, that) => isNone(self) ? that() : self);
|
|
287
|
+
|
|
288
|
+
/**
|
|
289
|
+
* Similar to `orElse`, but instead of returning a simple union, it returns an `Either` object,
|
|
290
|
+
* which contains information about which of the two `Option`s has been chosen.
|
|
291
|
+
*
|
|
292
|
+
* This is useful when it's important to know whether the value was retrieved from the first `Option` or the second option.
|
|
293
|
+
*
|
|
294
|
+
* @param self - The first `Option` to be checked.
|
|
295
|
+
* @param that - The second `Option` to be considered if the first `Option` is `None`.
|
|
296
|
+
*
|
|
297
|
+
* @category error handling
|
|
298
|
+
* @since 2.0.0
|
|
299
|
+
*/
|
|
300
|
+
const orElseEither = /*#__PURE__*/dual(2, (self, that) => isNone(self) ? map(that(), right) : map(self, left));
|
|
301
|
+
|
|
302
|
+
/**
|
|
303
|
+
* Given an `Iterable` collection of `Option`s, returns the first `Some` found in the collection.
|
|
304
|
+
*
|
|
305
|
+
* @param collection - An iterable collection of `Option` to be searched.
|
|
306
|
+
*
|
|
307
|
+
* @example
|
|
308
|
+
* import * as O from "effect/Option"
|
|
309
|
+
*
|
|
310
|
+
* assert.deepStrictEqual(O.firstSomeOf([O.none(), O.some(1), O.some(2)]), O.some(1))
|
|
311
|
+
*
|
|
312
|
+
* @category error handling
|
|
313
|
+
* @since 2.0.0
|
|
314
|
+
*/
|
|
315
|
+
const firstSomeOf = collection => {
|
|
316
|
+
let out = none();
|
|
317
|
+
for (out of collection) {
|
|
318
|
+
if (isSome(out)) {
|
|
319
|
+
return out;
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
return out;
|
|
323
|
+
};
|
|
324
|
+
|
|
325
|
+
/**
|
|
326
|
+
* Constructs a new `Option` from a nullable type. If the value is `null` or `undefined`, returns `None`, otherwise
|
|
327
|
+
* returns the value wrapped in a `Some`.
|
|
328
|
+
*
|
|
329
|
+
* @param nullableValue - The nullable value to be converted to an `Option`.
|
|
330
|
+
*
|
|
331
|
+
* @example
|
|
332
|
+
* import * as O from "effect/Option"
|
|
333
|
+
*
|
|
334
|
+
* assert.deepStrictEqual(O.fromNullable(undefined), O.none())
|
|
335
|
+
* assert.deepStrictEqual(O.fromNullable(null), O.none())
|
|
336
|
+
* assert.deepStrictEqual(O.fromNullable(1), O.some(1))
|
|
337
|
+
*
|
|
338
|
+
* @category conversions
|
|
339
|
+
* @since 2.0.0
|
|
340
|
+
*/
|
|
341
|
+
const fromNullable = nullableValue => nullableValue == null ? none() : some(nullableValue);
|
|
342
|
+
|
|
343
|
+
/**
|
|
344
|
+
* This API is useful for lifting a function that returns `null` or `undefined` into the `Option` context.
|
|
345
|
+
*
|
|
346
|
+
* @example
|
|
347
|
+
* import * as O from "effect/Option"
|
|
348
|
+
*
|
|
349
|
+
* const parse = (s: string): number | undefined => {
|
|
350
|
+
* const n = parseFloat(s)
|
|
351
|
+
* return isNaN(n) ? undefined : n
|
|
352
|
+
* }
|
|
353
|
+
*
|
|
354
|
+
* const parseOption = O.liftNullable(parse)
|
|
355
|
+
*
|
|
356
|
+
* assert.deepStrictEqual(parseOption('1'), O.some(1))
|
|
357
|
+
* assert.deepStrictEqual(parseOption('not a number'), O.none())
|
|
358
|
+
*
|
|
359
|
+
* @category conversions
|
|
360
|
+
* @since 2.0.0
|
|
361
|
+
*/
|
|
362
|
+
const liftNullable = f => (...a) => fromNullable(f(...a));
|
|
363
|
+
|
|
364
|
+
/**
|
|
365
|
+
* Returns the value of the `Option` if it is a `Some`, otherwise returns `null`.
|
|
366
|
+
*
|
|
367
|
+
* @param self - The `Option` to extract the value from.
|
|
368
|
+
*
|
|
369
|
+
* @example
|
|
370
|
+
* import * as O from "effect/Option"
|
|
371
|
+
*
|
|
372
|
+
* assert.deepStrictEqual(O.getOrNull(O.some(1)), 1)
|
|
373
|
+
* assert.deepStrictEqual(O.getOrNull(O.none()), null)
|
|
374
|
+
*
|
|
375
|
+
* @category getters
|
|
376
|
+
* @since 2.0.0
|
|
377
|
+
*/
|
|
378
|
+
const getOrNull = /*#__PURE__*/getOrElse(constNull);
|
|
379
|
+
|
|
380
|
+
/**
|
|
381
|
+
* Returns the value of the `Option` if it is a `Some`, otherwise returns `undefined`.
|
|
382
|
+
*
|
|
383
|
+
* @param self - The `Option` to extract the value from.
|
|
384
|
+
*
|
|
385
|
+
* @example
|
|
386
|
+
* import * as O from "effect/Option"
|
|
387
|
+
*
|
|
388
|
+
* assert.deepStrictEqual(O.getOrUndefined(O.some(1)), 1)
|
|
389
|
+
* assert.deepStrictEqual(O.getOrUndefined(O.none()), undefined)
|
|
390
|
+
*
|
|
391
|
+
* @category getters
|
|
392
|
+
* @since 2.0.0
|
|
393
|
+
*/
|
|
394
|
+
const getOrUndefined = /*#__PURE__*/getOrElse(constUndefined);
|
|
395
|
+
|
|
396
|
+
/**
|
|
397
|
+
* A utility function that lifts a function that throws exceptions into a function that returns an `Option`.
|
|
398
|
+
*
|
|
399
|
+
* This function is useful for any function that might throw an exception, allowing the developer to handle
|
|
400
|
+
* the exception in a more functional way.
|
|
401
|
+
*
|
|
402
|
+
* @param f - the function that can throw exceptions.
|
|
403
|
+
*
|
|
404
|
+
* @example
|
|
405
|
+
* import * as O from "effect/Option"
|
|
406
|
+
*
|
|
407
|
+
* const parse = O.liftThrowable(JSON.parse)
|
|
408
|
+
*
|
|
409
|
+
* assert.deepStrictEqual(parse("1"), O.some(1))
|
|
410
|
+
* assert.deepStrictEqual(parse(""), O.none())
|
|
411
|
+
*
|
|
412
|
+
* @category conversions
|
|
413
|
+
* @since 2.0.0
|
|
414
|
+
*/
|
|
415
|
+
const liftThrowable = f => (...a) => {
|
|
416
|
+
try {
|
|
417
|
+
return some(f(...a));
|
|
418
|
+
} catch (e) {
|
|
419
|
+
return none();
|
|
420
|
+
}
|
|
421
|
+
};
|
|
422
|
+
|
|
423
|
+
/**
|
|
424
|
+
* Extracts the value of an `Option` or throws if the `Option` is `None`.
|
|
425
|
+
*
|
|
426
|
+
* If a default error is sufficient for your use case and you don't need to configure the thrown error, see {@link getOrThrow}.
|
|
427
|
+
*
|
|
428
|
+
* @param self - The `Option` to extract the value from.
|
|
429
|
+
* @param onNone - A function that will be called if the `Option` is `None`. It returns the error to be thrown.
|
|
430
|
+
*
|
|
431
|
+
* @example
|
|
432
|
+
* import * as O from "effect/Option"
|
|
433
|
+
*
|
|
434
|
+
* assert.deepStrictEqual(
|
|
435
|
+
* O.getOrThrowWith(O.some(1), () => new Error('Unexpected None')),
|
|
436
|
+
* 1
|
|
437
|
+
* )
|
|
438
|
+
* assert.throws(() => O.getOrThrowWith(O.none(), () => new Error('Unexpected None')))
|
|
439
|
+
*
|
|
440
|
+
* @category conversions
|
|
441
|
+
* @since 2.0.0
|
|
442
|
+
*/
|
|
443
|
+
const getOrThrowWith = /*#__PURE__*/dual(2, (self, onNone) => {
|
|
444
|
+
if (isSome(self)) {
|
|
445
|
+
return self.value;
|
|
446
|
+
}
|
|
447
|
+
throw onNone();
|
|
448
|
+
});
|
|
449
|
+
|
|
450
|
+
/**
|
|
451
|
+
* Extracts the value of an `Option` or throws if the `Option` is `None`.
|
|
452
|
+
*
|
|
453
|
+
* The thrown error is a default error. To configure the error thrown, see {@link getOrThrowWith}.
|
|
454
|
+
*
|
|
455
|
+
* @param self - The `Option` to extract the value from.
|
|
456
|
+
* @throws `Error("getOrThrow called on a None")`
|
|
457
|
+
*
|
|
458
|
+
* @example
|
|
459
|
+
* import * as O from "effect/Option"
|
|
460
|
+
*
|
|
461
|
+
* assert.deepStrictEqual(O.getOrThrow(O.some(1)), 1)
|
|
462
|
+
* assert.throws(() => O.getOrThrow(O.none()))
|
|
463
|
+
*
|
|
464
|
+
* @category conversions
|
|
465
|
+
* @since 2.0.0
|
|
466
|
+
*/
|
|
467
|
+
const getOrThrow = /*#__PURE__*/getOrThrowWith(() => new Error("getOrThrow called on a None"));
|
|
468
|
+
|
|
469
|
+
/**
|
|
470
|
+
* Maps the `Some` side of an `Option` value to a new `Option` value.
|
|
471
|
+
*
|
|
472
|
+
* @param self - An `Option` to map
|
|
473
|
+
* @param f - The function to map over the value of the `Option`
|
|
474
|
+
*
|
|
475
|
+
* @category transforming
|
|
476
|
+
* @since 2.0.0
|
|
477
|
+
*/
|
|
478
|
+
const map = /*#__PURE__*/dual(2, (self, f) => isNone(self) ? none() : some(f(self.value)));
|
|
479
|
+
|
|
480
|
+
/**
|
|
481
|
+
* Maps the `Some` value of this `Option` to the specified constant value.
|
|
482
|
+
*
|
|
483
|
+
* @category transforming
|
|
484
|
+
* @since 2.0.0
|
|
485
|
+
*/
|
|
486
|
+
const as = /*#__PURE__*/dual(2, (self, b) => map(self, () => b));
|
|
487
|
+
|
|
488
|
+
/**
|
|
489
|
+
* Maps the `Some` value of this `Option` to the `void` constant value.
|
|
490
|
+
*
|
|
491
|
+
* This is useful when the value of the `Option` is not needed, but the presence or absence of the value is important.
|
|
492
|
+
*
|
|
493
|
+
* @category transforming
|
|
494
|
+
* @since 2.0.0
|
|
495
|
+
*/
|
|
496
|
+
const asUnit = /*#__PURE__*/as(undefined);
|
|
497
|
+
|
|
498
|
+
/**
|
|
499
|
+
* @since 2.0.0
|
|
500
|
+
*/
|
|
501
|
+
const unit = /*#__PURE__*/some(undefined);
|
|
502
|
+
|
|
503
|
+
/**
|
|
504
|
+
* Applies a function to the value of an `Option` and flattens the result, if the input is `Some`.
|
|
505
|
+
*
|
|
506
|
+
* @category transforming
|
|
507
|
+
* @since 2.0.0
|
|
508
|
+
*/
|
|
509
|
+
const flatMap = /*#__PURE__*/dual(2, (self, f) => isNone(self) ? none() : f(self.value));
|
|
510
|
+
|
|
511
|
+
/**
|
|
512
|
+
* This is `flatMap` + `fromNullable`, useful when working with optional values.
|
|
513
|
+
*
|
|
514
|
+
* @example
|
|
515
|
+
* import { some, none, flatMapNullable } from 'effect/Option'
|
|
516
|
+
* import { pipe } from "effect/Function"
|
|
517
|
+
*
|
|
518
|
+
* interface Employee {
|
|
519
|
+
* company?: {
|
|
520
|
+
* address?: {
|
|
521
|
+
* street?: {
|
|
522
|
+
* name?: string
|
|
523
|
+
* }
|
|
524
|
+
* }
|
|
525
|
+
* }
|
|
526
|
+
* }
|
|
527
|
+
*
|
|
528
|
+
* const employee1: Employee = { company: { address: { street: { name: 'high street' } } } }
|
|
529
|
+
*
|
|
530
|
+
* assert.deepStrictEqual(
|
|
531
|
+
* pipe(
|
|
532
|
+
* some(employee1),
|
|
533
|
+
* flatMapNullable(employee => employee.company?.address?.street?.name),
|
|
534
|
+
* ),
|
|
535
|
+
* some('high street')
|
|
536
|
+
* )
|
|
537
|
+
*
|
|
538
|
+
* const employee2: Employee = { company: { address: { street: {} } } }
|
|
539
|
+
*
|
|
540
|
+
* assert.deepStrictEqual(
|
|
541
|
+
* pipe(
|
|
542
|
+
* some(employee2),
|
|
543
|
+
* flatMapNullable(employee => employee.company?.address?.street?.name),
|
|
544
|
+
* ),
|
|
545
|
+
* none()
|
|
546
|
+
* )
|
|
547
|
+
*
|
|
548
|
+
* @category transforming
|
|
549
|
+
* @since 2.0.0
|
|
550
|
+
*/
|
|
551
|
+
const flatMapNullable = /*#__PURE__*/dual(2, (self, f) => isNone(self) ? none() : fromNullable(f(self.value)));
|
|
552
|
+
|
|
553
|
+
/**
|
|
554
|
+
* @category transforming
|
|
555
|
+
* @since 2.0.0
|
|
556
|
+
*/
|
|
557
|
+
const flatten = /*#__PURE__*/flatMap(identity);
|
|
558
|
+
|
|
559
|
+
/**
|
|
560
|
+
* @category transforming
|
|
561
|
+
* @since 2.0.0
|
|
562
|
+
*/
|
|
563
|
+
const zipRight = /*#__PURE__*/dual(2, (self, that) => flatMap(self, () => that));
|
|
564
|
+
|
|
565
|
+
/**
|
|
566
|
+
* @category transforming
|
|
567
|
+
* @since 2.0.0
|
|
568
|
+
*/
|
|
569
|
+
const composeK = /*#__PURE__*/dual(2, (afb, bfc) => a => flatMap(afb(a), bfc));
|
|
570
|
+
|
|
571
|
+
/**
|
|
572
|
+
* Sequences the specified `that` `Option` but ignores its value.
|
|
573
|
+
*
|
|
574
|
+
* It is useful when we want to chain multiple operations, but only care about the result of `self`.
|
|
575
|
+
*
|
|
576
|
+
* @param that - The `Option` that will be ignored in the chain and discarded
|
|
577
|
+
* @param self - The `Option` we care about
|
|
578
|
+
*
|
|
579
|
+
* @category transforming
|
|
580
|
+
* @since 2.0.0
|
|
581
|
+
*/
|
|
582
|
+
const zipLeft = /*#__PURE__*/dual(2, (self, that) => tap(self, () => that));
|
|
583
|
+
|
|
584
|
+
/**
|
|
585
|
+
* Applies the provided function `f` to the value of the `Option` if it is `Some` and returns the original `Option`
|
|
586
|
+
* unless `f` returns `None`, in which case it returns `None`.
|
|
587
|
+
*
|
|
588
|
+
* This function is useful for performing additional computations on the value of the input `Option` without affecting its value.
|
|
589
|
+
*
|
|
590
|
+
* @param f - Function to apply to the value of the `Option` if it is `Some`
|
|
591
|
+
* @param self - The `Option` to apply the function to
|
|
592
|
+
*
|
|
593
|
+
* @example
|
|
594
|
+
* import * as O from "effect/Option"
|
|
595
|
+
*
|
|
596
|
+
* const getInteger = (n: number) => Number.isInteger(n) ? O.some(n) : O.none()
|
|
597
|
+
*
|
|
598
|
+
* assert.deepStrictEqual(O.tap(O.none(), getInteger), O.none())
|
|
599
|
+
* assert.deepStrictEqual(O.tap(O.some(1), getInteger), O.some(1))
|
|
600
|
+
* assert.deepStrictEqual(O.tap(O.some(1.14), getInteger), O.none())
|
|
601
|
+
*
|
|
602
|
+
* @category transforming
|
|
603
|
+
* @since 2.0.0
|
|
604
|
+
*/
|
|
605
|
+
const tap = /*#__PURE__*/dual(2, (self, f) => flatMap(self, a => map(f(a), () => a)));
|
|
606
|
+
|
|
607
|
+
/**
|
|
608
|
+
* @category combining
|
|
609
|
+
* @since 2.0.0
|
|
610
|
+
*/
|
|
611
|
+
const product = (self, that) => isSome(self) && isSome(that) ? some([self.value, that.value]) : none();
|
|
612
|
+
|
|
613
|
+
/**
|
|
614
|
+
* @category combining
|
|
615
|
+
* @since 2.0.0
|
|
616
|
+
*/
|
|
617
|
+
const productMany = (self, collection) => {
|
|
618
|
+
if (isNone(self)) {
|
|
619
|
+
return none();
|
|
620
|
+
}
|
|
621
|
+
const out = [self.value];
|
|
622
|
+
for (const o of collection) {
|
|
623
|
+
if (isNone(o)) {
|
|
624
|
+
return none();
|
|
625
|
+
}
|
|
626
|
+
out.push(o.value);
|
|
627
|
+
}
|
|
628
|
+
return some(out);
|
|
629
|
+
};
|
|
630
|
+
|
|
631
|
+
/**
|
|
632
|
+
* Takes a structure of `Option`s and returns an `Option` of values with the same structure.
|
|
633
|
+
*
|
|
634
|
+
* - If a tuple is supplied, then the returned `Option` will contain a tuple with the same length.
|
|
635
|
+
* - If a struct is supplied, then the returned `Option` will contain a struct with the same keys.
|
|
636
|
+
* - If an iterable is supplied, then the returned `Option` will contain an array.
|
|
637
|
+
*
|
|
638
|
+
* @param fields - the struct of `Option`s to be sequenced.
|
|
639
|
+
*
|
|
640
|
+
* @example
|
|
641
|
+
* import * as O from "effect/Option"
|
|
642
|
+
*
|
|
643
|
+
* assert.deepStrictEqual(O.all([O.some(1), O.some(2)]), O.some([1, 2]))
|
|
644
|
+
* assert.deepStrictEqual(O.all({ a: O.some(1), b: O.some("hello") }), O.some({ a: 1, b: "hello" }))
|
|
645
|
+
* assert.deepStrictEqual(O.all({ a: O.some(1), b: O.none() }), O.none())
|
|
646
|
+
*
|
|
647
|
+
* @category combining
|
|
648
|
+
* @since 2.0.0
|
|
649
|
+
*/
|
|
650
|
+
// @ts-expect-error
|
|
651
|
+
const all = input => {
|
|
652
|
+
if (Symbol.iterator in input) {
|
|
653
|
+
const out = [];
|
|
654
|
+
for (const o of input) {
|
|
655
|
+
if (isNone(o)) {
|
|
656
|
+
return none();
|
|
657
|
+
}
|
|
658
|
+
out.push(o.value);
|
|
659
|
+
}
|
|
660
|
+
return some(out);
|
|
661
|
+
}
|
|
662
|
+
const out = {};
|
|
663
|
+
for (const key of Object.keys(input)) {
|
|
664
|
+
const o = input[key];
|
|
665
|
+
if (isNone(o)) {
|
|
666
|
+
return none();
|
|
667
|
+
}
|
|
668
|
+
out[key] = o.value;
|
|
669
|
+
}
|
|
670
|
+
return some(out);
|
|
671
|
+
};
|
|
672
|
+
|
|
673
|
+
/**
|
|
674
|
+
* Zips two `Option` values together using a provided function, returning a new `Option` of the result.
|
|
675
|
+
*
|
|
676
|
+
* @param self - The left-hand side of the zip operation
|
|
677
|
+
* @param that - The right-hand side of the zip operation
|
|
678
|
+
* @param f - The function used to combine the values of the two `Option`s
|
|
679
|
+
*
|
|
680
|
+
* @example
|
|
681
|
+
* import * as O from "effect/Option"
|
|
682
|
+
*
|
|
683
|
+
* type Complex = [number, number]
|
|
684
|
+
*
|
|
685
|
+
* const complex = (real: number, imaginary: number): Complex => [real, imaginary]
|
|
686
|
+
*
|
|
687
|
+
* assert.deepStrictEqual(O.zipWith(O.none(), O.none(), complex), O.none())
|
|
688
|
+
* assert.deepStrictEqual(O.zipWith(O.some(1), O.none(), complex), O.none())
|
|
689
|
+
* assert.deepStrictEqual(O.zipWith(O.none(), O.some(1), complex), O.none())
|
|
690
|
+
* assert.deepStrictEqual(O.zipWith(O.some(1), O.some(2), complex), O.some([1, 2]))
|
|
691
|
+
*
|
|
692
|
+
* assert.deepStrictEqual(O.zipWith(O.some(1), complex)(O.some(2)), O.some([2, 1]))
|
|
693
|
+
*
|
|
694
|
+
* @category combining
|
|
695
|
+
* @since 2.0.0
|
|
696
|
+
*/
|
|
697
|
+
const zipWith = /*#__PURE__*/dual(3, (self, that, f) => map(product(self, that), ([a, b]) => f(a, b)));
|
|
698
|
+
|
|
699
|
+
/**
|
|
700
|
+
* @category combining
|
|
701
|
+
* @since 2.0.0
|
|
702
|
+
*/
|
|
703
|
+
const ap = /*#__PURE__*/dual(2, (self, that) => zipWith(self, that, (f, a) => f(a)));
|
|
704
|
+
|
|
705
|
+
/**
|
|
706
|
+
* Reduces an `Iterable` of `Option<A>` to a single value of type `B`, elements that are `None` are ignored.
|
|
707
|
+
*
|
|
708
|
+
* @param self - The Iterable of `Option<A>` to be reduced.
|
|
709
|
+
* @param b - The initial value of the accumulator.
|
|
710
|
+
* @param f - The reducing function that takes the current accumulator value and the unwrapped value of an `Option<A>`.
|
|
711
|
+
*
|
|
712
|
+
* @example
|
|
713
|
+
* import { some, none, reduceCompact } from 'effect/Option'
|
|
714
|
+
* import { pipe } from "effect/Function"
|
|
715
|
+
*
|
|
716
|
+
* const iterable = [some(1), none(), some(2), none()]
|
|
717
|
+
* assert.deepStrictEqual(pipe(iterable, reduceCompact(0, (b, a) => b + a)), 3)
|
|
718
|
+
*
|
|
719
|
+
* @category folding
|
|
720
|
+
* @since 2.0.0
|
|
721
|
+
*/
|
|
722
|
+
const reduceCompact = /*#__PURE__*/dual(3, (self, b, f) => {
|
|
723
|
+
let out = b;
|
|
724
|
+
for (const oa of self) {
|
|
725
|
+
if (isSome(oa)) {
|
|
726
|
+
out = f(out, oa.value);
|
|
727
|
+
}
|
|
728
|
+
}
|
|
729
|
+
return out;
|
|
730
|
+
});
|
|
731
|
+
|
|
732
|
+
/**
|
|
733
|
+
* Transforms an `Option` into an `Array`.
|
|
734
|
+
* If the input is `None`, an empty array is returned.
|
|
735
|
+
* If the input is `Some`, the value is wrapped in an array.
|
|
736
|
+
*
|
|
737
|
+
* @param self - The `Option` to convert to an array.
|
|
738
|
+
*
|
|
739
|
+
* @example
|
|
740
|
+
* import * as O from "effect/Option"
|
|
741
|
+
*
|
|
742
|
+
* assert.deepStrictEqual(O.toArray(O.some(1)), [1])
|
|
743
|
+
* assert.deepStrictEqual(O.toArray(O.none()), [])
|
|
744
|
+
*
|
|
745
|
+
* @category conversions
|
|
746
|
+
* @since 2.0.0
|
|
747
|
+
*/
|
|
748
|
+
const toArray = self => isNone(self) ? [] : [self.value];
|
|
749
|
+
|
|
750
|
+
/**
|
|
751
|
+
* @category filtering
|
|
752
|
+
* @since 2.0.0
|
|
753
|
+
*/
|
|
754
|
+
const partitionMap = /*#__PURE__*/dual(2, (self, f) => {
|
|
755
|
+
if (isNone(self)) {
|
|
756
|
+
return [none(), none()];
|
|
757
|
+
}
|
|
758
|
+
const e = f(self.value);
|
|
759
|
+
return isLeft(e) ? [some(e.left), none()] : [none(), some(e.right)];
|
|
760
|
+
});
|
|
761
|
+
|
|
762
|
+
/**
|
|
763
|
+
* Maps over the value of an `Option` and filters out `None`s.
|
|
764
|
+
*
|
|
765
|
+
* Useful when in addition to filtering you also want to change the type of the `Option`.
|
|
766
|
+
*
|
|
767
|
+
* @param self - The `Option` to map over.
|
|
768
|
+
* @param f - A function to apply to the value of the `Option`.
|
|
769
|
+
*
|
|
770
|
+
* @example
|
|
771
|
+
* import * as O from "effect/Option"
|
|
772
|
+
*
|
|
773
|
+
* const evenNumber = (n: number) => n % 2 === 0 ? O.some(n) : O.none()
|
|
774
|
+
*
|
|
775
|
+
* assert.deepStrictEqual(O.filterMap(O.none(), evenNumber), O.none())
|
|
776
|
+
* assert.deepStrictEqual(O.filterMap(O.some(3), evenNumber), O.none())
|
|
777
|
+
* assert.deepStrictEqual(O.filterMap(O.some(2), evenNumber), O.some(2))
|
|
778
|
+
*
|
|
779
|
+
* @category filtering
|
|
780
|
+
* @since 2.0.0
|
|
781
|
+
*/
|
|
782
|
+
const filterMap = /*#__PURE__*/dual(2, (self, f) => isNone(self) ? none() : f(self.value));
|
|
783
|
+
|
|
784
|
+
/**
|
|
785
|
+
* Filters an `Option` using a predicate. If the predicate is not satisfied or the `Option` is `None` returns `None`.
|
|
786
|
+
*
|
|
787
|
+
* If you need to change the type of the `Option` in addition to filtering, see `filterMap`.
|
|
788
|
+
*
|
|
789
|
+
* @param predicate - A predicate function to apply to the `Option` value.
|
|
790
|
+
* @param fb - The `Option` to filter.
|
|
791
|
+
*
|
|
792
|
+
* @example
|
|
793
|
+
* import * as O from "effect/Option"
|
|
794
|
+
*
|
|
795
|
+
* // predicate
|
|
796
|
+
* const isEven = (n: number) => n % 2 === 0
|
|
797
|
+
*
|
|
798
|
+
* assert.deepStrictEqual(O.filter(O.none(), isEven), O.none())
|
|
799
|
+
* assert.deepStrictEqual(O.filter(O.some(3), isEven), O.none())
|
|
800
|
+
* assert.deepStrictEqual(O.filter(O.some(2), isEven), O.some(2))
|
|
801
|
+
*
|
|
802
|
+
* // refinement
|
|
803
|
+
* const isNumber = (v: unknown): v is number => typeof v === "number"
|
|
804
|
+
*
|
|
805
|
+
* assert.deepStrictEqual(O.filter(O.none(), isNumber), O.none())
|
|
806
|
+
* assert.deepStrictEqual(O.filter(O.some('hello'), isNumber), O.none())
|
|
807
|
+
* assert.deepStrictEqual(O.filter(O.some(2), isNumber), O.some(2))
|
|
808
|
+
*
|
|
809
|
+
* @category filtering
|
|
810
|
+
* @since 2.0.0
|
|
811
|
+
*/
|
|
812
|
+
const filter = /*#__PURE__*/dual(2, (self, predicate) => filterMap(self, b => predicate(b) ? some$1(b) : none$1));
|
|
813
|
+
|
|
814
|
+
/**
|
|
815
|
+
* @example
|
|
816
|
+
* import { none, some, getEquivalence } from 'effect/Option'
|
|
817
|
+
* import * as N from 'effect/Number'
|
|
818
|
+
*
|
|
819
|
+
* const isEquivalent = getEquivalence(N.Equivalence)
|
|
820
|
+
* assert.deepStrictEqual(isEquivalent(none(), none()), true)
|
|
821
|
+
* assert.deepStrictEqual(isEquivalent(none(), some(1)), false)
|
|
822
|
+
* assert.deepStrictEqual(isEquivalent(some(1), none()), false)
|
|
823
|
+
* assert.deepStrictEqual(isEquivalent(some(1), some(2)), false)
|
|
824
|
+
* assert.deepStrictEqual(isEquivalent(some(1), some(1)), true)
|
|
825
|
+
*
|
|
826
|
+
* @category equivalence
|
|
827
|
+
* @since 2.0.0
|
|
828
|
+
*/
|
|
829
|
+
const getEquivalence = isEquivalent => make((x, y) => x === y || (isNone(x) ? isNone(y) : isNone(y) ? false : isEquivalent(x.value, y.value)));
|
|
830
|
+
|
|
831
|
+
/**
|
|
832
|
+
* The `Order` instance allows `Option` values to be compared with
|
|
833
|
+
* `compare`, whenever there is an `Order` instance for
|
|
834
|
+
* the type the `Option` contains.
|
|
835
|
+
*
|
|
836
|
+
* `None` is considered to be less than any `Some` value.
|
|
837
|
+
*
|
|
838
|
+
* @example
|
|
839
|
+
* import { none, some, getOrder } from 'effect/Option'
|
|
840
|
+
* import * as N from 'effect/Number'
|
|
841
|
+
* import { pipe } from "effect/Function"
|
|
842
|
+
*
|
|
843
|
+
* const O = getOrder(N.Order)
|
|
844
|
+
* assert.deepStrictEqual(O(none(), none()), 0)
|
|
845
|
+
* assert.deepStrictEqual(O(none(), some(1)), -1)
|
|
846
|
+
* assert.deepStrictEqual(O(some(1), none()), 1)
|
|
847
|
+
* assert.deepStrictEqual(O(some(1), some(2)), -1)
|
|
848
|
+
* assert.deepStrictEqual(O(some(1), some(1)), 0)
|
|
849
|
+
*
|
|
850
|
+
* @category sorting
|
|
851
|
+
* @since 2.0.0
|
|
852
|
+
*/
|
|
853
|
+
const getOrder = O => make$1((self, that) => isSome(self) ? isSome(that) ? O(self.value, that.value) : 1 : -1);
|
|
854
|
+
|
|
855
|
+
/**
|
|
856
|
+
* Lifts a binary function into `Option`.
|
|
857
|
+
*
|
|
858
|
+
* @param f - The function to lift.
|
|
859
|
+
*
|
|
860
|
+
* @category lifting
|
|
861
|
+
* @since 2.0.0
|
|
862
|
+
*/
|
|
863
|
+
const lift2 = f => dual(2, (self, that) => zipWith(self, that, f));
|
|
864
|
+
|
|
865
|
+
/**
|
|
866
|
+
* Transforms a `Predicate` function into a `Some` of the input value if the predicate returns `true` or `None`
|
|
867
|
+
* if the predicate returns `false`.
|
|
868
|
+
*
|
|
869
|
+
* @param predicate - A `Predicate` function that takes in a value of type `A` and returns a boolean.
|
|
870
|
+
*
|
|
871
|
+
* @example
|
|
872
|
+
* import * as O from "effect/Option"
|
|
873
|
+
*
|
|
874
|
+
* const getOption = O.liftPredicate((n: number) => n >= 0)
|
|
875
|
+
*
|
|
876
|
+
* assert.deepStrictEqual(getOption(-1), O.none())
|
|
877
|
+
* assert.deepStrictEqual(getOption(1), O.some(1))
|
|
878
|
+
*
|
|
879
|
+
* @category lifting
|
|
880
|
+
* @since 2.0.0
|
|
881
|
+
*/
|
|
882
|
+
const liftPredicate = predicate => b => predicate(b) ? some(b) : none();
|
|
883
|
+
|
|
884
|
+
/**
|
|
885
|
+
* Returns a function that checks if a `Option` contains a given value using a provided `isEquivalent` function.
|
|
886
|
+
*
|
|
887
|
+
* @param equivalent - An `Equivalence` instance to compare values of the `Option`.
|
|
888
|
+
* @param self - The `Option` to apply the comparison to.
|
|
889
|
+
* @param a - The value to compare against the `Option`.
|
|
890
|
+
*
|
|
891
|
+
* @example
|
|
892
|
+
* import { some, none, containsWith } from 'effect/Option'
|
|
893
|
+
* import { Equivalence } from 'effect/Number'
|
|
894
|
+
* import { pipe } from "effect/Function"
|
|
895
|
+
*
|
|
896
|
+
* assert.deepStrictEqual(pipe(some(2), containsWith(Equivalence)(2)), true)
|
|
897
|
+
* assert.deepStrictEqual(pipe(some(1), containsWith(Equivalence)(2)), false)
|
|
898
|
+
* assert.deepStrictEqual(pipe(none(), containsWith(Equivalence)(2)), false)
|
|
899
|
+
*
|
|
900
|
+
* @category elements
|
|
901
|
+
* @since 2.0.0
|
|
902
|
+
*/
|
|
903
|
+
const containsWith = isEquivalent => dual(2, (self, a) => isNone(self) ? false : isEquivalent(self.value, a));
|
|
904
|
+
const _equivalence = /*#__PURE__*/equivalence();
|
|
905
|
+
|
|
906
|
+
/**
|
|
907
|
+
* Returns a function that checks if an `Option` contains a given value using the default `Equivalence`.
|
|
908
|
+
*
|
|
909
|
+
* @category elements
|
|
910
|
+
* @since 2.0.0
|
|
911
|
+
*/
|
|
912
|
+
const contains = /*#__PURE__*/containsWith(_equivalence);
|
|
913
|
+
|
|
914
|
+
/**
|
|
915
|
+
* Check if a value in an `Option` type meets a certain predicate.
|
|
916
|
+
*
|
|
917
|
+
* @param self - The `Option` to check.
|
|
918
|
+
* @param predicate - The condition to check.
|
|
919
|
+
*
|
|
920
|
+
* @example
|
|
921
|
+
* import { some, none, exists } from 'effect/Option'
|
|
922
|
+
* import { pipe } from "effect/Function"
|
|
923
|
+
*
|
|
924
|
+
* const isEven = (n: number) => n % 2 === 0
|
|
925
|
+
*
|
|
926
|
+
* assert.deepStrictEqual(pipe(some(2), exists(isEven)), true)
|
|
927
|
+
* assert.deepStrictEqual(pipe(some(1), exists(isEven)), false)
|
|
928
|
+
* assert.deepStrictEqual(pipe(none(), exists(isEven)), false)
|
|
929
|
+
*
|
|
930
|
+
* @since 2.0.0
|
|
931
|
+
*/
|
|
932
|
+
const exists = /*#__PURE__*/dual(2, (self, predicate) => isNone(self) ? false : predicate(self.value));
|
|
933
|
+
|
|
934
|
+
// -------------------------------------------------------------------------------------
|
|
935
|
+
// math
|
|
936
|
+
// -------------------------------------------------------------------------------------
|
|
937
|
+
|
|
938
|
+
/**
|
|
939
|
+
* @category math
|
|
940
|
+
* @since 2.0.0
|
|
941
|
+
*/
|
|
942
|
+
const sum = /*#__PURE__*/lift2(sum$1);
|
|
943
|
+
|
|
944
|
+
/**
|
|
945
|
+
* @category math
|
|
946
|
+
* @since 2.0.0
|
|
947
|
+
*/
|
|
948
|
+
const multiply = /*#__PURE__*/lift2(multiply$1);
|
|
949
|
+
|
|
950
|
+
/**
|
|
951
|
+
* @category math
|
|
952
|
+
* @since 2.0.0
|
|
953
|
+
*/
|
|
954
|
+
const subtract = /*#__PURE__*/lift2(subtract$1);
|
|
955
|
+
|
|
956
|
+
/**
|
|
957
|
+
* @category math
|
|
958
|
+
* @since 2.0.0
|
|
959
|
+
*/
|
|
960
|
+
const divide = /*#__PURE__*/lift2(divide$1);
|
|
961
|
+
|
|
962
|
+
/**
|
|
963
|
+
* Sum all numbers in an iterable of `Option<number>` ignoring the `None` values.
|
|
964
|
+
*
|
|
965
|
+
* @param self - The iterable of `Option<number>` to be summed.
|
|
966
|
+
*
|
|
967
|
+
* @example
|
|
968
|
+
* import { sumCompact, some, none } from 'effect/Option'
|
|
969
|
+
*
|
|
970
|
+
* const iterable = [some(2), none(), some(3), none()]
|
|
971
|
+
* assert.deepStrictEqual(sumCompact(iterable), 5)
|
|
972
|
+
*
|
|
973
|
+
* @category math
|
|
974
|
+
* @since 2.0.0
|
|
975
|
+
*/
|
|
976
|
+
const sumCompact = self => {
|
|
977
|
+
let out = 0;
|
|
978
|
+
for (const oa of self) {
|
|
979
|
+
if (isSome(oa)) {
|
|
980
|
+
out += oa.value;
|
|
981
|
+
}
|
|
982
|
+
}
|
|
983
|
+
return out;
|
|
984
|
+
};
|
|
985
|
+
|
|
986
|
+
/**
|
|
987
|
+
* Multiply all numbers in an iterable of `Option<number>` ignoring the `None` values.
|
|
988
|
+
*
|
|
989
|
+
* @param self - The iterable of `Option<number>` to be multiplied.
|
|
990
|
+
*
|
|
991
|
+
* @example
|
|
992
|
+
* import { multiplyCompact, some, none } from 'effect/Option'
|
|
993
|
+
*
|
|
994
|
+
* const iterable = [some(2), none(), some(3), none()]
|
|
995
|
+
* assert.deepStrictEqual(multiplyCompact(iterable), 6)
|
|
996
|
+
*
|
|
997
|
+
* @category math
|
|
998
|
+
* @since 2.0.0
|
|
999
|
+
*/
|
|
1000
|
+
const multiplyCompact = self => {
|
|
1001
|
+
let out = 1;
|
|
1002
|
+
for (const oa of self) {
|
|
1003
|
+
if (isSome(oa)) {
|
|
1004
|
+
const a = oa.value;
|
|
1005
|
+
if (a === 0) {
|
|
1006
|
+
return 0;
|
|
1007
|
+
}
|
|
1008
|
+
out *= a;
|
|
1009
|
+
}
|
|
1010
|
+
}
|
|
1011
|
+
return out;
|
|
1012
|
+
};
|
|
1013
|
+
|
|
1014
|
+
// -------------------------------------------------------------------------------------
|
|
1015
|
+
// do notation
|
|
1016
|
+
// -------------------------------------------------------------------------------------
|
|
1017
|
+
|
|
1018
|
+
/**
|
|
1019
|
+
* @category do notation
|
|
1020
|
+
* @since 2.0.0
|
|
1021
|
+
*/
|
|
1022
|
+
const bindTo = /*#__PURE__*/dual(2, (self, name) => map(self, a => ({
|
|
1023
|
+
[name]: a
|
|
1024
|
+
})));
|
|
1025
|
+
const let_ = /*#__PURE__*/dual(3, (self, name, f) => map(self, a => Object.assign({}, a, {
|
|
1026
|
+
[name]: f(a)
|
|
1027
|
+
})));
|
|
1028
|
+
|
|
1029
|
+
/**
|
|
1030
|
+
* @category do notation
|
|
1031
|
+
* @since 2.0.0
|
|
1032
|
+
*/
|
|
1033
|
+
const bind = /*#__PURE__*/dual(3, (self, name, f) => flatMap(self, a => map(f(a), b => Object.assign({}, a, {
|
|
1034
|
+
[name]: b
|
|
1035
|
+
}))));
|
|
1036
|
+
|
|
1037
|
+
/**
|
|
1038
|
+
* @category do notation
|
|
1039
|
+
* @since 2.0.0
|
|
1040
|
+
*/
|
|
1041
|
+
const Do = /*#__PURE__*/some({});
|
|
1042
|
+
const adapter = /*#__PURE__*/adapter$1();
|
|
1043
|
+
|
|
1044
|
+
/**
|
|
1045
|
+
* @category generators
|
|
1046
|
+
* @since 2.0.0
|
|
1047
|
+
*/
|
|
1048
|
+
const gen = f => {
|
|
1049
|
+
const iterator = f(adapter);
|
|
1050
|
+
let state = iterator.next();
|
|
1051
|
+
if (state.done) {
|
|
1052
|
+
return some(void 0);
|
|
1053
|
+
} else {
|
|
1054
|
+
let current = state.value.value;
|
|
1055
|
+
if (isNone(current)) {
|
|
1056
|
+
return current;
|
|
1057
|
+
}
|
|
1058
|
+
while (!state.done) {
|
|
1059
|
+
state = iterator.next(current.value);
|
|
1060
|
+
if (!state.done) {
|
|
1061
|
+
current = state.value.value;
|
|
1062
|
+
if (isNone(current)) {
|
|
1063
|
+
return current;
|
|
1064
|
+
}
|
|
1065
|
+
}
|
|
1066
|
+
}
|
|
1067
|
+
return some(state.value);
|
|
1068
|
+
}
|
|
1069
|
+
};
|
|
1070
|
+
|
|
1071
|
+
export { Do, TypeId, all, ap, as, asUnit, bind, bindTo, composeK, contains, containsWith, divide, exists, filter, filterMap, firstSomeOf, flatMap, flatMapNullable, flatten, fromIterable, fromNullable, gen, getEquivalence, getLeft, getOrElse, getOrNull, getOrThrow, getOrThrowWith, getOrUndefined, getOrder, getRight, isNone, isOption, isSome, let_ as let, lift2, liftNullable, liftPredicate, liftThrowable, map, match, multiply, multiplyCompact, none, orElse, orElseEither, partitionMap, product, productMany, reduceCompact, some, subtract, sum, sumCompact, tap, toArray, toRefinement, unit, zipLeft, zipRight, zipWith };
|