@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
@@ -0,0 +1,824 @@
1
+ import * as RA from "../../Array.js"
2
+ import * as Chunk from "../../Chunk.js"
3
+ import * as Equal from "../../Equal.js"
4
+ import type { LazyArg } from "../../Function.js"
5
+ import { dual, pipe } from "../../Function.js"
6
+ import * as Hash from "../../Hash.js"
7
+ import * as HashMap from "../../HashMap.js"
8
+ import * as Option from "../../Option.js"
9
+ import { hasProperty } from "../../Predicate.js"
10
+ import * as STM from "../../STM.js"
11
+ import type * as TArray from "../../TArray.js"
12
+ import type * as TMap from "../../TMap.js"
13
+ import type * as TRef from "../../TRef.js"
14
+ import * as core from "./core.js"
15
+ import type * as Journal from "./journal.js"
16
+ import * as stm from "./stm.js"
17
+ import * as tArray from "./tArray.js"
18
+ import * as tRef from "./tRef.js"
19
+
20
+ /** @internal */
21
+ const TMapSymbolKey = "effect/TMap"
22
+
23
+ /** @internal */
24
+ export const TMapTypeId: TMap.TMapTypeId = Symbol.for(
25
+ TMapSymbolKey
26
+ ) as TMap.TMapTypeId
27
+
28
+ const tMapVariance = {
29
+ /* c8 ignore next */
30
+ _K: (_: any) => _,
31
+ /* c8 ignore next */
32
+ _V: (_: any) => _
33
+ }
34
+
35
+ /** @internal */
36
+ class TMapImpl<in out K, in out V> implements TMap.TMap<K, V> {
37
+ readonly [TMapTypeId] = tMapVariance
38
+ constructor(
39
+ readonly tBuckets: TRef.TRef<TArray.TArray<Chunk.Chunk<readonly [K, V]>>>,
40
+ readonly tSize: TRef.TRef<number>
41
+ ) {}
42
+ }
43
+
44
+ const isTMap = (u: unknown) => hasProperty(u, TMapTypeId)
45
+
46
+ /** @internal */
47
+ const InitialCapacity = 16
48
+ const LoadFactor = 0.75
49
+
50
+ /** @internal */
51
+ const nextPowerOfTwo = (size: number): number => {
52
+ const n = -1 >>> Math.clz32(size - 1)
53
+ return n < 0 ? 1 : n + 1
54
+ }
55
+
56
+ /** @internal */
57
+ const hash = <K>(key: K): number => {
58
+ const h = Hash.hash(key)
59
+ return h ^ (h >>> 16)
60
+ }
61
+
62
+ /** @internal */
63
+ const indexOf = <K>(k: K, capacity: number): number => hash(k) & (capacity - 1)
64
+
65
+ /** @internal */
66
+ const allocate = <K, V>(
67
+ capacity: number,
68
+ data: Chunk.Chunk<readonly [K, V]>
69
+ ): STM.STM<TMap.TMap<K, V>> => {
70
+ const buckets = Array.from({ length: capacity }, () => Chunk.empty<readonly [K, V]>())
71
+ const distinct = new Map<K, V>(data)
72
+ let size = 0
73
+ for (const entry of distinct) {
74
+ const index = indexOf(entry[0], capacity)
75
+ buckets[index] = pipe(buckets[index], Chunk.prepend(entry))
76
+ size = size + 1
77
+ }
78
+ return pipe(
79
+ tArray.fromIterable(buckets),
80
+ core.flatMap((buckets) =>
81
+ pipe(
82
+ tRef.make(buckets),
83
+ core.flatMap((tBuckets) =>
84
+ pipe(
85
+ tRef.make(size),
86
+ core.map((tSize) => new TMapImpl(tBuckets, tSize))
87
+ )
88
+ )
89
+ )
90
+ )
91
+ )
92
+ }
93
+
94
+ /** @internal */
95
+ export const empty = <K, V>(): STM.STM<TMap.TMap<K, V>> => fromIterable<K, V>([])
96
+
97
+ /** @internal */
98
+ export const find = dual<
99
+ <K, V, A>(
100
+ pf: (key: K, value: V) => Option.Option<A>
101
+ ) => (self: TMap.TMap<K, V>) => STM.STM<Option.Option<A>>,
102
+ <K, V, A>(
103
+ self: TMap.TMap<K, V>,
104
+ pf: (key: K, value: V) => Option.Option<A>
105
+ ) => STM.STM<Option.Option<A>>
106
+ >(2, (self, pf) =>
107
+ findSTM(self, (key, value) => {
108
+ const option = pf(key, value)
109
+ if (Option.isSome(option)) {
110
+ return core.succeed(option.value)
111
+ }
112
+ return core.fail(Option.none())
113
+ }))
114
+
115
+ /** @internal */
116
+ export const findSTM = dual<
117
+ <K, V, A, E, R>(
118
+ f: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
119
+ ) => (self: TMap.TMap<K, V>) => STM.STM<Option.Option<A>, E, R>,
120
+ <K, V, A, E, R>(
121
+ self: TMap.TMap<K, V>,
122
+ f: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
123
+ ) => STM.STM<Option.Option<A>, E, R>
124
+ >(2, <K, V, A, E, R>(
125
+ self: TMap.TMap<K, V>,
126
+ f: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
127
+ ) =>
128
+ reduceSTM(self, Option.none<A>(), (acc, value, key) =>
129
+ Option.isNone(acc) ?
130
+ core.matchSTM(f(key, value), {
131
+ onFailure: Option.match({
132
+ onNone: () => stm.succeedNone,
133
+ onSome: core.fail
134
+ }),
135
+ onSuccess: stm.succeedSome
136
+ }) :
137
+ STM.succeed(acc)))
138
+
139
+ /** @internal */
140
+ export const findAll = dual<
141
+ <K, V, A>(
142
+ pf: (key: K, value: V) => Option.Option<A>
143
+ ) => (self: TMap.TMap<K, V>) => STM.STM<Array<A>>,
144
+ <K, V, A>(
145
+ self: TMap.TMap<K, V>,
146
+ pf: (key: K, value: V) => Option.Option<A>
147
+ ) => STM.STM<Array<A>>
148
+ >(2, (self, pf) =>
149
+ findAllSTM(self, (key, value) => {
150
+ const option = pf(key, value)
151
+ if (Option.isSome(option)) {
152
+ return core.succeed(option.value)
153
+ }
154
+ return core.fail(Option.none())
155
+ }))
156
+
157
+ /** @internal */
158
+ export const findAllSTM = dual<
159
+ <K, V, A, E, R>(
160
+ pf: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
161
+ ) => (self: TMap.TMap<K, V>) => STM.STM<Array<A>, E, R>,
162
+ <K, V, A, E, R>(
163
+ self: TMap.TMap<K, V>,
164
+ pf: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
165
+ ) => STM.STM<Array<A>, E, R>
166
+ >(2, <K, V, A, E, R>(
167
+ self: TMap.TMap<K, V>,
168
+ pf: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
169
+ ) =>
170
+ core.map(
171
+ reduceSTM(self, Chunk.empty<A>(), (acc, value, key) =>
172
+ core.matchSTM(pf(key, value), {
173
+ onFailure: Option.match({
174
+ onNone: () => core.succeed(acc),
175
+ onSome: core.fail
176
+ }),
177
+ onSuccess: (a) => core.succeed(Chunk.append(acc, a))
178
+ })),
179
+ (a) => Array.from(a)
180
+ ))
181
+
182
+ /** @internal */
183
+ export const forEach = dual<
184
+ <K, V, X, E, R>(f: (key: K, value: V) => STM.STM<X, E, R>) => (self: TMap.TMap<K, V>) => STM.STM<void, E, R>,
185
+ <K, V, X, E, R>(self: TMap.TMap<K, V>, f: (key: K, value: V) => STM.STM<X, E, R>) => STM.STM<void, E, R>
186
+ >(2, (self, f) =>
187
+ reduceSTM(
188
+ self,
189
+ void 0 as void,
190
+ (_, value, key) => stm.asVoid(f(key, value))
191
+ ))
192
+
193
+ /** @internal */
194
+ export const fromIterable = <K, V>(iterable: Iterable<readonly [K, V]>): STM.STM<TMap.TMap<K, V>> =>
195
+ stm.suspend(() => {
196
+ const data = Chunk.fromIterable(iterable)
197
+ const capacity = data.length < InitialCapacity
198
+ ? InitialCapacity
199
+ : nextPowerOfTwo(data.length)
200
+ return allocate(capacity, data)
201
+ })
202
+
203
+ /** @internal */
204
+ export const get = dual<
205
+ <K>(key: K) => <V>(self: TMap.TMap<K, V>) => STM.STM<Option.Option<V>>,
206
+ <K, V>(self: TMap.TMap<K, V>, key: K) => STM.STM<Option.Option<V>>
207
+ >(2, <K, V>(self: TMap.TMap<K, V>, key: K) =>
208
+ core.effect<never, Option.Option<V>>((journal) => {
209
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
210
+ const index = indexOf(key, buckets.chunk.length)
211
+ const bucket = tRef.unsafeGet(buckets.chunk[index], journal)
212
+ return pipe(
213
+ Chunk.findFirst(bucket, (entry) => Equal.equals(entry[0])(key)),
214
+ Option.map((entry) => entry[1])
215
+ )
216
+ }))
217
+
218
+ /** @internal */
219
+ export const getOrElse = dual<
220
+ <K, V>(key: K, fallback: LazyArg<V>) => (self: TMap.TMap<K, V>) => STM.STM<V>,
221
+ <K, V>(self: TMap.TMap<K, V>, key: K, fallback: LazyArg<V>) => STM.STM<V>
222
+ >(3, (self, key, fallback) =>
223
+ core.map(
224
+ get(self, key),
225
+ Option.getOrElse(fallback)
226
+ ))
227
+
228
+ /** @internal */
229
+ export const has = dual<
230
+ <K>(key: K) => <V>(self: TMap.TMap<K, V>) => STM.STM<boolean>,
231
+ <K, V>(self: TMap.TMap<K, V>, key: K) => STM.STM<boolean>
232
+ >(2, (self, key) => core.map(get(self, key), Option.isSome))
233
+
234
+ /** @internal */
235
+ export const isEmpty = <K, V>(self: TMap.TMap<K, V>): STM.STM<boolean> =>
236
+ core.map(tRef.get(self.tSize), (size) => size === 0)
237
+
238
+ /** @internal */
239
+ export const keys = <K, V>(self: TMap.TMap<K, V>): STM.STM<Array<K>> =>
240
+ core.map(toReadonlyArray(self), RA.map((entry) => entry[0]))
241
+
242
+ /** @internal */
243
+ export const make = <K, V>(...entries: Array<readonly [K, V]>): STM.STM<TMap.TMap<K, V>> => fromIterable(entries)
244
+
245
+ /** @internal */
246
+ export const merge = dual<
247
+ <K, V>(key: K, value: V, f: (x: V, y: V) => V) => (self: TMap.TMap<K, V>) => STM.STM<V>,
248
+ <K, V>(self: TMap.TMap<K, V>, key: K, value: V, f: (x: V, y: V) => V) => STM.STM<V>
249
+ >(4, (self, key, value, f) =>
250
+ core.flatMap(
251
+ get(self, key),
252
+ Option.match({
253
+ onNone: () => stm.as(set(self, key, value), value),
254
+ onSome: (v0) => {
255
+ const v1 = f(v0, value)
256
+ return stm.as(set(self, key, v1), v1)
257
+ }
258
+ })
259
+ ))
260
+
261
+ /** @internal */
262
+ export const reduce = dual<
263
+ <Z, K, V>(zero: Z, f: (acc: Z, value: V, key: K) => Z) => (self: TMap.TMap<K, V>) => STM.STM<Z>,
264
+ <K, V, Z>(self: TMap.TMap<K, V>, zero: Z, f: (acc: Z, value: V, key: K) => Z) => STM.STM<Z>
265
+ >(
266
+ 3,
267
+ <K, V, Z>(self: TMap.TMap<K, V>, zero: Z, f: (acc: Z, value: V, key: K) => Z) =>
268
+ core.effect<never, Z>((journal) => {
269
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
270
+ let result = zero
271
+ let index = 0
272
+ while (index < buckets.chunk.length) {
273
+ const bucket = buckets.chunk[index]
274
+ const items = tRef.unsafeGet(bucket, journal)
275
+ result = Chunk.reduce(items, result, (acc, entry) => f(acc, entry[1], entry[0]))
276
+ index = index + 1
277
+ }
278
+ return result
279
+ })
280
+ )
281
+
282
+ /** @internal */
283
+ export const reduceSTM = dual<
284
+ <Z, V, K, R, E>(
285
+ zero: Z,
286
+ f: (acc: Z, value: V, key: K) => STM.STM<Z, E, R>
287
+ ) => (self: TMap.TMap<K, V>) => STM.STM<Z, E, R>,
288
+ <Z, V, K, R, E>(
289
+ self: TMap.TMap<K, V>,
290
+ zero: Z,
291
+ f: (acc: Z, value: V, key: K) => STM.STM<Z, E, R>
292
+ ) => STM.STM<Z, E, R>
293
+ >(3, (self, zero, f) =>
294
+ core.flatMap(
295
+ toReadonlyArray(self),
296
+ stm.reduce(zero, (acc, entry) => f(acc, entry[1], entry[0]))
297
+ ))
298
+
299
+ /** @internal */
300
+ export const remove = dual<
301
+ <K>(key: K) => <V>(self: TMap.TMap<K, V>) => STM.STM<void>,
302
+ <K, V>(self: TMap.TMap<K, V>, key: K) => STM.STM<void>
303
+ >(2, (self, key) =>
304
+ core.effect<never, void>((journal) => {
305
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
306
+ const index = indexOf(key, buckets.chunk.length)
307
+ const bucket = tRef.unsafeGet(buckets.chunk[index], journal)
308
+ const [toRemove, toRetain] = Chunk.partition(bucket, (entry) => Equal.equals(entry[1], key))
309
+ if (Chunk.isNonEmpty(toRemove)) {
310
+ const currentSize = tRef.unsafeGet(self.tSize, journal)
311
+ tRef.unsafeSet(buckets.chunk[index], toRetain, journal)
312
+ tRef.unsafeSet(self.tSize, currentSize - 1, journal)
313
+ }
314
+ }))
315
+
316
+ /** @internal */
317
+ export const removeAll = dual<
318
+ <K>(keys: Iterable<K>) => <V>(self: TMap.TMap<K, V>) => STM.STM<void>,
319
+ <K, V>(self: TMap.TMap<K, V>, keys: Iterable<K>) => STM.STM<void>
320
+ >(2, <K, V>(self: TMap.TMap<K, V>, keys: Iterable<K>) =>
321
+ core.effect<never, void>((journal) => {
322
+ const iterator = keys[Symbol.iterator]()
323
+ let next: IteratorResult<K, any>
324
+ while ((next = iterator.next()) && !next.done) {
325
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
326
+ const index = indexOf(next.value, buckets.chunk.length)
327
+ const bucket = tRef.unsafeGet(buckets.chunk[index], journal)
328
+ const [toRemove, toRetain] = Chunk.partition(bucket, (entry) => Equal.equals(next.value)(entry[0]))
329
+ if (Chunk.isNonEmpty(toRemove)) {
330
+ const currentSize = tRef.unsafeGet(self.tSize, journal)
331
+ tRef.unsafeSet(buckets.chunk[index], toRetain, journal)
332
+ tRef.unsafeSet(self.tSize, currentSize - 1, journal)
333
+ }
334
+ }
335
+ }))
336
+
337
+ /** @internal */
338
+ export const removeIf: {
339
+ <K, V>(
340
+ predicate: (key: K, value: V) => boolean,
341
+ options: {
342
+ readonly discard: true
343
+ }
344
+ ): (self: TMap.TMap<K, V>) => STM.STM<void>
345
+ <K, V>(
346
+ predicate: (key: K, value: V) => boolean,
347
+ options?: {
348
+ readonly discard: false
349
+ }
350
+ ): (self: TMap.TMap<K, V>) => STM.STM<Array<[K, V]>>
351
+ <K, V>(
352
+ self: TMap.TMap<K, V>,
353
+ predicate: (key: K, value: V) => boolean,
354
+ options: {
355
+ readonly discard: true
356
+ }
357
+ ): STM.STM<void>
358
+ <K, V>(
359
+ self: TMap.TMap<K, V>,
360
+ predicate: (key: K, value: V) => boolean,
361
+ options?: {
362
+ readonly discard: false
363
+ }
364
+ ): STM.STM<Array<[K, V]>>
365
+ } = dual((args) => isTMap(args[0]), <K, V>(
366
+ self: TMap.TMap<K, V>,
367
+ predicate: (key: K, value: V) => boolean,
368
+ options?: {
369
+ readonly discard: boolean
370
+ }
371
+ ) =>
372
+ core.effect((journal) => {
373
+ const discard = options?.discard === true
374
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
375
+ const capacity = buckets.chunk.length
376
+ const removed: Array<[K, V]> = []
377
+ let index = 0
378
+ let newSize = 0
379
+ while (index < capacity) {
380
+ const bucket = tRef.unsafeGet(buckets.chunk[index], journal)
381
+ const iterator = bucket[Symbol.iterator]()
382
+ let next: IteratorResult<readonly [K, V], any>
383
+ let newBucket = Chunk.empty<readonly [K, V]>()
384
+ while ((next = iterator.next()) && !next.done) {
385
+ const [k, v] = next.value
386
+ if (!predicate(k, v)) {
387
+ newBucket = Chunk.prepend(newBucket, next.value)
388
+ newSize = newSize + 1
389
+ } else {
390
+ if (!discard) {
391
+ removed.push([k, v])
392
+ }
393
+ }
394
+ }
395
+ tRef.unsafeSet(buckets.chunk[index], newBucket, journal)
396
+ index = index + 1
397
+ }
398
+ tRef.unsafeSet(self.tSize, newSize, journal)
399
+ if (!discard) {
400
+ return removed
401
+ }
402
+ }))
403
+
404
+ /** @internal */
405
+ export const retainIf: {
406
+ <K, V>(
407
+ predicate: (key: K, value: V) => boolean,
408
+ options: {
409
+ readonly discard: true
410
+ }
411
+ ): (self: TMap.TMap<K, V>) => STM.STM<void>
412
+ <K, V>(
413
+ predicate: (key: K, value: V) => boolean,
414
+ options?: {
415
+ readonly discard: false
416
+ }
417
+ ): (self: TMap.TMap<K, V>) => STM.STM<Array<[K, V]>>
418
+ <K, V>(
419
+ self: TMap.TMap<K, V>,
420
+ predicate: (key: K, value: V) => boolean,
421
+ options: {
422
+ readonly discard: true
423
+ }
424
+ ): STM.STM<void>
425
+ <K, V>(
426
+ self: TMap.TMap<K, V>,
427
+ predicate: (key: K, value: V) => boolean,
428
+ options?: {
429
+ readonly discard: false
430
+ }
431
+ ): STM.STM<Array<[K, V]>>
432
+ } = dual(
433
+ (args) => isTMap(args[0]),
434
+ (self, predicate, options) => removeIf(self, (key, value) => !predicate(key, value), options)
435
+ )
436
+
437
+ /** @internal */
438
+ export const set = dual<
439
+ <K, V>(key: K, value: V) => (self: TMap.TMap<K, V>) => STM.STM<void>,
440
+ <K, V>(self: TMap.TMap<K, V>, key: K, value: V) => STM.STM<void>
441
+ >(3, <K, V>(self: TMap.TMap<K, V>, key: K, value: V) => {
442
+ const resize = (journal: Journal.Journal, buckets: TArray.TArray<Chunk.Chunk<readonly [K, V]>>): void => {
443
+ const capacity = buckets.chunk.length
444
+ const newCapacity = capacity << 1
445
+ const newBuckets = Array.from({ length: newCapacity }, () => Chunk.empty<readonly [K, V]>())
446
+ let index = 0
447
+ while (index < capacity) {
448
+ const pairs = tRef.unsafeGet(buckets.chunk[index], journal)
449
+ const iterator = pairs[Symbol.iterator]()
450
+ let next: IteratorResult<readonly [K, V], any>
451
+ while ((next = iterator.next()) && !next.done) {
452
+ const newIndex = indexOf(next.value[0], newCapacity)
453
+ newBuckets[newIndex] = Chunk.prepend(newBuckets[newIndex], next.value)
454
+ }
455
+ index = index + 1
456
+ }
457
+ // insert new pair
458
+ const newIndex = indexOf(key, newCapacity)
459
+ newBuckets[newIndex] = Chunk.prepend(newBuckets[newIndex], [key, value] as const)
460
+
461
+ const newArray: Array<TRef.TRef<Chunk.Chunk<readonly [K, V]>>> = []
462
+ index = 0
463
+ while (index < newCapacity) {
464
+ newArray[index] = new tRef.TRefImpl(newBuckets[index])
465
+ index = index + 1
466
+ }
467
+ const newTArray: TArray.TArray<Chunk.Chunk<readonly [K, V]>> = new tArray.TArrayImpl(newArray)
468
+ tRef.unsafeSet(self.tBuckets, newTArray, journal)
469
+ }
470
+ return core.effect<never, void>((journal) => {
471
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
472
+ const capacity = buckets.chunk.length
473
+ const index = indexOf(key, capacity)
474
+ const bucket = tRef.unsafeGet(buckets.chunk[index], journal)
475
+ const shouldUpdate = Chunk.some(bucket, (entry) => Equal.equals(key)(entry[0]))
476
+ if (shouldUpdate) {
477
+ const newBucket = Chunk.map(bucket, (entry) =>
478
+ Equal.equals(key)(entry[0]) ?
479
+ [key, value] as const :
480
+ entry)
481
+ tRef.unsafeSet(buckets.chunk[index], newBucket, journal)
482
+ } else {
483
+ const newSize = tRef.unsafeGet(self.tSize, journal) + 1
484
+ tRef.unsafeSet(self.tSize, newSize, journal)
485
+ if (capacity * LoadFactor < newSize) {
486
+ resize(journal, buckets)
487
+ } else {
488
+ const newBucket = Chunk.prepend(bucket, [key, value] as const)
489
+ tRef.unsafeSet(buckets.chunk[index], newBucket, journal)
490
+ }
491
+ }
492
+ })
493
+ })
494
+
495
+ /** @internal */
496
+ export const setIfAbsent = dual<
497
+ <K, V>(key: K, value: V) => (self: TMap.TMap<K, V>) => STM.STM<void>,
498
+ <K, V>(self: TMap.TMap<K, V>, key: K, value: V) => STM.STM<void>
499
+ >(3, (self, key, value) =>
500
+ core.flatMap(
501
+ get(self, key),
502
+ Option.match({
503
+ onNone: () => set(self, key, value),
504
+ onSome: () => stm.void
505
+ })
506
+ ))
507
+
508
+ /** @internal */
509
+ export const size = <K, V>(self: TMap.TMap<K, V>): STM.STM<number> => tRef.get(self.tSize)
510
+
511
+ /** @internal */
512
+ export const takeFirst = dual<
513
+ <K, V, A>(pf: (key: K, value: V) => Option.Option<A>) => (self: TMap.TMap<K, V>) => STM.STM<A>,
514
+ <K, V, A>(self: TMap.TMap<K, V>, pf: (key: K, value: V) => Option.Option<A>) => STM.STM<A>
515
+ >(2, <K, V, A>(self: TMap.TMap<K, V>, pf: (key: K, value: V) => Option.Option<A>) =>
516
+ pipe(
517
+ core.effect<never, Option.Option<A>>((journal) => {
518
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
519
+ const capacity = buckets.chunk.length
520
+ const size = tRef.unsafeGet(self.tSize, journal)
521
+ let result: Option.Option<A> = Option.none()
522
+ let index = 0
523
+ while (index < capacity && Option.isNone(result)) {
524
+ const bucket = tRef.unsafeGet(buckets.chunk[index], journal)
525
+ const recreate = Chunk.some(bucket, (entry) => Option.isSome(pf(entry[0], entry[1])))
526
+ if (recreate) {
527
+ const iterator = bucket[Symbol.iterator]()
528
+ let newBucket = Chunk.empty<readonly [K, V]>()
529
+ let next: IteratorResult<readonly [K, V], any>
530
+ while ((next = iterator.next()) && !next.done && Option.isNone(result)) {
531
+ const option = pf(next.value[0], next.value[1])
532
+ if (Option.isSome(option) && Option.isNone(result)) {
533
+ result = option
534
+ } else {
535
+ newBucket = Chunk.prepend(newBucket, next.value)
536
+ }
537
+ }
538
+ tRef.unsafeSet(buckets.chunk[index], newBucket, journal)
539
+ }
540
+ index = index + 1
541
+ }
542
+ if (Option.isSome(result)) {
543
+ tRef.unsafeSet(self.tSize, size - 1, journal)
544
+ }
545
+ return result
546
+ }),
547
+ stm.collect((option) =>
548
+ Option.isSome(option) ?
549
+ Option.some(option.value) :
550
+ Option.none<A>()
551
+ )
552
+ ))
553
+
554
+ /** @internal */
555
+ export const takeFirstSTM = dual<
556
+ <K, V, A, E, R>(
557
+ pf: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
558
+ ) => (self: TMap.TMap<K, V>) => STM.STM<A, E, R>,
559
+ <K, V, A, E, R>(self: TMap.TMap<K, V>, pf: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>) => STM.STM<A, E, R>
560
+ >(2, (self, pf) =>
561
+ pipe(
562
+ findSTM(self, (key, value) => core.map(pf(key, value), (a) => [key, a] as const)),
563
+ stm.collect((option) => Option.isSome(option) ? Option.some(option.value) : Option.none()),
564
+ core.flatMap((entry) => stm.as(remove(self, entry[0]), entry[1]))
565
+ ))
566
+
567
+ /** @internal */
568
+ export const takeSome = dual<
569
+ <K, V, A>(
570
+ pf: (key: K, value: V) => Option.Option<A>
571
+ ) => (self: TMap.TMap<K, V>) => STM.STM<RA.NonEmptyArray<A>>,
572
+ <K, V, A>(
573
+ self: TMap.TMap<K, V>,
574
+ pf: (key: K, value: V) => Option.Option<A>
575
+ ) => STM.STM<RA.NonEmptyArray<A>>
576
+ >(2, <K, V, A>(self: TMap.TMap<K, V>, pf: (key: K, value: V) => Option.Option<A>) =>
577
+ pipe(
578
+ core.effect<never, Option.Option<RA.NonEmptyArray<A>>>((journal) => {
579
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
580
+ const capacity = buckets.chunk.length
581
+ const builder: Array<A> = []
582
+ let newSize = 0
583
+ let index = 0
584
+ while (index < capacity) {
585
+ const bucket = tRef.unsafeGet(buckets.chunk[index], journal)
586
+ const recreate = Chunk.some(bucket, (entry) => Option.isSome(pf(entry[0], entry[1])))
587
+ if (recreate) {
588
+ const iterator = bucket[Symbol.iterator]()
589
+ let newBucket = Chunk.empty<readonly [K, V]>()
590
+ let next: IteratorResult<readonly [K, V], any>
591
+ while ((next = iterator.next()) && !next.done) {
592
+ const option = pf(next.value[0], next.value[1])
593
+ if (Option.isSome(option)) {
594
+ builder.push(option.value)
595
+ } else {
596
+ newBucket = Chunk.prepend(newBucket, next.value)
597
+ newSize = newSize + 1
598
+ }
599
+ }
600
+ tRef.unsafeSet(buckets.chunk[index], newBucket, journal)
601
+ } else {
602
+ newSize = newSize + bucket.length
603
+ }
604
+ index = index + 1
605
+ }
606
+ tRef.unsafeSet(self.tSize, newSize, journal)
607
+ if (builder.length > 0) {
608
+ return Option.some(builder as RA.NonEmptyArray<A>)
609
+ }
610
+ return Option.none()
611
+ }),
612
+ stm.collect((option) =>
613
+ Option.isSome(option) ?
614
+ Option.some(option.value) :
615
+ Option.none<RA.NonEmptyArray<A>>()
616
+ )
617
+ ))
618
+
619
+ /** @internal */
620
+ export const takeSomeSTM = dual<
621
+ <K, V, A, E, R>(
622
+ pf: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
623
+ ) => (self: TMap.TMap<K, V>) => STM.STM<RA.NonEmptyArray<A>, E, R>,
624
+ <K, V, A, E, R>(
625
+ self: TMap.TMap<K, V>,
626
+ pf: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
627
+ ) => STM.STM<RA.NonEmptyArray<A>, E, R>
628
+ >(2, <K, V, A, E, R>(
629
+ self: TMap.TMap<K, V>,
630
+ pf: (key: K, value: V) => STM.STM<A, Option.Option<E>, R>
631
+ ) =>
632
+ pipe(
633
+ findAllSTM(
634
+ self,
635
+ (key, value) => core.map(pf(key, value), (a) => [key, a] as const)
636
+ ),
637
+ core.map((chunk) =>
638
+ RA.isNonEmptyArray(chunk) ?
639
+ Option.some(chunk) :
640
+ Option.none()
641
+ ),
642
+ stm.collect((option) =>
643
+ Option.isSome(option) ?
644
+ Option.some(option.value) :
645
+ Option.none()
646
+ ),
647
+ core.flatMap((entries) =>
648
+ stm.as(
649
+ removeAll(self, entries.map((entry) => entry[0])),
650
+ RA.map(entries, (entry) => entry[1]) as RA.NonEmptyArray<A>
651
+ )
652
+ )
653
+ ))
654
+
655
+ const toReadonlyArray = <K, V>(self: TMap.TMap<K, V>): STM.STM<ReadonlyArray<readonly [K, V]>> =>
656
+ core.effect<never, Array<readonly [K, V]>>((journal) => {
657
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
658
+ const capacity = buckets.chunk.length
659
+ const builder: Array<readonly [K, V]> = []
660
+ let index = 0
661
+ while (index < capacity) {
662
+ const bucket = buckets.chunk[index]
663
+ for (const entry of tRef.unsafeGet(bucket, journal)) {
664
+ builder.push(entry)
665
+ }
666
+ index = index + 1
667
+ }
668
+ return builder
669
+ })
670
+
671
+ /** @internal */
672
+ export const toChunk = <K, V>(self: TMap.TMap<K, V>): STM.STM<Chunk.Chunk<[K, V]>> =>
673
+ reduce(
674
+ self,
675
+ Chunk.empty<[K, V]>(),
676
+ (acc, value, key) => Chunk.append(acc, [key, value])
677
+ )
678
+
679
+ /** @internal */
680
+ export const toHashMap = <K, V>(self: TMap.TMap<K, V>): STM.STM<HashMap.HashMap<K, V>> =>
681
+ reduce(
682
+ self,
683
+ HashMap.empty<K, V>(),
684
+ (acc, value, key) => pipe(acc, HashMap.set(key, value))
685
+ )
686
+
687
+ /** @internal */
688
+ export const toArray = <K, V>(self: TMap.TMap<K, V>): STM.STM<Array<[K, V]>> =>
689
+ reduce(
690
+ self,
691
+ [] as Array<[K, V]>,
692
+ (acc, value, key) => {
693
+ acc.unshift([key, value])
694
+ return acc
695
+ }
696
+ )
697
+
698
+ /** @internal */
699
+ export const toMap = <K, V>(self: TMap.TMap<K, V>): STM.STM<Map<K, V>> =>
700
+ reduce(
701
+ self,
702
+ new Map<K, V>(),
703
+ (acc, value, key) => acc.set(key, value)
704
+ )
705
+
706
+ /** @internal */
707
+ export const transform = dual<
708
+ <K, V>(f: (key: K, value: V) => readonly [K, V]) => (self: TMap.TMap<K, V>) => STM.STM<void>,
709
+ <K, V>(self: TMap.TMap<K, V>, f: (key: K, value: V) => readonly [K, V]) => STM.STM<void>
710
+ >(
711
+ 2,
712
+ <K, V>(self: TMap.TMap<K, V>, f: (key: K, value: V) => readonly [K, V]) =>
713
+ core.effect<never, void>((journal) => {
714
+ const buckets = pipe(self.tBuckets, tRef.unsafeGet(journal))
715
+ const capacity = buckets.chunk.length
716
+ const newBuckets = Array.from({ length: capacity }, () => Chunk.empty<readonly [K, V]>())
717
+ let newSize = 0
718
+ let index = 0
719
+ while (index < capacity) {
720
+ const bucket = buckets.chunk[index]
721
+ const pairs = tRef.unsafeGet(bucket, journal)
722
+ const iterator = pairs[Symbol.iterator]()
723
+ let next: IteratorResult<readonly [K, V], any>
724
+ while ((next = iterator.next()) && !next.done) {
725
+ const newPair = f(next.value[0], next.value[1])
726
+ const index = indexOf(newPair[0], capacity)
727
+ const newBucket = newBuckets[index]
728
+ if (!Chunk.some(newBucket, (entry) => Equal.equals(entry[0], newPair[0]))) {
729
+ newBuckets[index] = Chunk.prepend(newBucket, newPair)
730
+ newSize = newSize + 1
731
+ }
732
+ }
733
+ index = index + 1
734
+ }
735
+ index = 0
736
+ while (index < capacity) {
737
+ tRef.unsafeSet(buckets.chunk[index], newBuckets[index], journal)
738
+ index = index + 1
739
+ }
740
+ tRef.unsafeSet(self.tSize, newSize, journal)
741
+ })
742
+ )
743
+
744
+ /** @internal */
745
+ export const transformSTM = dual<
746
+ <K, V, R, E>(
747
+ f: (key: K, value: V) => STM.STM<readonly [K, V], E, R>
748
+ ) => (self: TMap.TMap<K, V>) => STM.STM<void, E, R>,
749
+ <K, V, R, E>(self: TMap.TMap<K, V>, f: (key: K, value: V) => STM.STM<readonly [K, V], E, R>) => STM.STM<void, E, R>
750
+ >(
751
+ 2,
752
+ <K, V, R, E>(self: TMap.TMap<K, V>, f: (key: K, value: V) => STM.STM<readonly [K, V], E, R>) =>
753
+ pipe(
754
+ core.flatMap(
755
+ toReadonlyArray(self),
756
+ stm.forEach((entry) => f(entry[0], entry[1]))
757
+ ),
758
+ core.flatMap((newData) =>
759
+ core.effect<never, void>((journal) => {
760
+ const buckets = tRef.unsafeGet(self.tBuckets, journal)
761
+ const capacity = buckets.chunk.length
762
+ const newBuckets = Array.from({ length: capacity }, () => Chunk.empty<readonly [K, V]>())
763
+ const iterator = newData[Symbol.iterator]()
764
+ let newSize = 0
765
+ let next: IteratorResult<readonly [K, V], any>
766
+ while ((next = iterator.next()) && !next.done) {
767
+ const index = indexOf(next.value[0], capacity)
768
+ const newBucket = newBuckets[index]
769
+ if (!Chunk.some(newBucket, (entry) => Equal.equals(entry[0])(next.value[0]))) {
770
+ newBuckets[index] = Chunk.prepend(newBucket, next.value)
771
+ newSize = newSize + 1
772
+ }
773
+ }
774
+ let index = 0
775
+ while (index < capacity) {
776
+ tRef.unsafeSet(buckets.chunk[index], newBuckets[index], journal)
777
+ index = index + 1
778
+ }
779
+ tRef.unsafeSet(self.tSize, newSize, journal)
780
+ })
781
+ )
782
+ )
783
+ )
784
+
785
+ /** @internal */
786
+ export const transformValues = dual<
787
+ <V>(f: (value: V) => V) => <K>(self: TMap.TMap<K, V>) => STM.STM<void>,
788
+ <K, V>(self: TMap.TMap<K, V>, f: (value: V) => V) => STM.STM<void>
789
+ >(2, (self, f) => transform(self, (key, value) => [key, f(value)]))
790
+
791
+ /** @internal */
792
+ export const transformValuesSTM = dual<
793
+ <V, R, E>(f: (value: V) => STM.STM<V, E, R>) => <K>(self: TMap.TMap<K, V>) => STM.STM<void, E, R>,
794
+ <K, V, R, E>(self: TMap.TMap<K, V>, f: (value: V) => STM.STM<V, E, R>) => STM.STM<void, E, R>
795
+ >(2, (self, f) =>
796
+ transformSTM(
797
+ self,
798
+ (key, value) => core.map(f(value), (value) => [key, value])
799
+ ))
800
+
801
+ /** @internal */
802
+ export const updateWith = dual<
803
+ <K, V>(
804
+ key: K,
805
+ f: (value: Option.Option<V>) => Option.Option<V>
806
+ ) => (self: TMap.TMap<K, V>) => STM.STM<Option.Option<V>>,
807
+ <K, V>(
808
+ self: TMap.TMap<K, V>,
809
+ key: K,
810
+ f: (value: Option.Option<V>) => Option.Option<V>
811
+ ) => STM.STM<Option.Option<V>>
812
+ >(3, (self, key, f) =>
813
+ core.flatMap(get(self, key), (option) =>
814
+ Option.match(
815
+ f(option),
816
+ {
817
+ onNone: () => stm.as(remove(self, key), Option.none()),
818
+ onSome: (value) => stm.as(set(self, key, value), Option.some(value))
819
+ }
820
+ )))
821
+
822
+ /** @internal */
823
+ export const values = <K, V>(self: TMap.TMap<K, V>): STM.STM<Array<V>> =>
824
+ core.map(toReadonlyArray(self), RA.map((entry) => entry[1]))