@clayroach/effect 3.19.14-source-capture.6 → 3.19.14-source-capture.8

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.
Files changed (371) hide show
  1. package/dist/cjs/Utils.js +1 -1
  2. package/dist/cjs/Utils.js.map +1 -1
  3. package/dist/cjs/internal/clock.js +1 -1
  4. package/dist/cjs/internal/clock.js.map +1 -1
  5. package/dist/esm/Utils.js +1 -1
  6. package/dist/esm/Utils.js.map +1 -1
  7. package/dist/esm/internal/clock.js +1 -1
  8. package/dist/esm/internal/clock.js.map +1 -1
  9. package/package.json +1 -1
  10. package/src/Arbitrary.ts +0 -1101
  11. package/src/Array.ts +0 -3589
  12. package/src/BigDecimal.ts +0 -1349
  13. package/src/BigInt.ts +0 -643
  14. package/src/Boolean.ts +0 -287
  15. package/src/Brand.ts +0 -360
  16. package/src/Cache.ts +0 -281
  17. package/src/Cause.ts +0 -1555
  18. package/src/Channel.ts +0 -2355
  19. package/src/ChildExecutorDecision.ts +0 -146
  20. package/src/Chunk.ts +0 -1495
  21. package/src/Clock.ts +0 -111
  22. package/src/Config.ts +0 -542
  23. package/src/ConfigError.ts +0 -270
  24. package/src/ConfigProvider.ts +0 -333
  25. package/src/ConfigProviderPathPatch.ts +0 -100
  26. package/src/Console.ts +0 -226
  27. package/src/Context.ts +0 -585
  28. package/src/Cron.ts +0 -706
  29. package/src/Data.ts +0 -596
  30. package/src/DateTime.ts +0 -1686
  31. package/src/DefaultServices.ts +0 -34
  32. package/src/Deferred.ts +0 -301
  33. package/src/Differ.ts +0 -450
  34. package/src/Duration.ts +0 -1000
  35. package/src/Effect.ts +0 -14839
  36. package/src/Effectable.ts +0 -107
  37. package/src/Either.ts +0 -1040
  38. package/src/Encoding.ts +0 -195
  39. package/src/Equal.ts +0 -98
  40. package/src/Equivalence.ts +0 -235
  41. package/src/ExecutionPlan.ts +0 -308
  42. package/src/ExecutionStrategy.ts +0 -119
  43. package/src/Exit.ts +0 -467
  44. package/src/FastCheck.ts +0 -9
  45. package/src/Fiber.ts +0 -744
  46. package/src/FiberHandle.ts +0 -540
  47. package/src/FiberId.ts +0 -195
  48. package/src/FiberMap.ts +0 -656
  49. package/src/FiberRef.ts +0 -431
  50. package/src/FiberRefs.ts +0 -204
  51. package/src/FiberRefsPatch.ts +0 -105
  52. package/src/FiberSet.ts +0 -491
  53. package/src/FiberStatus.ts +0 -108
  54. package/src/Function.ts +0 -1222
  55. package/src/GlobalValue.ts +0 -53
  56. package/src/Graph.ts +0 -3732
  57. package/src/GroupBy.ts +0 -103
  58. package/src/HKT.ts +0 -45
  59. package/src/Hash.ts +0 -195
  60. package/src/HashMap.ts +0 -519
  61. package/src/HashRing.ts +0 -317
  62. package/src/HashSet.ts +0 -2346
  63. package/src/Inspectable.ts +0 -287
  64. package/src/Iterable.ts +0 -1119
  65. package/src/JSONSchema.ts +0 -1044
  66. package/src/KeyedPool.ts +0 -167
  67. package/src/Layer.ts +0 -1251
  68. package/src/LayerMap.ts +0 -436
  69. package/src/List.ts +0 -977
  70. package/src/LogLevel.ts +0 -285
  71. package/src/LogSpan.ts +0 -25
  72. package/src/Logger.ts +0 -702
  73. package/src/Mailbox.ts +0 -268
  74. package/src/ManagedRuntime.ts +0 -180
  75. package/src/Match.ts +0 -1477
  76. package/src/MergeDecision.ts +0 -95
  77. package/src/MergeState.ts +0 -172
  78. package/src/MergeStrategy.ts +0 -107
  79. package/src/Metric.ts +0 -780
  80. package/src/MetricBoundaries.ts +0 -69
  81. package/src/MetricHook.ts +0 -151
  82. package/src/MetricKey.ts +0 -224
  83. package/src/MetricKeyType.ts +0 -262
  84. package/src/MetricLabel.ts +0 -47
  85. package/src/MetricPair.ts +0 -71
  86. package/src/MetricPolling.ts +0 -148
  87. package/src/MetricRegistry.ts +0 -48
  88. package/src/MetricState.ts +0 -257
  89. package/src/Micro.ts +0 -4405
  90. package/src/ModuleVersion.ts +0 -18
  91. package/src/MutableHashMap.ts +0 -411
  92. package/src/MutableHashSet.ts +0 -706
  93. package/src/MutableList.ts +0 -297
  94. package/src/MutableQueue.ts +0 -227
  95. package/src/MutableRef.ts +0 -202
  96. package/src/NonEmptyIterable.ts +0 -32
  97. package/src/Number.ts +0 -1071
  98. package/src/Option.ts +0 -2170
  99. package/src/Order.ts +0 -373
  100. package/src/Ordering.ts +0 -111
  101. package/src/ParseResult.ts +0 -2031
  102. package/src/PartitionedSemaphore.ts +0 -200
  103. package/src/Pipeable.ts +0 -566
  104. package/src/Pool.ts +0 -204
  105. package/src/Predicate.ts +0 -1405
  106. package/src/Pretty.ts +0 -205
  107. package/src/PrimaryKey.ts +0 -23
  108. package/src/PubSub.ts +0 -182
  109. package/src/Queue.ts +0 -644
  110. package/src/Random.ts +0 -204
  111. package/src/RateLimiter.ts +0 -138
  112. package/src/RcMap.ts +0 -141
  113. package/src/RcRef.ts +0 -122
  114. package/src/Readable.ts +0 -93
  115. package/src/Record.ts +0 -1274
  116. package/src/RedBlackTree.ts +0 -421
  117. package/src/Redacted.ts +0 -144
  118. package/src/Ref.ts +0 -180
  119. package/src/RegExp.ts +0 -38
  120. package/src/Reloadable.ts +0 -127
  121. package/src/Request.ts +0 -347
  122. package/src/RequestBlock.ts +0 -118
  123. package/src/RequestResolver.ts +0 -366
  124. package/src/Resource.ts +0 -119
  125. package/src/Runtime.ts +0 -383
  126. package/src/RuntimeFlags.ts +0 -368
  127. package/src/RuntimeFlagsPatch.ts +0 -183
  128. package/src/STM.ts +0 -2045
  129. package/src/Schedule.ts +0 -2219
  130. package/src/ScheduleDecision.ts +0 -62
  131. package/src/ScheduleInterval.ts +0 -151
  132. package/src/ScheduleIntervals.ts +0 -122
  133. package/src/Scheduler.ts +0 -353
  134. package/src/Schema.ts +0 -10914
  135. package/src/SchemaAST.ts +0 -3043
  136. package/src/Scope.ts +0 -204
  137. package/src/ScopedCache.ts +0 -151
  138. package/src/ScopedRef.ts +0 -117
  139. package/src/Secret.ts +0 -88
  140. package/src/SingleProducerAsyncInput.ts +0 -67
  141. package/src/Sink.ts +0 -1461
  142. package/src/SortedMap.ts +0 -287
  143. package/src/SortedSet.ts +0 -390
  144. package/src/Stream.ts +0 -6468
  145. package/src/StreamEmit.ts +0 -136
  146. package/src/StreamHaltStrategy.ts +0 -123
  147. package/src/Streamable.ts +0 -45
  148. package/src/String.ts +0 -778
  149. package/src/Struct.ts +0 -243
  150. package/src/Subscribable.ts +0 -100
  151. package/src/SubscriptionRef.ts +0 -298
  152. package/src/Supervisor.ts +0 -240
  153. package/src/Symbol.ts +0 -29
  154. package/src/SynchronizedRef.ts +0 -270
  155. package/src/TArray.ts +0 -495
  156. package/src/TDeferred.ts +0 -100
  157. package/src/TMap.ts +0 -515
  158. package/src/TPriorityQueue.ts +0 -223
  159. package/src/TPubSub.ts +0 -200
  160. package/src/TQueue.ts +0 -432
  161. package/src/TRandom.ts +0 -129
  162. package/src/TReentrantLock.ts +0 -224
  163. package/src/TRef.ts +0 -178
  164. package/src/TSemaphore.ts +0 -129
  165. package/src/TSet.ts +0 -365
  166. package/src/TSubscriptionRef.ts +0 -192
  167. package/src/Take.ts +0 -258
  168. package/src/TestAnnotation.ts +0 -158
  169. package/src/TestAnnotationMap.ts +0 -119
  170. package/src/TestAnnotations.ts +0 -117
  171. package/src/TestClock.ts +0 -556
  172. package/src/TestConfig.ts +0 -47
  173. package/src/TestContext.ts +0 -36
  174. package/src/TestLive.ts +0 -53
  175. package/src/TestServices.ts +0 -390
  176. package/src/TestSized.ts +0 -55
  177. package/src/Tracer.ts +0 -198
  178. package/src/Trie.ts +0 -840
  179. package/src/Tuple.ts +0 -305
  180. package/src/Types.ts +0 -353
  181. package/src/Unify.ts +0 -113
  182. package/src/UpstreamPullRequest.ts +0 -117
  183. package/src/UpstreamPullStrategy.ts +0 -121
  184. package/src/Utils.ts +0 -809
  185. package/src/index.ts +0 -1561
  186. package/src/internal/array.ts +0 -8
  187. package/src/internal/blockedRequests.ts +0 -520
  188. package/src/internal/cache.ts +0 -733
  189. package/src/internal/cause.ts +0 -1050
  190. package/src/internal/channel/channelExecutor.ts +0 -1200
  191. package/src/internal/channel/channelState.ts +0 -134
  192. package/src/internal/channel/childExecutorDecision.ts +0 -96
  193. package/src/internal/channel/continuation.ts +0 -200
  194. package/src/internal/channel/mergeDecision.ts +0 -113
  195. package/src/internal/channel/mergeState.ts +0 -120
  196. package/src/internal/channel/mergeStrategy.ts +0 -72
  197. package/src/internal/channel/singleProducerAsyncInput.ts +0 -259
  198. package/src/internal/channel/subexecutor.ts +0 -229
  199. package/src/internal/channel/upstreamPullRequest.ts +0 -84
  200. package/src/internal/channel/upstreamPullStrategy.ts +0 -87
  201. package/src/internal/channel.ts +0 -2603
  202. package/src/internal/clock.ts +0 -95
  203. package/src/internal/completedRequestMap.ts +0 -9
  204. package/src/internal/concurrency.ts +0 -54
  205. package/src/internal/config.ts +0 -716
  206. package/src/internal/configError.ts +0 -304
  207. package/src/internal/configProvider/pathPatch.ts +0 -97
  208. package/src/internal/configProvider.ts +0 -799
  209. package/src/internal/console.ts +0 -153
  210. package/src/internal/context.ts +0 -337
  211. package/src/internal/core-effect.ts +0 -2293
  212. package/src/internal/core-stream.ts +0 -998
  213. package/src/internal/core.ts +0 -3273
  214. package/src/internal/data.ts +0 -36
  215. package/src/internal/dataSource.ts +0 -327
  216. package/src/internal/dateTime.ts +0 -1277
  217. package/src/internal/defaultServices/console.ts +0 -100
  218. package/src/internal/defaultServices.ts +0 -163
  219. package/src/internal/deferred.ts +0 -46
  220. package/src/internal/differ/chunkPatch.ts +0 -211
  221. package/src/internal/differ/contextPatch.ts +0 -232
  222. package/src/internal/differ/hashMapPatch.ts +0 -220
  223. package/src/internal/differ/hashSetPatch.ts +0 -176
  224. package/src/internal/differ/orPatch.ts +0 -311
  225. package/src/internal/differ/readonlyArrayPatch.ts +0 -210
  226. package/src/internal/differ.ts +0 -200
  227. package/src/internal/doNotation.ts +0 -80
  228. package/src/internal/effect/circular.ts +0 -905
  229. package/src/internal/effectable.ts +0 -131
  230. package/src/internal/either.ts +0 -110
  231. package/src/internal/encoding/base64.ts +0 -286
  232. package/src/internal/encoding/base64Url.ts +0 -29
  233. package/src/internal/encoding/common.ts +0 -51
  234. package/src/internal/encoding/hex.ts +0 -315
  235. package/src/internal/errors.ts +0 -7
  236. package/src/internal/executionPlan.ts +0 -114
  237. package/src/internal/executionStrategy.ts +0 -74
  238. package/src/internal/fiber.ts +0 -388
  239. package/src/internal/fiberId.ts +0 -267
  240. package/src/internal/fiberMessage.ts +0 -82
  241. package/src/internal/fiberRefs/patch.ts +0 -144
  242. package/src/internal/fiberRefs.ts +0 -297
  243. package/src/internal/fiberRuntime.ts +0 -3915
  244. package/src/internal/fiberScope.ts +0 -71
  245. package/src/internal/fiberStatus.ts +0 -119
  246. package/src/internal/groupBy.ts +0 -530
  247. package/src/internal/hashMap/array.ts +0 -49
  248. package/src/internal/hashMap/bitwise.ts +0 -32
  249. package/src/internal/hashMap/config.ts +0 -14
  250. package/src/internal/hashMap/keySet.ts +0 -8
  251. package/src/internal/hashMap/node.ts +0 -391
  252. package/src/internal/hashMap.ts +0 -586
  253. package/src/internal/hashSet.ts +0 -323
  254. package/src/internal/keyedPool.ts +0 -244
  255. package/src/internal/layer/circular.ts +0 -228
  256. package/src/internal/layer.ts +0 -1487
  257. package/src/internal/logSpan.ts +0 -20
  258. package/src/internal/logger-circular.ts +0 -24
  259. package/src/internal/logger.ts +0 -485
  260. package/src/internal/mailbox.ts +0 -561
  261. package/src/internal/managedRuntime/circular.ts +0 -6
  262. package/src/internal/managedRuntime.ts +0 -134
  263. package/src/internal/matcher.ts +0 -652
  264. package/src/internal/metric/boundaries.ts +0 -75
  265. package/src/internal/metric/hook.ts +0 -483
  266. package/src/internal/metric/key.ts +0 -167
  267. package/src/internal/metric/keyType.ts +0 -238
  268. package/src/internal/metric/label.ts +0 -41
  269. package/src/internal/metric/pair.ts +0 -48
  270. package/src/internal/metric/polling.ts +0 -149
  271. package/src/internal/metric/registry.ts +0 -187
  272. package/src/internal/metric/state.ts +0 -290
  273. package/src/internal/metric.ts +0 -577
  274. package/src/internal/opCodes/cause.ts +0 -35
  275. package/src/internal/opCodes/channel.ts +0 -83
  276. package/src/internal/opCodes/channelChildExecutorDecision.ts +0 -17
  277. package/src/internal/opCodes/channelMergeDecision.ts +0 -11
  278. package/src/internal/opCodes/channelMergeState.ts +0 -17
  279. package/src/internal/opCodes/channelMergeStrategy.ts +0 -11
  280. package/src/internal/opCodes/channelState.ts +0 -23
  281. package/src/internal/opCodes/channelUpstreamPullRequest.ts +0 -11
  282. package/src/internal/opCodes/channelUpstreamPullStrategy.ts +0 -11
  283. package/src/internal/opCodes/config.ts +0 -65
  284. package/src/internal/opCodes/configError.ts +0 -35
  285. package/src/internal/opCodes/continuation.ts +0 -11
  286. package/src/internal/opCodes/deferred.ts +0 -11
  287. package/src/internal/opCodes/effect.ts +0 -89
  288. package/src/internal/opCodes/layer.ts +0 -59
  289. package/src/internal/opCodes/streamHaltStrategy.ts +0 -23
  290. package/src/internal/option.ts +0 -80
  291. package/src/internal/pool.ts +0 -432
  292. package/src/internal/pubsub.ts +0 -1762
  293. package/src/internal/query.ts +0 -204
  294. package/src/internal/queue.ts +0 -766
  295. package/src/internal/random.ts +0 -161
  296. package/src/internal/rateLimiter.ts +0 -93
  297. package/src/internal/rcMap.ts +0 -285
  298. package/src/internal/rcRef.ts +0 -192
  299. package/src/internal/redBlackTree/iterator.ts +0 -200
  300. package/src/internal/redBlackTree/node.ts +0 -68
  301. package/src/internal/redBlackTree.ts +0 -1245
  302. package/src/internal/redacted.ts +0 -73
  303. package/src/internal/ref.ts +0 -171
  304. package/src/internal/reloadable.ts +0 -140
  305. package/src/internal/request.ts +0 -177
  306. package/src/internal/resource.ts +0 -76
  307. package/src/internal/ringBuffer.ts +0 -68
  308. package/src/internal/runtime.ts +0 -558
  309. package/src/internal/runtimeFlags.ts +0 -188
  310. package/src/internal/runtimeFlagsPatch.ts +0 -103
  311. package/src/internal/schedule/decision.ts +0 -47
  312. package/src/internal/schedule/interval.ts +0 -101
  313. package/src/internal/schedule/intervals.ts +0 -180
  314. package/src/internal/schedule.ts +0 -2199
  315. package/src/internal/schema/errors.ts +0 -191
  316. package/src/internal/schema/schemaId.ts +0 -106
  317. package/src/internal/schema/util.ts +0 -50
  318. package/src/internal/scopedCache.ts +0 -644
  319. package/src/internal/scopedRef.ts +0 -118
  320. package/src/internal/secret.ts +0 -89
  321. package/src/internal/singleShotGen.ts +0 -35
  322. package/src/internal/sink.ts +0 -2120
  323. package/src/internal/stack.ts +0 -10
  324. package/src/internal/stm/core.ts +0 -817
  325. package/src/internal/stm/entry.ts +0 -59
  326. package/src/internal/stm/journal.ts +0 -123
  327. package/src/internal/stm/opCodes/stm.ts +0 -71
  328. package/src/internal/stm/opCodes/stmState.ts +0 -17
  329. package/src/internal/stm/opCodes/strategy.ts +0 -17
  330. package/src/internal/stm/opCodes/tExit.ts +0 -29
  331. package/src/internal/stm/opCodes/tryCommit.ts +0 -11
  332. package/src/internal/stm/stm.ts +0 -1453
  333. package/src/internal/stm/stmState.ts +0 -136
  334. package/src/internal/stm/tArray.ts +0 -550
  335. package/src/internal/stm/tDeferred.ts +0 -81
  336. package/src/internal/stm/tExit.ts +0 -190
  337. package/src/internal/stm/tMap.ts +0 -824
  338. package/src/internal/stm/tPriorityQueue.ts +0 -267
  339. package/src/internal/stm/tPubSub.ts +0 -551
  340. package/src/internal/stm/tQueue.ts +0 -393
  341. package/src/internal/stm/tRandom.ts +0 -140
  342. package/src/internal/stm/tReentrantLock.ts +0 -352
  343. package/src/internal/stm/tRef.ts +0 -195
  344. package/src/internal/stm/tSemaphore.ts +0 -113
  345. package/src/internal/stm/tSet.ts +0 -259
  346. package/src/internal/stm/tSubscriptionRef.ts +0 -286
  347. package/src/internal/stm/tryCommit.ts +0 -34
  348. package/src/internal/stm/txnId.ts +0 -14
  349. package/src/internal/stm/versioned.ts +0 -4
  350. package/src/internal/stream/debounceState.ts +0 -57
  351. package/src/internal/stream/emit.ts +0 -123
  352. package/src/internal/stream/haltStrategy.ts +0 -94
  353. package/src/internal/stream/handoff.ts +0 -187
  354. package/src/internal/stream/handoffSignal.ts +0 -59
  355. package/src/internal/stream/pull.ts +0 -34
  356. package/src/internal/stream/sinkEndReason.ts +0 -30
  357. package/src/internal/stream/zipAllState.ts +0 -88
  358. package/src/internal/stream/zipChunksState.ts +0 -56
  359. package/src/internal/stream.ts +0 -8801
  360. package/src/internal/string-utils.ts +0 -107
  361. package/src/internal/subscriptionRef.ts +0 -138
  362. package/src/internal/supervisor/patch.ts +0 -190
  363. package/src/internal/supervisor.ts +0 -303
  364. package/src/internal/synchronizedRef.ts +0 -114
  365. package/src/internal/take.ts +0 -199
  366. package/src/internal/testing/sleep.ts +0 -27
  367. package/src/internal/testing/suspendedWarningData.ts +0 -85
  368. package/src/internal/testing/warningData.ts +0 -94
  369. package/src/internal/tracer.ts +0 -293
  370. package/src/internal/trie.ts +0 -722
  371. package/src/internal/version.ts +0 -7
