effect 4.0.0-beta.74 → 4.0.0-beta.75

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 (796) hide show
  1. package/dist/Array.d.ts +729 -611
  2. package/dist/Array.d.ts.map +1 -1
  3. package/dist/Array.js +273 -213
  4. package/dist/Array.js.map +1 -1
  5. package/dist/BigDecimal.d.ts +37 -30
  6. package/dist/BigDecimal.d.ts.map +1 -1
  7. package/dist/BigDecimal.js +19 -16
  8. package/dist/BigDecimal.js.map +1 -1
  9. package/dist/BigInt.d.ts +34 -40
  10. package/dist/BigInt.d.ts.map +1 -1
  11. package/dist/BigInt.js +16 -16
  12. package/dist/BigInt.js.map +1 -1
  13. package/dist/Boolean.d.ts +8 -8
  14. package/dist/Boolean.js +4 -4
  15. package/dist/Brand.d.ts +13 -11
  16. package/dist/Brand.d.ts.map +1 -1
  17. package/dist/Brand.js +10 -8
  18. package/dist/Brand.js.map +1 -1
  19. package/dist/Cause.d.ts +21 -23
  20. package/dist/Cause.d.ts.map +1 -1
  21. package/dist/Cause.js +21 -23
  22. package/dist/Cause.js.map +1 -1
  23. package/dist/Channel.d.ts +219 -9
  24. package/dist/Channel.d.ts.map +1 -1
  25. package/dist/Channel.js +83 -3
  26. package/dist/Channel.js.map +1 -1
  27. package/dist/ChannelSchema.d.ts +11 -11
  28. package/dist/ChannelSchema.js +5 -5
  29. package/dist/Chunk.d.ts +69 -16
  30. package/dist/Chunk.d.ts.map +1 -1
  31. package/dist/Chunk.js +43 -8
  32. package/dist/Chunk.js.map +1 -1
  33. package/dist/Clock.d.ts +3 -3
  34. package/dist/Clock.js +3 -3
  35. package/dist/Combiner.d.ts +9 -13
  36. package/dist/Combiner.d.ts.map +1 -1
  37. package/dist/Combiner.js +9 -13
  38. package/dist/Combiner.js.map +1 -1
  39. package/dist/Config.d.ts +49 -56
  40. package/dist/Config.d.ts.map +1 -1
  41. package/dist/Config.js +40 -43
  42. package/dist/Config.js.map +1 -1
  43. package/dist/ConfigProvider.d.ts +34 -44
  44. package/dist/ConfigProvider.d.ts.map +1 -1
  45. package/dist/ConfigProvider.js +24 -32
  46. package/dist/ConfigProvider.js.map +1 -1
  47. package/dist/Console.d.ts +2 -2
  48. package/dist/Console.js +2 -2
  49. package/dist/Context.d.ts +60 -72
  50. package/dist/Context.d.ts.map +1 -1
  51. package/dist/Context.js +28 -32
  52. package/dist/Context.js.map +1 -1
  53. package/dist/Cron.d.ts +2 -2
  54. package/dist/Cron.js +2 -2
  55. package/dist/Crypto.d.ts +4 -4
  56. package/dist/Crypto.js +4 -4
  57. package/dist/Data.d.ts +21 -15
  58. package/dist/Data.d.ts.map +1 -1
  59. package/dist/Data.js +7 -7
  60. package/dist/Data.js.map +1 -1
  61. package/dist/DateTime.d.ts +35 -16
  62. package/dist/DateTime.d.ts.map +1 -1
  63. package/dist/DateTime.js +35 -8
  64. package/dist/DateTime.js.map +1 -1
  65. package/dist/Deferred.d.ts +24 -15
  66. package/dist/Deferred.d.ts.map +1 -1
  67. package/dist/Deferred.js +8 -5
  68. package/dist/Deferred.js.map +1 -1
  69. package/dist/Duration.d.ts +44 -31
  70. package/dist/Duration.d.ts.map +1 -1
  71. package/dist/Duration.js +22 -11
  72. package/dist/Duration.js.map +1 -1
  73. package/dist/Effect.d.ts +516 -416
  74. package/dist/Effect.d.ts.map +1 -1
  75. package/dist/Effect.js +234 -174
  76. package/dist/Effect.js.map +1 -1
  77. package/dist/Encoding.d.ts +5 -0
  78. package/dist/Encoding.d.ts.map +1 -1
  79. package/dist/Encoding.js +5 -0
  80. package/dist/Encoding.js.map +1 -1
  81. package/dist/Equal.d.ts +26 -39
  82. package/dist/Equal.d.ts.map +1 -1
  83. package/dist/Equal.js +10 -17
  84. package/dist/Equal.js.map +1 -1
  85. package/dist/Equivalence.d.ts +71 -99
  86. package/dist/Equivalence.d.ts.map +1 -1
  87. package/dist/Equivalence.js +53 -73
  88. package/dist/Equivalence.js.map +1 -1
  89. package/dist/ErrorReporter.d.ts +1 -1
  90. package/dist/ErrorReporter.js +1 -1
  91. package/dist/Exit.d.ts +79 -96
  92. package/dist/Exit.d.ts.map +1 -1
  93. package/dist/Exit.js +57 -64
  94. package/dist/Exit.js.map +1 -1
  95. package/dist/Fiber.d.ts +8 -6
  96. package/dist/Fiber.d.ts.map +1 -1
  97. package/dist/Fiber.js +8 -6
  98. package/dist/Fiber.js.map +1 -1
  99. package/dist/FiberHandle.d.ts +25 -0
  100. package/dist/FiberHandle.d.ts.map +1 -1
  101. package/dist/FiberHandle.js +15 -0
  102. package/dist/FiberHandle.js.map +1 -1
  103. package/dist/FiberMap.d.ts +35 -0
  104. package/dist/FiberMap.d.ts.map +1 -1
  105. package/dist/FiberMap.js +15 -0
  106. package/dist/FiberMap.js.map +1 -1
  107. package/dist/FiberSet.d.ts +20 -0
  108. package/dist/FiberSet.d.ts.map +1 -1
  109. package/dist/FiberSet.js +10 -0
  110. package/dist/FiberSet.js.map +1 -1
  111. package/dist/Filter.d.ts +4 -4
  112. package/dist/Filter.js +4 -4
  113. package/dist/Formatter.d.ts +14 -19
  114. package/dist/Formatter.d.ts.map +1 -1
  115. package/dist/Formatter.js +14 -19
  116. package/dist/Formatter.js.map +1 -1
  117. package/dist/Function.d.ts +15 -16
  118. package/dist/Function.d.ts.map +1 -1
  119. package/dist/Function.js +9 -10
  120. package/dist/Function.js.map +1 -1
  121. package/dist/Graph.d.ts +2 -2
  122. package/dist/Graph.js +2 -2
  123. package/dist/HKT.d.ts +2 -2
  124. package/dist/Hash.d.ts +2 -1
  125. package/dist/Hash.d.ts.map +1 -1
  126. package/dist/Hash.js +2 -1
  127. package/dist/Hash.js.map +1 -1
  128. package/dist/HashMap.d.ts +15 -0
  129. package/dist/HashMap.d.ts.map +1 -1
  130. package/dist/HashMap.js +5 -0
  131. package/dist/HashMap.js.map +1 -1
  132. package/dist/HashRing.d.ts +9 -9
  133. package/dist/HashRing.js +3 -3
  134. package/dist/Iterable.d.ts +24 -12
  135. package/dist/Iterable.d.ts.map +1 -1
  136. package/dist/Iterable.js +16 -6
  137. package/dist/Iterable.js.map +1 -1
  138. package/dist/JsonPatch.d.ts +2 -3
  139. package/dist/JsonPatch.d.ts.map +1 -1
  140. package/dist/JsonPatch.js +2 -3
  141. package/dist/JsonPatch.js.map +1 -1
  142. package/dist/JsonPointer.d.ts +2 -6
  143. package/dist/JsonPointer.d.ts.map +1 -1
  144. package/dist/JsonPointer.js +2 -6
  145. package/dist/JsonPointer.js.map +1 -1
  146. package/dist/JsonSchema.d.ts +17 -13
  147. package/dist/JsonSchema.d.ts.map +1 -1
  148. package/dist/JsonSchema.js +17 -13
  149. package/dist/JsonSchema.js.map +1 -1
  150. package/dist/Latch.d.ts +4 -3
  151. package/dist/Latch.d.ts.map +1 -1
  152. package/dist/Latch.js +4 -3
  153. package/dist/Latch.js.map +1 -1
  154. package/dist/Layer.d.ts +92 -114
  155. package/dist/Layer.d.ts.map +1 -1
  156. package/dist/Layer.js +38 -46
  157. package/dist/Layer.js.map +1 -1
  158. package/dist/Logger.d.ts +11 -14
  159. package/dist/Logger.d.ts.map +1 -1
  160. package/dist/Logger.js +11 -14
  161. package/dist/Logger.js.map +1 -1
  162. package/dist/Match.d.ts +2 -2
  163. package/dist/Match.js +2 -2
  164. package/dist/Metric.d.ts +89 -109
  165. package/dist/Metric.d.ts.map +1 -1
  166. package/dist/Metric.js +51 -61
  167. package/dist/Metric.js.map +1 -1
  168. package/dist/MutableHashMap.d.ts +21 -12
  169. package/dist/MutableHashMap.d.ts.map +1 -1
  170. package/dist/MutableHashMap.js +7 -4
  171. package/dist/MutableHashMap.js.map +1 -1
  172. package/dist/MutableList.d.ts +15 -0
  173. package/dist/MutableList.d.ts.map +1 -1
  174. package/dist/MutableList.js +15 -0
  175. package/dist/MutableList.js.map +1 -1
  176. package/dist/MutableRef.d.ts +56 -42
  177. package/dist/MutableRef.d.ts.map +1 -1
  178. package/dist/MutableRef.js +28 -22
  179. package/dist/MutableRef.js.map +1 -1
  180. package/dist/Newtype.d.ts +10 -7
  181. package/dist/Newtype.d.ts.map +1 -1
  182. package/dist/Newtype.js +10 -7
  183. package/dist/Newtype.js.map +1 -1
  184. package/dist/Number.d.ts +23 -11
  185. package/dist/Number.d.ts.map +1 -1
  186. package/dist/Number.js +9 -5
  187. package/dist/Number.js.map +1 -1
  188. package/dist/Optic.d.ts +16 -16
  189. package/dist/Optic.d.ts.map +1 -1
  190. package/dist/Optic.js +10 -9
  191. package/dist/Optic.js.map +1 -1
  192. package/dist/Option.d.ts +196 -168
  193. package/dist/Option.d.ts.map +1 -1
  194. package/dist/Option.js +96 -79
  195. package/dist/Option.js.map +1 -1
  196. package/dist/Order.d.ts +118 -179
  197. package/dist/Order.d.ts.map +1 -1
  198. package/dist/Order.js +92 -144
  199. package/dist/Order.js.map +1 -1
  200. package/dist/PartitionedSemaphore.d.ts +14 -14
  201. package/dist/PartitionedSemaphore.js +6 -6
  202. package/dist/Path.d.ts +2 -2
  203. package/dist/Path.js +2 -2
  204. package/dist/Pipeable.d.ts +2 -2
  205. package/dist/Pipeable.js +2 -2
  206. package/dist/PlatformError.d.ts +4 -4
  207. package/dist/PlatformError.js +4 -4
  208. package/dist/Pool.d.ts +7 -11
  209. package/dist/Pool.d.ts.map +1 -1
  210. package/dist/Pool.js +3 -5
  211. package/dist/Pool.js.map +1 -1
  212. package/dist/Predicate.d.ts +274 -263
  213. package/dist/Predicate.d.ts.map +1 -1
  214. package/dist/Predicate.js +128 -123
  215. package/dist/Predicate.js.map +1 -1
  216. package/dist/PubSub.d.ts +24 -14
  217. package/dist/PubSub.d.ts.map +1 -1
  218. package/dist/PubSub.js +16 -6
  219. package/dist/PubSub.js.map +1 -1
  220. package/dist/Pull.d.ts +4 -4
  221. package/dist/Pull.js +4 -4
  222. package/dist/Queue.d.ts +46 -7
  223. package/dist/Queue.d.ts.map +1 -1
  224. package/dist/Queue.js +46 -7
  225. package/dist/Queue.js.map +1 -1
  226. package/dist/RcRef.d.ts +0 -4
  227. package/dist/RcRef.d.ts.map +1 -1
  228. package/dist/RcRef.js.map +1 -1
  229. package/dist/Redactable.d.ts +2 -2
  230. package/dist/Redactable.js +2 -2
  231. package/dist/Redacted.d.ts +3 -3
  232. package/dist/Redacted.js +3 -3
  233. package/dist/Reducer.d.ts +2 -3
  234. package/dist/Reducer.d.ts.map +1 -1
  235. package/dist/Reducer.js +2 -3
  236. package/dist/Reducer.js.map +1 -1
  237. package/dist/Ref.d.ts +17 -16
  238. package/dist/Ref.d.ts.map +1 -1
  239. package/dist/Ref.js +15 -14
  240. package/dist/Ref.js.map +1 -1
  241. package/dist/References.d.ts +4 -4
  242. package/dist/References.js +4 -4
  243. package/dist/Request.d.ts +18 -18
  244. package/dist/Request.js +6 -6
  245. package/dist/Resource.d.ts +2 -2
  246. package/dist/Resource.js +2 -2
  247. package/dist/Result.d.ts +77 -33
  248. package/dist/Result.d.ts.map +1 -1
  249. package/dist/Result.js +42 -19
  250. package/dist/Result.js.map +1 -1
  251. package/dist/Runtime.d.ts +11 -8
  252. package/dist/Runtime.d.ts.map +1 -1
  253. package/dist/Runtime.js +11 -8
  254. package/dist/Runtime.js.map +1 -1
  255. package/dist/Schedule.d.ts +107 -45
  256. package/dist/Schedule.d.ts.map +1 -1
  257. package/dist/Schedule.js +41 -29
  258. package/dist/Schedule.js.map +1 -1
  259. package/dist/Scheduler.d.ts +6 -4
  260. package/dist/Scheduler.d.ts.map +1 -1
  261. package/dist/Scheduler.js +6 -4
  262. package/dist/Scheduler.js.map +1 -1
  263. package/dist/Schema.d.ts +443 -371
  264. package/dist/Schema.d.ts.map +1 -1
  265. package/dist/Schema.js +518 -427
  266. package/dist/Schema.js.map +1 -1
  267. package/dist/SchemaAST.d.ts +42 -21
  268. package/dist/SchemaAST.d.ts.map +1 -1
  269. package/dist/SchemaAST.js +80 -59
  270. package/dist/SchemaAST.js.map +1 -1
  271. package/dist/SchemaGetter.d.ts +126 -106
  272. package/dist/SchemaGetter.d.ts.map +1 -1
  273. package/dist/SchemaGetter.js +121 -101
  274. package/dist/SchemaGetter.js.map +1 -1
  275. package/dist/SchemaIssue.d.ts +37 -39
  276. package/dist/SchemaIssue.d.ts.map +1 -1
  277. package/dist/SchemaIssue.js +16 -17
  278. package/dist/SchemaIssue.js.map +1 -1
  279. package/dist/SchemaParser.d.ts +72 -153
  280. package/dist/SchemaParser.d.ts.map +1 -1
  281. package/dist/SchemaParser.js +72 -145
  282. package/dist/SchemaParser.js.map +1 -1
  283. package/dist/SchemaRepresentation.d.ts +30 -21
  284. package/dist/SchemaRepresentation.d.ts.map +1 -1
  285. package/dist/SchemaRepresentation.js +26 -22
  286. package/dist/SchemaRepresentation.js.map +1 -1
  287. package/dist/SchemaTransformation.d.ts +169 -145
  288. package/dist/SchemaTransformation.d.ts.map +1 -1
  289. package/dist/SchemaTransformation.js +183 -159
  290. package/dist/SchemaTransformation.js.map +1 -1
  291. package/dist/SchemaUtils.js +2 -2
  292. package/dist/SchemaUtils.js.map +1 -1
  293. package/dist/Scope.d.ts +15 -0
  294. package/dist/Scope.d.ts.map +1 -1
  295. package/dist/Scope.js +15 -0
  296. package/dist/Scope.js.map +1 -1
  297. package/dist/ScopedCache.d.ts +1 -1
  298. package/dist/ScopedCache.js +1 -1
  299. package/dist/ScopedRef.d.ts +14 -18
  300. package/dist/ScopedRef.d.ts.map +1 -1
  301. package/dist/ScopedRef.js +6 -8
  302. package/dist/ScopedRef.js.map +1 -1
  303. package/dist/Semaphore.d.ts +9 -9
  304. package/dist/Semaphore.js +3 -3
  305. package/dist/Sink.d.ts +13 -13
  306. package/dist/Sink.d.ts.map +1 -1
  307. package/dist/Sink.js +9 -9
  308. package/dist/Sink.js.map +1 -1
  309. package/dist/Stdio.d.ts +4 -5
  310. package/dist/Stdio.d.ts.map +1 -1
  311. package/dist/Stdio.js +4 -5
  312. package/dist/Stdio.js.map +1 -1
  313. package/dist/Stream.d.ts +321 -44
  314. package/dist/Stream.d.ts.map +1 -1
  315. package/dist/Stream.js +137 -22
  316. package/dist/Stream.js.map +1 -1
  317. package/dist/String.d.ts +6 -9
  318. package/dist/String.d.ts.map +1 -1
  319. package/dist/String.js +2 -3
  320. package/dist/String.js.map +1 -1
  321. package/dist/Struct.d.ts +15 -13
  322. package/dist/Struct.d.ts.map +1 -1
  323. package/dist/Struct.js +11 -9
  324. package/dist/Struct.js.map +1 -1
  325. package/dist/SubscriptionRef.d.ts +24 -19
  326. package/dist/SubscriptionRef.d.ts.map +1 -1
  327. package/dist/SubscriptionRef.js +12 -7
  328. package/dist/SubscriptionRef.js.map +1 -1
  329. package/dist/SynchronizedRef.d.ts +88 -63
  330. package/dist/SynchronizedRef.d.ts.map +1 -1
  331. package/dist/SynchronizedRef.js +32 -23
  332. package/dist/SynchronizedRef.js.map +1 -1
  333. package/dist/Tracer.d.ts +4 -4
  334. package/dist/Tracer.js +4 -4
  335. package/dist/Trie.d.ts +15 -0
  336. package/dist/Trie.d.ts.map +1 -1
  337. package/dist/Trie.js +5 -0
  338. package/dist/Trie.js.map +1 -1
  339. package/dist/Tuple.d.ts +25 -19
  340. package/dist/Tuple.d.ts.map +1 -1
  341. package/dist/Tuple.js +17 -13
  342. package/dist/Tuple.js.map +1 -1
  343. package/dist/TxReentrantLock.d.ts +6 -3
  344. package/dist/TxReentrantLock.d.ts.map +1 -1
  345. package/dist/TxReentrantLock.js +2 -1
  346. package/dist/TxReentrantLock.js.map +1 -1
  347. package/dist/TxRef.d.ts +16 -16
  348. package/dist/TxRef.js +8 -8
  349. package/dist/TxSubscriptionRef.d.ts +43 -27
  350. package/dist/TxSubscriptionRef.d.ts.map +1 -1
  351. package/dist/TxSubscriptionRef.js +19 -13
  352. package/dist/TxSubscriptionRef.js.map +1 -1
  353. package/dist/Types.d.ts +12 -38
  354. package/dist/Types.d.ts.map +1 -1
  355. package/dist/Types.js +0 -2
  356. package/dist/UndefinedOr.d.ts +15 -14
  357. package/dist/UndefinedOr.d.ts.map +1 -1
  358. package/dist/UndefinedOr.js +11 -10
  359. package/dist/UndefinedOr.js.map +1 -1
  360. package/dist/Unify.d.ts +2 -2
  361. package/dist/internal/schema/annotations.js.map +1 -1
  362. package/dist/internal/schema/arbitrary.js +9 -9
  363. package/dist/internal/schema/arbitrary.js.map +1 -1
  364. package/dist/internal/schema/equivalence.js +9 -9
  365. package/dist/internal/schema/equivalence.js.map +1 -1
  366. package/dist/internal/schema/representation.js +14 -14
  367. package/dist/internal/schema/representation.js.map +1 -1
  368. package/dist/internal/schema/schema.js +11 -11
  369. package/dist/internal/schema/schema.js.map +1 -1
  370. package/dist/testing/TestSchema.d.ts +10 -10
  371. package/dist/testing/TestSchema.d.ts.map +1 -1
  372. package/dist/testing/TestSchema.js +9 -9
  373. package/dist/testing/TestSchema.js.map +1 -1
  374. package/dist/unstable/ai/AiError.d.ts +4 -2
  375. package/dist/unstable/ai/AiError.d.ts.map +1 -1
  376. package/dist/unstable/ai/AiError.js +4 -2
  377. package/dist/unstable/ai/AiError.js.map +1 -1
  378. package/dist/unstable/ai/AnthropicStructuredOutput.d.ts +17 -20
  379. package/dist/unstable/ai/AnthropicStructuredOutput.d.ts.map +1 -1
  380. package/dist/unstable/ai/AnthropicStructuredOutput.js +36 -39
  381. package/dist/unstable/ai/AnthropicStructuredOutput.js.map +1 -1
  382. package/dist/unstable/ai/Chat.d.ts +4 -5
  383. package/dist/unstable/ai/Chat.d.ts.map +1 -1
  384. package/dist/unstable/ai/Chat.js +4 -5
  385. package/dist/unstable/ai/Chat.js.map +1 -1
  386. package/dist/unstable/ai/EmbeddingModel.d.ts +4 -4
  387. package/dist/unstable/ai/EmbeddingModel.js +4 -4
  388. package/dist/unstable/ai/IdGenerator.d.ts +2 -3
  389. package/dist/unstable/ai/IdGenerator.d.ts.map +1 -1
  390. package/dist/unstable/ai/IdGenerator.js +2 -3
  391. package/dist/unstable/ai/IdGenerator.js.map +1 -1
  392. package/dist/unstable/ai/LanguageModel.d.ts +3 -2
  393. package/dist/unstable/ai/LanguageModel.d.ts.map +1 -1
  394. package/dist/unstable/ai/LanguageModel.js +5 -4
  395. package/dist/unstable/ai/LanguageModel.js.map +1 -1
  396. package/dist/unstable/ai/McpSchema.d.ts +14 -12
  397. package/dist/unstable/ai/McpSchema.d.ts.map +1 -1
  398. package/dist/unstable/ai/McpSchema.js +19 -17
  399. package/dist/unstable/ai/McpSchema.js.map +1 -1
  400. package/dist/unstable/ai/McpServer.d.ts +11 -4
  401. package/dist/unstable/ai/McpServer.d.ts.map +1 -1
  402. package/dist/unstable/ai/McpServer.js +8 -5
  403. package/dist/unstable/ai/McpServer.js.map +1 -1
  404. package/dist/unstable/ai/OpenAiStructuredOutput.d.ts +20 -18
  405. package/dist/unstable/ai/OpenAiStructuredOutput.d.ts.map +1 -1
  406. package/dist/unstable/ai/OpenAiStructuredOutput.js +45 -43
  407. package/dist/unstable/ai/OpenAiStructuredOutput.js.map +1 -1
  408. package/dist/unstable/ai/Prompt.d.ts +2 -2
  409. package/dist/unstable/ai/Prompt.js +3 -3
  410. package/dist/unstable/ai/Prompt.js.map +1 -1
  411. package/dist/unstable/ai/ResponseIdTracker.d.ts +3 -2
  412. package/dist/unstable/ai/ResponseIdTracker.d.ts.map +1 -1
  413. package/dist/unstable/ai/ResponseIdTracker.js +3 -2
  414. package/dist/unstable/ai/ResponseIdTracker.js.map +1 -1
  415. package/dist/unstable/ai/Telemetry.d.ts +21 -6
  416. package/dist/unstable/ai/Telemetry.d.ts.map +1 -1
  417. package/dist/unstable/ai/Telemetry.js +7 -2
  418. package/dist/unstable/ai/Telemetry.js.map +1 -1
  419. package/dist/unstable/ai/Tool.d.ts +7 -6
  420. package/dist/unstable/ai/Tool.d.ts.map +1 -1
  421. package/dist/unstable/ai/Tool.js +8 -7
  422. package/dist/unstable/ai/Tool.js.map +1 -1
  423. package/dist/unstable/ai/Toolkit.d.ts +2 -2
  424. package/dist/unstable/ai/Toolkit.js +2 -2
  425. package/dist/unstable/cli/Command.d.ts +37 -16
  426. package/dist/unstable/cli/Command.d.ts.map +1 -1
  427. package/dist/unstable/cli/Command.js +15 -8
  428. package/dist/unstable/cli/Command.js.map +1 -1
  429. package/dist/unstable/cli/Completions.d.ts +1 -1
  430. package/dist/unstable/cli/Completions.js +1 -1
  431. package/dist/unstable/cli/Flag.d.ts +7 -6
  432. package/dist/unstable/cli/Flag.d.ts.map +1 -1
  433. package/dist/unstable/cli/Flag.js +7 -6
  434. package/dist/unstable/cli/Flag.js.map +1 -1
  435. package/dist/unstable/cli/GlobalFlag.d.ts +6 -1
  436. package/dist/unstable/cli/GlobalFlag.d.ts.map +1 -1
  437. package/dist/unstable/cli/GlobalFlag.js +7 -2
  438. package/dist/unstable/cli/GlobalFlag.js.map +1 -1
  439. package/dist/unstable/cli/Param.d.ts +3 -3
  440. package/dist/unstable/cli/Param.d.ts.map +1 -1
  441. package/dist/unstable/cli/Param.js +13 -10
  442. package/dist/unstable/cli/Param.js.map +1 -1
  443. package/dist/unstable/cli/Primitive.d.ts +3 -2
  444. package/dist/unstable/cli/Primitive.d.ts.map +1 -1
  445. package/dist/unstable/cli/Primitive.js +3 -2
  446. package/dist/unstable/cli/Primitive.js.map +1 -1
  447. package/dist/unstable/cluster/ClusterCron.d.ts +1 -2
  448. package/dist/unstable/cluster/ClusterCron.d.ts.map +1 -1
  449. package/dist/unstable/cluster/ClusterCron.js.map +1 -1
  450. package/dist/unstable/cluster/ClusterMetrics.d.ts +5 -0
  451. package/dist/unstable/cluster/ClusterMetrics.d.ts.map +1 -1
  452. package/dist/unstable/cluster/ClusterMetrics.js +5 -0
  453. package/dist/unstable/cluster/ClusterMetrics.js.map +1 -1
  454. package/dist/unstable/cluster/ClusterSchema.d.ts +3 -3
  455. package/dist/unstable/cluster/ClusterSchema.js +3 -3
  456. package/dist/unstable/cluster/ClusterWorkflowEngine.js +15 -15
  457. package/dist/unstable/cluster/ClusterWorkflowEngine.js.map +1 -1
  458. package/dist/unstable/cluster/EntityResource.d.ts +10 -0
  459. package/dist/unstable/cluster/EntityResource.d.ts.map +1 -1
  460. package/dist/unstable/cluster/EntityResource.js +10 -0
  461. package/dist/unstable/cluster/EntityResource.js.map +1 -1
  462. package/dist/unstable/cluster/Envelope.d.ts +2 -2
  463. package/dist/unstable/cluster/Envelope.d.ts.map +1 -1
  464. package/dist/unstable/cluster/Envelope.js +2 -2
  465. package/dist/unstable/cluster/Envelope.js.map +1 -1
  466. package/dist/unstable/cluster/Reply.d.ts +2 -2
  467. package/dist/unstable/cluster/Reply.d.ts.map +1 -1
  468. package/dist/unstable/cluster/Reply.js +12 -12
  469. package/dist/unstable/cluster/Reply.js.map +1 -1
  470. package/dist/unstable/cluster/RunnerHealth.d.ts +2 -1
  471. package/dist/unstable/cluster/RunnerHealth.d.ts.map +1 -1
  472. package/dist/unstable/cluster/RunnerHealth.js +2 -1
  473. package/dist/unstable/cluster/RunnerHealth.js.map +1 -1
  474. package/dist/unstable/cluster/RunnerServer.d.ts +2 -2
  475. package/dist/unstable/cluster/RunnerServer.js +2 -2
  476. package/dist/unstable/cluster/Runners.d.ts +3 -3
  477. package/dist/unstable/cluster/Runners.js +3 -3
  478. package/dist/unstable/cluster/ShardId.js +3 -3
  479. package/dist/unstable/cluster/ShardId.js.map +1 -1
  480. package/dist/unstable/cluster/Sharding.d.ts +3 -3
  481. package/dist/unstable/cluster/Sharding.js +3 -3
  482. package/dist/unstable/cluster/ShardingConfig.d.ts +4 -4
  483. package/dist/unstable/cluster/ShardingConfig.js +4 -4
  484. package/dist/unstable/cluster/Snowflake.d.ts +1 -1
  485. package/dist/unstable/cluster/Snowflake.js +3 -3
  486. package/dist/unstable/cluster/Snowflake.js.map +1 -1
  487. package/dist/unstable/cluster/internal/entityManager.js +2 -2
  488. package/dist/unstable/cluster/internal/entityManager.js.map +1 -1
  489. package/dist/unstable/encoding/Msgpack.d.ts +2 -2
  490. package/dist/unstable/encoding/Msgpack.d.ts.map +1 -1
  491. package/dist/unstable/encoding/Msgpack.js +5 -5
  492. package/dist/unstable/encoding/Msgpack.js.map +1 -1
  493. package/dist/unstable/encoding/Ndjson.d.ts +5 -0
  494. package/dist/unstable/encoding/Ndjson.d.ts.map +1 -1
  495. package/dist/unstable/encoding/Ndjson.js +5 -0
  496. package/dist/unstable/encoding/Ndjson.js.map +1 -1
  497. package/dist/unstable/encoding/Sse.d.ts +2 -2
  498. package/dist/unstable/encoding/Sse.d.ts.map +1 -1
  499. package/dist/unstable/encoding/Sse.js +2 -2
  500. package/dist/unstable/encoding/Sse.js.map +1 -1
  501. package/dist/unstable/eventlog/EventGroup.d.ts +2 -1
  502. package/dist/unstable/eventlog/EventGroup.d.ts.map +1 -1
  503. package/dist/unstable/eventlog/EventGroup.js +2 -1
  504. package/dist/unstable/eventlog/EventGroup.js.map +1 -1
  505. package/dist/unstable/eventlog/EventJournal.d.ts +10 -0
  506. package/dist/unstable/eventlog/EventJournal.d.ts.map +1 -1
  507. package/dist/unstable/eventlog/EventJournal.js +10 -0
  508. package/dist/unstable/eventlog/EventJournal.js.map +1 -1
  509. package/dist/unstable/eventlog/EventLog.d.ts +3 -3
  510. package/dist/unstable/eventlog/EventLog.js +3 -3
  511. package/dist/unstable/eventlog/EventLogServerEncrypted.d.ts +2 -3
  512. package/dist/unstable/eventlog/EventLogServerEncrypted.d.ts.map +1 -1
  513. package/dist/unstable/eventlog/EventLogServerEncrypted.js +2 -3
  514. package/dist/unstable/eventlog/EventLogServerEncrypted.js.map +1 -1
  515. package/dist/unstable/eventlog/EventLogServerUnencrypted.d.ts +5 -7
  516. package/dist/unstable/eventlog/EventLogServerUnencrypted.d.ts.map +1 -1
  517. package/dist/unstable/eventlog/EventLogServerUnencrypted.js +5 -7
  518. package/dist/unstable/eventlog/EventLogServerUnencrypted.js.map +1 -1
  519. package/dist/unstable/eventlog/EventLogSessionAuth.d.ts +4 -4
  520. package/dist/unstable/eventlog/EventLogSessionAuth.js +4 -4
  521. package/dist/unstable/http/Cookies.js +4 -4
  522. package/dist/unstable/http/Cookies.js.map +1 -1
  523. package/dist/unstable/http/Etag.d.ts +2 -3
  524. package/dist/unstable/http/Etag.d.ts.map +1 -1
  525. package/dist/unstable/http/Etag.js +2 -3
  526. package/dist/unstable/http/Etag.js.map +1 -1
  527. package/dist/unstable/http/Headers.js +2 -2
  528. package/dist/unstable/http/Headers.js.map +1 -1
  529. package/dist/unstable/http/HttpBody.js +2 -2
  530. package/dist/unstable/http/HttpBody.js.map +1 -1
  531. package/dist/unstable/http/HttpClient.d.ts +2 -2
  532. package/dist/unstable/http/HttpClient.js +2 -2
  533. package/dist/unstable/http/HttpClientRequest.d.ts +30 -3
  534. package/dist/unstable/http/HttpClientRequest.d.ts.map +1 -1
  535. package/dist/unstable/http/HttpClientRequest.js +10 -1
  536. package/dist/unstable/http/HttpClientRequest.js.map +1 -1
  537. package/dist/unstable/http/HttpRouter.d.ts +1 -1
  538. package/dist/unstable/http/HttpRouter.js +1 -1
  539. package/dist/unstable/http/HttpServerResponse.d.ts +25 -20
  540. package/dist/unstable/http/HttpServerResponse.d.ts.map +1 -1
  541. package/dist/unstable/http/HttpServerResponse.js +13 -8
  542. package/dist/unstable/http/HttpServerResponse.js.map +1 -1
  543. package/dist/unstable/http/Multipart.js +3 -3
  544. package/dist/unstable/http/Multipart.js.map +1 -1
  545. package/dist/unstable/http/UrlParams.d.ts +30 -0
  546. package/dist/unstable/http/UrlParams.d.ts.map +1 -1
  547. package/dist/unstable/http/UrlParams.js +16 -6
  548. package/dist/unstable/http/UrlParams.js.map +1 -1
  549. package/dist/unstable/httpapi/HttpApi.d.ts +3 -2
  550. package/dist/unstable/httpapi/HttpApi.d.ts.map +1 -1
  551. package/dist/unstable/httpapi/HttpApi.js +3 -2
  552. package/dist/unstable/httpapi/HttpApi.js.map +1 -1
  553. package/dist/unstable/httpapi/HttpApiBuilder.d.ts.map +1 -1
  554. package/dist/unstable/httpapi/HttpApiBuilder.js +10 -8
  555. package/dist/unstable/httpapi/HttpApiBuilder.js.map +1 -1
  556. package/dist/unstable/httpapi/HttpApiClient.js +15 -15
  557. package/dist/unstable/httpapi/HttpApiClient.js.map +1 -1
  558. package/dist/unstable/httpapi/HttpApiMiddleware.d.ts +3 -3
  559. package/dist/unstable/httpapi/HttpApiMiddleware.js +3 -3
  560. package/dist/unstable/httpapi/HttpApiSchema.d.ts +2 -2
  561. package/dist/unstable/httpapi/HttpApiSchema.d.ts.map +1 -1
  562. package/dist/unstable/httpapi/HttpApiSchema.js +9 -9
  563. package/dist/unstable/httpapi/HttpApiSchema.js.map +1 -1
  564. package/dist/unstable/httpapi/OpenApi.js +11 -11
  565. package/dist/unstable/httpapi/OpenApi.js.map +1 -1
  566. package/dist/unstable/observability/OtlpResource.d.ts +5 -0
  567. package/dist/unstable/observability/OtlpResource.d.ts.map +1 -1
  568. package/dist/unstable/observability/OtlpResource.js +5 -0
  569. package/dist/unstable/observability/OtlpResource.js.map +1 -1
  570. package/dist/unstable/observability/PrometheusMetrics.d.ts +4 -2
  571. package/dist/unstable/observability/PrometheusMetrics.d.ts.map +1 -1
  572. package/dist/unstable/observability/PrometheusMetrics.js +4 -2
  573. package/dist/unstable/observability/PrometheusMetrics.js.map +1 -1
  574. package/dist/unstable/reactivity/Atom.d.ts +3 -3
  575. package/dist/unstable/reactivity/Atom.js +3 -3
  576. package/dist/unstable/rpc/RpcSchema.d.ts +2 -2
  577. package/dist/unstable/rpc/RpcSchema.d.ts.map +1 -1
  578. package/dist/unstable/rpc/RpcSerialization.d.ts +2 -2
  579. package/dist/unstable/rpc/RpcSerialization.js +2 -2
  580. package/dist/unstable/schema/Model.js +5 -5
  581. package/dist/unstable/schema/Model.js.map +1 -1
  582. package/dist/unstable/schema/VariantSchema.d.ts +2 -2
  583. package/dist/unstable/schema/VariantSchema.d.ts.map +1 -1
  584. package/dist/unstable/sql/SqlSchema.d.ts +4 -4
  585. package/dist/unstable/sql/SqlSchema.js +4 -4
  586. package/dist/unstable/workers/Transferable.d.ts +2 -2
  587. package/dist/unstable/workers/Transferable.d.ts.map +1 -1
  588. package/dist/unstable/workers/Transferable.js +5 -5
  589. package/dist/unstable/workers/Transferable.js.map +1 -1
  590. package/dist/unstable/workflow/DurableDeferred.js +7 -7
  591. package/dist/unstable/workflow/DurableDeferred.js.map +1 -1
  592. package/dist/unstable/workflow/DurableQueue.d.ts +1 -2
  593. package/dist/unstable/workflow/DurableQueue.d.ts.map +1 -1
  594. package/dist/unstable/workflow/DurableQueue.js +1 -2
  595. package/dist/unstable/workflow/DurableQueue.js.map +1 -1
  596. package/dist/unstable/workflow/Workflow.d.ts +35 -15
  597. package/dist/unstable/workflow/Workflow.d.ts.map +1 -1
  598. package/dist/unstable/workflow/Workflow.js +94 -72
  599. package/dist/unstable/workflow/Workflow.js.map +1 -1
  600. package/dist/unstable/workflow/WorkflowEngine.d.ts +10 -2
  601. package/dist/unstable/workflow/WorkflowEngine.d.ts.map +1 -1
  602. package/dist/unstable/workflow/WorkflowEngine.js +16 -8
  603. package/dist/unstable/workflow/WorkflowEngine.js.map +1 -1
  604. package/dist/unstable/workflow/WorkflowProxy.d.ts +2 -4
  605. package/dist/unstable/workflow/WorkflowProxy.d.ts.map +1 -1
  606. package/dist/unstable/workflow/WorkflowProxy.js +9 -11
  607. package/dist/unstable/workflow/WorkflowProxy.js.map +1 -1
  608. package/dist/unstable/workflow/WorkflowProxyServer.js +7 -7
  609. package/dist/unstable/workflow/WorkflowProxyServer.js.map +1 -1
  610. package/package.json +1 -1
  611. package/src/Array.ts +729 -611
  612. package/src/BigDecimal.ts +37 -30
  613. package/src/BigInt.ts +34 -40
  614. package/src/Boolean.ts +8 -8
  615. package/src/Brand.ts +16 -14
  616. package/src/Cause.ts +21 -23
  617. package/src/Channel.ts +249 -9
  618. package/src/ChannelSchema.ts +11 -11
  619. package/src/Chunk.ts +69 -16
  620. package/src/Clock.ts +3 -3
  621. package/src/Combiner.ts +9 -13
  622. package/src/Config.ts +60 -67
  623. package/src/ConfigProvider.ts +34 -44
  624. package/src/Console.ts +2 -2
  625. package/src/Context.ts +60 -72
  626. package/src/Cron.ts +2 -2
  627. package/src/Crypto.ts +4 -4
  628. package/src/Data.ts +21 -15
  629. package/src/DateTime.ts +35 -16
  630. package/src/Deferred.ts +24 -15
  631. package/src/Duration.ts +44 -31
  632. package/src/Effect.ts +516 -416
  633. package/src/Encoding.ts +5 -0
  634. package/src/Equal.ts +26 -39
  635. package/src/Equivalence.ts +71 -99
  636. package/src/ErrorReporter.ts +1 -1
  637. package/src/Exit.ts +79 -96
  638. package/src/Fiber.ts +8 -6
  639. package/src/FiberHandle.ts +25 -0
  640. package/src/FiberMap.ts +35 -0
  641. package/src/FiberSet.ts +20 -0
  642. package/src/Filter.ts +4 -4
  643. package/src/Formatter.ts +14 -19
  644. package/src/Function.ts +15 -16
  645. package/src/Graph.ts +2 -2
  646. package/src/HKT.ts +2 -2
  647. package/src/Hash.ts +2 -1
  648. package/src/HashMap.ts +15 -0
  649. package/src/HashRing.ts +9 -9
  650. package/src/Iterable.ts +24 -12
  651. package/src/JsonPatch.ts +2 -3
  652. package/src/JsonPointer.ts +2 -6
  653. package/src/JsonSchema.ts +17 -13
  654. package/src/Latch.ts +4 -3
  655. package/src/Layer.ts +92 -114
  656. package/src/Logger.ts +15 -18
  657. package/src/Match.ts +2 -2
  658. package/src/Metric.ts +109 -137
  659. package/src/MutableHashMap.ts +35 -20
  660. package/src/MutableList.ts +15 -0
  661. package/src/MutableRef.ts +56 -42
  662. package/src/Newtype.ts +10 -7
  663. package/src/Number.ts +23 -11
  664. package/src/Optic.ts +25 -22
  665. package/src/Option.ts +196 -168
  666. package/src/Order.ts +118 -179
  667. package/src/PartitionedSemaphore.ts +14 -14
  668. package/src/Path.ts +2 -2
  669. package/src/Pipeable.ts +2 -2
  670. package/src/PlatformError.ts +4 -4
  671. package/src/Pool.ts +7 -11
  672. package/src/Predicate.ts +274 -263
  673. package/src/PubSub.ts +24 -14
  674. package/src/Pull.ts +4 -4
  675. package/src/Queue.ts +46 -7
  676. package/src/RcRef.ts +0 -4
  677. package/src/Redactable.ts +2 -2
  678. package/src/Redacted.ts +3 -3
  679. package/src/Reducer.ts +2 -3
  680. package/src/Ref.ts +43 -40
  681. package/src/References.ts +4 -4
  682. package/src/Request.ts +18 -18
  683. package/src/Resource.ts +2 -2
  684. package/src/Result.ts +87 -33
  685. package/src/Runtime.ts +11 -8
  686. package/src/Schedule.ts +112 -45
  687. package/src/Scheduler.ts +6 -4
  688. package/src/Schema.ts +843 -649
  689. package/src/SchemaAST.ts +148 -117
  690. package/src/SchemaGetter.ts +142 -121
  691. package/src/SchemaIssue.ts +39 -41
  692. package/src/SchemaParser.ts +173 -229
  693. package/src/SchemaRepresentation.ts +38 -28
  694. package/src/SchemaTransformation.ts +233 -207
  695. package/src/SchemaUtils.ts +2 -2
  696. package/src/Scope.ts +15 -0
  697. package/src/ScopedCache.ts +1 -1
  698. package/src/ScopedRef.ts +14 -18
  699. package/src/Semaphore.ts +9 -9
  700. package/src/Sink.ts +13 -13
  701. package/src/Stdio.ts +4 -5
  702. package/src/Stream.ts +354 -57
  703. package/src/String.ts +6 -9
  704. package/src/Struct.ts +15 -13
  705. package/src/SubscriptionRef.ts +24 -19
  706. package/src/SynchronizedRef.ts +88 -63
  707. package/src/Tracer.ts +4 -4
  708. package/src/Trie.ts +15 -0
  709. package/src/Tuple.ts +25 -19
  710. package/src/TxReentrantLock.ts +6 -3
  711. package/src/TxRef.ts +16 -16
  712. package/src/TxSubscriptionRef.ts +43 -27
  713. package/src/Types.ts +12 -39
  714. package/src/UndefinedOr.ts +15 -14
  715. package/src/Unify.ts +2 -2
  716. package/src/internal/schema/annotations.ts +4 -4
  717. package/src/internal/schema/arbitrary.ts +16 -16
  718. package/src/internal/schema/equivalence.ts +11 -11
  719. package/src/internal/schema/representation.ts +23 -23
  720. package/src/internal/schema/schema.ts +17 -17
  721. package/src/testing/TestSchema.ts +20 -20
  722. package/src/unstable/ai/AiError.ts +4 -2
  723. package/src/unstable/ai/AnthropicStructuredOutput.ts +59 -56
  724. package/src/unstable/ai/Chat.ts +4 -5
  725. package/src/unstable/ai/EmbeddingModel.ts +4 -4
  726. package/src/unstable/ai/IdGenerator.ts +2 -3
  727. package/src/unstable/ai/LanguageModel.ts +5 -4
  728. package/src/unstable/ai/McpSchema.ts +19 -17
  729. package/src/unstable/ai/McpServer.ts +14 -7
  730. package/src/unstable/ai/OpenAiStructuredOutput.ts +72 -61
  731. package/src/unstable/ai/Prompt.ts +5 -5
  732. package/src/unstable/ai/ResponseIdTracker.ts +3 -2
  733. package/src/unstable/ai/Telemetry.ts +21 -6
  734. package/src/unstable/ai/Tool.ts +11 -10
  735. package/src/unstable/ai/Toolkit.ts +2 -2
  736. package/src/unstable/cli/Command.ts +37 -16
  737. package/src/unstable/cli/Completions.ts +1 -1
  738. package/src/unstable/cli/Flag.ts +7 -6
  739. package/src/unstable/cli/GlobalFlag.ts +7 -1
  740. package/src/unstable/cli/Param.ts +23 -18
  741. package/src/unstable/cli/Primitive.ts +3 -2
  742. package/src/unstable/cluster/ClusterCron.ts +1 -2
  743. package/src/unstable/cluster/ClusterMetrics.ts +5 -0
  744. package/src/unstable/cluster/ClusterSchema.ts +3 -3
  745. package/src/unstable/cluster/ClusterWorkflowEngine.ts +15 -15
  746. package/src/unstable/cluster/EntityResource.ts +10 -0
  747. package/src/unstable/cluster/Envelope.ts +3 -3
  748. package/src/unstable/cluster/Reply.ts +14 -12
  749. package/src/unstable/cluster/RunnerHealth.ts +2 -1
  750. package/src/unstable/cluster/RunnerServer.ts +2 -2
  751. package/src/unstable/cluster/Runners.ts +3 -3
  752. package/src/unstable/cluster/ShardId.ts +3 -3
  753. package/src/unstable/cluster/Sharding.ts +3 -3
  754. package/src/unstable/cluster/ShardingConfig.ts +4 -4
  755. package/src/unstable/cluster/Snowflake.ts +3 -3
  756. package/src/unstable/cluster/internal/entityManager.ts +2 -2
  757. package/src/unstable/encoding/Msgpack.ts +6 -6
  758. package/src/unstable/encoding/Ndjson.ts +5 -0
  759. package/src/unstable/encoding/Sse.ts +2 -2
  760. package/src/unstable/eventlog/EventGroup.ts +2 -1
  761. package/src/unstable/eventlog/EventJournal.ts +10 -0
  762. package/src/unstable/eventlog/EventLog.ts +3 -3
  763. package/src/unstable/eventlog/EventLogServerEncrypted.ts +2 -3
  764. package/src/unstable/eventlog/EventLogServerUnencrypted.ts +5 -7
  765. package/src/unstable/eventlog/EventLogSessionAuth.ts +4 -4
  766. package/src/unstable/http/Cookies.ts +4 -4
  767. package/src/unstable/http/Etag.ts +2 -3
  768. package/src/unstable/http/Headers.ts +2 -2
  769. package/src/unstable/http/HttpBody.ts +2 -2
  770. package/src/unstable/http/HttpClient.ts +2 -2
  771. package/src/unstable/http/HttpClientRequest.ts +30 -3
  772. package/src/unstable/http/HttpRouter.ts +1 -1
  773. package/src/unstable/http/HttpServerResponse.ts +25 -20
  774. package/src/unstable/http/Multipart.ts +3 -3
  775. package/src/unstable/http/UrlParams.ts +36 -6
  776. package/src/unstable/httpapi/HttpApi.ts +5 -4
  777. package/src/unstable/httpapi/HttpApiBuilder.ts +14 -13
  778. package/src/unstable/httpapi/HttpApiClient.ts +16 -16
  779. package/src/unstable/httpapi/HttpApiMiddleware.ts +3 -3
  780. package/src/unstable/httpapi/HttpApiSchema.ts +15 -15
  781. package/src/unstable/httpapi/OpenApi.ts +18 -18
  782. package/src/unstable/observability/OtlpResource.ts +5 -0
  783. package/src/unstable/observability/PrometheusMetrics.ts +4 -2
  784. package/src/unstable/reactivity/Atom.ts +3 -3
  785. package/src/unstable/rpc/RpcSchema.ts +2 -2
  786. package/src/unstable/rpc/RpcSerialization.ts +2 -2
  787. package/src/unstable/schema/Model.ts +5 -5
  788. package/src/unstable/schema/VariantSchema.ts +2 -2
  789. package/src/unstable/sql/SqlSchema.ts +4 -4
  790. package/src/unstable/workers/Transferable.ts +6 -6
  791. package/src/unstable/workflow/DurableDeferred.ts +7 -7
  792. package/src/unstable/workflow/DurableQueue.ts +1 -2
  793. package/src/unstable/workflow/Workflow.ts +159 -114
  794. package/src/unstable/workflow/WorkflowEngine.ts +16 -8
  795. package/src/unstable/workflow/WorkflowProxy.ts +9 -11
  796. package/src/unstable/workflow/WorkflowProxyServer.ts +7 -7
