@clayroach/effect 3.19.14-source-capture.8 → 3.19.14-source-trace.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/SourceLocation/package.json +6 -0
- package/dist/cjs/Effect.js +2 -28
- package/dist/cjs/Effect.js.map +1 -1
- package/dist/cjs/FiberRef.js +12 -1
- package/dist/cjs/FiberRef.js.map +1 -1
- package/dist/cjs/Layer.js +2 -24
- package/dist/cjs/Layer.js.map +1 -1
- package/dist/cjs/RuntimeFlags.js +1 -29
- package/dist/cjs/RuntimeFlags.js.map +1 -1
- package/dist/cjs/SourceLocation.js +60 -0
- package/dist/cjs/SourceLocation.js.map +1 -0
- package/dist/cjs/Tracer.js +1 -15
- package/dist/cjs/Tracer.js.map +1 -1
- package/dist/cjs/Utils.js +1 -1
- package/dist/cjs/Utils.js.map +1 -1
- package/dist/cjs/index.js +3 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/internal/clock.js +1 -1
- package/dist/cjs/internal/clock.js.map +1 -1
- package/dist/cjs/internal/core.js +17 -50
- package/dist/cjs/internal/core.js.map +1 -1
- package/dist/cjs/internal/effect/circular.js +18 -30
- package/dist/cjs/internal/effect/circular.js.map +1 -1
- package/dist/cjs/internal/fiberRuntime.js +16 -65
- package/dist/cjs/internal/fiberRuntime.js.map +1 -1
- package/dist/cjs/internal/layer/circular.js +1 -5
- package/dist/cjs/internal/layer/circular.js.map +1 -1
- package/dist/cjs/internal/layer.js +1 -3
- package/dist/cjs/internal/layer.js.map +1 -1
- package/dist/cjs/internal/logger.js +25 -2
- package/dist/cjs/internal/logger.js.map +1 -1
- package/dist/cjs/internal/runtimeFlags.js +2 -11
- package/dist/cjs/internal/runtimeFlags.js.map +1 -1
- package/dist/cjs/internal/tracer.js +1 -114
- package/dist/cjs/internal/tracer.js.map +1 -1
- package/dist/dts/Config.d.ts +2 -2
- package/dist/dts/Config.d.ts.map +1 -1
- package/dist/dts/Effect.d.ts +8 -29
- package/dist/dts/Effect.d.ts.map +1 -1
- package/dist/dts/FiberRef.d.ts +12 -0
- package/dist/dts/FiberRef.d.ts.map +1 -1
- package/dist/dts/Layer.d.ts +0 -22
- package/dist/dts/Layer.d.ts.map +1 -1
- package/dist/dts/RuntimeFlags.d.ts +0 -28
- package/dist/dts/RuntimeFlags.d.ts.map +1 -1
- package/dist/dts/SourceLocation.d.ts +88 -0
- package/dist/dts/SourceLocation.d.ts.map +1 -0
- package/dist/dts/Tracer.d.ts +0 -15
- package/dist/dts/Tracer.d.ts.map +1 -1
- package/dist/dts/index.d.ts +6 -0
- package/dist/dts/index.d.ts.map +1 -1
- package/dist/dts/internal/core.d.ts.map +1 -1
- package/dist/dts/internal/layer.d.ts.map +1 -1
- package/dist/dts/internal/runtimeFlags.d.ts.map +1 -1
- package/dist/esm/Effect.js +0 -26
- package/dist/esm/Effect.js.map +1 -1
- package/dist/esm/FiberRef.js +11 -0
- package/dist/esm/FiberRef.js.map +1 -1
- package/dist/esm/Layer.js +0 -22
- package/dist/esm/Layer.js.map +1 -1
- package/dist/esm/RuntimeFlags.js +0 -28
- package/dist/esm/RuntimeFlags.js.map +1 -1
- package/dist/esm/SourceLocation.js +51 -0
- package/dist/esm/SourceLocation.js.map +1 -0
- package/dist/esm/Tracer.js +0 -14
- package/dist/esm/Tracer.js.map +1 -1
- package/dist/esm/Utils.js +1 -1
- package/dist/esm/Utils.js.map +1 -1
- package/dist/esm/index.js +6 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/internal/clock.js +1 -1
- package/dist/esm/internal/clock.js.map +1 -1
- package/dist/esm/internal/core.js +12 -45
- package/dist/esm/internal/core.js.map +1 -1
- package/dist/esm/internal/effect/circular.js +18 -30
- package/dist/esm/internal/effect/circular.js.map +1 -1
- package/dist/esm/internal/fiberRuntime.js +13 -60
- package/dist/esm/internal/fiberRuntime.js.map +1 -1
- package/dist/esm/internal/layer/circular.js +0 -4
- package/dist/esm/internal/layer/circular.js.map +1 -1
- package/dist/esm/internal/layer.js +0 -2
- package/dist/esm/internal/layer.js.map +1 -1
- package/dist/esm/internal/logger.js +25 -2
- package/dist/esm/internal/logger.js.map +1 -1
- package/dist/esm/internal/runtimeFlags.js +1 -9
- package/dist/esm/internal/runtimeFlags.js.map +1 -1
- package/dist/esm/internal/tracer.js +0 -111
- package/dist/esm/internal/tracer.js.map +1 -1
- package/package.json +12 -1
- package/src/Arbitrary.ts +1101 -0
- package/src/Array.ts +3589 -0
- package/src/BigDecimal.ts +1349 -0
- package/src/BigInt.ts +643 -0
- package/src/Boolean.ts +287 -0
- package/src/Brand.ts +360 -0
- package/src/Cache.ts +281 -0
- package/src/Cause.ts +1555 -0
- package/src/Channel.ts +2355 -0
- package/src/ChildExecutorDecision.ts +146 -0
- package/src/Chunk.ts +1495 -0
- package/src/Clock.ts +111 -0
- package/src/Config.ts +542 -0
- package/src/ConfigError.ts +270 -0
- package/src/ConfigProvider.ts +333 -0
- package/src/ConfigProviderPathPatch.ts +100 -0
- package/src/Console.ts +226 -0
- package/src/Context.ts +585 -0
- package/src/Cron.ts +706 -0
- package/src/Data.ts +596 -0
- package/src/DateTime.ts +1686 -0
- package/src/DefaultServices.ts +34 -0
- package/src/Deferred.ts +301 -0
- package/src/Differ.ts +450 -0
- package/src/Duration.ts +1000 -0
- package/src/Effect.ts +14817 -0
- package/src/Effectable.ts +107 -0
- package/src/Either.ts +1040 -0
- package/src/Encoding.ts +195 -0
- package/src/Equal.ts +98 -0
- package/src/Equivalence.ts +235 -0
- package/src/ExecutionPlan.ts +308 -0
- package/src/ExecutionStrategy.ts +119 -0
- package/src/Exit.ts +467 -0
- package/src/FastCheck.ts +9 -0
- package/src/Fiber.ts +744 -0
- package/src/FiberHandle.ts +540 -0
- package/src/FiberId.ts +195 -0
- package/src/FiberMap.ts +656 -0
- package/src/FiberRef.ts +444 -0
- package/src/FiberRefs.ts +204 -0
- package/src/FiberRefsPatch.ts +105 -0
- package/src/FiberSet.ts +491 -0
- package/src/FiberStatus.ts +108 -0
- package/src/Function.ts +1222 -0
- package/src/GlobalValue.ts +53 -0
- package/src/Graph.ts +3732 -0
- package/src/GroupBy.ts +103 -0
- package/src/HKT.ts +45 -0
- package/src/Hash.ts +195 -0
- package/src/HashMap.ts +519 -0
- package/src/HashRing.ts +317 -0
- package/src/HashSet.ts +2346 -0
- package/src/Inspectable.ts +287 -0
- package/src/Iterable.ts +1119 -0
- package/src/JSONSchema.ts +1044 -0
- package/src/KeyedPool.ts +167 -0
- package/src/Layer.ts +1228 -0
- package/src/LayerMap.ts +436 -0
- package/src/List.ts +977 -0
- package/src/LogLevel.ts +285 -0
- package/src/LogSpan.ts +25 -0
- package/src/Logger.ts +702 -0
- package/src/Mailbox.ts +268 -0
- package/src/ManagedRuntime.ts +180 -0
- package/src/Match.ts +1477 -0
- package/src/MergeDecision.ts +95 -0
- package/src/MergeState.ts +172 -0
- package/src/MergeStrategy.ts +107 -0
- package/src/Metric.ts +780 -0
- package/src/MetricBoundaries.ts +69 -0
- package/src/MetricHook.ts +151 -0
- package/src/MetricKey.ts +224 -0
- package/src/MetricKeyType.ts +262 -0
- package/src/MetricLabel.ts +47 -0
- package/src/MetricPair.ts +71 -0
- package/src/MetricPolling.ts +148 -0
- package/src/MetricRegistry.ts +48 -0
- package/src/MetricState.ts +257 -0
- package/src/Micro.ts +4405 -0
- package/src/ModuleVersion.ts +18 -0
- package/src/MutableHashMap.ts +411 -0
- package/src/MutableHashSet.ts +706 -0
- package/src/MutableList.ts +297 -0
- package/src/MutableQueue.ts +227 -0
- package/src/MutableRef.ts +202 -0
- package/src/NonEmptyIterable.ts +32 -0
- package/src/Number.ts +1071 -0
- package/src/Option.ts +2170 -0
- package/src/Order.ts +373 -0
- package/src/Ordering.ts +111 -0
- package/src/ParseResult.ts +2031 -0
- package/src/PartitionedSemaphore.ts +200 -0
- package/src/Pipeable.ts +566 -0
- package/src/Pool.ts +204 -0
- package/src/Predicate.ts +1405 -0
- package/src/Pretty.ts +205 -0
- package/src/PrimaryKey.ts +23 -0
- package/src/PubSub.ts +182 -0
- package/src/Queue.ts +644 -0
- package/src/Random.ts +204 -0
- package/src/RateLimiter.ts +138 -0
- package/src/RcMap.ts +141 -0
- package/src/RcRef.ts +122 -0
- package/src/Readable.ts +93 -0
- package/src/Record.ts +1274 -0
- package/src/RedBlackTree.ts +421 -0
- package/src/Redacted.ts +144 -0
- package/src/Ref.ts +180 -0
- package/src/RegExp.ts +38 -0
- package/src/Reloadable.ts +127 -0
- package/src/Request.ts +347 -0
- package/src/RequestBlock.ts +118 -0
- package/src/RequestResolver.ts +366 -0
- package/src/Resource.ts +119 -0
- package/src/Runtime.ts +383 -0
- package/src/RuntimeFlags.ts +336 -0
- package/src/RuntimeFlagsPatch.ts +183 -0
- package/src/STM.ts +2045 -0
- package/src/Schedule.ts +2219 -0
- package/src/ScheduleDecision.ts +62 -0
- package/src/ScheduleInterval.ts +151 -0
- package/src/ScheduleIntervals.ts +122 -0
- package/src/Scheduler.ts +353 -0
- package/src/Schema.ts +10914 -0
- package/src/SchemaAST.ts +3043 -0
- package/src/Scope.ts +204 -0
- package/src/ScopedCache.ts +151 -0
- package/src/ScopedRef.ts +117 -0
- package/src/Secret.ts +88 -0
- package/src/SingleProducerAsyncInput.ts +67 -0
- package/src/Sink.ts +1461 -0
- package/src/SortedMap.ts +287 -0
- package/src/SortedSet.ts +390 -0
- package/src/SourceLocation.ts +108 -0
- package/src/Stream.ts +6468 -0
- package/src/StreamEmit.ts +136 -0
- package/src/StreamHaltStrategy.ts +123 -0
- package/src/Streamable.ts +45 -0
- package/src/String.ts +778 -0
- package/src/Struct.ts +243 -0
- package/src/Subscribable.ts +100 -0
- package/src/SubscriptionRef.ts +298 -0
- package/src/Supervisor.ts +240 -0
- package/src/Symbol.ts +29 -0
- package/src/SynchronizedRef.ts +270 -0
- package/src/TArray.ts +495 -0
- package/src/TDeferred.ts +100 -0
- package/src/TMap.ts +515 -0
- package/src/TPriorityQueue.ts +223 -0
- package/src/TPubSub.ts +200 -0
- package/src/TQueue.ts +432 -0
- package/src/TRandom.ts +129 -0
- package/src/TReentrantLock.ts +224 -0
- package/src/TRef.ts +178 -0
- package/src/TSemaphore.ts +129 -0
- package/src/TSet.ts +365 -0
- package/src/TSubscriptionRef.ts +192 -0
- package/src/Take.ts +258 -0
- package/src/TestAnnotation.ts +158 -0
- package/src/TestAnnotationMap.ts +119 -0
- package/src/TestAnnotations.ts +117 -0
- package/src/TestClock.ts +556 -0
- package/src/TestConfig.ts +47 -0
- package/src/TestContext.ts +36 -0
- package/src/TestLive.ts +53 -0
- package/src/TestServices.ts +390 -0
- package/src/TestSized.ts +55 -0
- package/src/Tracer.ts +182 -0
- package/src/Trie.ts +840 -0
- package/src/Tuple.ts +305 -0
- package/src/Types.ts +353 -0
- package/src/Unify.ts +113 -0
- package/src/UpstreamPullRequest.ts +117 -0
- package/src/UpstreamPullStrategy.ts +121 -0
- package/src/Utils.ts +809 -0
- package/src/index.ts +1568 -0
- package/src/internal/array.ts +8 -0
- package/src/internal/blockedRequests.ts +520 -0
- package/src/internal/cache.ts +733 -0
- package/src/internal/cause.ts +1050 -0
- package/src/internal/channel/channelExecutor.ts +1200 -0
- package/src/internal/channel/channelState.ts +134 -0
- package/src/internal/channel/childExecutorDecision.ts +96 -0
- package/src/internal/channel/continuation.ts +200 -0
- package/src/internal/channel/mergeDecision.ts +113 -0
- package/src/internal/channel/mergeState.ts +120 -0
- package/src/internal/channel/mergeStrategy.ts +72 -0
- package/src/internal/channel/singleProducerAsyncInput.ts +259 -0
- package/src/internal/channel/subexecutor.ts +229 -0
- package/src/internal/channel/upstreamPullRequest.ts +84 -0
- package/src/internal/channel/upstreamPullStrategy.ts +87 -0
- package/src/internal/channel.ts +2603 -0
- package/src/internal/clock.ts +95 -0
- package/src/internal/completedRequestMap.ts +9 -0
- package/src/internal/concurrency.ts +54 -0
- package/src/internal/config.ts +716 -0
- package/src/internal/configError.ts +304 -0
- package/src/internal/configProvider/pathPatch.ts +97 -0
- package/src/internal/configProvider.ts +799 -0
- package/src/internal/console.ts +153 -0
- package/src/internal/context.ts +337 -0
- package/src/internal/core-effect.ts +2293 -0
- package/src/internal/core-stream.ts +998 -0
- package/src/internal/core.ts +3189 -0
- package/src/internal/data.ts +36 -0
- package/src/internal/dataSource.ts +327 -0
- package/src/internal/dateTime.ts +1277 -0
- package/src/internal/defaultServices/console.ts +100 -0
- package/src/internal/defaultServices.ts +163 -0
- package/src/internal/deferred.ts +46 -0
- package/src/internal/differ/chunkPatch.ts +211 -0
- package/src/internal/differ/contextPatch.ts +232 -0
- package/src/internal/differ/hashMapPatch.ts +220 -0
- package/src/internal/differ/hashSetPatch.ts +176 -0
- package/src/internal/differ/orPatch.ts +311 -0
- package/src/internal/differ/readonlyArrayPatch.ts +210 -0
- package/src/internal/differ.ts +200 -0
- package/src/internal/doNotation.ts +80 -0
- package/src/internal/effect/circular.ts +895 -0
- package/src/internal/effectable.ts +131 -0
- package/src/internal/either.ts +110 -0
- package/src/internal/encoding/base64.ts +286 -0
- package/src/internal/encoding/base64Url.ts +29 -0
- package/src/internal/encoding/common.ts +51 -0
- package/src/internal/encoding/hex.ts +315 -0
- package/src/internal/errors.ts +7 -0
- package/src/internal/executionPlan.ts +114 -0
- package/src/internal/executionStrategy.ts +74 -0
- package/src/internal/fiber.ts +388 -0
- package/src/internal/fiberId.ts +267 -0
- package/src/internal/fiberMessage.ts +82 -0
- package/src/internal/fiberRefs/patch.ts +144 -0
- package/src/internal/fiberRefs.ts +297 -0
- package/src/internal/fiberRuntime.ts +3842 -0
- package/src/internal/fiberScope.ts +71 -0
- package/src/internal/fiberStatus.ts +119 -0
- package/src/internal/groupBy.ts +530 -0
- package/src/internal/hashMap/array.ts +49 -0
- package/src/internal/hashMap/bitwise.ts +32 -0
- package/src/internal/hashMap/config.ts +14 -0
- package/src/internal/hashMap/keySet.ts +8 -0
- package/src/internal/hashMap/node.ts +391 -0
- package/src/internal/hashMap.ts +586 -0
- package/src/internal/hashSet.ts +323 -0
- package/src/internal/keyedPool.ts +244 -0
- package/src/internal/layer/circular.ts +214 -0
- package/src/internal/layer.ts +1483 -0
- package/src/internal/logSpan.ts +20 -0
- package/src/internal/logger-circular.ts +24 -0
- package/src/internal/logger.ts +522 -0
- package/src/internal/mailbox.ts +561 -0
- package/src/internal/managedRuntime/circular.ts +6 -0
- package/src/internal/managedRuntime.ts +134 -0
- package/src/internal/matcher.ts +652 -0
- package/src/internal/metric/boundaries.ts +75 -0
- package/src/internal/metric/hook.ts +483 -0
- package/src/internal/metric/key.ts +167 -0
- package/src/internal/metric/keyType.ts +238 -0
- package/src/internal/metric/label.ts +41 -0
- package/src/internal/metric/pair.ts +48 -0
- package/src/internal/metric/polling.ts +149 -0
- package/src/internal/metric/registry.ts +187 -0
- package/src/internal/metric/state.ts +290 -0
- package/src/internal/metric.ts +577 -0
- package/src/internal/opCodes/cause.ts +35 -0
- package/src/internal/opCodes/channel.ts +83 -0
- package/src/internal/opCodes/channelChildExecutorDecision.ts +17 -0
- package/src/internal/opCodes/channelMergeDecision.ts +11 -0
- package/src/internal/opCodes/channelMergeState.ts +17 -0
- package/src/internal/opCodes/channelMergeStrategy.ts +11 -0
- package/src/internal/opCodes/channelState.ts +23 -0
- package/src/internal/opCodes/channelUpstreamPullRequest.ts +11 -0
- package/src/internal/opCodes/channelUpstreamPullStrategy.ts +11 -0
- package/src/internal/opCodes/config.ts +65 -0
- package/src/internal/opCodes/configError.ts +35 -0
- package/src/internal/opCodes/continuation.ts +11 -0
- package/src/internal/opCodes/deferred.ts +11 -0
- package/src/internal/opCodes/effect.ts +89 -0
- package/src/internal/opCodes/layer.ts +59 -0
- package/src/internal/opCodes/streamHaltStrategy.ts +23 -0
- package/src/internal/option.ts +80 -0
- package/src/internal/pool.ts +432 -0
- package/src/internal/pubsub.ts +1762 -0
- package/src/internal/query.ts +204 -0
- package/src/internal/queue.ts +766 -0
- package/src/internal/random.ts +161 -0
- package/src/internal/rateLimiter.ts +93 -0
- package/src/internal/rcMap.ts +285 -0
- package/src/internal/rcRef.ts +192 -0
- package/src/internal/redBlackTree/iterator.ts +200 -0
- package/src/internal/redBlackTree/node.ts +68 -0
- package/src/internal/redBlackTree.ts +1245 -0
- package/src/internal/redacted.ts +73 -0
- package/src/internal/ref.ts +171 -0
- package/src/internal/reloadable.ts +140 -0
- package/src/internal/request.ts +177 -0
- package/src/internal/resource.ts +76 -0
- package/src/internal/ringBuffer.ts +68 -0
- package/src/internal/runtime.ts +558 -0
- package/src/internal/runtimeFlags.ts +178 -0
- package/src/internal/runtimeFlagsPatch.ts +103 -0
- package/src/internal/schedule/decision.ts +47 -0
- package/src/internal/schedule/interval.ts +101 -0
- package/src/internal/schedule/intervals.ts +180 -0
- package/src/internal/schedule.ts +2199 -0
- package/src/internal/schema/errors.ts +191 -0
- package/src/internal/schema/schemaId.ts +106 -0
- package/src/internal/schema/util.ts +50 -0
- package/src/internal/scopedCache.ts +644 -0
- package/src/internal/scopedRef.ts +118 -0
- package/src/internal/secret.ts +89 -0
- package/src/internal/singleShotGen.ts +35 -0
- package/src/internal/sink.ts +2120 -0
- package/src/internal/stack.ts +10 -0
- package/src/internal/stm/core.ts +817 -0
- package/src/internal/stm/entry.ts +59 -0
- package/src/internal/stm/journal.ts +123 -0
- package/src/internal/stm/opCodes/stm.ts +71 -0
- package/src/internal/stm/opCodes/stmState.ts +17 -0
- package/src/internal/stm/opCodes/strategy.ts +17 -0
- package/src/internal/stm/opCodes/tExit.ts +29 -0
- package/src/internal/stm/opCodes/tryCommit.ts +11 -0
- package/src/internal/stm/stm.ts +1453 -0
- package/src/internal/stm/stmState.ts +136 -0
- package/src/internal/stm/tArray.ts +550 -0
- package/src/internal/stm/tDeferred.ts +81 -0
- package/src/internal/stm/tExit.ts +190 -0
- package/src/internal/stm/tMap.ts +824 -0
- package/src/internal/stm/tPriorityQueue.ts +267 -0
- package/src/internal/stm/tPubSub.ts +551 -0
- package/src/internal/stm/tQueue.ts +393 -0
- package/src/internal/stm/tRandom.ts +140 -0
- package/src/internal/stm/tReentrantLock.ts +352 -0
- package/src/internal/stm/tRef.ts +195 -0
- package/src/internal/stm/tSemaphore.ts +113 -0
- package/src/internal/stm/tSet.ts +259 -0
- package/src/internal/stm/tSubscriptionRef.ts +286 -0
- package/src/internal/stm/tryCommit.ts +34 -0
- package/src/internal/stm/txnId.ts +14 -0
- package/src/internal/stm/versioned.ts +4 -0
- package/src/internal/stream/debounceState.ts +57 -0
- package/src/internal/stream/emit.ts +123 -0
- package/src/internal/stream/haltStrategy.ts +94 -0
- package/src/internal/stream/handoff.ts +187 -0
- package/src/internal/stream/handoffSignal.ts +59 -0
- package/src/internal/stream/pull.ts +34 -0
- package/src/internal/stream/sinkEndReason.ts +30 -0
- package/src/internal/stream/zipAllState.ts +88 -0
- package/src/internal/stream/zipChunksState.ts +56 -0
- package/src/internal/stream.ts +8801 -0
- package/src/internal/string-utils.ts +107 -0
- package/src/internal/subscriptionRef.ts +138 -0
- package/src/internal/supervisor/patch.ts +190 -0
- package/src/internal/supervisor.ts +303 -0
- package/src/internal/synchronizedRef.ts +114 -0
- package/src/internal/take.ts +199 -0
- package/src/internal/testing/sleep.ts +27 -0
- package/src/internal/testing/suspendedWarningData.ts +85 -0
- package/src/internal/testing/warningData.ts +94 -0
- package/src/internal/tracer.ts +150 -0
- package/src/internal/trie.ts +722 -0
- package/src/internal/version.ts +7 -0
package/src/Function.ts
ADDED
|
@@ -0,0 +1,1222 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @since 2.0.0
|
|
3
|
+
*/
|
|
4
|
+
import type { TypeLambda } from "./HKT.js"
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* @category type lambdas
|
|
8
|
+
* @since 2.0.0
|
|
9
|
+
*/
|
|
10
|
+
export interface FunctionTypeLambda extends TypeLambda {
|
|
11
|
+
readonly type: (a: this["In"]) => this["Target"]
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Tests if a value is a `function`.
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* ```ts
|
|
19
|
+
* import * as assert from "node:assert"
|
|
20
|
+
* import { isFunction } from "effect/Predicate"
|
|
21
|
+
*
|
|
22
|
+
* assert.deepStrictEqual(isFunction(isFunction), true)
|
|
23
|
+
* assert.deepStrictEqual(isFunction("function"), false)
|
|
24
|
+
* ```
|
|
25
|
+
*
|
|
26
|
+
* @category guards
|
|
27
|
+
* @since 2.0.0
|
|
28
|
+
*/
|
|
29
|
+
export const isFunction = (input: unknown): input is Function => typeof input === "function"
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Creates a function that can be used in a data-last (aka `pipe`able) or
|
|
33
|
+
* data-first style.
|
|
34
|
+
*
|
|
35
|
+
* The first parameter to `dual` is either the arity of the uncurried function
|
|
36
|
+
* or a predicate that determines if the function is being used in a data-first
|
|
37
|
+
* or data-last style.
|
|
38
|
+
*
|
|
39
|
+
* Using the arity is the most common use case, but there are some cases where
|
|
40
|
+
* you may want to use a predicate. For example, if you have a function that
|
|
41
|
+
* takes an optional argument, you can use a predicate to determine if the
|
|
42
|
+
* function is being used in a data-first or data-last style.
|
|
43
|
+
*
|
|
44
|
+
* You can pass either the arity of the uncurried function or a predicate
|
|
45
|
+
* which determines if the function is being used in a data-first or
|
|
46
|
+
* data-last style.
|
|
47
|
+
*
|
|
48
|
+
* **Example** (Using arity to determine data-first or data-last style)
|
|
49
|
+
*
|
|
50
|
+
* ```ts
|
|
51
|
+
* import { dual, pipe } from "effect/Function"
|
|
52
|
+
*
|
|
53
|
+
* const sum = dual<
|
|
54
|
+
* (that: number) => (self: number) => number,
|
|
55
|
+
* (self: number, that: number) => number
|
|
56
|
+
* >(2, (self, that) => self + that)
|
|
57
|
+
*
|
|
58
|
+
* console.log(sum(2, 3)) // 5
|
|
59
|
+
* console.log(pipe(2, sum(3))) // 5
|
|
60
|
+
* ```
|
|
61
|
+
*
|
|
62
|
+
* **Example** (Using call signatures to define the overloads)
|
|
63
|
+
*
|
|
64
|
+
* ```ts
|
|
65
|
+
* import { dual, pipe } from "effect/Function"
|
|
66
|
+
*
|
|
67
|
+
* const sum: {
|
|
68
|
+
* (that: number): (self: number) => number
|
|
69
|
+
* (self: number, that: number): number
|
|
70
|
+
* } = dual(2, (self: number, that: number): number => self + that)
|
|
71
|
+
*
|
|
72
|
+
* console.log(sum(2, 3)) // 5
|
|
73
|
+
* console.log(pipe(2, sum(3))) // 5
|
|
74
|
+
* ```
|
|
75
|
+
*
|
|
76
|
+
* **Example** (Using a predicate to determine data-first or data-last style)
|
|
77
|
+
*
|
|
78
|
+
* ```ts
|
|
79
|
+
* import { dual, pipe } from "effect/Function"
|
|
80
|
+
*
|
|
81
|
+
* const sum = dual<
|
|
82
|
+
* (that: number) => (self: number) => number,
|
|
83
|
+
* (self: number, that: number) => number
|
|
84
|
+
* >(
|
|
85
|
+
* (args) => args.length === 2,
|
|
86
|
+
* (self, that) => self + that
|
|
87
|
+
* )
|
|
88
|
+
*
|
|
89
|
+
* console.log(sum(2, 3)) // 5
|
|
90
|
+
* console.log(pipe(2, sum(3))) // 5
|
|
91
|
+
* ```
|
|
92
|
+
*
|
|
93
|
+
* @since 2.0.0
|
|
94
|
+
*/
|
|
95
|
+
export const dual: {
|
|
96
|
+
<DataLast extends (...args: Array<any>) => any, DataFirst extends (...args: Array<any>) => any>(
|
|
97
|
+
arity: Parameters<DataFirst>["length"],
|
|
98
|
+
body: DataFirst
|
|
99
|
+
): DataLast & DataFirst
|
|
100
|
+
<DataLast extends (...args: Array<any>) => any, DataFirst extends (...args: Array<any>) => any>(
|
|
101
|
+
isDataFirst: (args: IArguments) => boolean,
|
|
102
|
+
body: DataFirst
|
|
103
|
+
): DataLast & DataFirst
|
|
104
|
+
} = function(arity, body) {
|
|
105
|
+
if (typeof arity === "function") {
|
|
106
|
+
return function() {
|
|
107
|
+
if (arity(arguments)) {
|
|
108
|
+
// @ts-expect-error
|
|
109
|
+
return body.apply(this, arguments)
|
|
110
|
+
}
|
|
111
|
+
return ((self: any) => body(self, ...arguments)) as any
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
switch (arity) {
|
|
116
|
+
case 0:
|
|
117
|
+
case 1:
|
|
118
|
+
throw new RangeError(`Invalid arity ${arity}`)
|
|
119
|
+
|
|
120
|
+
case 2:
|
|
121
|
+
return function(a, b) {
|
|
122
|
+
if (arguments.length >= 2) {
|
|
123
|
+
return body(a, b)
|
|
124
|
+
}
|
|
125
|
+
return function(self: any) {
|
|
126
|
+
return body(self, a)
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
case 3:
|
|
131
|
+
return function(a, b, c) {
|
|
132
|
+
if (arguments.length >= 3) {
|
|
133
|
+
return body(a, b, c)
|
|
134
|
+
}
|
|
135
|
+
return function(self: any) {
|
|
136
|
+
return body(self, a, b)
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
case 4:
|
|
141
|
+
return function(a, b, c, d) {
|
|
142
|
+
if (arguments.length >= 4) {
|
|
143
|
+
return body(a, b, c, d)
|
|
144
|
+
}
|
|
145
|
+
return function(self: any) {
|
|
146
|
+
return body(self, a, b, c)
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
case 5:
|
|
151
|
+
return function(a, b, c, d, e) {
|
|
152
|
+
if (arguments.length >= 5) {
|
|
153
|
+
return body(a, b, c, d, e)
|
|
154
|
+
}
|
|
155
|
+
return function(self: any) {
|
|
156
|
+
return body(self, a, b, c, d)
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
default:
|
|
161
|
+
return function() {
|
|
162
|
+
if (arguments.length >= arity) {
|
|
163
|
+
// @ts-expect-error
|
|
164
|
+
return body.apply(this, arguments)
|
|
165
|
+
}
|
|
166
|
+
const args = arguments
|
|
167
|
+
return function(self: any) {
|
|
168
|
+
return body(self, ...args)
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Apply a function to given values.
|
|
175
|
+
*
|
|
176
|
+
* @example
|
|
177
|
+
* ```ts
|
|
178
|
+
* import * as assert from "node:assert"
|
|
179
|
+
* import { pipe, apply } from "effect/Function"
|
|
180
|
+
* import { length } from "effect/String"
|
|
181
|
+
*
|
|
182
|
+
* assert.deepStrictEqual(pipe(length, apply("hello")), 5)
|
|
183
|
+
* ```
|
|
184
|
+
*
|
|
185
|
+
* @since 2.0.0
|
|
186
|
+
*/
|
|
187
|
+
export const apply = <A extends ReadonlyArray<unknown>>(...a: A) => <B>(self: (...a: A) => B): B => self(...a)
|
|
188
|
+
|
|
189
|
+
/**
|
|
190
|
+
* A lazy argument.
|
|
191
|
+
*
|
|
192
|
+
* @example
|
|
193
|
+
* ```ts
|
|
194
|
+
* import * as assert from "node:assert"
|
|
195
|
+
* import { LazyArg, constant } from "effect/Function"
|
|
196
|
+
*
|
|
197
|
+
* const constNull: LazyArg<null> = constant(null)
|
|
198
|
+
* ```
|
|
199
|
+
*
|
|
200
|
+
* @since 2.0.0
|
|
201
|
+
*/
|
|
202
|
+
export interface LazyArg<A> {
|
|
203
|
+
(): A
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
/**
|
|
207
|
+
* @example
|
|
208
|
+
* ```ts
|
|
209
|
+
* import * as assert from "node:assert"
|
|
210
|
+
* import { FunctionN } from "effect/Function"
|
|
211
|
+
*
|
|
212
|
+
* const sum: FunctionN<[number, number], number> = (a, b) => a + b
|
|
213
|
+
* ```
|
|
214
|
+
*
|
|
215
|
+
* @since 2.0.0
|
|
216
|
+
*/
|
|
217
|
+
export interface FunctionN<A extends ReadonlyArray<unknown>, B> {
|
|
218
|
+
(...args: A): B
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
/**
|
|
222
|
+
* The identity function, i.e. A function that returns its input argument.
|
|
223
|
+
*
|
|
224
|
+
* @example
|
|
225
|
+
* ```ts
|
|
226
|
+
* import * as assert from "node:assert"
|
|
227
|
+
* import { identity } from "effect/Function"
|
|
228
|
+
*
|
|
229
|
+
* assert.deepStrictEqual(identity(5), 5)
|
|
230
|
+
* ```
|
|
231
|
+
*
|
|
232
|
+
* @since 2.0.0
|
|
233
|
+
*/
|
|
234
|
+
export const identity = <A>(a: A): A => a
|
|
235
|
+
|
|
236
|
+
/**
|
|
237
|
+
* A function that ensures that the type of an expression matches some type,
|
|
238
|
+
* without changing the resulting type of that expression.
|
|
239
|
+
*
|
|
240
|
+
* @example
|
|
241
|
+
* ```ts
|
|
242
|
+
* import * as assert from "node:assert"
|
|
243
|
+
* import { satisfies } from "effect/Function"
|
|
244
|
+
*
|
|
245
|
+
* const test1 = satisfies<number>()(5 as const)
|
|
246
|
+
* //^? const test: 5
|
|
247
|
+
* // @ts-expect-error
|
|
248
|
+
* const test2 = satisfies<string>()(5)
|
|
249
|
+
* //^? Argument of type 'number' is not assignable to parameter of type 'string'
|
|
250
|
+
*
|
|
251
|
+
* assert.deepStrictEqual(satisfies<number>()(5), 5)
|
|
252
|
+
* ```
|
|
253
|
+
*
|
|
254
|
+
* @since 2.0.0
|
|
255
|
+
*/
|
|
256
|
+
export const satisfies = <A>() => <B extends A>(b: B) => b
|
|
257
|
+
|
|
258
|
+
/**
|
|
259
|
+
* Casts the result to the specified type.
|
|
260
|
+
*
|
|
261
|
+
* @example
|
|
262
|
+
* ```ts
|
|
263
|
+
* import * as assert from "node:assert"
|
|
264
|
+
* import { unsafeCoerce, identity } from "effect/Function"
|
|
265
|
+
*
|
|
266
|
+
* assert.deepStrictEqual(unsafeCoerce, identity)
|
|
267
|
+
* ```
|
|
268
|
+
*
|
|
269
|
+
* @since 2.0.0
|
|
270
|
+
*/
|
|
271
|
+
export const unsafeCoerce: <A, B>(a: A) => B = identity as any
|
|
272
|
+
|
|
273
|
+
/**
|
|
274
|
+
* Creates a constant value that never changes.
|
|
275
|
+
*
|
|
276
|
+
* This is useful when you want to pass a value to a higher-order function (a function that takes another function as its argument)
|
|
277
|
+
* and want that inner function to always use the same value, no matter how many times it is called.
|
|
278
|
+
*
|
|
279
|
+
* @example
|
|
280
|
+
* ```ts
|
|
281
|
+
* import * as assert from "node:assert"
|
|
282
|
+
* import { constant } from "effect/Function"
|
|
283
|
+
*
|
|
284
|
+
* const constNull = constant(null)
|
|
285
|
+
*
|
|
286
|
+
* assert.deepStrictEqual(constNull(), null)
|
|
287
|
+
* assert.deepStrictEqual(constNull(), null)
|
|
288
|
+
* ```
|
|
289
|
+
*
|
|
290
|
+
* @since 2.0.0
|
|
291
|
+
*/
|
|
292
|
+
export const constant = <A>(value: A): LazyArg<A> => () => value
|
|
293
|
+
|
|
294
|
+
/**
|
|
295
|
+
* A thunk that returns always `true`.
|
|
296
|
+
*
|
|
297
|
+
* @example
|
|
298
|
+
* ```ts
|
|
299
|
+
* import * as assert from "node:assert"
|
|
300
|
+
* import { constTrue } from "effect/Function"
|
|
301
|
+
*
|
|
302
|
+
* assert.deepStrictEqual(constTrue(), true)
|
|
303
|
+
* ```
|
|
304
|
+
*
|
|
305
|
+
* @since 2.0.0
|
|
306
|
+
*/
|
|
307
|
+
export const constTrue: LazyArg<boolean> = constant(true)
|
|
308
|
+
|
|
309
|
+
/**
|
|
310
|
+
* A thunk that returns always `false`.
|
|
311
|
+
*
|
|
312
|
+
* @example
|
|
313
|
+
* ```ts
|
|
314
|
+
* import * as assert from "node:assert"
|
|
315
|
+
* import { constFalse } from "effect/Function"
|
|
316
|
+
*
|
|
317
|
+
* assert.deepStrictEqual(constFalse(), false)
|
|
318
|
+
* ```
|
|
319
|
+
*
|
|
320
|
+
* @since 2.0.0
|
|
321
|
+
*/
|
|
322
|
+
export const constFalse: LazyArg<boolean> = constant(false)
|
|
323
|
+
|
|
324
|
+
/**
|
|
325
|
+
* A thunk that returns always `null`.
|
|
326
|
+
*
|
|
327
|
+
* @example
|
|
328
|
+
* ```ts
|
|
329
|
+
* import * as assert from "node:assert"
|
|
330
|
+
* import { constNull } from "effect/Function"
|
|
331
|
+
*
|
|
332
|
+
* assert.deepStrictEqual(constNull(), null)
|
|
333
|
+
* ```
|
|
334
|
+
*
|
|
335
|
+
* @since 2.0.0
|
|
336
|
+
*/
|
|
337
|
+
export const constNull: LazyArg<null> = constant(null)
|
|
338
|
+
|
|
339
|
+
/**
|
|
340
|
+
* A thunk that returns always `undefined`.
|
|
341
|
+
*
|
|
342
|
+
* @example
|
|
343
|
+
* ```ts
|
|
344
|
+
* import * as assert from "node:assert"
|
|
345
|
+
* import { constUndefined } from "effect/Function"
|
|
346
|
+
*
|
|
347
|
+
* assert.deepStrictEqual(constUndefined(), undefined)
|
|
348
|
+
* ```
|
|
349
|
+
*
|
|
350
|
+
* @since 2.0.0
|
|
351
|
+
*/
|
|
352
|
+
export const constUndefined: LazyArg<undefined> = constant(undefined)
|
|
353
|
+
|
|
354
|
+
/**
|
|
355
|
+
* A thunk that returns always `void`.
|
|
356
|
+
*
|
|
357
|
+
* @example
|
|
358
|
+
* ```ts
|
|
359
|
+
* import * as assert from "node:assert"
|
|
360
|
+
* import { constVoid } from "effect/Function"
|
|
361
|
+
*
|
|
362
|
+
* assert.deepStrictEqual(constVoid(), undefined)
|
|
363
|
+
* ```
|
|
364
|
+
*
|
|
365
|
+
* @since 2.0.0
|
|
366
|
+
*/
|
|
367
|
+
export const constVoid: LazyArg<void> = constUndefined
|
|
368
|
+
|
|
369
|
+
/**
|
|
370
|
+
* Reverses the order of arguments for a curried function.
|
|
371
|
+
*
|
|
372
|
+
* @example
|
|
373
|
+
* ```ts
|
|
374
|
+
* import * as assert from "node:assert"
|
|
375
|
+
* import { flip } from "effect/Function"
|
|
376
|
+
*
|
|
377
|
+
* const f = (a: number) => (b: string) => a - b.length
|
|
378
|
+
*
|
|
379
|
+
* assert.deepStrictEqual(flip(f)('aaa')(2), -1)
|
|
380
|
+
* ```
|
|
381
|
+
*
|
|
382
|
+
* @since 2.0.0
|
|
383
|
+
*/
|
|
384
|
+
export const flip = <A extends Array<unknown>, B extends Array<unknown>, C>(
|
|
385
|
+
f: (...a: A) => (...b: B) => C
|
|
386
|
+
): (...b: B) => (...a: A) => C =>
|
|
387
|
+
(...b) =>
|
|
388
|
+
(...a) => f(...a)(...b)
|
|
389
|
+
|
|
390
|
+
/**
|
|
391
|
+
* Composes two functions, `ab` and `bc` into a single function that takes in an argument `a` of type `A` and returns a result of type `C`.
|
|
392
|
+
* The result is obtained by first applying the `ab` function to `a` and then applying the `bc` function to the result of `ab`.
|
|
393
|
+
*
|
|
394
|
+
* @example
|
|
395
|
+
* ```ts
|
|
396
|
+
* import * as assert from "node:assert"
|
|
397
|
+
* import { compose } from "effect/Function"
|
|
398
|
+
*
|
|
399
|
+
* const increment = (n: number) => n + 1;
|
|
400
|
+
* const square = (n: number) => n * n;
|
|
401
|
+
*
|
|
402
|
+
* assert.strictEqual(compose(increment, square)(2), 9);
|
|
403
|
+
* ```
|
|
404
|
+
*
|
|
405
|
+
* @since 2.0.0
|
|
406
|
+
*/
|
|
407
|
+
export const compose: {
|
|
408
|
+
<B, C>(bc: (b: B) => C): <A>(self: (a: A) => B) => (a: A) => C
|
|
409
|
+
<A, B, C>(self: (a: A) => B, bc: (b: B) => C): (a: A) => C
|
|
410
|
+
} = dual(2, <A, B, C>(ab: (a: A) => B, bc: (b: B) => C): (a: A) => C => (a) => bc(ab(a)))
|
|
411
|
+
|
|
412
|
+
/**
|
|
413
|
+
* The `absurd` function is a stub for cases where a value of type `never` is encountered in your code,
|
|
414
|
+
* meaning that it should be impossible for this code to be executed.
|
|
415
|
+
*
|
|
416
|
+
* This function is particularly useful when it's necessary to specify that certain cases are impossible.
|
|
417
|
+
*
|
|
418
|
+
* @since 2.0.0
|
|
419
|
+
*/
|
|
420
|
+
export const absurd = <A>(_: never): A => {
|
|
421
|
+
throw new Error("Called `absurd` function which should be uncallable")
|
|
422
|
+
}
|
|
423
|
+
|
|
424
|
+
/**
|
|
425
|
+
* Creates a version of this function: instead of `n` arguments, it accepts a single tuple argument.
|
|
426
|
+
*
|
|
427
|
+
* @example
|
|
428
|
+
* ```ts
|
|
429
|
+
* import * as assert from "node:assert"
|
|
430
|
+
* import { tupled } from "effect/Function"
|
|
431
|
+
*
|
|
432
|
+
* const sumTupled = tupled((x: number, y: number): number => x + y)
|
|
433
|
+
*
|
|
434
|
+
* assert.deepStrictEqual(sumTupled([1, 2]), 3)
|
|
435
|
+
* ```
|
|
436
|
+
*
|
|
437
|
+
* @since 2.0.0
|
|
438
|
+
*/
|
|
439
|
+
export const tupled = <A extends ReadonlyArray<unknown>, B>(f: (...a: A) => B): (a: A) => B => (a) => f(...a)
|
|
440
|
+
|
|
441
|
+
/**
|
|
442
|
+
* Inverse function of `tupled`
|
|
443
|
+
*
|
|
444
|
+
* @example
|
|
445
|
+
* ```ts
|
|
446
|
+
* import * as assert from "node:assert"
|
|
447
|
+
* import { untupled } from "effect/Function"
|
|
448
|
+
*
|
|
449
|
+
* const getFirst = untupled(<A, B>(tuple: [A, B]): A => tuple[0])
|
|
450
|
+
*
|
|
451
|
+
* assert.deepStrictEqual(getFirst(1, 2), 1)
|
|
452
|
+
* ```
|
|
453
|
+
*
|
|
454
|
+
* @since 2.0.0
|
|
455
|
+
*/
|
|
456
|
+
export const untupled = <A extends ReadonlyArray<unknown>, B>(f: (a: A) => B): (...a: A) => B => (...a) => f(a)
|
|
457
|
+
|
|
458
|
+
/**
|
|
459
|
+
* Pipes the value of an expression into a pipeline of functions.
|
|
460
|
+
*
|
|
461
|
+
* **Details**
|
|
462
|
+
*
|
|
463
|
+
* The `pipe` function is a utility that allows us to compose functions in a
|
|
464
|
+
* readable and sequential manner. It takes the output of one function and
|
|
465
|
+
* passes it as the input to the next function in the pipeline. This enables us
|
|
466
|
+
* to build complex transformations by chaining multiple functions together.
|
|
467
|
+
*
|
|
468
|
+
* ```ts skip-type-checking
|
|
469
|
+
* import { pipe } from "effect"
|
|
470
|
+
*
|
|
471
|
+
* const result = pipe(input, func1, func2, ..., funcN)
|
|
472
|
+
* ```
|
|
473
|
+
*
|
|
474
|
+
* In this syntax, `input` is the initial value, and `func1`, `func2`, ...,
|
|
475
|
+
* `funcN` are the functions to be applied in sequence. The result of each
|
|
476
|
+
* function becomes the input for the next function, and the final result is
|
|
477
|
+
* returned.
|
|
478
|
+
*
|
|
479
|
+
* Here's an illustration of how `pipe` works:
|
|
480
|
+
*
|
|
481
|
+
* ```
|
|
482
|
+
* ┌───────┐ ┌───────┐ ┌───────┐ ┌───────┐ ┌───────┐ ┌────────┐
|
|
483
|
+
* │ input │───►│ func1 │───►│ func2 │───►│ ... │───►│ funcN │───►│ result │
|
|
484
|
+
* └───────┘ └───────┘ └───────┘ └───────┘ └───────┘ └────────┘
|
|
485
|
+
* ```
|
|
486
|
+
*
|
|
487
|
+
* It's important to note that functions passed to `pipe` must have a **single
|
|
488
|
+
* argument** because they are only called with a single argument.
|
|
489
|
+
*
|
|
490
|
+
* **When to Use**
|
|
491
|
+
*
|
|
492
|
+
* This is useful in combination with data-last functions as a simulation of
|
|
493
|
+
* methods:
|
|
494
|
+
*
|
|
495
|
+
* ```ts skip-type-checking
|
|
496
|
+
* as.map(f).filter(g)
|
|
497
|
+
* ```
|
|
498
|
+
*
|
|
499
|
+
* becomes:
|
|
500
|
+
*
|
|
501
|
+
* ```ts skip-type-checking
|
|
502
|
+
* import { pipe, Array } from "effect"
|
|
503
|
+
*
|
|
504
|
+
* pipe(as, Array.map(f), Array.filter(g))
|
|
505
|
+
* ```
|
|
506
|
+
*
|
|
507
|
+
* **Example** (Chaining Arithmetic Operations)
|
|
508
|
+
*
|
|
509
|
+
* ```ts
|
|
510
|
+
* import { pipe } from "effect"
|
|
511
|
+
*
|
|
512
|
+
* // Define simple arithmetic operations
|
|
513
|
+
* const increment = (x: number) => x + 1
|
|
514
|
+
* const double = (x: number) => x * 2
|
|
515
|
+
* const subtractTen = (x: number) => x - 10
|
|
516
|
+
*
|
|
517
|
+
* // Sequentially apply these operations using `pipe`
|
|
518
|
+
* const result = pipe(5, increment, double, subtractTen)
|
|
519
|
+
*
|
|
520
|
+
* console.log(result)
|
|
521
|
+
* // Output: 2
|
|
522
|
+
* ```
|
|
523
|
+
*
|
|
524
|
+
* @since 2.0.0
|
|
525
|
+
*/
|
|
526
|
+
export function pipe<A>(a: A): A
|
|
527
|
+
export function pipe<A, B = never>(a: A, ab: (a: A) => B): B
|
|
528
|
+
export function pipe<A, B = never, C = never>(
|
|
529
|
+
a: A,
|
|
530
|
+
ab: (a: A) => B,
|
|
531
|
+
bc: (b: B) => C
|
|
532
|
+
): C
|
|
533
|
+
export function pipe<A, B = never, C = never, D = never>(
|
|
534
|
+
a: A,
|
|
535
|
+
ab: (a: A) => B,
|
|
536
|
+
bc: (b: B) => C,
|
|
537
|
+
cd: (c: C) => D
|
|
538
|
+
): D
|
|
539
|
+
export function pipe<A, B = never, C = never, D = never, E = never>(
|
|
540
|
+
a: A,
|
|
541
|
+
ab: (a: A) => B,
|
|
542
|
+
bc: (b: B) => C,
|
|
543
|
+
cd: (c: C) => D,
|
|
544
|
+
de: (d: D) => E
|
|
545
|
+
): E
|
|
546
|
+
export function pipe<A, B = never, C = never, D = never, E = never, F = never>(
|
|
547
|
+
a: A,
|
|
548
|
+
ab: (a: A) => B,
|
|
549
|
+
bc: (b: B) => C,
|
|
550
|
+
cd: (c: C) => D,
|
|
551
|
+
de: (d: D) => E,
|
|
552
|
+
ef: (e: E) => F
|
|
553
|
+
): F
|
|
554
|
+
export function pipe<
|
|
555
|
+
A,
|
|
556
|
+
B = never,
|
|
557
|
+
C = never,
|
|
558
|
+
D = never,
|
|
559
|
+
E = never,
|
|
560
|
+
F = never,
|
|
561
|
+
G = never
|
|
562
|
+
>(
|
|
563
|
+
a: A,
|
|
564
|
+
ab: (a: A) => B,
|
|
565
|
+
bc: (b: B) => C,
|
|
566
|
+
cd: (c: C) => D,
|
|
567
|
+
de: (d: D) => E,
|
|
568
|
+
ef: (e: E) => F,
|
|
569
|
+
fg: (f: F) => G
|
|
570
|
+
): G
|
|
571
|
+
export function pipe<
|
|
572
|
+
A,
|
|
573
|
+
B = never,
|
|
574
|
+
C = never,
|
|
575
|
+
D = never,
|
|
576
|
+
E = never,
|
|
577
|
+
F = never,
|
|
578
|
+
G = never,
|
|
579
|
+
H = never
|
|
580
|
+
>(
|
|
581
|
+
a: A,
|
|
582
|
+
ab: (a: A) => B,
|
|
583
|
+
bc: (b: B) => C,
|
|
584
|
+
cd: (c: C) => D,
|
|
585
|
+
de: (d: D) => E,
|
|
586
|
+
ef: (e: E) => F,
|
|
587
|
+
fg: (f: F) => G,
|
|
588
|
+
gh: (g: G) => H
|
|
589
|
+
): H
|
|
590
|
+
export function pipe<
|
|
591
|
+
A,
|
|
592
|
+
B = never,
|
|
593
|
+
C = never,
|
|
594
|
+
D = never,
|
|
595
|
+
E = never,
|
|
596
|
+
F = never,
|
|
597
|
+
G = never,
|
|
598
|
+
H = never,
|
|
599
|
+
I = never
|
|
600
|
+
>(
|
|
601
|
+
a: A,
|
|
602
|
+
ab: (a: A) => B,
|
|
603
|
+
bc: (b: B) => C,
|
|
604
|
+
cd: (c: C) => D,
|
|
605
|
+
de: (d: D) => E,
|
|
606
|
+
ef: (e: E) => F,
|
|
607
|
+
fg: (f: F) => G,
|
|
608
|
+
gh: (g: G) => H,
|
|
609
|
+
hi: (h: H) => I
|
|
610
|
+
): I
|
|
611
|
+
export function pipe<
|
|
612
|
+
A,
|
|
613
|
+
B = never,
|
|
614
|
+
C = never,
|
|
615
|
+
D = never,
|
|
616
|
+
E = never,
|
|
617
|
+
F = never,
|
|
618
|
+
G = never,
|
|
619
|
+
H = never,
|
|
620
|
+
I = never,
|
|
621
|
+
J = never
|
|
622
|
+
>(
|
|
623
|
+
a: A,
|
|
624
|
+
ab: (a: A) => B,
|
|
625
|
+
bc: (b: B) => C,
|
|
626
|
+
cd: (c: C) => D,
|
|
627
|
+
de: (d: D) => E,
|
|
628
|
+
ef: (e: E) => F,
|
|
629
|
+
fg: (f: F) => G,
|
|
630
|
+
gh: (g: G) => H,
|
|
631
|
+
hi: (h: H) => I,
|
|
632
|
+
ij: (i: I) => J
|
|
633
|
+
): J
|
|
634
|
+
export function pipe<
|
|
635
|
+
A,
|
|
636
|
+
B = never,
|
|
637
|
+
C = never,
|
|
638
|
+
D = never,
|
|
639
|
+
E = never,
|
|
640
|
+
F = never,
|
|
641
|
+
G = never,
|
|
642
|
+
H = never,
|
|
643
|
+
I = never,
|
|
644
|
+
J = never,
|
|
645
|
+
K = never
|
|
646
|
+
>(
|
|
647
|
+
a: A,
|
|
648
|
+
ab: (a: A) => B,
|
|
649
|
+
bc: (b: B) => C,
|
|
650
|
+
cd: (c: C) => D,
|
|
651
|
+
de: (d: D) => E,
|
|
652
|
+
ef: (e: E) => F,
|
|
653
|
+
fg: (f: F) => G,
|
|
654
|
+
gh: (g: G) => H,
|
|
655
|
+
hi: (h: H) => I,
|
|
656
|
+
ij: (i: I) => J,
|
|
657
|
+
jk: (j: J) => K
|
|
658
|
+
): K
|
|
659
|
+
export function pipe<
|
|
660
|
+
A,
|
|
661
|
+
B = never,
|
|
662
|
+
C = never,
|
|
663
|
+
D = never,
|
|
664
|
+
E = never,
|
|
665
|
+
F = never,
|
|
666
|
+
G = never,
|
|
667
|
+
H = never,
|
|
668
|
+
I = never,
|
|
669
|
+
J = never,
|
|
670
|
+
K = never,
|
|
671
|
+
L = never
|
|
672
|
+
>(
|
|
673
|
+
a: A,
|
|
674
|
+
ab: (a: A) => B,
|
|
675
|
+
bc: (b: B) => C,
|
|
676
|
+
cd: (c: C) => D,
|
|
677
|
+
de: (d: D) => E,
|
|
678
|
+
ef: (e: E) => F,
|
|
679
|
+
fg: (f: F) => G,
|
|
680
|
+
gh: (g: G) => H,
|
|
681
|
+
hi: (h: H) => I,
|
|
682
|
+
ij: (i: I) => J,
|
|
683
|
+
jk: (j: J) => K,
|
|
684
|
+
kl: (k: K) => L
|
|
685
|
+
): L
|
|
686
|
+
export function pipe<
|
|
687
|
+
A,
|
|
688
|
+
B = never,
|
|
689
|
+
C = never,
|
|
690
|
+
D = never,
|
|
691
|
+
E = never,
|
|
692
|
+
F = never,
|
|
693
|
+
G = never,
|
|
694
|
+
H = never,
|
|
695
|
+
I = never,
|
|
696
|
+
J = never,
|
|
697
|
+
K = never,
|
|
698
|
+
L = never,
|
|
699
|
+
M = never
|
|
700
|
+
>(
|
|
701
|
+
a: A,
|
|
702
|
+
ab: (a: A) => B,
|
|
703
|
+
bc: (b: B) => C,
|
|
704
|
+
cd: (c: C) => D,
|
|
705
|
+
de: (d: D) => E,
|
|
706
|
+
ef: (e: E) => F,
|
|
707
|
+
fg: (f: F) => G,
|
|
708
|
+
gh: (g: G) => H,
|
|
709
|
+
hi: (h: H) => I,
|
|
710
|
+
ij: (i: I) => J,
|
|
711
|
+
jk: (j: J) => K,
|
|
712
|
+
kl: (k: K) => L,
|
|
713
|
+
lm: (l: L) => M
|
|
714
|
+
): M
|
|
715
|
+
export function pipe<
|
|
716
|
+
A,
|
|
717
|
+
B = never,
|
|
718
|
+
C = never,
|
|
719
|
+
D = never,
|
|
720
|
+
E = never,
|
|
721
|
+
F = never,
|
|
722
|
+
G = never,
|
|
723
|
+
H = never,
|
|
724
|
+
I = never,
|
|
725
|
+
J = never,
|
|
726
|
+
K = never,
|
|
727
|
+
L = never,
|
|
728
|
+
M = never,
|
|
729
|
+
N = never
|
|
730
|
+
>(
|
|
731
|
+
a: A,
|
|
732
|
+
ab: (a: A) => B,
|
|
733
|
+
bc: (b: B) => C,
|
|
734
|
+
cd: (c: C) => D,
|
|
735
|
+
de: (d: D) => E,
|
|
736
|
+
ef: (e: E) => F,
|
|
737
|
+
fg: (f: F) => G,
|
|
738
|
+
gh: (g: G) => H,
|
|
739
|
+
hi: (h: H) => I,
|
|
740
|
+
ij: (i: I) => J,
|
|
741
|
+
jk: (j: J) => K,
|
|
742
|
+
kl: (k: K) => L,
|
|
743
|
+
lm: (l: L) => M,
|
|
744
|
+
mn: (m: M) => N
|
|
745
|
+
): N
|
|
746
|
+
export function pipe<
|
|
747
|
+
A,
|
|
748
|
+
B = never,
|
|
749
|
+
C = never,
|
|
750
|
+
D = never,
|
|
751
|
+
E = never,
|
|
752
|
+
F = never,
|
|
753
|
+
G = never,
|
|
754
|
+
H = never,
|
|
755
|
+
I = never,
|
|
756
|
+
J = never,
|
|
757
|
+
K = never,
|
|
758
|
+
L = never,
|
|
759
|
+
M = never,
|
|
760
|
+
N = never,
|
|
761
|
+
O = never
|
|
762
|
+
>(
|
|
763
|
+
a: A,
|
|
764
|
+
ab: (a: A) => B,
|
|
765
|
+
bc: (b: B) => C,
|
|
766
|
+
cd: (c: C) => D,
|
|
767
|
+
de: (d: D) => E,
|
|
768
|
+
ef: (e: E) => F,
|
|
769
|
+
fg: (f: F) => G,
|
|
770
|
+
gh: (g: G) => H,
|
|
771
|
+
hi: (h: H) => I,
|
|
772
|
+
ij: (i: I) => J,
|
|
773
|
+
jk: (j: J) => K,
|
|
774
|
+
kl: (k: K) => L,
|
|
775
|
+
lm: (l: L) => M,
|
|
776
|
+
mn: (m: M) => N,
|
|
777
|
+
no: (n: N) => O
|
|
778
|
+
): O
|
|
779
|
+
export function pipe<
|
|
780
|
+
A,
|
|
781
|
+
B = never,
|
|
782
|
+
C = never,
|
|
783
|
+
D = never,
|
|
784
|
+
E = never,
|
|
785
|
+
F = never,
|
|
786
|
+
G = never,
|
|
787
|
+
H = never,
|
|
788
|
+
I = never,
|
|
789
|
+
J = never,
|
|
790
|
+
K = never,
|
|
791
|
+
L = never,
|
|
792
|
+
M = never,
|
|
793
|
+
N = never,
|
|
794
|
+
O = never,
|
|
795
|
+
P = never
|
|
796
|
+
>(
|
|
797
|
+
a: A,
|
|
798
|
+
ab: (a: A) => B,
|
|
799
|
+
bc: (b: B) => C,
|
|
800
|
+
cd: (c: C) => D,
|
|
801
|
+
de: (d: D) => E,
|
|
802
|
+
ef: (e: E) => F,
|
|
803
|
+
fg: (f: F) => G,
|
|
804
|
+
gh: (g: G) => H,
|
|
805
|
+
hi: (h: H) => I,
|
|
806
|
+
ij: (i: I) => J,
|
|
807
|
+
jk: (j: J) => K,
|
|
808
|
+
kl: (k: K) => L,
|
|
809
|
+
lm: (l: L) => M,
|
|
810
|
+
mn: (m: M) => N,
|
|
811
|
+
no: (n: N) => O,
|
|
812
|
+
op: (o: O) => P
|
|
813
|
+
): P
|
|
814
|
+
export function pipe<
|
|
815
|
+
A,
|
|
816
|
+
B = never,
|
|
817
|
+
C = never,
|
|
818
|
+
D = never,
|
|
819
|
+
E = never,
|
|
820
|
+
F = never,
|
|
821
|
+
G = never,
|
|
822
|
+
H = never,
|
|
823
|
+
I = never,
|
|
824
|
+
J = never,
|
|
825
|
+
K = never,
|
|
826
|
+
L = never,
|
|
827
|
+
M = never,
|
|
828
|
+
N = never,
|
|
829
|
+
O = never,
|
|
830
|
+
P = never,
|
|
831
|
+
Q = never
|
|
832
|
+
>(
|
|
833
|
+
a: A,
|
|
834
|
+
ab: (a: A) => B,
|
|
835
|
+
bc: (b: B) => C,
|
|
836
|
+
cd: (c: C) => D,
|
|
837
|
+
de: (d: D) => E,
|
|
838
|
+
ef: (e: E) => F,
|
|
839
|
+
fg: (f: F) => G,
|
|
840
|
+
gh: (g: G) => H,
|
|
841
|
+
hi: (h: H) => I,
|
|
842
|
+
ij: (i: I) => J,
|
|
843
|
+
jk: (j: J) => K,
|
|
844
|
+
kl: (k: K) => L,
|
|
845
|
+
lm: (l: L) => M,
|
|
846
|
+
mn: (m: M) => N,
|
|
847
|
+
no: (n: N) => O,
|
|
848
|
+
op: (o: O) => P,
|
|
849
|
+
pq: (p: P) => Q
|
|
850
|
+
): Q
|
|
851
|
+
export function pipe<
|
|
852
|
+
A,
|
|
853
|
+
B = never,
|
|
854
|
+
C = never,
|
|
855
|
+
D = never,
|
|
856
|
+
E = never,
|
|
857
|
+
F = never,
|
|
858
|
+
G = never,
|
|
859
|
+
H = never,
|
|
860
|
+
I = never,
|
|
861
|
+
J = never,
|
|
862
|
+
K = never,
|
|
863
|
+
L = never,
|
|
864
|
+
M = never,
|
|
865
|
+
N = never,
|
|
866
|
+
O = never,
|
|
867
|
+
P = never,
|
|
868
|
+
Q = never,
|
|
869
|
+
R = never
|
|
870
|
+
>(
|
|
871
|
+
a: A,
|
|
872
|
+
ab: (a: A) => B,
|
|
873
|
+
bc: (b: B) => C,
|
|
874
|
+
cd: (c: C) => D,
|
|
875
|
+
de: (d: D) => E,
|
|
876
|
+
ef: (e: E) => F,
|
|
877
|
+
fg: (f: F) => G,
|
|
878
|
+
gh: (g: G) => H,
|
|
879
|
+
hi: (h: H) => I,
|
|
880
|
+
ij: (i: I) => J,
|
|
881
|
+
jk: (j: J) => K,
|
|
882
|
+
kl: (k: K) => L,
|
|
883
|
+
lm: (l: L) => M,
|
|
884
|
+
mn: (m: M) => N,
|
|
885
|
+
no: (n: N) => O,
|
|
886
|
+
op: (o: O) => P,
|
|
887
|
+
pq: (p: P) => Q,
|
|
888
|
+
qr: (q: Q) => R
|
|
889
|
+
): R
|
|
890
|
+
export function pipe<
|
|
891
|
+
A,
|
|
892
|
+
B = never,
|
|
893
|
+
C = never,
|
|
894
|
+
D = never,
|
|
895
|
+
E = never,
|
|
896
|
+
F = never,
|
|
897
|
+
G = never,
|
|
898
|
+
H = never,
|
|
899
|
+
I = never,
|
|
900
|
+
J = never,
|
|
901
|
+
K = never,
|
|
902
|
+
L = never,
|
|
903
|
+
M = never,
|
|
904
|
+
N = never,
|
|
905
|
+
O = never,
|
|
906
|
+
P = never,
|
|
907
|
+
Q = never,
|
|
908
|
+
R = never,
|
|
909
|
+
S = never
|
|
910
|
+
>(
|
|
911
|
+
a: A,
|
|
912
|
+
ab: (a: A) => B,
|
|
913
|
+
bc: (b: B) => C,
|
|
914
|
+
cd: (c: C) => D,
|
|
915
|
+
de: (d: D) => E,
|
|
916
|
+
ef: (e: E) => F,
|
|
917
|
+
fg: (f: F) => G,
|
|
918
|
+
gh: (g: G) => H,
|
|
919
|
+
hi: (h: H) => I,
|
|
920
|
+
ij: (i: I) => J,
|
|
921
|
+
jk: (j: J) => K,
|
|
922
|
+
kl: (k: K) => L,
|
|
923
|
+
lm: (l: L) => M,
|
|
924
|
+
mn: (m: M) => N,
|
|
925
|
+
no: (n: N) => O,
|
|
926
|
+
op: (o: O) => P,
|
|
927
|
+
pq: (p: P) => Q,
|
|
928
|
+
qr: (q: Q) => R,
|
|
929
|
+
rs: (r: R) => S
|
|
930
|
+
): S
|
|
931
|
+
export function pipe<
|
|
932
|
+
A,
|
|
933
|
+
B = never,
|
|
934
|
+
C = never,
|
|
935
|
+
D = never,
|
|
936
|
+
E = never,
|
|
937
|
+
F = never,
|
|
938
|
+
G = never,
|
|
939
|
+
H = never,
|
|
940
|
+
I = never,
|
|
941
|
+
J = never,
|
|
942
|
+
K = never,
|
|
943
|
+
L = never,
|
|
944
|
+
M = never,
|
|
945
|
+
N = never,
|
|
946
|
+
O = never,
|
|
947
|
+
P = never,
|
|
948
|
+
Q = never,
|
|
949
|
+
R = never,
|
|
950
|
+
S = never,
|
|
951
|
+
T = never
|
|
952
|
+
>(
|
|
953
|
+
a: A,
|
|
954
|
+
ab: (a: A) => B,
|
|
955
|
+
bc: (b: B) => C,
|
|
956
|
+
cd: (c: C) => D,
|
|
957
|
+
de: (d: D) => E,
|
|
958
|
+
ef: (e: E) => F,
|
|
959
|
+
fg: (f: F) => G,
|
|
960
|
+
gh: (g: G) => H,
|
|
961
|
+
hi: (h: H) => I,
|
|
962
|
+
ij: (i: I) => J,
|
|
963
|
+
jk: (j: J) => K,
|
|
964
|
+
kl: (k: K) => L,
|
|
965
|
+
lm: (l: L) => M,
|
|
966
|
+
mn: (m: M) => N,
|
|
967
|
+
no: (n: N) => O,
|
|
968
|
+
op: (o: O) => P,
|
|
969
|
+
pq: (p: P) => Q,
|
|
970
|
+
qr: (q: Q) => R,
|
|
971
|
+
rs: (r: R) => S,
|
|
972
|
+
st: (s: S) => T
|
|
973
|
+
): T
|
|
974
|
+
export function pipe(
|
|
975
|
+
a: unknown,
|
|
976
|
+
ab?: Function,
|
|
977
|
+
bc?: Function,
|
|
978
|
+
cd?: Function,
|
|
979
|
+
de?: Function,
|
|
980
|
+
ef?: Function,
|
|
981
|
+
fg?: Function,
|
|
982
|
+
gh?: Function,
|
|
983
|
+
hi?: Function
|
|
984
|
+
): unknown {
|
|
985
|
+
switch (arguments.length) {
|
|
986
|
+
case 1:
|
|
987
|
+
return a
|
|
988
|
+
case 2:
|
|
989
|
+
return ab!(a)
|
|
990
|
+
case 3:
|
|
991
|
+
return bc!(ab!(a))
|
|
992
|
+
case 4:
|
|
993
|
+
return cd!(bc!(ab!(a)))
|
|
994
|
+
case 5:
|
|
995
|
+
return de!(cd!(bc!(ab!(a))))
|
|
996
|
+
case 6:
|
|
997
|
+
return ef!(de!(cd!(bc!(ab!(a)))))
|
|
998
|
+
case 7:
|
|
999
|
+
return fg!(ef!(de!(cd!(bc!(ab!(a))))))
|
|
1000
|
+
case 8:
|
|
1001
|
+
return gh!(fg!(ef!(de!(cd!(bc!(ab!(a)))))))
|
|
1002
|
+
case 9:
|
|
1003
|
+
return hi!(gh!(fg!(ef!(de!(cd!(bc!(ab!(a))))))))
|
|
1004
|
+
default: {
|
|
1005
|
+
let ret = arguments[0]
|
|
1006
|
+
for (let i = 1; i < arguments.length; i++) {
|
|
1007
|
+
ret = arguments[i](ret)
|
|
1008
|
+
}
|
|
1009
|
+
return ret
|
|
1010
|
+
}
|
|
1011
|
+
}
|
|
1012
|
+
}
|
|
1013
|
+
|
|
1014
|
+
/**
|
|
1015
|
+
* Performs left-to-right function composition. The first argument may have any arity, the remaining arguments must be unary.
|
|
1016
|
+
*
|
|
1017
|
+
* See also [`pipe`](#pipe).
|
|
1018
|
+
*
|
|
1019
|
+
* @example
|
|
1020
|
+
* ```ts
|
|
1021
|
+
* import * as assert from "node:assert"
|
|
1022
|
+
* import { flow } from "effect/Function"
|
|
1023
|
+
*
|
|
1024
|
+
* const len = (s: string): number => s.length
|
|
1025
|
+
* const double = (n: number): number => n * 2
|
|
1026
|
+
*
|
|
1027
|
+
* const f = flow(len, double)
|
|
1028
|
+
*
|
|
1029
|
+
* assert.strictEqual(f('aaa'), 6)
|
|
1030
|
+
* ```
|
|
1031
|
+
*
|
|
1032
|
+
* @since 2.0.0
|
|
1033
|
+
*/
|
|
1034
|
+
export function flow<A extends ReadonlyArray<unknown>, B = never>(
|
|
1035
|
+
ab: (...a: A) => B
|
|
1036
|
+
): (...a: A) => B
|
|
1037
|
+
export function flow<A extends ReadonlyArray<unknown>, B = never, C = never>(
|
|
1038
|
+
ab: (...a: A) => B,
|
|
1039
|
+
bc: (b: B) => C
|
|
1040
|
+
): (...a: A) => C
|
|
1041
|
+
export function flow<
|
|
1042
|
+
A extends ReadonlyArray<unknown>,
|
|
1043
|
+
B = never,
|
|
1044
|
+
C = never,
|
|
1045
|
+
D = never
|
|
1046
|
+
>(ab: (...a: A) => B, bc: (b: B) => C, cd: (c: C) => D): (...a: A) => D
|
|
1047
|
+
export function flow<
|
|
1048
|
+
A extends ReadonlyArray<unknown>,
|
|
1049
|
+
B = never,
|
|
1050
|
+
C = never,
|
|
1051
|
+
D = never,
|
|
1052
|
+
E = never
|
|
1053
|
+
>(
|
|
1054
|
+
ab: (...a: A) => B,
|
|
1055
|
+
bc: (b: B) => C,
|
|
1056
|
+
cd: (c: C) => D,
|
|
1057
|
+
de: (d: D) => E
|
|
1058
|
+
): (...a: A) => E
|
|
1059
|
+
export function flow<
|
|
1060
|
+
A extends ReadonlyArray<unknown>,
|
|
1061
|
+
B = never,
|
|
1062
|
+
C = never,
|
|
1063
|
+
D = never,
|
|
1064
|
+
E = never,
|
|
1065
|
+
F = never
|
|
1066
|
+
>(
|
|
1067
|
+
ab: (...a: A) => B,
|
|
1068
|
+
bc: (b: B) => C,
|
|
1069
|
+
cd: (c: C) => D,
|
|
1070
|
+
de: (d: D) => E,
|
|
1071
|
+
ef: (e: E) => F
|
|
1072
|
+
): (...a: A) => F
|
|
1073
|
+
export function flow<
|
|
1074
|
+
A extends ReadonlyArray<unknown>,
|
|
1075
|
+
B = never,
|
|
1076
|
+
C = never,
|
|
1077
|
+
D = never,
|
|
1078
|
+
E = never,
|
|
1079
|
+
F = never,
|
|
1080
|
+
G = never
|
|
1081
|
+
>(
|
|
1082
|
+
ab: (...a: A) => B,
|
|
1083
|
+
bc: (b: B) => C,
|
|
1084
|
+
cd: (c: C) => D,
|
|
1085
|
+
de: (d: D) => E,
|
|
1086
|
+
ef: (e: E) => F,
|
|
1087
|
+
fg: (f: F) => G
|
|
1088
|
+
): (...a: A) => G
|
|
1089
|
+
export function flow<
|
|
1090
|
+
A extends ReadonlyArray<unknown>,
|
|
1091
|
+
B = never,
|
|
1092
|
+
C = never,
|
|
1093
|
+
D = never,
|
|
1094
|
+
E = never,
|
|
1095
|
+
F = never,
|
|
1096
|
+
G = never,
|
|
1097
|
+
H = never
|
|
1098
|
+
>(
|
|
1099
|
+
ab: (...a: A) => B,
|
|
1100
|
+
bc: (b: B) => C,
|
|
1101
|
+
cd: (c: C) => D,
|
|
1102
|
+
de: (d: D) => E,
|
|
1103
|
+
ef: (e: E) => F,
|
|
1104
|
+
fg: (f: F) => G,
|
|
1105
|
+
gh: (g: G) => H
|
|
1106
|
+
): (...a: A) => H
|
|
1107
|
+
export function flow<
|
|
1108
|
+
A extends ReadonlyArray<unknown>,
|
|
1109
|
+
B = never,
|
|
1110
|
+
C = never,
|
|
1111
|
+
D = never,
|
|
1112
|
+
E = never,
|
|
1113
|
+
F = never,
|
|
1114
|
+
G = never,
|
|
1115
|
+
H = never,
|
|
1116
|
+
I = never
|
|
1117
|
+
>(
|
|
1118
|
+
ab: (...a: A) => B,
|
|
1119
|
+
bc: (b: B) => C,
|
|
1120
|
+
cd: (c: C) => D,
|
|
1121
|
+
de: (d: D) => E,
|
|
1122
|
+
ef: (e: E) => F,
|
|
1123
|
+
fg: (f: F) => G,
|
|
1124
|
+
gh: (g: G) => H,
|
|
1125
|
+
hi: (h: H) => I
|
|
1126
|
+
): (...a: A) => I
|
|
1127
|
+
export function flow<
|
|
1128
|
+
A extends ReadonlyArray<unknown>,
|
|
1129
|
+
B = never,
|
|
1130
|
+
C = never,
|
|
1131
|
+
D = never,
|
|
1132
|
+
E = never,
|
|
1133
|
+
F = never,
|
|
1134
|
+
G = never,
|
|
1135
|
+
H = never,
|
|
1136
|
+
I = never,
|
|
1137
|
+
J = never
|
|
1138
|
+
>(
|
|
1139
|
+
ab: (...a: A) => B,
|
|
1140
|
+
bc: (b: B) => C,
|
|
1141
|
+
cd: (c: C) => D,
|
|
1142
|
+
de: (d: D) => E,
|
|
1143
|
+
ef: (e: E) => F,
|
|
1144
|
+
fg: (f: F) => G,
|
|
1145
|
+
gh: (g: G) => H,
|
|
1146
|
+
hi: (h: H) => I,
|
|
1147
|
+
ij: (i: I) => J
|
|
1148
|
+
): (...a: A) => J
|
|
1149
|
+
export function flow(
|
|
1150
|
+
ab: Function,
|
|
1151
|
+
bc?: Function,
|
|
1152
|
+
cd?: Function,
|
|
1153
|
+
de?: Function,
|
|
1154
|
+
ef?: Function,
|
|
1155
|
+
fg?: Function,
|
|
1156
|
+
gh?: Function,
|
|
1157
|
+
hi?: Function,
|
|
1158
|
+
ij?: Function
|
|
1159
|
+
): unknown {
|
|
1160
|
+
switch (arguments.length) {
|
|
1161
|
+
case 1:
|
|
1162
|
+
return ab
|
|
1163
|
+
case 2:
|
|
1164
|
+
return function(this: unknown) {
|
|
1165
|
+
return bc!(ab.apply(this, arguments))
|
|
1166
|
+
}
|
|
1167
|
+
case 3:
|
|
1168
|
+
return function(this: unknown) {
|
|
1169
|
+
return cd!(bc!(ab.apply(this, arguments)))
|
|
1170
|
+
}
|
|
1171
|
+
case 4:
|
|
1172
|
+
return function(this: unknown) {
|
|
1173
|
+
return de!(cd!(bc!(ab.apply(this, arguments))))
|
|
1174
|
+
}
|
|
1175
|
+
case 5:
|
|
1176
|
+
return function(this: unknown) {
|
|
1177
|
+
return ef!(de!(cd!(bc!(ab.apply(this, arguments)))))
|
|
1178
|
+
}
|
|
1179
|
+
case 6:
|
|
1180
|
+
return function(this: unknown) {
|
|
1181
|
+
return fg!(ef!(de!(cd!(bc!(ab.apply(this, arguments))))))
|
|
1182
|
+
}
|
|
1183
|
+
case 7:
|
|
1184
|
+
return function(this: unknown) {
|
|
1185
|
+
return gh!(fg!(ef!(de!(cd!(bc!(ab.apply(this, arguments)))))))
|
|
1186
|
+
}
|
|
1187
|
+
case 8:
|
|
1188
|
+
return function(this: unknown) {
|
|
1189
|
+
return hi!(gh!(fg!(ef!(de!(cd!(bc!(ab.apply(this, arguments))))))))
|
|
1190
|
+
}
|
|
1191
|
+
case 9:
|
|
1192
|
+
return function(this: unknown) {
|
|
1193
|
+
return ij!(hi!(gh!(fg!(ef!(de!(cd!(bc!(ab.apply(this, arguments)))))))))
|
|
1194
|
+
}
|
|
1195
|
+
}
|
|
1196
|
+
return
|
|
1197
|
+
}
|
|
1198
|
+
|
|
1199
|
+
/**
|
|
1200
|
+
* Type hole simulation.
|
|
1201
|
+
*
|
|
1202
|
+
* @since 2.0.0
|
|
1203
|
+
*/
|
|
1204
|
+
export const hole: <T>() => T = unsafeCoerce(absurd)
|
|
1205
|
+
|
|
1206
|
+
/**
|
|
1207
|
+
* The SK combinator, also known as the "S-K combinator" or "S-combinator", is a fundamental combinator in the
|
|
1208
|
+
* lambda calculus and the SKI combinator calculus.
|
|
1209
|
+
*
|
|
1210
|
+
* This function is useful for discarding the first argument passed to it and returning the second argument.
|
|
1211
|
+
*
|
|
1212
|
+
* @example
|
|
1213
|
+
* ```ts
|
|
1214
|
+
* import * as assert from "node:assert"
|
|
1215
|
+
* import { SK } from "effect/Function";
|
|
1216
|
+
*
|
|
1217
|
+
* assert.deepStrictEqual(SK(0, "hello"), "hello")
|
|
1218
|
+
* ```
|
|
1219
|
+
*
|
|
1220
|
+
* @since 2.0.0
|
|
1221
|
+
*/
|
|
1222
|
+
export const SK = <A, B>(_: A, b: B): B => b
|