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

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,530 @@
1
+ import * as Cause from "../Cause.js"
2
+ import type * as Channel from "../Channel.js"
3
+ import * as Chunk from "../Chunk.js"
4
+ import * as Deferred from "../Deferred.js"
5
+ import * as Effect from "../Effect.js"
6
+ import * as Effectable from "../Effectable.js"
7
+ import * as Exit from "../Exit.js"
8
+ import { dual, pipe } from "../Function.js"
9
+ import type * as GroupBy from "../GroupBy.js"
10
+ import * as Option from "../Option.js"
11
+ import { pipeArguments } from "../Pipeable.js"
12
+ import { hasProperty, type Predicate } from "../Predicate.js"
13
+ import * as Queue from "../Queue.js"
14
+ import * as Ref from "../Ref.js"
15
+ import * as Scope from "../Scope.js"
16
+ import type * as Stream from "../Stream.js"
17
+ import type * as Take from "../Take.js"
18
+ import type { NoInfer } from "../Types.js"
19
+ import * as channel from "./channel.js"
20
+ import * as channelExecutor from "./channel/channelExecutor.js"
21
+ import * as core from "./core-stream.js"
22
+ import * as stream from "./stream.js"
23
+ import * as take from "./take.js"
24
+
25
+ /** @internal */
26
+ const GroupBySymbolKey = "effect/GroupBy"
27
+
28
+ /** @internal */
29
+ export const GroupByTypeId: GroupBy.GroupByTypeId = Symbol.for(
30
+ GroupBySymbolKey
31
+ ) as GroupBy.GroupByTypeId
32
+
33
+ const groupByVariance = {
34
+ /* c8 ignore next */
35
+ _R: (_: never) => _,
36
+ /* c8 ignore next */
37
+ _E: (_: never) => _,
38
+ /* c8 ignore next */
39
+ _K: (_: never) => _,
40
+ /* c8 ignore next */
41
+ _V: (_: never) => _
42
+ }
43
+
44
+ /** @internal */
45
+ export const isGroupBy = (u: unknown): u is GroupBy.GroupBy<unknown, unknown, unknown, unknown> =>
46
+ hasProperty(u, GroupByTypeId)
47
+
48
+ /** @internal */
49
+ export const evaluate = dual<
50
+ <K, V, E, A, E2, R2>(
51
+ f: (key: K, stream: Stream.Stream<V, E>) => Stream.Stream<A, E2, R2>,
52
+ options?: {
53
+ readonly bufferSize?: number | undefined
54
+ }
55
+ ) => <R>(self: GroupBy.GroupBy<K, V, E, R>) => Stream.Stream<A, E | E2, R2 | R>,
56
+ <K, V, E, R, A, E2, R2>(
57
+ self: GroupBy.GroupBy<K, V, E, R>,
58
+ f: (key: K, stream: Stream.Stream<V, E>) => Stream.Stream<A, E2, R2>,
59
+ options?: {
60
+ readonly bufferSize?: number | undefined
61
+ }
62
+ ) => Stream.Stream<A, E | E2, R2 | R>
63
+ >(
64
+ (args) => isGroupBy(args[0]),
65
+ <K, V, E, R, A, E2, R2>(
66
+ self: GroupBy.GroupBy<K, V, E, R>,
67
+ f: (key: K, stream: Stream.Stream<V, E>) => Stream.Stream<A, E2, R2>,
68
+ options?: {
69
+ readonly bufferSize?: number | undefined
70
+ }
71
+ ): Stream.Stream<A, E | E2, R2 | R> =>
72
+ stream.flatMap(
73
+ self.grouped,
74
+ ([key, queue]) => f(key, stream.flattenTake(stream.fromQueue(queue, { shutdown: true }))),
75
+ { concurrency: "unbounded", bufferSize: options?.bufferSize ?? 16 }
76
+ )
77
+ )
78
+
79
+ /** @internal */
80
+ export const filter = dual<
81
+ <K>(predicate: Predicate<NoInfer<K>>) => <V, E, R>(self: GroupBy.GroupBy<K, V, E, R>) => GroupBy.GroupBy<K, V, E, R>,
82
+ <K, V, E, R>(self: GroupBy.GroupBy<K, V, E, R>, predicate: Predicate<K>) => GroupBy.GroupBy<K, V, E, R>
83
+ >(2, <K, V, E, R>(self: GroupBy.GroupBy<K, V, E, R>, predicate: Predicate<K>): GroupBy.GroupBy<K, V, E, R> =>
84
+ make(
85
+ pipe(
86
+ self.grouped,
87
+ stream.filterEffect((tuple) => {
88
+ if (predicate(tuple[0])) {
89
+ return pipe(Effect.succeed(tuple), Effect.as(true))
90
+ }
91
+ return pipe(Queue.shutdown(tuple[1]), Effect.as(false))
92
+ })
93
+ )
94
+ ))
95
+
96
+ /** @internal */
97
+ export const first = dual<
98
+ (n: number) => <K, V, E, R>(self: GroupBy.GroupBy<K, V, E, R>) => GroupBy.GroupBy<K, V, E, R>,
99
+ <K, V, E, R>(self: GroupBy.GroupBy<K, V, E, R>, n: number) => GroupBy.GroupBy<K, V, E, R>
100
+ >(2, <K, V, E, R>(self: GroupBy.GroupBy<K, V, E, R>, n: number): GroupBy.GroupBy<K, V, E, R> =>
101
+ make(
102
+ pipe(
103
+ stream.zipWithIndex(self.grouped),
104
+ stream.filterEffect((tuple) => {
105
+ const index = tuple[1]
106
+ const queue = tuple[0][1]
107
+ if (index < n) {
108
+ return pipe(Effect.succeed(tuple), Effect.as(true))
109
+ }
110
+ return pipe(Queue.shutdown(queue), Effect.as(false))
111
+ }),
112
+ stream.map((tuple) => tuple[0])
113
+ )
114
+ ))
115
+
116
+ /** @internal */
117
+ export const make = <K, V, E, R>(
118
+ grouped: Stream.Stream<readonly [K, Queue.Dequeue<Take.Take<V, E>>], E, R>
119
+ ): GroupBy.GroupBy<K, V, E, R> => ({
120
+ [GroupByTypeId]: groupByVariance,
121
+ pipe() {
122
+ return pipeArguments(this, arguments)
123
+ },
124
+ grouped
125
+ })
126
+
127
+ // Circular with Stream
128
+
129
+ /** @internal */
130
+ export const groupBy = dual<
131
+ <A, K, V, E2, R2>(
132
+ f: (a: A) => Effect.Effect<readonly [K, V], E2, R2>,
133
+ options?: {
134
+ readonly bufferSize?: number | undefined
135
+ }
136
+ ) => <E, R>(self: Stream.Stream<A, E, R>) => GroupBy.GroupBy<K, V, E2 | E, R2 | R>,
137
+ <A, E, R, K, V, E2, R2>(
138
+ self: Stream.Stream<A, E, R>,
139
+ f: (a: A) => Effect.Effect<readonly [K, V], E2, R2>,
140
+ options?: {
141
+ readonly bufferSize?: number | undefined
142
+ }
143
+ ) => GroupBy.GroupBy<K, V, E2 | E, R2 | R>
144
+ >(
145
+ (args) => stream.isStream(args[0]),
146
+ <A, E, R, K, V, E2, R2>(
147
+ self: Stream.Stream<A, E, R>,
148
+ f: (a: A) => Effect.Effect<readonly [K, V], E2, R2>,
149
+ options?: {
150
+ readonly bufferSize?: number | undefined
151
+ }
152
+ ): GroupBy.GroupBy<K, V, E | E2, R | R2> =>
153
+ make(
154
+ stream.unwrapScoped(
155
+ Effect.gen(function*() {
156
+ const decider = yield* Deferred.make<(key: K, value: V) => Effect.Effect<Predicate<number>>>()
157
+ const output = yield* Effect.acquireRelease(
158
+ Queue.bounded<Exit.Exit<readonly [K, Queue.Dequeue<Take.Take<V, E | E2>>], Option.Option<E | E2>>>(
159
+ options?.bufferSize ?? 16
160
+ ),
161
+ (queue) => Queue.shutdown(queue)
162
+ )
163
+ const ref = yield* Ref.make<Map<K, number>>(new Map())
164
+ const add = yield* pipe(
165
+ stream.mapEffectSequential(self, f),
166
+ stream.distributedWithDynamicCallback(
167
+ options?.bufferSize ?? 16,
168
+ ([key, value]) => Effect.flatMap(Deferred.await(decider), (f) => f(key, value)),
169
+ (exit) => Queue.offer(output, exit)
170
+ )
171
+ )
172
+ yield* Deferred.succeed(decider, (key, _) =>
173
+ pipe(
174
+ Ref.get(ref),
175
+ Effect.map((map) => Option.fromNullable(map.get(key))),
176
+ Effect.flatMap(Option.match({
177
+ onNone: () =>
178
+ Effect.flatMap(add, ([index, queue]) =>
179
+ Effect.zipRight(
180
+ Ref.update(ref, (map) => map.set(key, index)),
181
+ pipe(
182
+ Queue.offer(
183
+ output,
184
+ Exit.succeed(
185
+ [
186
+ key,
187
+ mapDequeue(queue, (exit) =>
188
+ new take.TakeImpl(pipe(
189
+ exit,
190
+ Exit.map((tuple) => Chunk.of(tuple[1]))
191
+ )))
192
+ ] as const
193
+ )
194
+ ),
195
+ Effect.as<Predicate<number>>((n: number) => n === index)
196
+ )
197
+ )),
198
+ onSome: (index) => Effect.succeed<Predicate<number>>((n: number) => n === index)
199
+ }))
200
+ ))
201
+ return stream.flattenExitOption(stream.fromQueue(output, { shutdown: true }))
202
+ })
203
+ )
204
+ )
205
+ )
206
+
207
+ /** @internal */
208
+ export const mapEffectOptions = dual<
209
+ {
210
+ <A, A2, E2, R2>(
211
+ f: (a: A) => Effect.Effect<A2, E2, R2>,
212
+ options?: {
213
+ readonly concurrency?: number | "unbounded" | undefined
214
+ readonly unordered?: boolean | undefined
215
+ }
216
+ ): <E, R>(self: Stream.Stream<A, E, R>) => Stream.Stream<A2, E2 | E, R2 | R>
217
+ <A, A2, E2, R2, K>(
218
+ f: (a: A) => Effect.Effect<A2, E2, R2>,
219
+ options: {
220
+ readonly key: (a: A) => K
221
+ readonly bufferSize?: number | undefined
222
+ }
223
+ ): <E, R>(self: Stream.Stream<A, E, R>) => Stream.Stream<A2, E2 | E, R2 | R>
224
+ },
225
+ {
226
+ <A, E, R, A2, E2, R2>(
227
+ self: Stream.Stream<A, E, R>,
228
+ f: (a: A) => Effect.Effect<A2, E2, R2>,
229
+ options?: {
230
+ readonly concurrency?: number | "unbounded" | undefined
231
+ readonly unordered?: boolean | undefined
232
+ }
233
+ ): Stream.Stream<A2, E2 | E, R2 | R>
234
+ <A, E, R, A2, E2, R2, K>(
235
+ self: Stream.Stream<A, E, R>,
236
+ f: (a: A) => Effect.Effect<A2, E2, R2>,
237
+ options: {
238
+ readonly key: (a: A) => K
239
+ readonly bufferSize?: number | undefined
240
+ }
241
+ ): Stream.Stream<A2, E2 | E, R2 | R>
242
+ }
243
+ >(
244
+ (args) => typeof args[0] !== "function",
245
+ (<A, E, R, A2, E2, R2, K>(
246
+ self: Stream.Stream<A, E, R>,
247
+ f: (a: A) => Effect.Effect<A2, E2, R2>,
248
+ options?: {
249
+ readonly key?: ((a: A) => K) | undefined
250
+ readonly concurrency?: number | "unbounded" | undefined
251
+ readonly unordered?: boolean | undefined
252
+ readonly bufferSize?: number | undefined
253
+ }
254
+ ): Stream.Stream<A2, E2 | E, R2 | R> => {
255
+ if (options?.key) {
256
+ return evaluate(
257
+ groupByKey(self, options.key, { bufferSize: options.bufferSize }),
258
+ (_, s) => stream.mapEffectSequential(s, f)
259
+ )
260
+ }
261
+
262
+ return stream.matchConcurrency(
263
+ options?.concurrency,
264
+ () => stream.mapEffectSequential(self, f),
265
+ (n) =>
266
+ options?.unordered ?
267
+ stream.flatMap(self, (a) => stream.fromEffect(f(a)), { concurrency: n }) :
268
+ stream.mapEffectPar(self, n, f)
269
+ )
270
+ }) as any
271
+ )
272
+
273
+ /** @internal */
274
+ export const bindEffect = dual<
275
+ <N extends string, A, B, E2, R2>(
276
+ tag: Exclude<N, keyof A>,
277
+ f: (_: NoInfer<A>) => Effect.Effect<B, E2, R2>,
278
+ options?: {
279
+ readonly concurrency?: number | "unbounded" | undefined
280
+ readonly bufferSize?: number | undefined
281
+ }
282
+ ) => <E, R>(self: Stream.Stream<A, E, R>) => Stream.Stream<
283
+ { [K in keyof A | N]: K extends keyof A ? A[K] : B },
284
+ E | E2,
285
+ R | R2
286
+ >,
287
+ <A, E, R, N extends string, B, E2, R2>(
288
+ self: Stream.Stream<A, E, R>,
289
+ tag: Exclude<N, keyof A>,
290
+ f: (_: NoInfer<A>) => Effect.Effect<B, E2, R2>,
291
+ options?: {
292
+ readonly concurrency?: number | "unbounded" | undefined
293
+ readonly unordered?: boolean | undefined
294
+ }
295
+ ) => Stream.Stream<
296
+ { [K in keyof A | N]: K extends keyof A ? A[K] : B },
297
+ E | E2,
298
+ R | R2
299
+ >
300
+ >((args) => typeof args[0] !== "string", <A, E, R, N extends string, B, E2, R2>(
301
+ self: Stream.Stream<A, E, R>,
302
+ tag: Exclude<N, keyof A>,
303
+ f: (_: A) => Effect.Effect<B, E2, R2>,
304
+ options?: {
305
+ readonly concurrency?: number | "unbounded" | undefined
306
+ readonly unordered?: boolean | undefined
307
+ }
308
+ ) =>
309
+ mapEffectOptions(self, (k) =>
310
+ Effect.map(
311
+ f(k),
312
+ (a) => ({ ...k, [tag]: a } as { [K in keyof A | N]: K extends keyof A ? A[K] : B })
313
+ ), options))
314
+
315
+ const mapDequeue = <A, B>(dequeue: Queue.Dequeue<A>, f: (a: A) => B): Queue.Dequeue<B> => new MapDequeue(dequeue, f)
316
+
317
+ class MapDequeue<in out A, out B> extends Effectable.Class<B> implements Queue.Dequeue<B> {
318
+ readonly [Queue.DequeueTypeId] = {
319
+ _Out: (_: never) => _
320
+ }
321
+
322
+ constructor(
323
+ readonly dequeue: Queue.Dequeue<A>,
324
+ readonly f: (a: A) => B
325
+ ) {
326
+ super()
327
+ }
328
+
329
+ capacity(): number {
330
+ return Queue.capacity(this.dequeue)
331
+ }
332
+
333
+ get size(): Effect.Effect<number> {
334
+ return Queue.size(this.dequeue)
335
+ }
336
+
337
+ unsafeSize(): Option.Option<number> {
338
+ return this.dequeue.unsafeSize()
339
+ }
340
+
341
+ get awaitShutdown(): Effect.Effect<void> {
342
+ return Queue.awaitShutdown(this.dequeue)
343
+ }
344
+
345
+ isActive(): boolean {
346
+ return this.dequeue.isActive()
347
+ }
348
+
349
+ get isShutdown(): Effect.Effect<boolean> {
350
+ return Queue.isShutdown(this.dequeue)
351
+ }
352
+
353
+ get shutdown(): Effect.Effect<void> {
354
+ return Queue.shutdown(this.dequeue)
355
+ }
356
+
357
+ get isFull(): Effect.Effect<boolean> {
358
+ return Queue.isFull(this.dequeue)
359
+ }
360
+
361
+ get isEmpty(): Effect.Effect<boolean> {
362
+ return Queue.isEmpty(this.dequeue)
363
+ }
364
+
365
+ get take(): Effect.Effect<B> {
366
+ return pipe(Queue.take(this.dequeue), Effect.map((a) => this.f(a)))
367
+ }
368
+
369
+ get takeAll(): Effect.Effect<Chunk.Chunk<B>> {
370
+ return pipe(Queue.takeAll(this.dequeue), Effect.map(Chunk.map((a) => this.f(a))))
371
+ }
372
+
373
+ takeUpTo(max: number): Effect.Effect<Chunk.Chunk<B>> {
374
+ return pipe(Queue.takeUpTo(this.dequeue, max), Effect.map(Chunk.map((a) => this.f(a))))
375
+ }
376
+
377
+ takeBetween(min: number, max: number): Effect.Effect<Chunk.Chunk<B>> {
378
+ return pipe(Queue.takeBetween(this.dequeue, min, max), Effect.map(Chunk.map((a) => this.f(a))))
379
+ }
380
+
381
+ takeN(n: number): Effect.Effect<Chunk.Chunk<B>> {
382
+ return pipe(Queue.takeN(this.dequeue, n), Effect.map(Chunk.map((a) => this.f(a))))
383
+ }
384
+
385
+ poll(): Effect.Effect<Option.Option<B>> {
386
+ return pipe(Queue.poll(this.dequeue), Effect.map(Option.map((a) => this.f(a))))
387
+ }
388
+
389
+ pipe() {
390
+ return pipeArguments(this, arguments)
391
+ }
392
+
393
+ commit() {
394
+ return this.take
395
+ }
396
+ }
397
+
398
+ /** @internal */
399
+ export const groupByKey = dual<
400
+ <A, K>(
401
+ f: (a: A) => K,
402
+ options?: {
403
+ readonly bufferSize?: number | undefined
404
+ }
405
+ ) => <E, R>(self: Stream.Stream<A, E, R>) => GroupBy.GroupBy<K, A, E, R>,
406
+ <A, E, R, K>(
407
+ self: Stream.Stream<A, E, R>,
408
+ f: (a: A) => K,
409
+ options?: {
410
+ readonly bufferSize?: number | undefined
411
+ }
412
+ ) => GroupBy.GroupBy<K, A, E, R>
413
+ >(
414
+ (args) => typeof args[0] !== "function",
415
+ <A, E, R, K>(
416
+ self: Stream.Stream<A, E, R>,
417
+ f: (a: A) => K,
418
+ options?: {
419
+ readonly bufferSize?: number | undefined
420
+ }
421
+ ): GroupBy.GroupBy<K, A, E, R> => {
422
+ const loop = (
423
+ map: Map<K, Queue.Queue<Take.Take<A, E>>>,
424
+ outerQueue: Queue.Queue<Take.Take<readonly [K, Queue.Queue<Take.Take<A, E>>], E>>
425
+ ): Channel.Channel<never, Chunk.Chunk<A>, E, E, unknown, unknown, R> =>
426
+ core.readWithCause({
427
+ onInput: (input: Chunk.Chunk<A>) =>
428
+ core.flatMap(
429
+ core.fromEffect(
430
+ Effect.forEach(groupByIterable(input, f), ([key, values]) => {
431
+ const innerQueue = map.get(key)
432
+ if (innerQueue === undefined) {
433
+ return pipe(
434
+ Queue.bounded<Take.Take<A, E>>(options?.bufferSize ?? 16),
435
+ Effect.flatMap((innerQueue) =>
436
+ pipe(
437
+ Effect.sync(() => {
438
+ map.set(key, innerQueue)
439
+ }),
440
+ Effect.zipRight(
441
+ Queue.offer(outerQueue, take.of([key, innerQueue] as const))
442
+ ),
443
+ Effect.zipRight(
444
+ pipe(
445
+ Queue.offer(innerQueue, take.chunk(values)),
446
+ Effect.catchSomeCause((cause) =>
447
+ Cause.isInterruptedOnly(cause) ?
448
+ Option.some(Effect.void) :
449
+ Option.none()
450
+ )
451
+ )
452
+ )
453
+ )
454
+ )
455
+ )
456
+ }
457
+ return Effect.catchSomeCause(
458
+ Queue.offer(innerQueue, take.chunk(values)),
459
+ (cause) =>
460
+ Cause.isInterruptedOnly(cause) ?
461
+ Option.some(Effect.void) :
462
+ Option.none()
463
+ )
464
+ }, { discard: true })
465
+ ),
466
+ () => loop(map, outerQueue)
467
+ ),
468
+ onFailure: (cause) => core.fromEffect(Queue.offer(outerQueue, take.failCause(cause))),
469
+ onDone: () =>
470
+ core.fromEffect(
471
+ pipe(
472
+ Effect.forEach(map.entries(), ([_, innerQueue]) =>
473
+ pipe(
474
+ Queue.offer(innerQueue, take.end),
475
+ Effect.catchSomeCause((cause) =>
476
+ Cause.isInterruptedOnly(cause) ?
477
+ Option.some(Effect.void) :
478
+ Option.none()
479
+ )
480
+ ), { discard: true }),
481
+ Effect.zipRight(Queue.offer(outerQueue, take.end))
482
+ )
483
+ )
484
+ })
485
+ return make(stream.unwrapScopedWith((scope) =>
486
+ Effect.gen(function*() {
487
+ const map = new Map<K, Queue.Queue<Take.Take<A, E>>>()
488
+ const queue = yield* Queue.unbounded<Take.Take<readonly [K, Queue.Queue<Take.Take<A, E>>], E>>()
489
+ yield* Scope.addFinalizer(scope, Queue.shutdown(queue))
490
+ return yield* stream.toChannel(self).pipe(
491
+ core.pipeTo(loop(map, queue)),
492
+ channel.drain,
493
+ channelExecutor.runIn(scope),
494
+ Effect.forkIn(scope),
495
+ Effect.as(stream.flattenTake(stream.fromQueue(queue, { shutdown: true })))
496
+ )
497
+ })
498
+ ))
499
+ }
500
+ )
501
+
502
+ /**
503
+ * A variant of `groupBy` that retains the insertion order of keys.
504
+ *
505
+ * @internal
506
+ */
507
+ const groupByIterable = dual<
508
+ <V, K>(f: (value: V) => K) => (iterable: Iterable<V>) => Chunk.Chunk<[K, Chunk.Chunk<V>]>,
509
+ <V, K>(iterable: Iterable<V>, f: (value: V) => K) => Chunk.Chunk<[K, Chunk.Chunk<V>]>
510
+ >(2, <V, K>(iterable: Iterable<V>, f: (value: V) => K): Chunk.Chunk<[K, Chunk.Chunk<V>]> => {
511
+ const builder: Array<[K, Array<V>]> = []
512
+ const iterator = iterable[Symbol.iterator]()
513
+ const map = new Map<K, Array<V>>()
514
+ let next: IteratorResult<V, any>
515
+ while ((next = iterator.next()) && !next.done) {
516
+ const value = next.value
517
+ const key = f(value)
518
+ if (map.has(key)) {
519
+ const innerBuilder = map.get(key)!
520
+ innerBuilder.push(value)
521
+ } else {
522
+ const innerBuilder: Array<V> = [value]
523
+ builder.push([key, innerBuilder])
524
+ map.set(key, innerBuilder)
525
+ }
526
+ }
527
+ return Chunk.unsafeFromArray(
528
+ builder.map((tuple) => [tuple[0], Chunk.unsafeFromArray(tuple[1])])
529
+ )
530
+ })
@@ -0,0 +1,49 @@
1
+ /** @internal */
2
+ export function arrayUpdate<A>(mutate: boolean, at: number, v: A, arr: Array<A>) {
3
+ let out = arr
4
+ if (!mutate) {
5
+ const len = arr.length
6
+ out = new Array(len)
7
+ for (let i = 0; i < len; ++i) out[i] = arr[i]!
8
+ }
9
+ out[at] = v
10
+ return out
11
+ }
12
+
13
+ /** @internal */
14
+ export function arraySpliceOut<A>(mutate: boolean, at: number, arr: Array<A>) {
15
+ const newLen = arr.length - 1
16
+ let i = 0
17
+ let g = 0
18
+ let out = arr
19
+ if (mutate) {
20
+ i = g = at
21
+ } else {
22
+ out = new Array(newLen)
23
+ while (i < at) out[g++] = arr[i++]!
24
+ }
25
+ ++i
26
+ while (i <= newLen) out[g++] = arr[i++]!
27
+ if (mutate) {
28
+ out.length = newLen
29
+ }
30
+ return out
31
+ }
32
+
33
+ /** @internal */
34
+ export function arraySpliceIn<A>(mutate: boolean, at: number, v: A, arr: Array<A>) {
35
+ const len = arr.length
36
+ if (mutate) {
37
+ let i = len
38
+ while (i >= at) arr[i--] = arr[i]!
39
+ arr[at] = v
40
+ return arr
41
+ }
42
+ let i = 0,
43
+ g = 0
44
+ const out = new Array<A>(len + 1)
45
+ while (i < at) out[g++] = arr[i++]!
46
+ out[at] = v
47
+ while (i < len) out[++g] = arr[i++]!
48
+ return out
49
+ }
@@ -0,0 +1,32 @@
1
+ import { MASK } from "./config.js"
2
+
3
+ /**
4
+ * Hamming weight.
5
+ *
6
+ * Taken from: http://jsperf.com/hamming-weight
7
+ *
8
+ * @internal
9
+ */
10
+ export function popcount(x: number) {
11
+ x -= (x >> 1) & 0x55555555
12
+ x = (x & 0x33333333) + ((x >> 2) & 0x33333333)
13
+ x = (x + (x >> 4)) & 0x0f0f0f0f
14
+ x += x >> 8
15
+ x += x >> 16
16
+ return x & 0x7f
17
+ }
18
+
19
+ /** @internal */
20
+ export function hashFragment(shift: number, h: number) {
21
+ return (h >>> shift) & MASK
22
+ }
23
+
24
+ /** @internal */
25
+ export function toBitmap(x: number) {
26
+ return 1 << x
27
+ }
28
+
29
+ /** @internal */
30
+ export function fromBitmap(bitmap: number, bit: number) {
31
+ return popcount(bitmap & (bit - 1))
32
+ }
@@ -0,0 +1,14 @@
1
+ /** @internal */
2
+ export const SIZE = 5
3
+
4
+ /** @internal */
5
+ export const BUCKET_SIZE = Math.pow(2, SIZE)
6
+
7
+ /** @internal */
8
+ export const MASK = BUCKET_SIZE - 1
9
+
10
+ /** @internal */
11
+ export const MAX_INDEX_NODE = BUCKET_SIZE / 2
12
+
13
+ /** @internal */
14
+ export const MIN_ARRAY_NODE = BUCKET_SIZE / 4
@@ -0,0 +1,8 @@
1
+ import type { HashMap } from "../../HashMap.js"
2
+ import type { HashSet } from "../../HashSet.js"
3
+ import { makeImpl } from "../hashSet.js"
4
+
5
+ /** @internal */
6
+ export function keySet<K, V>(self: HashMap<K, V>): HashSet<K> {
7
+ return makeImpl(self)
8
+ }