@@ -5,9 +5,7 @@ import * as Reducer from "./Reducer.ts";
5
5
  *
6
6
  * **When to use**
7
7
  *
8
- * Use as a type annotation for equivalence functions
9
- * - Use when implementing custom equivalence logic
10
- * - Use when working with collection operations that require equivalence relations
8
+ * Use as a type annotation when you accept or return an equivalence function.
11
9
  *
12
10
  * **Details**
13
11
  *
@@ -52,9 +50,7 @@ export type Equivalence<in A> = (self: A, that: A) => boolean;
52
50
  *
53
51
  * **When to use**
54
52
  *
55
- * Use when rarely needed in application code
56
- * - Use primarily for internal type system operations and HKT (Higher-Kinded Types) abstractions
57
- * - Use when working with generic type constructors that require type lambdas
53
+ * Use when you need to abstract over `Equivalence` in higher-kinded type code.
58
54
  *
59
55
  * **Details**
60
56
  *
@@ -90,15 +86,15 @@ export interface EquivalenceTypeLambda extends TypeLambda {
90
86
  *
91
87
  * **When to use**
92
88
  *
93
- * Use when you need a custom equivalence that is not just strict equality
94
- * - Use when creating equivalences for complex types with custom comparison logic
95
- * - Use when you want the performance benefit of reference equality optimization
89
+ * Use when you need an equality rule that the built-in instances and input
90
+ * mapping helpers cannot express, and you can provide a law-abiding comparison.
96
91
  *
97
92
  * **Details**
98
93
  *
99
- * - First checks reference equality (`===`) for performance; if values are identical, returns `true` without calling the function
100
- * - Falls back to the provided equivalence function if values are not the same reference
101
- * - The provided function must satisfy reflexive, symmetric, and transitive properties
94
+ * The returned equivalence first checks reference equality (`===`) for
95
+ * performance. If the values are not the same reference, it falls back to the
96
+ * provided equivalence function, which must satisfy reflexive, symmetric, and
97
+ * transitive properties.
102
98
  *
103
99
  * **Example** (Case-insensitive string equivalence)
104
100
  *
@@ -139,16 +135,14 @@ export declare const make: <A>(isEquivalent: (self: A, that: A) => boolean) => E
139
135
  *
140
136
  * **When to use**
141
137
  *
142
- * Use when you need primitive types where `===` is appropriate
143
- * - Use when you need reference equality for objects
144
- * - Use as a building block for more complex equivalences via {@link mapInput} or {@link combine}
145
- * - Use when performance is critical and you do not need structural equality
138
+ * Use when you need strict equality (`===`) as the comparison.
146
139
  *
147
140
  * **Details**
148
141
  *
149
- * - Uses JavaScript's strict equality operator (`===`)
150
- * - For primitives: compares values directly
151
- * - For objects: compares by reference, so only the same object instance is equivalent
142
+ * Uses JavaScript's strict equality operator (`===`). Primitives compare by
143
+ * value. Objects compare by reference, so only the same object instance is
144
+ * equivalent. Use this as a building block for more complex equivalences via
145
+ * `mapInput` or `combine`.
152
146
  *
153
147
  * **Gotchas**
154
148
  *
@@ -189,7 +183,7 @@ export declare const strictEqual: <A>() => Equivalence<A>;
189
183
  *
190
184
  * **When to use**
191
185
  *
192
- * Use when an API needs an `Equivalence` instance for string equality.
186
+ * Use when you need to supply case-sensitive string equality.
193
187
  *
194
188
  * **Example** (Comparing strings)
195
189
  *
@@ -209,12 +203,7 @@ export declare const String: Equivalence<string>;
209
203
  *
210
204
  * **When to use**
211
205
  *
212
- * Use when an API needs an `Equivalence` instance for numeric equality where
213
- * `NaN` equals `NaN`.
214
- *
215
- * **Details**
216
- *
217
- * `NaN` is considered equal to `NaN`.
206
+ * Use when you need numeric equality that treats NaN as equal to itself.
218
207
  *
219
208
  * **Example** (Comparing numbers)
220
209
  *
@@ -235,7 +224,7 @@ export declare const Number: Equivalence<number>;
235
224
  *
236
225
  * **When to use**
237
226
  *
238
- * Use when an API needs an `Equivalence` instance for boolean equality.
227
+ * Use when you need to supply boolean equality.
239
228
  *
240
229
  * **Example** (Comparing booleans)
241
230
  *
@@ -255,7 +244,7 @@ export declare const Boolean: Equivalence<boolean>;
255
244
  *
256
245
  * **When to use**
257
246
  *
258
- * Use when an API needs an `Equivalence` instance for `bigint` equality.
247
+ * Use when you need to supply bigint equality.
259
248
  *
260
249
  * **Example** (Comparing bigints)
261
250
  *
@@ -275,15 +264,14 @@ export declare const BigInt: Equivalence<bigint>;
275
264
  *
276
265
  * **When to use**
277
266
  *
278
- * Use when you need to combine exactly two equivalences
279
- * - Use when building complex equivalences from simpler ones
280
- * - Use when you want both conditions to be satisfied
267
+ * Use when you need to combine exactly two equivalences with AND semantics.
281
268
  *
282
269
  * **Details**
283
270
  *
284
- * - Returns `true` only if both equivalences return `true`
285
- * - Short-circuits: if the first equivalence returns `false`, the second is not called
286
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
271
+ * Returns `true` only if both equivalences return `true`. The comparison
272
+ * short-circuits when the first equivalence returns `false`. The result is also
273
+ * an equivalence that satisfies reflexive, symmetric, and transitive
274
+ * properties.
287
275
  *
288
276
  * **Example** (Combining name and age equivalences)
289
277
  *
@@ -326,15 +314,14 @@ export declare const combine: {
326
314
  *
327
315
  * **When to use**
328
316
  *
329
- * Use when you need to combine exactly two equivalences
330
- * - Use when building complex equivalences from simpler ones
331
- * - Use when you want both conditions to be satisfied
317
+ * Use when you need to combine exactly two equivalences with AND semantics.
332
318
  *
333
319
  * **Details**
334
320
  *
335
- * - Returns `true` only if both equivalences return `true`
336
- * - Short-circuits: if the first equivalence returns `false`, the second is not called
337
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
321
+ * Returns `true` only if both equivalences return `true`. The comparison
322
+ * short-circuits when the first equivalence returns `false`. The result is also
323
+ * an equivalence that satisfies reflexive, symmetric, and transitive
324
+ * properties.
338
325
  *
339
326
  * **Example** (Combining name and age equivalences)
340
327
  *
@@ -377,15 +364,14 @@ export declare const combine: {
377
364
  *
378
365
  * **When to use**
379
366
  *
380
- * Use when you need to combine exactly two equivalences
381
- * - Use when building complex equivalences from simpler ones
382
- * - Use when you want both conditions to be satisfied
367
+ * Use when you need to combine exactly two equivalences with AND semantics.
383
368
  *
384
369
  * **Details**
385
370
  *
386
- * - Returns `true` only if both equivalences return `true`
387
- * - Short-circuits: if the first equivalence returns `false`, the second is not called
388
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
371
+ * Returns `true` only if both equivalences return `true`. The comparison
372
+ * short-circuits when the first equivalence returns `false`. The result is also
373
+ * an equivalence that satisfies reflexive, symmetric, and transitive
374
+ * properties.
389
375
  *
390
376
  * **Example** (Combining name and age equivalences)
391
377
  *
@@ -429,17 +415,15 @@ export declare const combine: {
429
415
  *
430
416
  * **When to use**
431
417
  *
432
- * Use when you need to combine three or more equivalences
433
- * - Use when you have a dynamic collection of equivalences to combine
434
- * - Use when building equivalences from arrays or iterables
435
- * - Prefer this over multiple `combine` calls when you have many equivalences
418
+ * Use when you need to combine many `Equivalence` instances from an iterable.
436
419
  *
437
420
  * **Details**
438
421
  *
439
- * - Returns `true` only if all equivalences in the collection return `true`
440
- * - Short-circuits: stops at the first equivalence that returns `false`
441
- * - Empty collections return an equivalence that always returns `true`
442
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
422
+ * Returns `true` only if all equivalences in the collection return `true`. The
423
+ * comparison stops at the first equivalence that returns `false`. Empty
424
+ * collections return an equivalence that always returns `true`. The result is
425
+ * also an equivalence that satisfies reflexive, symmetric, and transitive
426
+ * properties.
443
427
  *
444
428
  * **Example** (Combining multiple field equivalences)
445
429
  *
@@ -496,10 +480,7 @@ export declare const combineAll: <A>(collection: Iterable<Equivalence<A>>) => Eq
496
480
  *
497
481
  * **When to use**
498
482
  *
499
- * Use when you need an equivalence for a complex type based on a single property
500
- * - Use when you want to normalize values before comparison, such as case-insensitive strings
501
- * - Use when creating equivalences that focus on specific fields of objects
502
- * - Use as a building block for creating equivalences via {@link combine} or {@link combineAll}
483
+ * Use when you need an equivalence for one type by comparing a derived value.
503
484
  *
504
485
  * **Details**
505
486
  *
@@ -507,6 +488,8 @@ export declare const combineAll: <A>(collection: Iterable<Equivalence<A>>) => Eq
507
488
  * - The transformation function should be pure and have no side effects
508
489
  * - The resulting equivalence compares the transformed values using the provided equivalence
509
490
  * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
491
+ * - Useful for comparing by one property or normalizing values before
492
+ * comparison, such as case-insensitive strings
510
493
  *
511
494
  * **Example** (Equivalence based on object property)
512
495
  *
@@ -558,10 +541,7 @@ export declare const mapInput: {
558
541
  *
559
542
  * **When to use**
560
543
  *
561
- * Use when you need an equivalence for a complex type based on a single property
562
- * - Use when you want to normalize values before comparison, such as case-insensitive strings
563
- * - Use when creating equivalences that focus on specific fields of objects
564
- * - Use as a building block for creating equivalences via {@link combine} or {@link combineAll}
544
+ * Use when you need an equivalence for one type by comparing a derived value.
565
545
  *
566
546
  * **Details**
567
547
  *
@@ -569,6 +549,8 @@ export declare const mapInput: {
569
549
  * - The transformation function should be pure and have no side effects
570
550
  * - The resulting equivalence compares the transformed values using the provided equivalence
571
551
  * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
552
+ * - Useful for comparing by one property or normalizing values before
553
+ * comparison, such as case-insensitive strings
572
554
  *
573
555
  * **Example** (Equivalence based on object property)
574
556
  *
@@ -620,10 +602,7 @@ export declare const mapInput: {
620
602
  *
621
603
  * **When to use**
622
604
  *
623
- * Use when you need an equivalence for a complex type based on a single property
624
- * - Use when you want to normalize values before comparison, such as case-insensitive strings
625
- * - Use when creating equivalences that focus on specific fields of objects
626
- * - Use as a building block for creating equivalences via {@link combine} or {@link combineAll}
605
+ * Use when you need an equivalence for one type by comparing a derived value.
627
606
  *
628
607
  * **Details**
629
608
  *
@@ -631,6 +610,8 @@ export declare const mapInput: {
631
610
  * - The transformation function should be pure and have no side effects
632
611
  * - The resulting equivalence compares the transformed values using the provided equivalence
633
612
  * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
613
+ * - Useful for comparing by one property or normalizing values before
614
+ * comparison, such as case-insensitive strings
634
615
  *
635
616
  * **Example** (Equivalence based on object property)
636
617
  *
@@ -683,17 +664,16 @@ export declare const mapInput: {
683
664
  *
684
665
  * **When to use**
685
666
  *
686
- * Use when comparing tuples with different types at each position
687
- * - Use when you need different equivalence logic for each tuple element
688
- * - Use when working with fixed-length tuples instead of arrays
689
- * - Prefer this over `Array` when you have a known tuple structure with different types
667
+ * Use when you need an `Equivalence` for fixed-length tuples with per-position
668
+ * equivalences.
690
669
  *
691
670
  * **Details**
692
671
  *
693
- * - Requires tuples to have the same length; different lengths are never equivalent
694
- * - Applies each equivalence to the corresponding element position
695
- * - Returns `true` only if all elements are equivalent according to their respective equivalences
696
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
672
+ * Tuples must have the same length; different lengths are never equivalent.
673
+ * Each equivalence is applied to the corresponding element position. The result
674
+ * returns `true` only if all elements are equivalent according to their
675
+ * respective equivalences, and it also satisfies reflexive, symmetric, and
676
+ * transitive properties.
697
677
  *
698
678
  * **Example** (Homogeneous tuple equivalence)
699
679
  *
@@ -751,10 +731,7 @@ export {
751
731
  *
752
732
  * **When to use**
753
733
  *
754
- * Use when comparing arrays with homogeneous element types
755
- * - Use when all elements should use the same equivalence logic
756
- * - Use when working with variable-length arrays instead of fixed tuples
757
- * - Prefer this over `Tuple` when you have arrays of the same type
734
+ * Use when you need to compare arrays with one equivalence for every element.
758
735
  *
759
736
  * **Details**
760
737
  *
@@ -803,18 +780,16 @@ Array_ as Array };
803
780
  *
804
781
  * **When to use**
805
782
  *
806
- * Use when comparing objects with known, fixed property names
807
- * - Use when you need different equivalence logic for different properties
808
- * - Use when working with struct or interface types with specific fields
809
- * - Prefer this over `Record` when you have a fixed set of known properties
783
+ * Use when you need an `Equivalence` for objects with known, fixed property
784
+ * names.
810
785
  *
811
786
  * **Details**
812
787
  *
813
- * - Compares only the properties specified in the struct definition
814
- * - Properties not in the struct are ignored
815
- * - Returns `true` only if all specified properties are equivalent according to their equivalences
816
- * - Supports both string and symbol keys via `Reflect.ownKeys`
817
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
788
+ * Compares only the properties specified in the struct definition; other
789
+ * properties are ignored. String and symbol keys are supported via
790
+ * `Reflect.ownKeys`. The result returns `true` only if all specified properties
791
+ * are equivalent according to their equivalences, and it also satisfies
792
+ * reflexive, symmetric, and transitive properties.
818
793
  *
819
794
  * **Example** (Struct with different equivalences per field)
820
795
  *
@@ -876,10 +851,8 @@ export declare function Struct<R extends Record<string, Equivalence<any>>>(field
876
851
  *
877
852
  * **When to use**
878
853
  *
879
- * Use when comparing objects with dynamic or unknown property names
880
- * - Use when all property values should use the same equivalence logic
881
- * - Use when working with record or dictionary types
882
- * - Prefer this over `Struct` when you have variable properties or need to compare all properties uniformly
854
+ * Use when you need to compare records with the same equivalence for every
855
+ * property value.
883
856
  *
884
857
  * **Details**
885
858
  *
@@ -931,16 +904,14 @@ export declare function Record<A>(value: Equivalence<A>): Equivalence<Record<Pro
931
904
  *
932
905
  * **When to use**
933
906
  *
934
- * Use when you need to combine multiple equivalences from a collection using reducer patterns
935
- * - Use when implementing fold operations over collections of equivalences
936
- * - Use when working with reducers that operate on equivalences
907
+ * Use when you need a reducer that combines equivalences.
937
908
  *
938
909
  * **Details**
939
910
  *
940
- * - Returns a reducer that combines equivalences using {@link combine}
941
- * - Uses an equivalence that always returns `true` as the identity element for empty collections
942
- * - Uses {@link combineAll} for combining collections of equivalences
943
- * - The reducer can be used with fold operations on collections
911
+ * Returns a reducer that combines equivalences using `combine`. The identity
912
+ * element for empty collections is an equivalence that always returns `true`.
913
+ * The reducer uses `combineAll` for collections of equivalences and can be used
914
+ * with fold operations.
944
915
  *
945
916
  * **Example** (Creating a Reducer)
946
917
  *
@@ -971,7 +942,8 @@ export declare function makeReducer<A>(): Reducer.Reducer<Equivalence<A>>;
971
942
  *
972
943
  * **When to use**
973
944
  *
974
- * Use when comparing `Date` values by their millisecond timestamp.
945
+ * Use when you need an `Equivalence` for JavaScript date objects by their
946
+ * millisecond timestamp.
975
947
  *
976
948
  * **Details**
977
949
  *
@@ -1 +1 @@
1
- {"version":3,"file":"Equivalence.d.ts","sourceRoot":"","sources":["../src/Equivalence.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Equivalence.d.ts","sourceRoot":"","sources":["../src/Equivalence.ts"],"names":[],"mappings":"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"}
@@ -58,15 +58,15 @@ import * as Reducer from "./Reducer.js";
58
58
  *
59
59
  * **When to use**
60
60
  *
61
- * Use when you need a custom equivalence that is not just strict equality
62
- * - Use when creating equivalences for complex types with custom comparison logic
63
- * - Use when you want the performance benefit of reference equality optimization
61
+ * Use when you need an equality rule that the built-in instances and input
62
+ * mapping helpers cannot express, and you can provide a law-abiding comparison.
64
63
  *
65
64
  * **Details**
66
65
  *
67
- * - First checks reference equality (`===`) for performance; if values are identical, returns `true` without calling the function
68
- * - Falls back to the provided equivalence function if values are not the same reference
69
- * - The provided function must satisfy reflexive, symmetric, and transitive properties
66
+ * The returned equivalence first checks reference equality (`===`) for
67
+ * performance. If the values are not the same reference, it falls back to the
68
+ * provided equivalence function, which must satisfy reflexive, symmetric, and
69
+ * transitive properties.
70
70
  *
71
71
  * **Example** (Case-insensitive string equivalence)
72
72
  *
@@ -108,16 +108,14 @@ const isStrictEquivalent = (x, y) => x === y;
108
108
  *
109
109
  * **When to use**
110
110
  *
111
- * Use when you need primitive types where `===` is appropriate
112
- * - Use when you need reference equality for objects
113
- * - Use as a building block for more complex equivalences via {@link mapInput} or {@link combine}
114
- * - Use when performance is critical and you do not need structural equality
111
+ * Use when you need strict equality (`===`) as the comparison.
115
112
  *
116
113
  * **Details**
117
114
  *
118
- * - Uses JavaScript's strict equality operator (`===`)
119
- * - For primitives: compares values directly
120
- * - For objects: compares by reference, so only the same object instance is equivalent
115
+ * Uses JavaScript's strict equality operator (`===`). Primitives compare by
116
+ * value. Objects compare by reference, so only the same object instance is
117
+ * equivalent. Use this as a building block for more complex equivalences via
118
+ * `mapInput` or `combine`.
121
119
  *
122
120
  * **Gotchas**
123
121
  *
@@ -158,7 +156,7 @@ export const strictEqual = () => isStrictEquivalent;
158
156
  *
159
157
  * **When to use**
160
158
  *
161
- * Use when an API needs an `Equivalence` instance for string equality.
159
+ * Use when you need to supply case-sensitive string equality.
162
160
  *
163
161
  * **Example** (Comparing strings)
164
162
  *
@@ -178,12 +176,7 @@ export const String = isStrictEquivalent;
178
176
  *
179
177
  * **When to use**
180
178
  *
181
- * Use when an API needs an `Equivalence` instance for numeric equality where
182
- * `NaN` equals `NaN`.
183
- *
184
- * **Details**
185
- *
186
- * `NaN` is considered equal to `NaN`.
179
+ * Use when you need numeric equality that treats NaN as equal to itself.
187
180
  *
188
181
  * **Example** (Comparing numbers)
189
182
  *
@@ -204,7 +197,7 @@ export const Number = /*#__PURE__*/make((self, that) => globalThis.Number.isNaN(
204
197
  *
205
198
  * **When to use**
206
199
  *
207
- * Use when an API needs an `Equivalence` instance for boolean equality.
200
+ * Use when you need to supply boolean equality.
208
201
  *
209
202
  * **Example** (Comparing booleans)
210
203
  *
@@ -224,7 +217,7 @@ export const Boolean = isStrictEquivalent;
224
217
  *
225
218
  * **When to use**
226
219
  *
227
- * Use when an API needs an `Equivalence` instance for `bigint` equality.
220
+ * Use when you need to supply bigint equality.
228
221
  *
229
222
  * **Example** (Comparing bigints)
230
223
  *
@@ -244,15 +237,14 @@ export const BigInt = isStrictEquivalent;
244
237
  *
245
238
  * **When to use**
246
239
  *
247
- * Use when you need to combine exactly two equivalences
248
- * - Use when building complex equivalences from simpler ones
249
- * - Use when you want both conditions to be satisfied
240
+ * Use when you need to combine exactly two equivalences with AND semantics.
250
241
  *
251
242
  * **Details**
252
243
  *
253
- * - Returns `true` only if both equivalences return `true`
254
- * - Short-circuits: if the first equivalence returns `false`, the second is not called
255
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
244
+ * Returns `true` only if both equivalences return `true`. The comparison
245
+ * short-circuits when the first equivalence returns `false`. The result is also
246
+ * an equivalence that satisfies reflexive, symmetric, and transitive
247
+ * properties.
256
248
  *
257
249
  * **Example** (Combining name and age equivalences)
258
250
  *
@@ -295,17 +287,15 @@ export const combine = /*#__PURE__*/dual(2, (self, that) => make((x, y) => self(
295
287
  *
296
288
  * **When to use**
297
289
  *
298
- * Use when you need to combine three or more equivalences
299
- * - Use when you have a dynamic collection of equivalences to combine
300
- * - Use when building equivalences from arrays or iterables
301
- * - Prefer this over multiple `combine` calls when you have many equivalences
290
+ * Use when you need to combine many `Equivalence` instances from an iterable.
302
291
  *
303
292
  * **Details**
304
293
  *
305
- * - Returns `true` only if all equivalences in the collection return `true`
306
- * - Short-circuits: stops at the first equivalence that returns `false`
307
- * - Empty collections return an equivalence that always returns `true`
308
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
294
+ * Returns `true` only if all equivalences in the collection return `true`. The
295
+ * comparison stops at the first equivalence that returns `false`. Empty
296
+ * collections return an equivalence that always returns `true`. The result is
297
+ * also an equivalence that satisfies reflexive, symmetric, and transitive
298
+ * properties.
309
299
  *
310
300
  * **Example** (Combining multiple field equivalences)
311
301
  *
@@ -369,10 +359,7 @@ export const combineAll = collection => make((x, y) => {
369
359
  *
370
360
  * **When to use**
371
361
  *
372
- * Use when you need an equivalence for a complex type based on a single property
373
- * - Use when you want to normalize values before comparison, such as case-insensitive strings
374
- * - Use when creating equivalences that focus on specific fields of objects
375
- * - Use as a building block for creating equivalences via {@link combine} or {@link combineAll}
362
+ * Use when you need an equivalence for one type by comparing a derived value.
376
363
  *
377
364
  * **Details**
378
365
  *
@@ -380,6 +367,8 @@ export const combineAll = collection => make((x, y) => {
380
367
  * - The transformation function should be pure and have no side effects
381
368
  * - The resulting equivalence compares the transformed values using the provided equivalence
382
369
  * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
370
+ * - Useful for comparing by one property or normalizing values before
371
+ * comparison, such as case-insensitive strings
383
372
  *
384
373
  * **Example** (Equivalence based on object property)
385
374
  *
@@ -431,17 +420,16 @@ export const mapInput = /*#__PURE__*/dual(2, (self, f) => make((x, y) => self(f(
431
420
  *
432
421
  * **When to use**
433
422
  *
434
- * Use when comparing tuples with different types at each position
435
- * - Use when you need different equivalence logic for each tuple element
436
- * - Use when working with fixed-length tuples instead of arrays
437
- * - Prefer this over `Array` when you have a known tuple structure with different types
423
+ * Use when you need an `Equivalence` for fixed-length tuples with per-position
424
+ * equivalences.
438
425
  *
439
426
  * **Details**
440
427
  *
441
- * - Requires tuples to have the same length; different lengths are never equivalent
442
- * - Applies each equivalence to the corresponding element position
443
- * - Returns `true` only if all elements are equivalent according to their respective equivalences
444
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
428
+ * Tuples must have the same length; different lengths are never equivalent.
429
+ * Each equivalence is applied to the corresponding element position. The result
430
+ * returns `true` only if all elements are equivalent according to their
431
+ * respective equivalences, and it also satisfies reflexive, symmetric, and
432
+ * transitive properties.
445
433
  *
446
434
  * **Example** (Homogeneous tuple equivalence)
447
435
  *
@@ -517,10 +505,7 @@ export {
517
505
  *
518
506
  * **When to use**
519
507
  *
520
- * Use when comparing arrays with homogeneous element types
521
- * - Use when all elements should use the same equivalence logic
522
- * - Use when working with variable-length arrays instead of fixed tuples
523
- * - Prefer this over `Tuple` when you have arrays of the same type
508
+ * Use when you need to compare arrays with one equivalence for every element.
524
509
  *
525
510
  * **Details**
526
511
  *
@@ -569,18 +554,16 @@ Array_ as Array };
569
554
  *
570
555
  * **When to use**
571
556
  *
572
- * Use when comparing objects with known, fixed property names
573
- * - Use when you need different equivalence logic for different properties
574
- * - Use when working with struct or interface types with specific fields
575
- * - Prefer this over `Record` when you have a fixed set of known properties
557
+ * Use when you need an `Equivalence` for objects with known, fixed property
558
+ * names.
576
559
  *
577
560
  * **Details**
578
561
  *
579
- * - Compares only the properties specified in the struct definition
580
- * - Properties not in the struct are ignored
581
- * - Returns `true` only if all specified properties are equivalent according to their equivalences
582
- * - Supports both string and symbol keys via `Reflect.ownKeys`
583
- * - The result is also an equivalence that satisfies reflexive, symmetric, and transitive properties
562
+ * Compares only the properties specified in the struct definition; other
563
+ * properties are ignored. String and symbol keys are supported via
564
+ * `Reflect.ownKeys`. The result returns `true` only if all specified properties
565
+ * are equivalent according to their equivalences, and it also satisfies
566
+ * reflexive, symmetric, and transitive properties.
584
567
  *
585
568
  * **Example** (Struct with different equivalences per field)
586
569
  *
@@ -648,10 +631,8 @@ export function Struct(fields) {
648
631
  *
649
632
  * **When to use**
650
633
  *
651
- * Use when comparing objects with dynamic or unknown property names
652
- * - Use when all property values should use the same equivalence logic
653
- * - Use when working with record or dictionary types
654
- * - Prefer this over `Struct` when you have variable properties or need to compare all properties uniformly
634
+ * Use when you need to compare records with the same equivalence for every
635
+ * property value.
655
636
  *
656
637
  * **Details**
657
638
  *
@@ -715,16 +696,14 @@ export function Record(value) {
715
696
  *
716
697
  * **When to use**
717
698
  *
718
- * Use when you need to combine multiple equivalences from a collection using reducer patterns
719
- * - Use when implementing fold operations over collections of equivalences
720
- * - Use when working with reducers that operate on equivalences
699
+ * Use when you need a reducer that combines equivalences.
721
700
  *
722
701
  * **Details**
723
702
  *
724
- * - Returns a reducer that combines equivalences using {@link combine}
725
- * - Uses an equivalence that always returns `true` as the identity element for empty collections
726
- * - Uses {@link combineAll} for combining collections of equivalences
727
- * - The reducer can be used with fold operations on collections
703
+ * Returns a reducer that combines equivalences using `combine`. The identity
704
+ * element for empty collections is an equivalence that always returns `true`.
705
+ * The reducer uses `combineAll` for collections of equivalences and can be used
706
+ * with fold operations.
728
707
  *
729
708
  * **Example** (Creating a Reducer)
730
709
  *
@@ -757,7 +736,8 @@ export function makeReducer() {
757
736
  *
758
737
  * **When to use**
759
738
  *
760
- * Use when comparing `Date` values by their millisecond timestamp.
739
+ * Use when you need an `Equivalence` for JavaScript date objects by their
740
+ * millisecond timestamp.
761
741
  *
762
742
  * **Details**
763
743
  *