@clayroach/effect 3.19.14-source-capture.8 → 3.19.14-source-trace.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (452) hide show
  1. package/SourceLocation/package.json +6 -0
  2. package/dist/cjs/Effect.js +2 -28
  3. package/dist/cjs/Effect.js.map +1 -1
  4. package/dist/cjs/FiberRef.js +12 -1
  5. package/dist/cjs/FiberRef.js.map +1 -1
  6. package/dist/cjs/Layer.js +2 -24
  7. package/dist/cjs/Layer.js.map +1 -1
  8. package/dist/cjs/RuntimeFlags.js +1 -29
  9. package/dist/cjs/RuntimeFlags.js.map +1 -1
  10. package/dist/cjs/SourceLocation.js +60 -0
  11. package/dist/cjs/SourceLocation.js.map +1 -0
  12. package/dist/cjs/Tracer.js +1 -15
  13. package/dist/cjs/Tracer.js.map +1 -1
  14. package/dist/cjs/Utils.js +1 -1
  15. package/dist/cjs/Utils.js.map +1 -1
  16. package/dist/cjs/index.js +3 -1
  17. package/dist/cjs/index.js.map +1 -1
  18. package/dist/cjs/internal/clock.js +1 -1
  19. package/dist/cjs/internal/clock.js.map +1 -1
  20. package/dist/cjs/internal/core.js +17 -50
  21. package/dist/cjs/internal/core.js.map +1 -1
  22. package/dist/cjs/internal/effect/circular.js +18 -30
  23. package/dist/cjs/internal/effect/circular.js.map +1 -1
  24. package/dist/cjs/internal/fiberRuntime.js +16 -65
  25. package/dist/cjs/internal/fiberRuntime.js.map +1 -1
  26. package/dist/cjs/internal/layer/circular.js +1 -5
  27. package/dist/cjs/internal/layer/circular.js.map +1 -1
  28. package/dist/cjs/internal/layer.js +1 -3
  29. package/dist/cjs/internal/layer.js.map +1 -1
  30. package/dist/cjs/internal/logger.js +25 -2
  31. package/dist/cjs/internal/logger.js.map +1 -1
  32. package/dist/cjs/internal/runtimeFlags.js +2 -11
  33. package/dist/cjs/internal/runtimeFlags.js.map +1 -1
  34. package/dist/cjs/internal/tracer.js +1 -114
  35. package/dist/cjs/internal/tracer.js.map +1 -1
  36. package/dist/dts/Config.d.ts +2 -2
  37. package/dist/dts/Config.d.ts.map +1 -1
  38. package/dist/dts/Effect.d.ts +8 -29
  39. package/dist/dts/Effect.d.ts.map +1 -1
  40. package/dist/dts/FiberRef.d.ts +12 -0
  41. package/dist/dts/FiberRef.d.ts.map +1 -1
  42. package/dist/dts/Layer.d.ts +0 -22
  43. package/dist/dts/Layer.d.ts.map +1 -1
  44. package/dist/dts/RuntimeFlags.d.ts +0 -28
  45. package/dist/dts/RuntimeFlags.d.ts.map +1 -1
  46. package/dist/dts/SourceLocation.d.ts +88 -0
  47. package/dist/dts/SourceLocation.d.ts.map +1 -0
  48. package/dist/dts/Tracer.d.ts +0 -15
  49. package/dist/dts/Tracer.d.ts.map +1 -1
  50. package/dist/dts/index.d.ts +6 -0
  51. package/dist/dts/index.d.ts.map +1 -1
  52. package/dist/dts/internal/core.d.ts.map +1 -1
  53. package/dist/dts/internal/layer.d.ts.map +1 -1
  54. package/dist/dts/internal/runtimeFlags.d.ts.map +1 -1
  55. package/dist/esm/Effect.js +0 -26
  56. package/dist/esm/Effect.js.map +1 -1
  57. package/dist/esm/FiberRef.js +11 -0
  58. package/dist/esm/FiberRef.js.map +1 -1
  59. package/dist/esm/Layer.js +0 -22
  60. package/dist/esm/Layer.js.map +1 -1
  61. package/dist/esm/RuntimeFlags.js +0 -28
  62. package/dist/esm/RuntimeFlags.js.map +1 -1
  63. package/dist/esm/SourceLocation.js +51 -0
  64. package/dist/esm/SourceLocation.js.map +1 -0
  65. package/dist/esm/Tracer.js +0 -14
  66. package/dist/esm/Tracer.js.map +1 -1
  67. package/dist/esm/Utils.js +1 -1
  68. package/dist/esm/Utils.js.map +1 -1
  69. package/dist/esm/index.js +6 -0
  70. package/dist/esm/index.js.map +1 -1
  71. package/dist/esm/internal/clock.js +1 -1
  72. package/dist/esm/internal/clock.js.map +1 -1
  73. package/dist/esm/internal/core.js +12 -45
  74. package/dist/esm/internal/core.js.map +1 -1
  75. package/dist/esm/internal/effect/circular.js +18 -30
  76. package/dist/esm/internal/effect/circular.js.map +1 -1
  77. package/dist/esm/internal/fiberRuntime.js +13 -60
  78. package/dist/esm/internal/fiberRuntime.js.map +1 -1
  79. package/dist/esm/internal/layer/circular.js +0 -4
  80. package/dist/esm/internal/layer/circular.js.map +1 -1
  81. package/dist/esm/internal/layer.js +0 -2
  82. package/dist/esm/internal/layer.js.map +1 -1
  83. package/dist/esm/internal/logger.js +25 -2
  84. package/dist/esm/internal/logger.js.map +1 -1
  85. package/dist/esm/internal/runtimeFlags.js +1 -9
  86. package/dist/esm/internal/runtimeFlags.js.map +1 -1
  87. package/dist/esm/internal/tracer.js +0 -111
  88. package/dist/esm/internal/tracer.js.map +1 -1
  89. package/package.json +12 -1
  90. package/src/Arbitrary.ts +1101 -0
  91. package/src/Array.ts +3589 -0
  92. package/src/BigDecimal.ts +1349 -0
  93. package/src/BigInt.ts +643 -0
  94. package/src/Boolean.ts +287 -0
  95. package/src/Brand.ts +360 -0
  96. package/src/Cache.ts +281 -0
  97. package/src/Cause.ts +1555 -0
  98. package/src/Channel.ts +2355 -0
  99. package/src/ChildExecutorDecision.ts +146 -0
  100. package/src/Chunk.ts +1495 -0
  101. package/src/Clock.ts +111 -0
  102. package/src/Config.ts +542 -0
  103. package/src/ConfigError.ts +270 -0
  104. package/src/ConfigProvider.ts +333 -0
  105. package/src/ConfigProviderPathPatch.ts +100 -0
  106. package/src/Console.ts +226 -0
  107. package/src/Context.ts +585 -0
  108. package/src/Cron.ts +706 -0
  109. package/src/Data.ts +596 -0
  110. package/src/DateTime.ts +1686 -0
  111. package/src/DefaultServices.ts +34 -0
  112. package/src/Deferred.ts +301 -0
  113. package/src/Differ.ts +450 -0
  114. package/src/Duration.ts +1000 -0
  115. package/src/Effect.ts +14817 -0
  116. package/src/Effectable.ts +107 -0
  117. package/src/Either.ts +1040 -0
  118. package/src/Encoding.ts +195 -0
  119. package/src/Equal.ts +98 -0
  120. package/src/Equivalence.ts +235 -0
  121. package/src/ExecutionPlan.ts +308 -0
  122. package/src/ExecutionStrategy.ts +119 -0
  123. package/src/Exit.ts +467 -0
  124. package/src/FastCheck.ts +9 -0
  125. package/src/Fiber.ts +744 -0
  126. package/src/FiberHandle.ts +540 -0
  127. package/src/FiberId.ts +195 -0
  128. package/src/FiberMap.ts +656 -0
  129. package/src/FiberRef.ts +444 -0
  130. package/src/FiberRefs.ts +204 -0
  131. package/src/FiberRefsPatch.ts +105 -0
  132. package/src/FiberSet.ts +491 -0
  133. package/src/FiberStatus.ts +108 -0
  134. package/src/Function.ts +1222 -0
  135. package/src/GlobalValue.ts +53 -0
  136. package/src/Graph.ts +3732 -0
  137. package/src/GroupBy.ts +103 -0
  138. package/src/HKT.ts +45 -0
  139. package/src/Hash.ts +195 -0
  140. package/src/HashMap.ts +519 -0
  141. package/src/HashRing.ts +317 -0
  142. package/src/HashSet.ts +2346 -0
  143. package/src/Inspectable.ts +287 -0
  144. package/src/Iterable.ts +1119 -0
  145. package/src/JSONSchema.ts +1044 -0
  146. package/src/KeyedPool.ts +167 -0
  147. package/src/Layer.ts +1228 -0
  148. package/src/LayerMap.ts +436 -0
  149. package/src/List.ts +977 -0
  150. package/src/LogLevel.ts +285 -0
  151. package/src/LogSpan.ts +25 -0
  152. package/src/Logger.ts +702 -0
  153. package/src/Mailbox.ts +268 -0
  154. package/src/ManagedRuntime.ts +180 -0
  155. package/src/Match.ts +1477 -0
  156. package/src/MergeDecision.ts +95 -0
  157. package/src/MergeState.ts +172 -0
  158. package/src/MergeStrategy.ts +107 -0
  159. package/src/Metric.ts +780 -0
  160. package/src/MetricBoundaries.ts +69 -0
  161. package/src/MetricHook.ts +151 -0
  162. package/src/MetricKey.ts +224 -0
  163. package/src/MetricKeyType.ts +262 -0
  164. package/src/MetricLabel.ts +47 -0
  165. package/src/MetricPair.ts +71 -0
  166. package/src/MetricPolling.ts +148 -0
  167. package/src/MetricRegistry.ts +48 -0
  168. package/src/MetricState.ts +257 -0
  169. package/src/Micro.ts +4405 -0
  170. package/src/ModuleVersion.ts +18 -0
  171. package/src/MutableHashMap.ts +411 -0
  172. package/src/MutableHashSet.ts +706 -0
  173. package/src/MutableList.ts +297 -0
  174. package/src/MutableQueue.ts +227 -0
  175. package/src/MutableRef.ts +202 -0
  176. package/src/NonEmptyIterable.ts +32 -0
  177. package/src/Number.ts +1071 -0
  178. package/src/Option.ts +2170 -0
  179. package/src/Order.ts +373 -0
  180. package/src/Ordering.ts +111 -0
  181. package/src/ParseResult.ts +2031 -0
  182. package/src/PartitionedSemaphore.ts +200 -0
  183. package/src/Pipeable.ts +566 -0
  184. package/src/Pool.ts +204 -0
  185. package/src/Predicate.ts +1405 -0
  186. package/src/Pretty.ts +205 -0
  187. package/src/PrimaryKey.ts +23 -0
  188. package/src/PubSub.ts +182 -0
  189. package/src/Queue.ts +644 -0
  190. package/src/Random.ts +204 -0
  191. package/src/RateLimiter.ts +138 -0
  192. package/src/RcMap.ts +141 -0
  193. package/src/RcRef.ts +122 -0
  194. package/src/Readable.ts +93 -0
  195. package/src/Record.ts +1274 -0
  196. package/src/RedBlackTree.ts +421 -0
  197. package/src/Redacted.ts +144 -0
  198. package/src/Ref.ts +180 -0
  199. package/src/RegExp.ts +38 -0
  200. package/src/Reloadable.ts +127 -0
  201. package/src/Request.ts +347 -0
  202. package/src/RequestBlock.ts +118 -0
  203. package/src/RequestResolver.ts +366 -0
  204. package/src/Resource.ts +119 -0
  205. package/src/Runtime.ts +383 -0
  206. package/src/RuntimeFlags.ts +336 -0
  207. package/src/RuntimeFlagsPatch.ts +183 -0
  208. package/src/STM.ts +2045 -0
  209. package/src/Schedule.ts +2219 -0
  210. package/src/ScheduleDecision.ts +62 -0
  211. package/src/ScheduleInterval.ts +151 -0
  212. package/src/ScheduleIntervals.ts +122 -0
  213. package/src/Scheduler.ts +353 -0
  214. package/src/Schema.ts +10914 -0
  215. package/src/SchemaAST.ts +3043 -0
  216. package/src/Scope.ts +204 -0
  217. package/src/ScopedCache.ts +151 -0
  218. package/src/ScopedRef.ts +117 -0
  219. package/src/Secret.ts +88 -0
  220. package/src/SingleProducerAsyncInput.ts +67 -0
  221. package/src/Sink.ts +1461 -0
  222. package/src/SortedMap.ts +287 -0
  223. package/src/SortedSet.ts +390 -0
  224. package/src/SourceLocation.ts +108 -0
  225. package/src/Stream.ts +6468 -0
  226. package/src/StreamEmit.ts +136 -0
  227. package/src/StreamHaltStrategy.ts +123 -0
  228. package/src/Streamable.ts +45 -0
  229. package/src/String.ts +778 -0
  230. package/src/Struct.ts +243 -0
  231. package/src/Subscribable.ts +100 -0
  232. package/src/SubscriptionRef.ts +298 -0
  233. package/src/Supervisor.ts +240 -0
  234. package/src/Symbol.ts +29 -0
  235. package/src/SynchronizedRef.ts +270 -0
  236. package/src/TArray.ts +495 -0
  237. package/src/TDeferred.ts +100 -0
  238. package/src/TMap.ts +515 -0
  239. package/src/TPriorityQueue.ts +223 -0
  240. package/src/TPubSub.ts +200 -0
  241. package/src/TQueue.ts +432 -0
  242. package/src/TRandom.ts +129 -0
  243. package/src/TReentrantLock.ts +224 -0
  244. package/src/TRef.ts +178 -0
  245. package/src/TSemaphore.ts +129 -0
  246. package/src/TSet.ts +365 -0
  247. package/src/TSubscriptionRef.ts +192 -0
  248. package/src/Take.ts +258 -0
  249. package/src/TestAnnotation.ts +158 -0
  250. package/src/TestAnnotationMap.ts +119 -0
  251. package/src/TestAnnotations.ts +117 -0
  252. package/src/TestClock.ts +556 -0
  253. package/src/TestConfig.ts +47 -0
  254. package/src/TestContext.ts +36 -0
  255. package/src/TestLive.ts +53 -0
  256. package/src/TestServices.ts +390 -0
  257. package/src/TestSized.ts +55 -0
  258. package/src/Tracer.ts +182 -0
  259. package/src/Trie.ts +840 -0
  260. package/src/Tuple.ts +305 -0
  261. package/src/Types.ts +353 -0
  262. package/src/Unify.ts +113 -0
  263. package/src/UpstreamPullRequest.ts +117 -0
  264. package/src/UpstreamPullStrategy.ts +121 -0
  265. package/src/Utils.ts +809 -0
  266. package/src/index.ts +1568 -0
  267. package/src/internal/array.ts +8 -0
  268. package/src/internal/blockedRequests.ts +520 -0
  269. package/src/internal/cache.ts +733 -0
  270. package/src/internal/cause.ts +1050 -0
  271. package/src/internal/channel/channelExecutor.ts +1200 -0
  272. package/src/internal/channel/channelState.ts +134 -0
  273. package/src/internal/channel/childExecutorDecision.ts +96 -0
  274. package/src/internal/channel/continuation.ts +200 -0
  275. package/src/internal/channel/mergeDecision.ts +113 -0
  276. package/src/internal/channel/mergeState.ts +120 -0
  277. package/src/internal/channel/mergeStrategy.ts +72 -0
  278. package/src/internal/channel/singleProducerAsyncInput.ts +259 -0
  279. package/src/internal/channel/subexecutor.ts +229 -0
  280. package/src/internal/channel/upstreamPullRequest.ts +84 -0
  281. package/src/internal/channel/upstreamPullStrategy.ts +87 -0
  282. package/src/internal/channel.ts +2603 -0
  283. package/src/internal/clock.ts +95 -0
  284. package/src/internal/completedRequestMap.ts +9 -0
  285. package/src/internal/concurrency.ts +54 -0
  286. package/src/internal/config.ts +716 -0
  287. package/src/internal/configError.ts +304 -0
  288. package/src/internal/configProvider/pathPatch.ts +97 -0
  289. package/src/internal/configProvider.ts +799 -0
  290. package/src/internal/console.ts +153 -0
  291. package/src/internal/context.ts +337 -0
  292. package/src/internal/core-effect.ts +2293 -0
  293. package/src/internal/core-stream.ts +998 -0
  294. package/src/internal/core.ts +3189 -0
  295. package/src/internal/data.ts +36 -0
  296. package/src/internal/dataSource.ts +327 -0
  297. package/src/internal/dateTime.ts +1277 -0
  298. package/src/internal/defaultServices/console.ts +100 -0
  299. package/src/internal/defaultServices.ts +163 -0
  300. package/src/internal/deferred.ts +46 -0
  301. package/src/internal/differ/chunkPatch.ts +211 -0
  302. package/src/internal/differ/contextPatch.ts +232 -0
  303. package/src/internal/differ/hashMapPatch.ts +220 -0
  304. package/src/internal/differ/hashSetPatch.ts +176 -0
  305. package/src/internal/differ/orPatch.ts +311 -0
  306. package/src/internal/differ/readonlyArrayPatch.ts +210 -0
  307. package/src/internal/differ.ts +200 -0
  308. package/src/internal/doNotation.ts +80 -0
  309. package/src/internal/effect/circular.ts +895 -0
  310. package/src/internal/effectable.ts +131 -0
  311. package/src/internal/either.ts +110 -0
  312. package/src/internal/encoding/base64.ts +286 -0
  313. package/src/internal/encoding/base64Url.ts +29 -0
  314. package/src/internal/encoding/common.ts +51 -0
  315. package/src/internal/encoding/hex.ts +315 -0
  316. package/src/internal/errors.ts +7 -0
  317. package/src/internal/executionPlan.ts +114 -0
  318. package/src/internal/executionStrategy.ts +74 -0
  319. package/src/internal/fiber.ts +388 -0
  320. package/src/internal/fiberId.ts +267 -0
  321. package/src/internal/fiberMessage.ts +82 -0
  322. package/src/internal/fiberRefs/patch.ts +144 -0
  323. package/src/internal/fiberRefs.ts +297 -0
  324. package/src/internal/fiberRuntime.ts +3842 -0
  325. package/src/internal/fiberScope.ts +71 -0
  326. package/src/internal/fiberStatus.ts +119 -0
  327. package/src/internal/groupBy.ts +530 -0
  328. package/src/internal/hashMap/array.ts +49 -0
  329. package/src/internal/hashMap/bitwise.ts +32 -0
  330. package/src/internal/hashMap/config.ts +14 -0
  331. package/src/internal/hashMap/keySet.ts +8 -0
  332. package/src/internal/hashMap/node.ts +391 -0
  333. package/src/internal/hashMap.ts +586 -0
  334. package/src/internal/hashSet.ts +323 -0
  335. package/src/internal/keyedPool.ts +244 -0
  336. package/src/internal/layer/circular.ts +214 -0
  337. package/src/internal/layer.ts +1483 -0
  338. package/src/internal/logSpan.ts +20 -0
  339. package/src/internal/logger-circular.ts +24 -0
  340. package/src/internal/logger.ts +522 -0
  341. package/src/internal/mailbox.ts +561 -0
  342. package/src/internal/managedRuntime/circular.ts +6 -0
  343. package/src/internal/managedRuntime.ts +134 -0
  344. package/src/internal/matcher.ts +652 -0
  345. package/src/internal/metric/boundaries.ts +75 -0
  346. package/src/internal/metric/hook.ts +483 -0
  347. package/src/internal/metric/key.ts +167 -0
  348. package/src/internal/metric/keyType.ts +238 -0
  349. package/src/internal/metric/label.ts +41 -0
  350. package/src/internal/metric/pair.ts +48 -0
  351. package/src/internal/metric/polling.ts +149 -0
  352. package/src/internal/metric/registry.ts +187 -0
  353. package/src/internal/metric/state.ts +290 -0
  354. package/src/internal/metric.ts +577 -0
  355. package/src/internal/opCodes/cause.ts +35 -0
  356. package/src/internal/opCodes/channel.ts +83 -0
  357. package/src/internal/opCodes/channelChildExecutorDecision.ts +17 -0
  358. package/src/internal/opCodes/channelMergeDecision.ts +11 -0
  359. package/src/internal/opCodes/channelMergeState.ts +17 -0
  360. package/src/internal/opCodes/channelMergeStrategy.ts +11 -0
  361. package/src/internal/opCodes/channelState.ts +23 -0
  362. package/src/internal/opCodes/channelUpstreamPullRequest.ts +11 -0
  363. package/src/internal/opCodes/channelUpstreamPullStrategy.ts +11 -0
  364. package/src/internal/opCodes/config.ts +65 -0
  365. package/src/internal/opCodes/configError.ts +35 -0
  366. package/src/internal/opCodes/continuation.ts +11 -0
  367. package/src/internal/opCodes/deferred.ts +11 -0
  368. package/src/internal/opCodes/effect.ts +89 -0
  369. package/src/internal/opCodes/layer.ts +59 -0
  370. package/src/internal/opCodes/streamHaltStrategy.ts +23 -0
  371. package/src/internal/option.ts +80 -0
  372. package/src/internal/pool.ts +432 -0
  373. package/src/internal/pubsub.ts +1762 -0
  374. package/src/internal/query.ts +204 -0
  375. package/src/internal/queue.ts +766 -0
  376. package/src/internal/random.ts +161 -0
  377. package/src/internal/rateLimiter.ts +93 -0
  378. package/src/internal/rcMap.ts +285 -0
  379. package/src/internal/rcRef.ts +192 -0
  380. package/src/internal/redBlackTree/iterator.ts +200 -0
  381. package/src/internal/redBlackTree/node.ts +68 -0
  382. package/src/internal/redBlackTree.ts +1245 -0
  383. package/src/internal/redacted.ts +73 -0
  384. package/src/internal/ref.ts +171 -0
  385. package/src/internal/reloadable.ts +140 -0
  386. package/src/internal/request.ts +177 -0
  387. package/src/internal/resource.ts +76 -0
  388. package/src/internal/ringBuffer.ts +68 -0
  389. package/src/internal/runtime.ts +558 -0
  390. package/src/internal/runtimeFlags.ts +178 -0
  391. package/src/internal/runtimeFlagsPatch.ts +103 -0
  392. package/src/internal/schedule/decision.ts +47 -0
  393. package/src/internal/schedule/interval.ts +101 -0
  394. package/src/internal/schedule/intervals.ts +180 -0
  395. package/src/internal/schedule.ts +2199 -0
  396. package/src/internal/schema/errors.ts +191 -0
  397. package/src/internal/schema/schemaId.ts +106 -0
  398. package/src/internal/schema/util.ts +50 -0
  399. package/src/internal/scopedCache.ts +644 -0
  400. package/src/internal/scopedRef.ts +118 -0
  401. package/src/internal/secret.ts +89 -0
  402. package/src/internal/singleShotGen.ts +35 -0
  403. package/src/internal/sink.ts +2120 -0
  404. package/src/internal/stack.ts +10 -0
  405. package/src/internal/stm/core.ts +817 -0
  406. package/src/internal/stm/entry.ts +59 -0
  407. package/src/internal/stm/journal.ts +123 -0
  408. package/src/internal/stm/opCodes/stm.ts +71 -0
  409. package/src/internal/stm/opCodes/stmState.ts +17 -0
  410. package/src/internal/stm/opCodes/strategy.ts +17 -0
  411. package/src/internal/stm/opCodes/tExit.ts +29 -0
  412. package/src/internal/stm/opCodes/tryCommit.ts +11 -0
  413. package/src/internal/stm/stm.ts +1453 -0
  414. package/src/internal/stm/stmState.ts +136 -0
  415. package/src/internal/stm/tArray.ts +550 -0
  416. package/src/internal/stm/tDeferred.ts +81 -0
  417. package/src/internal/stm/tExit.ts +190 -0
  418. package/src/internal/stm/tMap.ts +824 -0
  419. package/src/internal/stm/tPriorityQueue.ts +267 -0
  420. package/src/internal/stm/tPubSub.ts +551 -0
  421. package/src/internal/stm/tQueue.ts +393 -0
  422. package/src/internal/stm/tRandom.ts +140 -0
  423. package/src/internal/stm/tReentrantLock.ts +352 -0
  424. package/src/internal/stm/tRef.ts +195 -0
  425. package/src/internal/stm/tSemaphore.ts +113 -0
  426. package/src/internal/stm/tSet.ts +259 -0
  427. package/src/internal/stm/tSubscriptionRef.ts +286 -0
  428. package/src/internal/stm/tryCommit.ts +34 -0
  429. package/src/internal/stm/txnId.ts +14 -0
  430. package/src/internal/stm/versioned.ts +4 -0
  431. package/src/internal/stream/debounceState.ts +57 -0
  432. package/src/internal/stream/emit.ts +123 -0
  433. package/src/internal/stream/haltStrategy.ts +94 -0
  434. package/src/internal/stream/handoff.ts +187 -0
  435. package/src/internal/stream/handoffSignal.ts +59 -0
  436. package/src/internal/stream/pull.ts +34 -0
  437. package/src/internal/stream/sinkEndReason.ts +30 -0
  438. package/src/internal/stream/zipAllState.ts +88 -0
  439. package/src/internal/stream/zipChunksState.ts +56 -0
  440. package/src/internal/stream.ts +8801 -0
  441. package/src/internal/string-utils.ts +107 -0
  442. package/src/internal/subscriptionRef.ts +138 -0
  443. package/src/internal/supervisor/patch.ts +190 -0
  444. package/src/internal/supervisor.ts +303 -0
  445. package/src/internal/synchronizedRef.ts +114 -0
  446. package/src/internal/take.ts +199 -0
  447. package/src/internal/testing/sleep.ts +27 -0
  448. package/src/internal/testing/suspendedWarningData.ts +85 -0
  449. package/src/internal/testing/warningData.ts +94 -0
  450. package/src/internal/tracer.ts +150 -0
  451. package/src/internal/trie.ts +722 -0
  452. package/src/internal/version.ts +7 -0