package/src/Boolean.ts DELETED
@@ -1,287 +0,0 @@
1
- /**
2
- * This module provides utility functions and type class instances for working with the `boolean` type in TypeScript.
3
- * It includes functions for basic boolean operations, as well as type class instances for
4
- * `Equivalence` and `Order`.
5
- *
6
- * @since 2.0.0
7
- */
8
- import * as equivalence from "./Equivalence.js"
9
- import type { LazyArg } from "./Function.js"
10
- import { dual } from "./Function.js"
11
- import * as order from "./Order.js"
12
- import * as predicate from "./Predicate.js"
13
-
14
- /**
15
- * Tests if a value is a `boolean`.
16
- *
17
- * @example
18
- * ```ts
19
- * import * as assert from "node:assert"
20
- * import { isBoolean } from "effect/Boolean"
21
- *
22
- * assert.deepStrictEqual(isBoolean(true), true)
23
- * assert.deepStrictEqual(isBoolean("true"), false)
24
- * ```
25
- *
26
- * @category guards
27
- * @since 2.0.0
28
- */
29
- export const isBoolean: (input: unknown) => input is boolean = predicate.isBoolean
30
-
31
- /**
32
- * This function returns the result of either of the given functions depending on the value of the boolean parameter.
33
- * It is useful when you have to run one of two functions depending on the boolean value.
34
- *
35
- * @example
36
- * ```ts
37
- * import * as assert from "node:assert"
38
- * import { Boolean } from "effect"
39
- *
40
- * assert.deepStrictEqual(Boolean.match(true, { onFalse: () => "It's false!", onTrue: () => "It's true!" }), "It's true!")
41
- * ```
42
- *
43
- * @category pattern matching
44
- * @since 2.0.0
45
- */
46
- export const match: {
47
- <A, B = A>(options: {
48
- readonly onFalse: LazyArg<A>
49
- readonly onTrue: LazyArg<B>
50
- }): (value: boolean) => A | B
51
- <A, B>(value: boolean, options: {
52
- readonly onFalse: LazyArg<A>
53
- readonly onTrue: LazyArg<B>
54
- }): A | B
55
- } = dual(2, <A, B>(value: boolean, options: {
56
- readonly onFalse: LazyArg<A>
57
- readonly onTrue: LazyArg<B>
58
- }): A | B => value ? options.onTrue() : options.onFalse())
59
-
60
- /**
61
- * @category instances
62
- * @since 2.0.0
63
- */
64
- export const Equivalence: equivalence.Equivalence<boolean> = equivalence.boolean
65
-
66
- /**
67
- * @category instances
68
- * @since 2.0.0
69
- */
70
- export const Order: order.Order<boolean> = order.boolean
71
-
72
- /**
73
- * Negates the given boolean: `!self`
74
- *
75
- * @example
76
- * ```ts
77
- * import * as assert from "node:assert"
78
- * import { not } from "effect/Boolean"
79
- *
80
- * assert.deepStrictEqual(not(true), false)
81
- * assert.deepStrictEqual(not(false), true)
82
- * ```
83
- *
84
- * @category combinators
85
- * @since 2.0.0
86
- */
87
- export const not = (self: boolean): boolean => !self
88
-
89
- /**
90
- * Combines two boolean using AND: `self && that`.
91
- *
92
- * @example
93
- * ```ts
94
- * import * as assert from "node:assert"
95
- * import { and } from "effect/Boolean"
96
- *
97
- * assert.deepStrictEqual(and(true, true), true)
98
- * assert.deepStrictEqual(and(true, false), false)
99
- * assert.deepStrictEqual(and(false, true), false)
100
- * assert.deepStrictEqual(and(false, false), false)
101
- * ```
102
- *
103
- * @category combinators
104
- * @since 2.0.0
105
- */
106
- export const and: {
107
- (that: boolean): (self: boolean) => boolean
108
- (self: boolean, that: boolean): boolean
109
- } = dual(2, (self: boolean, that: boolean): boolean => self && that)
110
-
111
- /**
112
- * Combines two boolean using NAND: `!(self && that)`.
113
- *
114
- * @example
115
- * ```ts
116
- * import * as assert from "node:assert"
117
- * import { nand } from "effect/Boolean"
118
- *
119
- * assert.deepStrictEqual(nand(true, true), false)
120
- * assert.deepStrictEqual(nand(true, false), true)
121
- * assert.deepStrictEqual(nand(false, true), true)
122
- * assert.deepStrictEqual(nand(false, false), true)
123
- * ```
124
- *
125
- * @category combinators
126
- * @since 2.0.0
127
- */
128
- export const nand: {
129
- (that: boolean): (self: boolean) => boolean
130
- (self: boolean, that: boolean): boolean
131
- } = dual(2, (self: boolean, that: boolean): boolean => !(self && that))
132
-
133
- /**
134
- * Combines two boolean using OR: `self || that`.
135
- *
136
- * @example
137
- * ```ts
138
- * import * as assert from "node:assert"
139
- * import { or } from "effect/Boolean"
140
- *
141
- * assert.deepStrictEqual(or(true, true), true)
142
- * assert.deepStrictEqual(or(true, false), true)
143
- * assert.deepStrictEqual(or(false, true), true)
144
- * assert.deepStrictEqual(or(false, false), false)
145
- * ```
146
- *
147
- * @category combinators
148
- * @since 2.0.0
149
- */
150
- export const or: {
151
- (that: boolean): (self: boolean) => boolean
152
- (self: boolean, that: boolean): boolean
153
- } = dual(2, (self: boolean, that: boolean): boolean => self || that)
154
-
155
- /**
156
- * Combines two booleans using NOR: `!(self || that)`.
157
- *
158
- * @example
159
- * ```ts
160
- * import * as assert from "node:assert"
161
- * import { nor } from "effect/Boolean"
162
- *
163
- * assert.deepStrictEqual(nor(true, true), false)
164
- * assert.deepStrictEqual(nor(true, false), false)
165
- * assert.deepStrictEqual(nor(false, true), false)
166
- * assert.deepStrictEqual(nor(false, false), true)
167
- * ```
168
- *
169
- * @category combinators
170
- * @since 2.0.0
171
- */
172
- export const nor: {
173
- (that: boolean): (self: boolean) => boolean
174
- (self: boolean, that: boolean): boolean
175
- } = dual(2, (self: boolean, that: boolean): boolean => !(self || that))
176
-
177
- /**
178
- * Combines two booleans using XOR: `(!self && that) || (self && !that)`.
179
- *
180
- * @example
181
- * ```ts
182
- * import * as assert from "node:assert"
183
- * import { xor } from "effect/Boolean"
184
- *
185
- * assert.deepStrictEqual(xor(true, true), false)
186
- * assert.deepStrictEqual(xor(true, false), true)
187
- * assert.deepStrictEqual(xor(false, true), true)
188
- * assert.deepStrictEqual(xor(false, false), false)
189
- * ```
190
- *
191
- * @category combinators
192
- * @since 2.0.0
193
- */
194
- export const xor: {
195
- (that: boolean): (self: boolean) => boolean
196
- (self: boolean, that: boolean): boolean
197
- } = dual(2, (self: boolean, that: boolean): boolean => (!self && that) || (self && !that))
198
-
199
- /**
200
- * Combines two booleans using EQV (aka XNOR): `!xor(self, that)`.
201
- *
202
- * @example
203
- * ```ts
204
- * import * as assert from "node:assert"
205
- * import { eqv } from "effect/Boolean"
206
- *
207
- * assert.deepStrictEqual(eqv(true, true), true)
208
- * assert.deepStrictEqual(eqv(true, false), false)
209
- * assert.deepStrictEqual(eqv(false, true), false)
210
- * assert.deepStrictEqual(eqv(false, false), true)
211
- * ```
212
- *
213
- * @category combinators
214
- * @since 2.0.0
215
- */
216
- export const eqv: {
217
- (that: boolean): (self: boolean) => boolean
218
- (self: boolean, that: boolean): boolean
219
- } = dual(2, (self: boolean, that: boolean): boolean => !xor(self, that))
220
-
221
- /**
222
- * Combines two booleans using an implication: `(!self || that)`.
223
- *
224
- * @example
225
- * ```ts
226
- * import * as assert from "node:assert"
227
- * import { implies } from "effect/Boolean"
228
- *
229
- * assert.deepStrictEqual(implies(true, true), true)
230
- * assert.deepStrictEqual(implies(true, false), false)
231
- * assert.deepStrictEqual(implies(false, true), true)
232
- * assert.deepStrictEqual(implies(false, false), true)
233
- * ```
234
- *
235
- * @category combinators
236
- * @since 2.0.0
237
- */
238
- export const implies: {
239
- (that: boolean): (self: boolean) => boolean
240
- (self: boolean, that: boolean): boolean
241
- } = dual(2, (self, that) => self ? that : true)
242
-
243
- /**
244
- * This utility function is used to check if all the elements in a collection of boolean values are `true`.
245
- *
246
- * @example
247
- * ```ts
248
- * import * as assert from "node:assert"
249
- * import { every } from "effect/Boolean"
250
- *
251
- * assert.deepStrictEqual(every([true, true, true]), true)
252
- * assert.deepStrictEqual(every([true, false, true]), false)
253
- * ```
254
- *
255
- * @since 2.0.0
256
- */
257
- export const every = (collection: Iterable<boolean>): boolean => {
258
- for (const b of collection) {
259
- if (!b) {
260
- return false
261
- }
262
- }
263
- return true
264
- }
265
-
266
- /**
267
- * This utility function is used to check if at least one of the elements in a collection of boolean values is `true`.
268
- *
269
- * @example
270
- * ```ts
271
- * import * as assert from "node:assert"
272
- * import { some } from "effect/Boolean"
273
- *
274
- * assert.deepStrictEqual(some([true, false, true]), true)
275
- * assert.deepStrictEqual(some([false, false, false]), false)
276
- * ```
277
- *
278
- * @since 2.0.0
279
- */
280
- export const some = (collection: Iterable<boolean>): boolean => {
281
- for (const b of collection) {
282
- if (b) {
283
- return true
284
- }
285
- }
286
- return false
287
- }
package/src/Brand.ts DELETED
@@ -1,360 +0,0 @@
1
- /**
2
- * This module provides types and utility functions to create and work with branded types,
3
- * which are TypeScript types with an added type tag to prevent accidental usage of a value in the wrong context.
4
- *
5
- * The `refined` and `nominal` functions are both used to create branded types in TypeScript.
6
- * The main difference between them is that `refined` allows for validation of the data, while `nominal` does not.
7
- *
8
- * The `nominal` function is used to create a new branded type that has the same underlying type as the input, but with a different name.
9
- * This is useful when you want to distinguish between two values of the same type that have different meanings.
10
- * The `nominal` function does not perform any validation of the input data.
11
- *
12
- * On the other hand, the `refined` function is used to create a new branded type that has the same underlying type as the input,
13
- * but with a different name, and it also allows for validation of the input data.
14
- * The `refined` function takes a predicate that is used to validate the input data.
15
- * If the input data fails the validation, a `BrandErrors` is returned, which provides information about the specific validation failure.
16
- *
17
- * @since 2.0.0
18
- */
19
- import * as Arr from "./Array.js"
20
- import * as Either from "./Either.js"
21
- import { identity, unsafeCoerce } from "./Function.js"
22
- import * as Option from "./Option.js"
23
- import type { Predicate } from "./Predicate.js"
24
- import type * as Types from "./Types.js"
25
-
26
- /**
27
- * @since 2.0.0
28
- * @category symbols
29
- */
30
- export const BrandTypeId: unique symbol = Symbol.for("effect/Brand")
31
-
32
- /**
33
- * @since 2.0.0
34
- * @category symbols
35
- */
36
- export type BrandTypeId = typeof BrandTypeId
37
-
38
- /**
39
- * @since 2.0.0
40
- * @category symbols
41
- */
42
- export const RefinedConstructorsTypeId: unique symbol = Symbol.for("effect/Brand/Refined")
43
-
44
- /**
45
- * @since 2.0.0
46
- * @category symbols
47
- */
48
- export type RefinedConstructorsTypeId = typeof RefinedConstructorsTypeId
49
-
50
- /**
51
- * A generic interface that defines a branded type.
52
- *
53
- * @since 2.0.0
54
- * @category models
55
- */
56
- export interface Brand<in out K extends string | symbol> {
57
- readonly [BrandTypeId]: {
58
- readonly [k in K]: K
59
- }
60
- }
61
-
62
- /**
63
- * @since 2.0.0
64
- */
65
- export declare namespace Brand {
66
- /**
67
- * Represents a list of refinement errors.
68
- *
69
- * @since 2.0.0
70
- * @category models
71
- */
72
- export interface BrandErrors extends Array<RefinementError> {}
73
-
74
- /**
75
- * Represents an error that occurs when the provided value of the branded type does not pass the refinement predicate.
76
- *
77
- * @since 2.0.0
78
- * @category models
79
- */
80
- export interface RefinementError {
81
- readonly meta: unknown
82
- readonly message: string
83
- }
84
-
85
- /**
86
- * @since 2.0.0
87
- * @category models
88
- */
89
- export interface Constructor<in out A extends Brand<any>> {
90
- readonly [RefinedConstructorsTypeId]: RefinedConstructorsTypeId
91
- /**
92
- * Constructs a branded type from a value of type `A`, throwing an error if
93
- * the provided `A` is not valid.
94
- */
95
- (args: Brand.Unbranded<A>): A
96
- /**
97
- * Constructs a branded type from a value of type `A`, returning `Some<A>`
98
- * if the provided `A` is valid, `None` otherwise.
99
- */
100
- option(args: Brand.Unbranded<A>): Option.Option<A>
101
- /**
102
- * Constructs a branded type from a value of type `A`, returning `Right<A>`
103
- * if the provided `A` is valid, `Left<BrandError>` otherwise.
104
- */
105
- either(args: Brand.Unbranded<A>): Either.Either<A, Brand.BrandErrors>
106
- /**
107
- * Attempts to refine the provided value of type `A`, returning `true` if
108
- * the provided `A` is valid, `false` otherwise.
109
- */
110
- is(a: Brand.Unbranded<A>): a is Brand.Unbranded<A> & A
111
- }
112
-
113
- /**
114
- * A utility type to extract a branded type from a `Brand.Constructor`.
115
- *
116
- * @since 2.0.0
117
- * @category models
118
- */
119
- export type FromConstructor<A> = A extends Brand.Constructor<infer B> ? B : never
120
-
121
- /**
122
- * A utility type to extract the value type from a brand.
123
- *
124
- * @since 2.0.0
125
- * @category models
126
- */
127
- export type Unbranded<P> = P extends infer Q & Brands<P> ? Q : P
128
-
129
- /**
130
- * A utility type to extract the brands from a branded type.
131
- *
132
- * @since 2.0.0
133
- * @category models
134
- */
135
- export type Brands<P> = P extends Brand<any> ? Types.UnionToIntersection<
136
- {
137
- [k in keyof P[BrandTypeId]]: k extends string | symbol ? Brand<k>
138
- : never
139
- }[keyof P[BrandTypeId]]
140
- >
141
- : never
142
-
143
- /**
144
- * A utility type that checks that all brands have the same base type.
145
- *
146
- * @since 2.0.0
147
- * @category models
148
- */
149
- export type EnsureCommonBase<
150
- Brands extends readonly [Brand.Constructor<any>, ...Array<Brand.Constructor<any>>]
151
- > = {
152
- [B in keyof Brands]: Brand.Unbranded<Brand.FromConstructor<Brands[0]>> extends
153
- Brand.Unbranded<Brand.FromConstructor<Brands[B]>>
154
- ? Brand.Unbranded<Brand.FromConstructor<Brands[B]>> extends Brand.Unbranded<Brand.FromConstructor<Brands[0]>>
155
- ? Brands[B]
156
- : Brands[B]
157
- : "ERROR: All brands should have the same base type"
158
- }
159
- }
160
-
161
- /**
162
- * @category alias
163
- * @since 2.0.0
164
- */
165
- export type Branded<A, K extends string | symbol> = A & Brand<K>
166
-
167
- /**
168
- * Returns a `BrandErrors` that contains a single `RefinementError`.
169
- *
170
- * @since 2.0.0
171
- * @category constructors
172
- */
173
- export const error = (message: string, meta?: unknown): Brand.BrandErrors => [{
174
- message,
175
- meta
176
- }]
177
-
178
- /**
179
- * Takes a variable number of `BrandErrors` and returns a single `BrandErrors` that contains all refinement errors.
180
- *
181
- * @since 2.0.0
182
- * @category constructors
183
- */
184
- export const errors: (...errors: Array<Brand.BrandErrors>) => Brand.BrandErrors = (
185
- ...errors: Array<Brand.BrandErrors>
186
- ): Brand.BrandErrors => Arr.flatten(errors)
187
-
188
- /**
189
- * Returns a `Brand.Constructor` that can construct a branded type from an unbranded value using the provided `refinement`
190
- * predicate as validation of the input data.
191
- *
192
- * If you don't want to perform any validation but only distinguish between two values of the same type but with different meanings,
193
- * see {@link nominal}.
194
- *
195
- * **Example**
196
- *
197
- * ```ts
198
- * import * as assert from "node:assert"
199
- * import { Brand } from "effect"
200
- *
201
- * type Int = number & Brand.Brand<"Int">
202
- *
203
- * const Int = Brand.refined<Int>(
204
- * (n) => Number.isInteger(n),
205
- * (n) => Brand.error(`Expected ${n} to be an integer`)
206
- * )
207
- *
208
- * console.log(Int(1))
209
- * // 1
210
- *
211
- * assert.throws(() => Int(1.1))
212
- * ```
213
- *
214
- * @since 2.0.0
215
- * @category constructors
216
- */
217
- export function refined<A extends Brand<any>>(
218
- f: (unbranded: Brand.Unbranded<A>) => Option.Option<Brand.BrandErrors>
219
- ): Brand.Constructor<A>
220
- export function refined<A extends Brand<any>>(
221
- refinement: Predicate<Brand.Unbranded<A>>,
222
- onFailure: (unbranded: Brand.Unbranded<A>) => Brand.BrandErrors
223
- ): Brand.Constructor<A>
224
- export function refined<A extends Brand<any>>(
225
- ...args: [(unbranded: Brand.Unbranded<A>) => Option.Option<Brand.BrandErrors>] | [
226
- Predicate<Brand.Unbranded<A>>,
227
- (unbranded: Brand.Unbranded<A>) => Brand.BrandErrors
228
- ]
229
- ): Brand.Constructor<A> {
230
- const either: (unbranded: Brand.Unbranded<A>) => Either.Either<A, Brand.BrandErrors> = args.length === 2 ?
231
- (unbranded) => args[0](unbranded) ? Either.right(unbranded as A) : Either.left(args[1](unbranded)) :
232
- (unbranded) => {
233
- return Option.match(args[0](unbranded), {
234
- onNone: () => Either.right(unbranded as A),
235
- onSome: Either.left
236
- })
237
- }
238
- return Object.assign((unbranded: Brand.Unbranded<A>) => Either.getOrThrowWith(either(unbranded), identity), {
239
- [RefinedConstructorsTypeId]: RefinedConstructorsTypeId,
240
- option: (args: any) => Option.getRight(either(args)),
241
- either,
242
- is: (args: any): args is Brand.Unbranded<A> & A => Either.isRight(either(args))
243
- }) as any
244
- }
245
-
246
- /**
247
- * This function returns a `Brand.Constructor` that **does not apply any runtime checks**, it just returns the provided value.
248
- * It can be used to create nominal types that allow distinguishing between two values of the same type but with different meanings.
249
- *
250
- * If you also want to perform some validation, see {@link refined}.
251
- *
252
- * **Example**
253
- *
254
- * ```ts
255
- * import * as assert from "node:assert"
256
- * import { Brand } from "effect"
257
- *
258
- * type UserId = number & Brand.Brand<"UserId">
259
- *
260
- * const UserId = Brand.nominal<UserId>()
261
- *
262
- * console.log(UserId(1))
263
- * // 1
264
- * ```
265
- *
266
- * @since 2.0.0
267
- * @category constructors
268
- */
269
- export const nominal = <A extends Brand<any>>(): Brand.Constructor<
270
- A
271
- > => {
272
- // @ts-expect-error
273
- return Object.assign((args) => args, {
274
- [RefinedConstructorsTypeId]: RefinedConstructorsTypeId,
275
- option: (args: any) => Option.some(args),
276
- either: (args: any) => Either.right(args),
277
- is: (_args: any): _args is Brand.Unbranded<A> & A => true
278
- })
279
- }
280
-
281
- /**
282
- * Combines two or more brands together to form a single branded type.
283
- * This API is useful when you want to validate that the input data passes multiple brand validators.
284
- *
285
- * **Example**
286
- *
287
- * ```ts
288
- * import * as assert from "node:assert"
289
- * import { Brand } from "effect"
290
- *
291
- * type Int = number & Brand.Brand<"Int">
292
- * const Int = Brand.refined<Int>(
293
- * (n) => Number.isInteger(n),
294
- * (n) => Brand.error(`Expected ${n} to be an integer`)
295
- * )
296
- * type Positive = number & Brand.Brand<"Positive">
297
- * const Positive = Brand.refined<Positive>(
298
- * (n) => n > 0,
299
- * (n) => Brand.error(`Expected ${n} to be positive`)
300
- * )
301
- *
302
- * const PositiveInt = Brand.all(Int, Positive)
303
- *
304
- * console.log(PositiveInt(1))
305
- * // 1
306
- *
307
- * assert.throws(() => PositiveInt(1.1))
308
- * ```
309
- *
310
- * @since 2.0.0
311
- * @category combining
312
- */
313
- export const all: <Brands extends readonly [Brand.Constructor<any>, ...Array<Brand.Constructor<any>>]>(
314
- ...brands: Brand.EnsureCommonBase<Brands>
315
- ) => Brand.Constructor<
316
- Types.UnionToIntersection<{ [B in keyof Brands]: Brand.FromConstructor<Brands[B]> }[number]> extends
317
- infer X extends Brand<any> ? X : Brand<any>
318
- > = <
319
- Brands extends readonly [Brand.Constructor<any>, ...Array<Brand.Constructor<any>>]
320
- >(...brands: Brand.EnsureCommonBase<Brands>): Brand.Constructor<
321
- Types.UnionToIntersection<
322
- {
323
- [B in keyof Brands]: Brand.FromConstructor<Brands[B]>
324
- }[number]
325
- > extends infer X extends Brand<any> ? X : Brand<any>
326
- > => {
327
- const either = (args: any): Either.Either<any, Brand.BrandErrors> => {
328
- let result: Either.Either<any, Brand.BrandErrors> = Either.right(args)
329
- for (const brand of brands) {
330
- const nextResult = brand.either(args)
331
- if (Either.isLeft(result) && Either.isLeft(nextResult)) {
332
- result = Either.left([...result.left, ...nextResult.left])
333
- } else {
334
- result = Either.isLeft(result) ? result : nextResult
335
- }
336
- }
337
- return result
338
- }
339
- // @ts-expect-error
340
- return Object.assign((args) =>
341
- Either.match(either(args), {
342
- onLeft: (e) => {
343
- throw e
344
- },
345
- onRight: identity
346
- }), {
347
- [RefinedConstructorsTypeId]: RefinedConstructorsTypeId,
348
- option: (args: any) => Option.getRight(either(args)),
349
- either,
350
- is: (args: any): args is any => Either.isRight(either(args))
351
- })
352
- }
353
-
354
- /**
355
- * Retrieves the unbranded value from a `Brand` instance.
356
- *
357
- * @since 3.15.0
358
- * @category getters
359
- */
360
- export const unbranded: <A extends Brand<any>>(branded: A) => Brand.Unbranded<A> = unsafeCoerce