package/src/Trie.ts ADDED
@@ -0,0 +1,840 @@
1
+ /**
2
+ * A `Trie` is used for locating specific `string` keys from within a set.
3
+ *
4
+ * It works similar to `HashMap`, but with keys required to be `string`.
5
+ * This constraint unlocks some performance optimizations and new methods to get string prefixes (e.g. `keysWithPrefix`, `longestPrefixOf`).
6
+ *
7
+ * Prefix search is also the main feature that makes a `Trie` more suited than `HashMap` for certain usecases.
8
+ *
9
+ * A `Trie` is often used to store a dictionary (list of words) that can be searched
10
+ * in a manner that allows for efficient generation of completion lists
11
+ * (e.g. predict the rest of a word a user is typing).
12
+ *
13
+ * A `Trie` has O(n) lookup time where `n` is the size of the key,
14
+ * or even less than `n` on search misses.
15
+ *
16
+ * @since 2.0.0
17
+ */
18
+ import type { Equal } from "./Equal.js"
19
+ import type { Inspectable } from "./Inspectable.js"
20
+ import * as TR from "./internal/trie.js"
21
+ import type { Option } from "./Option.js"
22
+ import type { Pipeable } from "./Pipeable.js"
23
+ import type { Covariant, NoInfer } from "./Types.js"
24
+
25
+ const TypeId: unique symbol = TR.TrieTypeId as TypeId
26
+
27
+ /**
28
+ * @since 2.0.0
29
+ * @category symbol
30
+ */
31
+ export type TypeId = typeof TypeId
32
+
33
+ /**
34
+ * @since 2.0.0
35
+ * @category models
36
+ */
37
+ export interface Trie<out Value> extends Iterable<[string, Value]>, Equal, Pipeable, Inspectable {
38
+ readonly [TypeId]: {
39
+ readonly _Value: Covariant<Value>
40
+ }
41
+ }
42
+
43
+ /**
44
+ * Creates an empty `Trie`.
45
+ *
46
+ * @example
47
+ * ```ts
48
+ * import * as assert from "node:assert"
49
+ * import { Trie, Equal } from "effect"
50
+ *
51
+ * const trie = Trie.empty<string>()
52
+ *
53
+ * assert.equal(Trie.size(trie), 0)
54
+ * assert.deepStrictEqual(Array.from(trie), [])
55
+ * ```
56
+ *
57
+ * @since 2.0.0
58
+ * @category constructors
59
+ */
60
+ export const empty: <V = never>() => Trie<V> = TR.empty
61
+
62
+ /**
63
+ * Creates a new `Trie` from an iterable collection of key/value pairs (e.g. `Array<[string, V]>`).
64
+ *
65
+ * @example
66
+ * ```ts
67
+ * import * as assert from "node:assert"
68
+ * import { Trie, Equal } from "effect"
69
+ *
70
+ * const iterable: Array<readonly [string, number]> = [["call", 0], ["me", 1], ["mind", 2], ["mid", 3]]
71
+ * const trie = Trie.fromIterable(iterable)
72
+ *
73
+ * // The entries in the `Trie` are extracted in alphabetical order, regardless of the insertion order
74
+ * assert.deepStrictEqual(Array.from(trie), [["call", 0], ["me", 1], ["mid", 3], ["mind", 2]])
75
+ * assert.equal(Equal.equals(Trie.make(["call", 0], ["me", 1], ["mind", 2], ["mid", 3]), trie), true)
76
+ * ```
77
+ *
78
+ * @since 2.0.0
79
+ * @category constructors
80
+ */
81
+ export const fromIterable: <V>(entries: Iterable<readonly [string, V]>) => Trie<V> = TR.fromIterable
82
+
83
+ /**
84
+ * Constructs a new `Trie` from the specified entries (`[string, V]`).
85
+ *
86
+ * @example
87
+ * ```ts
88
+ * import * as assert from "node:assert"
89
+ * import { Trie, Equal } from "effect"
90
+ *
91
+ * const trie = Trie.make(["ca", 0], ["me", 1])
92
+ *
93
+ * assert.deepStrictEqual(Array.from(trie), [["ca", 0], ["me", 1]])
94
+ * assert.equal(Equal.equals(Trie.fromIterable([["ca", 0], ["me", 1]]), trie), true)
95
+ * ```
96
+ *
97
+ * @since 2.0.0
98
+ * @category constructors
99
+ */
100
+ export const make: <Entries extends Array<readonly [string, any]>>(
101
+ ...entries: Entries
102
+ ) => Trie<Entries[number] extends readonly [any, infer V] ? V : never> = TR.make
103
+
104
+ /**
105
+ * Insert a new entry in the `Trie`.
106
+ *
107
+ * @example
108
+ * ```ts
109
+ * import * as assert from "node:assert"
110
+ * import { Trie } from "effect"
111
+ *
112
+ * const trie1 = Trie.empty<number>().pipe(
113
+ * Trie.insert("call", 0)
114
+ * )
115
+ * const trie2 = trie1.pipe(Trie.insert("me", 1))
116
+ * const trie3 = trie2.pipe(Trie.insert("mind", 2))
117
+ * const trie4 = trie3.pipe(Trie.insert("mid", 3))
118
+ *
119
+ * assert.deepStrictEqual(Array.from(trie1), [["call", 0]])
120
+ * assert.deepStrictEqual(Array.from(trie2), [["call", 0], ["me", 1]])
121
+ * assert.deepStrictEqual(Array.from(trie3), [["call", 0], ["me", 1], ["mind", 2]])
122
+ * assert.deepStrictEqual(Array.from(trie4), [["call", 0], ["me", 1], ["mid", 3], ["mind", 2]])
123
+ * ```
124
+ *
125
+ * @since 2.0.0
126
+ * @category mutations
127
+ */
128
+ export const insert: {
129
+ <V1>(key: string, value: V1): <V>(self: Trie<V>) => Trie<V | V1>
130
+ <V1, V>(self: Trie<V>, key: string, value: V1): Trie<V | V1>
131
+ } = TR.insert
132
+
133
+ /**
134
+ * Returns an `IterableIterator` of the keys within the `Trie`.
135
+ *
136
+ * The keys are returned in alphabetical order, regardless of insertion order.
137
+ *
138
+ * @example
139
+ * ```ts
140
+ * import * as assert from "node:assert"
141
+ * import { Trie } from "effect"
142
+ *
143
+ * const trie = Trie.empty<number>().pipe(
144
+ * Trie.insert("cab", 0),
145
+ * Trie.insert("abc", 1),
146
+ * Trie.insert("bca", 2)
147
+ * )
148
+ *
149
+ * const result = Array.from(Trie.keys(trie))
150
+ * assert.deepStrictEqual(result, ["abc", "bca", "cab"])
151
+ * ```
152
+ *
153
+ * @since 2.0.0
154
+ * @category getters
155
+ */
156
+ export const keys: <V>(self: Trie<V>) => IterableIterator<string> = TR.keys
157
+
158
+ /**
159
+ * Returns an `IterableIterator` of the values within the `Trie`.
160
+ *
161
+ * Values are ordered based on their key in alphabetical order, regardless of insertion order.
162
+ *
163
+ * @example
164
+ * ```ts
165
+ * import * as assert from "node:assert"
166
+ * import { Trie } from "effect"
167
+ *
168
+ * const trie = Trie.empty<number>().pipe(
169
+ * Trie.insert("call", 0),
170
+ * Trie.insert("me", 1),
171
+ * Trie.insert("and", 2)
172
+ * )
173
+ *
174
+ * const result = Array.from(Trie.values(trie))
175
+ * assert.deepStrictEqual(result, [2, 0, 1])
176
+ * ```
177
+ *
178
+ * @since 2.0.0
179
+ * @category getters
180
+ */
181
+ export const values: <V>(self: Trie<V>) => IterableIterator<V> = TR.values
182
+
183
+ /**
184
+ * Returns an `IterableIterator` of the entries within the `Trie`.
185
+ *
186
+ * The entries are returned by keys in alphabetical order, regardless of insertion order.
187
+ *
188
+ * @example
189
+ * ```ts
190
+ * import * as assert from "node:assert"
191
+ * import { Trie } from "effect"
192
+ *
193
+ * const trie = Trie.empty<number>().pipe(
194
+ * Trie.insert("call", 0),
195
+ * Trie.insert("me", 1)
196
+ * )
197
+ *
198
+ * const result = Array.from(Trie.entries(trie))
199
+ * assert.deepStrictEqual(result, [["call", 0], ["me", 1]])
200
+ * ```
201
+ *
202
+ * @since 2.0.0
203
+ * @category getters
204
+ */
205
+ export const entries: <V>(self: Trie<V>) => IterableIterator<[string, V]> = TR.entries
206
+
207
+ /**
208
+ * Returns an `Array<[K, V]>` of the entries within the `Trie`.
209
+ *
210
+ * Equivalent to `Array.from(Trie.entries(trie))`.
211
+ *
212
+ * @example
213
+ * ```ts
214
+ * import * as assert from "node:assert"
215
+ * import { Trie } from "effect"
216
+ *
217
+ * const trie = Trie.empty<number>().pipe(
218
+ * Trie.insert("call", 0),
219
+ * Trie.insert("me", 1)
220
+ * )
221
+ * const result = Trie.toEntries(trie)
222
+ *
223
+ * assert.deepStrictEqual(result, [["call", 0], ["me", 1]])
224
+ * ```
225
+ *
226
+ * @since 2.0.0
227
+ * @category getters
228
+ */
229
+ export const toEntries = <V>(self: Trie<V>): Array<[string, V]> => Array.from(entries(self))
230
+
231
+ /**
232
+ * Returns an `IterableIterator` of the keys within the `Trie`
233
+ * that have `prefix` as prefix (`prefix` included if it exists).
234
+ *
235
+ * @example
236
+ * ```ts
237
+ * import * as assert from "node:assert"
238
+ * import { Trie } from "effect"
239
+ *
240
+ * const trie = Trie.empty<number>().pipe(
241
+ * Trie.insert("she", 0),
242
+ * Trie.insert("shells", 1),
243
+ * Trie.insert("sea", 2),
244
+ * Trie.insert("shore", 3)
245
+ * )
246
+ *
247
+ * const result = Array.from(Trie.keysWithPrefix(trie, "she"))
248
+ * assert.deepStrictEqual(result, ["she", "shells"])
249
+ * ```
250
+ *
251
+ * @since 2.0.0
252
+ * @category getters
253
+ */
254
+ export const keysWithPrefix: {
255
+ (prefix: string): <V>(self: Trie<V>) => IterableIterator<string>
256
+ <V>(self: Trie<V>, prefix: string): IterableIterator<string>
257
+ } = TR.keysWithPrefix
258
+
259
+ /**
260
+ * Returns an `IterableIterator` of the values within the `Trie`
261
+ * that have `prefix` as prefix (`prefix` included if it exists).
262
+ *
263
+ * @example
264
+ * ```ts
265
+ * import * as assert from "node:assert"
266
+ * import { Trie } from "effect"
267
+ *
268
+ * const trie = Trie.empty<number>().pipe(
269
+ * Trie.insert("she", 0),
270
+ * Trie.insert("shells", 1),
271
+ * Trie.insert("sea", 2),
272
+ * Trie.insert("shore", 3)
273
+ * )
274
+ *
275
+ * const result = Array.from(Trie.valuesWithPrefix(trie, "she"))
276
+ *
277
+ * // 0: "she", 1: "shells"
278
+ * assert.deepStrictEqual(result, [0, 1])
279
+ * ```
280
+ *
281
+ * @since 2.0.0
282
+ * @category getters
283
+ */
284
+ export const valuesWithPrefix: {
285
+ (prefix: string): <V>(self: Trie<V>) => IterableIterator<V>
286
+ <V>(self: Trie<V>, prefix: string): IterableIterator<V>
287
+ } = TR.valuesWithPrefix
288
+
289
+ /**
290
+ * Returns an `IterableIterator` of the entries within the `Trie`
291
+ * that have `prefix` as prefix (`prefix` included if it exists).
292
+ *
293
+ * @example
294
+ * ```ts
295
+ * import * as assert from "node:assert"
296
+ * import { Trie } from "effect"
297
+ *
298
+ * const trie = Trie.empty<number>().pipe(
299
+ * Trie.insert("she", 0),
300
+ * Trie.insert("shells", 1),
301
+ * Trie.insert("sea", 2),
302
+ * Trie.insert("shore", 3)
303
+ * )
304
+ *
305
+ * const result = Array.from(Trie.entriesWithPrefix(trie, "she"))
306
+ * assert.deepStrictEqual(result, [["she", 0], ["shells", 1]])
307
+ * ```
308
+ *
309
+ * @since 2.0.0
310
+ * @category getters
311
+ */
312
+ export const entriesWithPrefix: {
313
+ (prefix: string): <V>(self: Trie<V>) => IterableIterator<[string, V]>
314
+ <V>(self: Trie<V>, prefix: string): IterableIterator<[string, V]>
315
+ } = TR.entriesWithPrefix
316
+
317
+ /**
318
+ * Returns `Array<[K, V]>` of the entries within the `Trie`
319
+ * that have `prefix` as prefix (`prefix` included if it exists).
320
+ *
321
+ * @example
322
+ * ```ts
323
+ * import * as assert from "node:assert"
324
+ * import { Trie } from "effect"
325
+ *
326
+ * const trie = Trie.empty<number>().pipe(
327
+ * Trie.insert("shells", 0),
328
+ * Trie.insert("sells", 1),
329
+ * Trie.insert("sea", 2),
330
+ * Trie.insert("she", 3)
331
+ * )
332
+ *
333
+ * const result = Trie.toEntriesWithPrefix(trie, "she")
334
+ * assert.deepStrictEqual(result, [["she", 3], ["shells", 0]])
335
+ * ```
336
+ *
337
+ * @since 2.0.0
338
+ * @category getters
339
+ */
340
+ export const toEntriesWithPrefix: {
341
+ (prefix: string): <V>(self: Trie<V>) => Array<[string, V]>
342
+ <V>(self: Trie<V>, prefix: string): Array<[string, V]>
343
+ } = TR.toEntriesWithPrefix
344
+
345
+ /**
346
+ * Returns the longest key/value in the `Trie`
347
+ * that is a prefix of that `key` if it exists, `None` otherwise.
348
+ *
349
+ * @example
350
+ * ```ts
351
+ * import * as assert from "node:assert"
352
+ * import { Trie, Option } from "effect"
353
+ *
354
+ * const trie = Trie.empty<number>().pipe(
355
+ * Trie.insert("shells", 0),
356
+ * Trie.insert("sells", 1),
357
+ * Trie.insert("she", 2)
358
+ * )
359
+ *
360
+ * assert.deepStrictEqual(Trie.longestPrefixOf(trie, "sell"), Option.none())
361
+ * assert.deepStrictEqual(Trie.longestPrefixOf(trie, "sells"), Option.some(["sells", 1]))
362
+ * assert.deepStrictEqual(Trie.longestPrefixOf(trie, "shell"), Option.some(["she", 2]))
363
+ * assert.deepStrictEqual(Trie.longestPrefixOf(trie, "shellsort"), Option.some(["shells", 0]))
364
+ * ```
365
+ *
366
+ * @since 2.0.0
367
+ * @category getters
368
+ */
369
+ export const longestPrefixOf: {
370
+ (key: string): <V>(self: Trie<V>) => Option<[string, V]>
371
+ <V>(self: Trie<V>, key: string): Option<[string, V]>
372
+ } = TR.longestPrefixOf
373
+
374
+ /**
375
+ * Returns the size of the `Trie` (number of entries in the `Trie`).
376
+ *
377
+ * @example
378
+ * ```ts
379
+ * import * as assert from "node:assert"
380
+ * import { Trie } from "effect"
381
+ *
382
+ * const trie = Trie.empty<number>().pipe(
383
+ * Trie.insert("a", 0),
384
+ * Trie.insert("b", 1)
385
+ * )
386
+ *
387
+ * assert.equal(Trie.size(trie), 2)
388
+ * ```
389
+ *
390
+ * @since 2.0.0
391
+ * @category getters
392
+ */
393
+ export const size: <V>(self: Trie<V>) => number = TR.size
394
+
395
+ /**
396
+ * Safely lookup the value for the specified key in the `Trie`.
397
+ *
398
+ * @example
399
+ * ```ts
400
+ * import * as assert from "node:assert"
401
+ * import { Trie, Option } from "effect"
402
+ *
403
+ * const trie = Trie.empty<number>().pipe(
404
+ * Trie.insert("call", 0),
405
+ * Trie.insert("me", 1),
406
+ * Trie.insert("mind", 2),
407
+ * Trie.insert("mid", 3)
408
+ * )
409
+ *
410
+ * assert.deepStrictEqual(Trie.get(trie, "call"), Option.some(0))
411
+ * assert.deepStrictEqual(Trie.get(trie, "me"), Option.some(1))
412
+ * assert.deepStrictEqual(Trie.get(trie, "mind"), Option.some(2))
413
+ * assert.deepStrictEqual(Trie.get(trie, "mid"), Option.some(3))
414
+ * assert.deepStrictEqual(Trie.get(trie, "cale"), Option.none())
415
+ * assert.deepStrictEqual(Trie.get(trie, "ma"), Option.none())
416
+ * assert.deepStrictEqual(Trie.get(trie, "midn"), Option.none())
417
+ * assert.deepStrictEqual(Trie.get(trie, "mea"), Option.none())
418
+ * ```
419
+ *
420
+ * @since 2.0.0
421
+ * @category elements
422
+ */
423
+ export const get: {
424
+ (key: string): <V>(self: Trie<V>) => Option<V>
425
+ <V>(self: Trie<V>, key: string): Option<V>
426
+ } = TR.get
427
+
428
+ /**
429
+ * Check if the given key exists in the `Trie`.
430
+ *
431
+ * @example
432
+ * ```ts
433
+ * import * as assert from "node:assert"
434
+ * import { Trie } from "effect"
435
+ *
436
+ * const trie = Trie.empty<number>().pipe(
437
+ * Trie.insert("call", 0),
438
+ * Trie.insert("me", 1),
439
+ * Trie.insert("mind", 2),
440
+ * Trie.insert("mid", 3)
441
+ * )
442
+ *
443
+ * assert.equal(Trie.has(trie, "call"), true)
444
+ * assert.equal(Trie.has(trie, "me"), true)
445
+ * assert.equal(Trie.has(trie, "mind"), true)
446
+ * assert.equal(Trie.has(trie, "mid"), true)
447
+ * assert.equal(Trie.has(trie, "cale"), false)
448
+ * assert.equal(Trie.has(trie, "ma"), false)
449
+ * assert.equal(Trie.has(trie, "midn"), false)
450
+ * assert.equal(Trie.has(trie, "mea"), false)
451
+ * ```
452
+ *
453
+ * @since 2.0.0
454
+ * @category elements
455
+ */
456
+ export const has: {
457
+ (key: string): <V>(self: Trie<V>) => boolean
458
+ <V>(self: Trie<V>, key: string): boolean
459
+ } = TR.has
460
+
461
+ /**
462
+ * Checks if the `Trie` contains any entries.
463
+ *
464
+ * @example
465
+ * ```ts
466
+ * import * as assert from "node:assert"
467
+ * import { Trie } from "effect"
468
+ *
469
+ * const trie = Trie.empty<number>()
470
+ * const trie1 = trie.pipe(Trie.insert("ma", 0))
471
+ *
472
+ * assert.equal(Trie.isEmpty(trie), true)
473
+ * assert.equal(Trie.isEmpty(trie1), false)
474
+ * ```
475
+ *
476
+ * @since 2.0.0
477
+ * @category elements
478
+ */
479
+ export const isEmpty: <V>(self: Trie<V>) => boolean = TR.isEmpty
480
+
481
+ /**
482
+ * Unsafely lookup the value for the specified key in the `Trie`.
483
+ *
484
+ * `unsafeGet` will throw if the key is not found. Use `get` instead to safely
485
+ * get a value from the `Trie`.
486
+ *
487
+ * @example
488
+ * ```ts
489
+ * import * as assert from "node:assert"
490
+ * import { Trie } from "effect"
491
+ *
492
+ * const trie = Trie.empty<number>().pipe(
493
+ * Trie.insert("call", 0),
494
+ * Trie.insert("me", 1)
495
+ * )
496
+ *
497
+ * assert.throws(() => Trie.unsafeGet(trie, "mae"))
498
+ * ```
499
+ *
500
+ * @since 2.0.0
501
+ * @category unsafe
502
+ */
503
+ export const unsafeGet: {
504
+ (key: string): <V>(self: Trie<V>) => V
505
+ <V>(self: Trie<V>, key: string): V
506
+ } = TR.unsafeGet
507
+
508
+ /**
509
+ * Remove the entry for the specified key in the `Trie`.
510
+ *
511
+ * @example
512
+ * ```ts
513
+ * import * as assert from "node:assert"
514
+ * import { Trie, Option } from "effect"
515
+ *
516
+ * const trie = Trie.empty<number>().pipe(
517
+ * Trie.insert("call", 0),
518
+ * Trie.insert("me", 1),
519
+ * Trie.insert("mind", 2),
520
+ * Trie.insert("mid", 3)
521
+ * )
522
+ *
523
+ * const trie1 = trie.pipe(Trie.remove("call"))
524
+ * const trie2 = trie1.pipe(Trie.remove("mea"))
525
+ *
526
+ * assert.deepStrictEqual(Trie.get(trie, "call"), Option.some(0))
527
+ * assert.deepStrictEqual(Trie.get(trie1, "call"), Option.none())
528
+ * assert.deepStrictEqual(Trie.get(trie2, "call"), Option.none())
529
+ * ```
530
+ *
531
+ * @since 2.0.0
532
+ * @category mutations
533
+ */
534
+ export const remove: {
535
+ (key: string): <V>(self: Trie<V>) => Trie<V>
536
+ <V>(self: Trie<V>, key: string): Trie<V>
537
+ } = TR.remove
538
+
539
+ /**
540
+ * Reduce a state over the entries of the `Trie`.
541
+ *
542
+ * @example
543
+ * ```ts
544
+ * import * as assert from "node:assert"
545
+ * import { Trie } from "effect"
546
+ *
547
+ * const trie = Trie.empty<number>().pipe(
548
+ * Trie.insert("shells", 0),
549
+ * Trie.insert("sells", 1),
550
+ * Trie.insert("she", 2)
551
+ * )
552
+ *
553
+ * assert.equal(
554
+ * trie.pipe(
555
+ * Trie.reduce(0, (acc, n) => acc + n)
556
+ * ),
557
+ * 3
558
+ * )
559
+ * assert.equal(
560
+ * trie.pipe(
561
+ * Trie.reduce(10, (acc, n) => acc + n)
562
+ * ),
563
+ * 13
564
+ * )
565
+ * assert.equal(
566
+ * trie.pipe(
567
+ * Trie.reduce("", (acc, _, key) => acc + key)
568
+ * ),
569
+ * "sellssheshells"
570
+ * )
571
+ * ```
572
+ *
573
+ * @since 2.0.0
574
+ * @category folding
575
+ */
576
+ export const reduce: {
577
+ <Z, V>(zero: Z, f: (accumulator: Z, value: V, key: string) => Z): (self: Trie<V>) => Z
578
+ <Z, V>(self: Trie<V>, zero: Z, f: (accumulator: Z, value: V, key: string) => Z): Z
579
+ } = TR.reduce
580
+
581
+ /**
582
+ * Maps over the entries of the `Trie` using the specified function.
583
+ *
584
+ * @example
585
+ * ```ts
586
+ * import * as assert from "node:assert"
587
+ * import { Trie, Equal } from "effect"
588
+ *
589
+ * const trie = Trie.empty<number>().pipe(
590
+ * Trie.insert("shells", 0),
591
+ * Trie.insert("sells", 1),
592
+ * Trie.insert("she", 2)
593
+ * )
594
+ *
595
+ * const trieMapV = Trie.empty<number>().pipe(
596
+ * Trie.insert("shells", 1),
597
+ * Trie.insert("sells", 2),
598
+ * Trie.insert("she", 3)
599
+ * )
600
+ *
601
+ * const trieMapK = Trie.empty<number>().pipe(
602
+ * Trie.insert("shells", 6),
603
+ * Trie.insert("sells", 5),
604
+ * Trie.insert("she", 3)
605
+ * )
606
+ *
607
+ * assert.equal(Equal.equals(Trie.map(trie, (v) => v + 1), trieMapV), true)
608
+ * assert.equal(Equal.equals(Trie.map(trie, (_, k) => k.length), trieMapK), true)
609
+ * ```
610
+ *
611
+ * @since 2.0.0
612
+ * @category folding
613
+ */
614
+ export const map: {
615
+ <A, V>(f: (value: V, key: string) => A): (self: Trie<V>) => Trie<A>
616
+ <V, A>(self: Trie<V>, f: (value: V, key: string) => A): Trie<A>
617
+ } = TR.map
618
+
619
+ /**
620
+ * Filters entries out of a `Trie` using the specified predicate.
621
+ *
622
+ * @example
623
+ * ```ts
624
+ * import * as assert from "node:assert"
625
+ * import { Trie, Equal } from "effect"
626
+ *
627
+ * const trie = Trie.empty<number>().pipe(
628
+ * Trie.insert("shells", 0),
629
+ * Trie.insert("sells", 1),
630
+ * Trie.insert("she", 2)
631
+ * )
632
+ *
633
+ * const trieMapV = Trie.empty<number>().pipe(
634
+ * Trie.insert("she", 2)
635
+ * )
636
+ *
637
+ * const trieMapK = Trie.empty<number>().pipe(
638
+ * Trie.insert("shells", 0),
639
+ * Trie.insert("sells", 1)
640
+ * )
641
+ *
642
+ * assert.equal(Equal.equals(Trie.filter(trie, (v) => v > 1), trieMapV), true)
643
+ * assert.equal(Equal.equals(Trie.filter(trie, (_, k) => k.length > 3), trieMapK), true)
644
+ * ```
645
+ *
646
+ * @since 2.0.0
647
+ * @category filtering
648
+ */
649
+ export const filter: {
650
+ <A, B extends A>(f: (a: NoInfer<A>, k: string) => a is B): (self: Trie<A>) => Trie<B>
651
+ <A>(f: (a: NoInfer<A>, k: string) => boolean): (self: Trie<A>) => Trie<A>
652
+ <A, B extends A>(self: Trie<A>, f: (a: A, k: string) => a is B): Trie<B>
653
+ <A>(self: Trie<A>, f: (a: A, k: string) => boolean): Trie<A>
654
+ } = TR.filter
655
+
656
+ /**
657
+ * Maps over the entries of the `Trie` using the specified partial function
658
+ * and filters out `None` values.
659
+ *
660
+ * @example
661
+ * ```ts
662
+ * import * as assert from "node:assert"
663
+ * import { Trie, Equal, Option } from "effect"
664
+ *
665
+ * const trie = Trie.empty<number>().pipe(
666
+ * Trie.insert("shells", 0),
667
+ * Trie.insert("sells", 1),
668
+ * Trie.insert("she", 2)
669
+ * )
670
+ *
671
+ * const trieMapV = Trie.empty<number>().pipe(
672
+ * Trie.insert("she", 2)
673
+ * )
674
+ *
675
+ * const trieMapK = Trie.empty<number>().pipe(
676
+ * Trie.insert("shells", 0),
677
+ * Trie.insert("sells", 1)
678
+ * )
679
+ *
680
+ * assert.equal(Equal.equals(Trie.filterMap(trie, (v) => v > 1 ? Option.some(v) : Option.none()), trieMapV), true)
681
+ * assert.equal(
682
+ * Equal.equals(Trie.filterMap(trie, (v, k) => k.length > 3 ? Option.some(v) : Option.none()), trieMapK),
683
+ * true
684
+ * )
685
+ * ```
686
+ *
687
+ * @since 2.0.0
688
+ * @category filtering
689
+ */
690
+ export const filterMap: {
691
+ <A, B>(f: (value: A, key: string) => Option<B>): (self: Trie<A>) => Trie<B>
692
+ <A, B>(self: Trie<A>, f: (value: A, key: string) => Option<B>): Trie<B>
693
+ } = TR.filterMap
694
+
695
+ /**
696
+ * Filters out `None` values from a `Trie` of `Options`s.
697
+ *
698
+ * @example
699
+ * ```ts
700
+ * import * as assert from "node:assert"
701
+ * import { Trie, Equal, Option } from "effect"
702
+ *
703
+ * const trie = Trie.empty<Option.Option<number>>().pipe(
704
+ * Trie.insert("shells", Option.some(0)),
705
+ * Trie.insert("sells", Option.none()),
706
+ * Trie.insert("she", Option.some(2))
707
+ * )
708
+ *
709
+ * const trieMapV = Trie.empty<number>().pipe(
710
+ * Trie.insert("shells", 0),
711
+ * Trie.insert("she", 2)
712
+ * )
713
+ *
714
+ * assert.equal(Equal.equals(Trie.compact(trie), trieMapV), true)
715
+ * ```
716
+ *
717
+ * @since 2.0.0
718
+ * @category filtering
719
+ */
720
+ export const compact: <A>(self: Trie<Option<A>>) => Trie<A> = TR.compact
721
+
722
+ /**
723
+ * Applies the specified function to the entries of the `Trie`.
724
+ *
725
+ * @example
726
+ * ```ts
727
+ * import * as assert from "node:assert"
728
+ * import { Trie } from "effect"
729
+ *
730
+ * let value = 0
731
+ *
732
+ * Trie.empty<number>().pipe(
733
+ * Trie.insert("shells", 0),
734
+ * Trie.insert("sells", 1),
735
+ * Trie.insert("she", 2),
736
+ * Trie.forEach((n, key) => {
737
+ * value += n + key.length
738
+ * })
739
+ * )
740
+ *
741
+ * assert.equal(value, 17)
742
+ * ```
743
+ *
744
+ * @since 2.0.0
745
+ * @category traversing
746
+ */
747
+ export const forEach: {
748
+ <V>(f: (value: V, key: string) => void): (self: Trie<V>) => void
749
+ <V>(self: Trie<V>, f: (value: V, key: string) => void): void
750
+ } = TR.forEach
751
+
752
+ /**
753
+ * Updates the value of the specified key within the `Trie` if it exists.
754
+ *
755
+ * @example
756
+ * ```ts
757
+ * import * as assert from "node:assert"
758
+ * import { Trie, Equal, Option } from "effect"
759
+ *
760
+ * const trie = Trie.empty<number>().pipe(
761
+ * Trie.insert("shells", 0),
762
+ * Trie.insert("sells", 1),
763
+ * Trie.insert("she", 2)
764
+ * )
765
+ *
766
+ * assert.deepStrictEqual(trie.pipe(Trie.modify("she", (v) => v + 10), Trie.get("she")), Option.some(12))
767
+ *
768
+ * assert.equal(Equal.equals(trie.pipe(Trie.modify("me", (v) => v)), trie), true)
769
+ * ```
770
+ *
771
+ * @since 2.0.0
772
+ * @category mutations
773
+ */
774
+ export const modify: {
775
+ <V1, V>(key: string, f: (v: V) => V1): (self: Trie<V>) => Trie<V1 | V>
776
+ <V1, V>(self: Trie<V>, key: string, f: (v: V) => V1): Trie<V | V1>
777
+ } = TR.modify
778
+
779
+ /**
780
+ * Removes all entries in the `Trie` which have the specified keys.
781
+ *
782
+ * @example
783
+ * ```ts
784
+ * import * as assert from "node:assert"
785
+ * import { Trie, Equal } from "effect"
786
+ *
787
+ * const trie = Trie.empty<number>().pipe(
788
+ * Trie.insert("shells", 0),
789
+ * Trie.insert("sells", 1),
790
+ * Trie.insert("she", 2)
791
+ * )
792
+ *
793
+ * assert.equal(
794
+ * Equal.equals(trie.pipe(Trie.removeMany(["she", "sells"])), Trie.empty<number>().pipe(Trie.insert("shells", 0))),
795
+ * true
796
+ * )
797
+ * ```
798
+ *
799
+ * @since 2.0.0
800
+ * @category mutations
801
+ */
802
+ export const removeMany: {
803
+ (keys: Iterable<string>): <V>(self: Trie<V>) => Trie<V>
804
+ <V>(self: Trie<V>, keys: Iterable<string>): Trie<V>
805
+ } = TR.removeMany
806
+
807
+ /**
808
+ * Insert multiple entries in the `Trie` at once.
809
+ *
810
+ * @example
811
+ * ```ts
812
+ * import * as assert from "node:assert"
813
+ * import { Trie, Equal } from "effect"
814
+ *
815
+ * const trie = Trie.empty<number>().pipe(
816
+ * Trie.insert("shells", 0),
817
+ * Trie.insert("sells", 1),
818
+ * Trie.insert("she", 2)
819
+ * )
820
+ *
821
+ * const trieInsert = Trie.empty<number>().pipe(
822
+ * Trie.insert("shells", 0),
823
+ * Trie.insertMany(
824
+ * [["sells", 1], ["she", 2]]
825
+ * )
826
+ * )
827
+ *
828
+ * assert.equal(
829
+ * Equal.equals(trie, trieInsert),
830
+ * true
831
+ * )
832
+ * ```
833
+ *
834
+ * @since 2.0.0
835
+ * @category mutations
836
+ */
837
+ export const insertMany: {
838
+ <V1>(iter: Iterable<[string, V1]>): <V>(self: Trie<V>) => Trie<V | V1>
839
+ <V1, V>(self: Trie<V>, iter: Iterable<[string, V1]>): Trie<V | V1>
840
+ } = TR.insertMany