@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,586 @@
1
+ import * as Equal from "../Equal.js"
2
+ import * as Dual from "../Function.js"
3
+ import { identity, pipe } from "../Function.js"
4
+ import * as Hash from "../Hash.js"
5
+ import type * as HM from "../HashMap.js"
6
+ import { format, NodeInspectSymbol, toJSON } from "../Inspectable.js"
7
+ import * as Option from "../Option.js"
8
+ import { pipeArguments } from "../Pipeable.js"
9
+ import { hasProperty } from "../Predicate.js"
10
+ import type { NoInfer } from "../Types.js"
11
+ import { fromBitmap, hashFragment, toBitmap } from "./hashMap/bitwise.js"
12
+ import { SIZE } from "./hashMap/config.js"
13
+ import * as Node from "./hashMap/node.js"
14
+
15
+ const HashMapSymbolKey = "effect/HashMap"
16
+
17
+ /** @internal */
18
+ export const HashMapTypeId: HM.TypeId = Symbol.for(HashMapSymbolKey) as HM.TypeId
19
+
20
+ type TraversalFn<K, V, A> = (k: K, v: V) => A
21
+
22
+ type Cont<K, V, A> =
23
+ | [
24
+ len: number,
25
+ children: Array<Node.Node<K, V>>,
26
+ i: number,
27
+ f: TraversalFn<K, V, A>,
28
+ cont: Cont<K, V, A>
29
+ ]
30
+ | undefined
31
+
32
+ interface VisitResult<K, V, A> {
33
+ value: A
34
+ cont: Cont<K, V, A>
35
+ }
36
+
37
+ /** @internal */
38
+ export interface HashMapImpl<out K, out V> extends HM.HashMap<K, V> {
39
+ _editable: boolean // mutable by design
40
+ _edit: number // mutable by design
41
+ _root: Node.Node<K, V> // mutable by design
42
+ _size: number // mutable by design
43
+ }
44
+
45
+ const HashMapProto: HM.HashMap<unknown, unknown> = {
46
+ [HashMapTypeId]: HashMapTypeId,
47
+ [Symbol.iterator]<K, V>(this: HashMapImpl<K, V>): Iterator<[K, V]> {
48
+ return new HashMapIterator(this, (k, v) => [k, v])
49
+ },
50
+ [Hash.symbol](this: HM.HashMap<unknown, unknown>): number {
51
+ let hash = Hash.hash(HashMapSymbolKey)
52
+ for (const item of this) {
53
+ hash ^= pipe(Hash.hash(item[0]), Hash.combine(Hash.hash(item[1])))
54
+ }
55
+ return Hash.cached(this, hash)
56
+ },
57
+ [Equal.symbol]<K, V>(this: HashMapImpl<K, V>, that: unknown): boolean {
58
+ if (isHashMap(that)) {
59
+ if ((that as HashMapImpl<K, V>)._size !== this._size) {
60
+ return false
61
+ }
62
+ for (const item of this) {
63
+ const elem = pipe(
64
+ that as HM.HashMap<K, V>,
65
+ getHash(item[0], Hash.hash(item[0]))
66
+ )
67
+ if (Option.isNone(elem)) {
68
+ return false
69
+ } else {
70
+ if (!Equal.equals(item[1], elem.value)) {
71
+ return false
72
+ }
73
+ }
74
+ }
75
+ return true
76
+ }
77
+ return false
78
+ },
79
+ toString<K, V>(this: HashMapImpl<K, V>) {
80
+ return format(this.toJSON())
81
+ },
82
+ toJSON() {
83
+ return {
84
+ _id: "HashMap",
85
+ values: Array.from(this).map(toJSON)
86
+ }
87
+ },
88
+ [NodeInspectSymbol]() {
89
+ return this.toJSON()
90
+ },
91
+ pipe() {
92
+ return pipeArguments(this, arguments)
93
+ }
94
+ }
95
+
96
+ const makeImpl = <K, V>(
97
+ editable: boolean,
98
+ edit: number,
99
+ root: Node.Node<K, V>,
100
+ size: number
101
+ ): HashMapImpl<K, V> => {
102
+ const map = Object.create(HashMapProto)
103
+ map._editable = editable
104
+ map._edit = edit
105
+ map._root = root
106
+ map._size = size
107
+ return map
108
+ }
109
+
110
+ class HashMapIterator<in out K, in out V, out T> implements IterableIterator<T> {
111
+ v: Option.Option<VisitResult<K, V, T>>
112
+
113
+ constructor(readonly map: HashMapImpl<K, V>, readonly f: TraversalFn<K, V, T>) {
114
+ this.v = visitLazy(this.map._root, this.f, undefined)
115
+ }
116
+
117
+ next(): IteratorResult<T> {
118
+ if (Option.isNone(this.v)) {
119
+ return { done: true, value: undefined }
120
+ }
121
+ const v0 = this.v.value
122
+ this.v = applyCont(v0.cont)
123
+ return { done: false, value: v0.value }
124
+ }
125
+
126
+ [Symbol.iterator](): IterableIterator<T> {
127
+ return new HashMapIterator(this.map, this.f)
128
+ }
129
+ }
130
+
131
+ const applyCont = <K, V, A>(cont: Cont<K, V, A>): Option.Option<VisitResult<K, V, A>> =>
132
+ cont
133
+ ? visitLazyChildren(cont[0], cont[1], cont[2], cont[3], cont[4])
134
+ : Option.none()
135
+
136
+ const visitLazy = <K, V, A>(
137
+ node: Node.Node<K, V>,
138
+ f: TraversalFn<K, V, A>,
139
+ cont: Cont<K, V, A> = undefined
140
+ ): Option.Option<VisitResult<K, V, A>> => {
141
+ switch (node._tag) {
142
+ case "LeafNode": {
143
+ if (Option.isSome(node.value)) {
144
+ return Option.some({
145
+ value: f(node.key, node.value.value),
146
+ cont
147
+ })
148
+ }
149
+ return applyCont(cont)
150
+ }
151
+ case "CollisionNode":
152
+ case "ArrayNode":
153
+ case "IndexedNode": {
154
+ const children = node.children
155
+ return visitLazyChildren(children.length, children, 0, f, cont)
156
+ }
157
+ default: {
158
+ return applyCont(cont)
159
+ }
160
+ }
161
+ }
162
+
163
+ const visitLazyChildren = <K, V, A>(
164
+ len: number,
165
+ children: Array<Node.Node<K, V>>,
166
+ i: number,
167
+ f: TraversalFn<K, V, A>,
168
+ cont: Cont<K, V, A>
169
+ ): Option.Option<VisitResult<K, V, A>> => {
170
+ while (i < len) {
171
+ const child = children[i++]
172
+ if (child && !Node.isEmptyNode(child)) {
173
+ return visitLazy(child, f, [len, children, i, f, cont])
174
+ }
175
+ }
176
+ return applyCont(cont)
177
+ }
178
+
179
+ const _empty = makeImpl<never, never>(false, 0, new Node.EmptyNode(), 0)
180
+
181
+ /** @internal */
182
+ export const empty = <K = never, V = never>(): HM.HashMap<K, V> => _empty
183
+
184
+ /** @internal */
185
+ export const make = <Entries extends ReadonlyArray<readonly [any, any]>>(
186
+ ...entries: Entries
187
+ ): HM.HashMap<
188
+ Entries[number] extends readonly [infer K, any] ? K : never,
189
+ Entries[number] extends readonly [any, infer V] ? V : never
190
+ > => fromIterable(entries)
191
+
192
+ /** @internal */
193
+ export const fromIterable = <K, V>(entries: Iterable<readonly [K, V]>): HM.HashMap<K, V> => {
194
+ const map = beginMutation(empty<K, V>())
195
+ for (const entry of entries) {
196
+ set(map, entry[0], entry[1])
197
+ }
198
+ return endMutation(map)
199
+ }
200
+
201
+ /** @internal */
202
+ export const isHashMap: {
203
+ <K, V>(u: Iterable<readonly [K, V]>): u is HM.HashMap<K, V>
204
+ (u: unknown): u is HM.HashMap<unknown, unknown>
205
+ } = (u: unknown): u is HM.HashMap<unknown, unknown> => hasProperty(u, HashMapTypeId)
206
+
207
+ /** @internal */
208
+ export const isEmpty = <K, V>(self: HM.HashMap<K, V>): boolean =>
209
+ self && Node.isEmptyNode((self as HashMapImpl<K, V>)._root)
210
+
211
+ /** @internal */
212
+ export const get = Dual.dual<
213
+ <K1 extends K, K>(key: K1) => <V>(self: HM.HashMap<K, V>) => Option.Option<V>,
214
+ <K, V, K1 extends K>(self: HM.HashMap<K, V>, key: K1) => Option.Option<V>
215
+ >(2, (self, key) => getHash(self, key, Hash.hash(key)))
216
+
217
+ /** @internal */
218
+ export const getHash = Dual.dual<
219
+ <K1 extends K, K>(key: K1, hash: number) => <V>(self: HM.HashMap<K, V>) => Option.Option<V>,
220
+ <K, V, K1 extends K>(self: HM.HashMap<K, V>, key: K1, hash: number) => Option.Option<V>
221
+ >(3, <K, V, K1 extends K>(self: HM.HashMap<K, V>, key: K1, hash: number) => {
222
+ let node = (self as HashMapImpl<K, V>)._root
223
+ let shift = 0
224
+
225
+ while (true) {
226
+ switch (node._tag) {
227
+ case "LeafNode": {
228
+ return Equal.equals(key, node.key) ? node.value : Option.none()
229
+ }
230
+ case "CollisionNode": {
231
+ if (hash === node.hash) {
232
+ const children = node.children
233
+ for (let i = 0, len = children.length; i < len; ++i) {
234
+ const child = children[i]!
235
+ if ("key" in child && Equal.equals(key, child.key)) {
236
+ return child.value
237
+ }
238
+ }
239
+ }
240
+ return Option.none()
241
+ }
242
+ case "IndexedNode": {
243
+ const frag = hashFragment(shift, hash)
244
+ const bit = toBitmap(frag)
245
+ if (node.mask & bit) {
246
+ node = node.children[fromBitmap(node.mask, bit)]!
247
+ shift += SIZE
248
+ break
249
+ }
250
+ return Option.none()
251
+ }
252
+ case "ArrayNode": {
253
+ node = node.children[hashFragment(shift, hash)]!
254
+ if (node) {
255
+ shift += SIZE
256
+ break
257
+ }
258
+ return Option.none()
259
+ }
260
+ default:
261
+ return Option.none()
262
+ }
263
+ }
264
+ })
265
+
266
+ /** @internal */
267
+ export const unsafeGet = Dual.dual<
268
+ <K1 extends K, K>(key: K1) => <V>(self: HM.HashMap<K, V>) => V,
269
+ <K, V, K1 extends K>(self: HM.HashMap<K, V>, key: K1) => V
270
+ >(2, (self, key) => {
271
+ const element = getHash(self, key, Hash.hash(key))
272
+ if (Option.isNone(element)) {
273
+ throw new Error("Expected map to contain key")
274
+ }
275
+ return element.value
276
+ })
277
+
278
+ /** @internal */
279
+ export const has = Dual.dual<
280
+ <K1 extends K, K>(key: K1) => <V>(self: HM.HashMap<K, V>) => boolean,
281
+ <K, V, K1 extends K>(self: HM.HashMap<K, V>, key: K1) => boolean
282
+ >(2, (self, key) => Option.isSome(getHash(self, key, Hash.hash(key))))
283
+
284
+ /** @internal */
285
+ export const hasHash = Dual.dual<
286
+ <K1 extends K, K>(key: K1, hash: number) => <V>(self: HM.HashMap<K, V>) => boolean,
287
+ <K, V, K1 extends K>(self: HM.HashMap<K, V>, key: K1, hash: number) => boolean
288
+ >(3, (self, key, hash) => Option.isSome(getHash(self, key, hash)))
289
+
290
+ /** @internal */
291
+ export const hasBy = Dual.dual<
292
+ <K, V>(predicate: (value: NoInfer<V>, key: NoInfer<K>) => boolean) => (self: HM.HashMap<K, V>) => boolean,
293
+ <K, V>(self: HM.HashMap<K, V>, predicate: (value: NoInfer<V>, key: NoInfer<K>) => boolean) => boolean
294
+ >(2, (self, predicate) => Option.isSome(findFirst(self, predicate)))
295
+
296
+ /** @internal */
297
+ export const set = Dual.dual<
298
+ <K, V>(key: K, value: V) => (self: HM.HashMap<K, V>) => HM.HashMap<K, V>,
299
+ <K, V>(self: HM.HashMap<K, V>, key: K, value: V) => HM.HashMap<K, V>
300
+ >(3, (self, key, value) => modifyAt(self, key, () => Option.some(value)))
301
+
302
+ /** @internal */
303
+ export const setTree = Dual.dual<
304
+ <K, V>(newRoot: Node.Node<K, V>, newSize: number) => (self: HM.HashMap<K, V>) => HM.HashMap<K, V>,
305
+ <K, V>(self: HM.HashMap<K, V>, newRoot: Node.Node<K, V>, newSize: number) => HM.HashMap<K, V>
306
+ >(3, <K, V>(self: HM.HashMap<K, V>, newRoot: Node.Node<K, V>, newSize: number) => {
307
+ if ((self as HashMapImpl<K, V>)._editable) {
308
+ ;(self as HashMapImpl<K, V>)._root = newRoot
309
+ ;(self as HashMapImpl<K, V>)._size = newSize
310
+ return self
311
+ }
312
+ return newRoot === (self as HashMapImpl<K, V>)._root
313
+ ? self
314
+ : makeImpl(
315
+ (self as HashMapImpl<K, V>)._editable,
316
+ (self as HashMapImpl<K, V>)._edit,
317
+ newRoot,
318
+ newSize
319
+ )
320
+ })
321
+
322
+ /** @internal */
323
+ export const keys = <K, V>(self: HM.HashMap<K, V>): IterableIterator<K> =>
324
+ new HashMapIterator(self as HashMapImpl<K, V>, (key) => key)
325
+
326
+ /** @internal */
327
+ export const values = <K, V>(self: HM.HashMap<K, V>): IterableIterator<V> =>
328
+ new HashMapIterator(self as HashMapImpl<K, V>, (_, value) => value)
329
+
330
+ /** @internal */
331
+ export const entries = <K, V>(self: HM.HashMap<K, V>): IterableIterator<[K, V]> =>
332
+ new HashMapIterator(self as HashMapImpl<K, V>, (key, value) => [key, value])
333
+
334
+ /** @internal */
335
+ export const size = <K, V>(self: HM.HashMap<K, V>): number => (self as HashMapImpl<K, V>)._size
336
+
337
+ /** @internal */
338
+ export const countBy = Dual.dual<
339
+ <K, V>(predicate: (value: NoInfer<V>, key: NoInfer<K>) => boolean) => (self: HM.HashMap<K, V>) => number,
340
+ <K, V>(self: HM.HashMap<K, V>, predicate: (value: NoInfer<V>, key: NoInfer<K>) => boolean) => number
341
+ >(2, (self, f) => {
342
+ let count = 0
343
+ for (const [k, a] of self) {
344
+ if (f(a, k)) {
345
+ count++
346
+ }
347
+ }
348
+ return count
349
+ })
350
+
351
+ /** @internal */
352
+ export const beginMutation = <K, V>(self: HM.HashMap<K, V>): HM.HashMap<K, V> =>
353
+ makeImpl(
354
+ true,
355
+ (self as HashMapImpl<K, V>)._edit + 1,
356
+ (self as HashMapImpl<K, V>)._root,
357
+ (self as HashMapImpl<K, V>)._size
358
+ )
359
+
360
+ /** @internal */
361
+ export const endMutation = <K, V>(self: HM.HashMap<K, V>): HM.HashMap<K, V> => {
362
+ ;(self as HashMapImpl<K, V>)._editable = false
363
+ return self
364
+ }
365
+
366
+ /** @internal */
367
+ export const mutate = Dual.dual<
368
+ <K, V>(f: (self: HM.HashMap<K, V>) => void) => (self: HM.HashMap<K, V>) => HM.HashMap<K, V>,
369
+ <K, V>(self: HM.HashMap<K, V>, f: (self: HM.HashMap<K, V>) => void) => HM.HashMap<K, V>
370
+ >(2, (self, f) => {
371
+ const transient = beginMutation(self)
372
+ f(transient)
373
+ return endMutation(transient)
374
+ })
375
+
376
+ /** @internal */
377
+ export const modifyAt = Dual.dual<
378
+ <K, V>(key: K, f: HM.HashMap.UpdateFn<V>) => (self: HM.HashMap<K, V>) => HM.HashMap<K, V>,
379
+ <K, V>(self: HM.HashMap<K, V>, key: K, f: HM.HashMap.UpdateFn<V>) => HM.HashMap<K, V>
380
+ >(3, (self, key, f) => modifyHash(self, key, Hash.hash(key), f))
381
+
382
+ /** @internal */
383
+ export const modifyHash = Dual.dual<
384
+ <K, V>(key: K, hash: number, f: HM.HashMap.UpdateFn<V>) => (self: HM.HashMap<K, V>) => HM.HashMap<K, V>,
385
+ <K, V>(self: HM.HashMap<K, V>, key: K, hash: number, f: HM.HashMap.UpdateFn<V>) => HM.HashMap<K, V>
386
+ >(4, <K, V>(self: HM.HashMap<K, V>, key: K, hash: number, f: HM.HashMap.UpdateFn<V>) => {
387
+ const size = { value: (self as HashMapImpl<K, V>)._size }
388
+ const newRoot = (self as HashMapImpl<K, V>)._root.modify(
389
+ (self as HashMapImpl<K, V>)._editable ?
390
+ (self as HashMapImpl<K, V>)._edit :
391
+ NaN,
392
+ 0,
393
+ f,
394
+ hash,
395
+ key,
396
+ size
397
+ )
398
+ return pipe(self, setTree(newRoot, size.value))
399
+ })
400
+
401
+ /** @internal */
402
+ export const modify = Dual.dual<
403
+ <K, V>(key: K, f: (v: V) => V) => (self: HM.HashMap<K, V>) => HM.HashMap<K, V>,
404
+ <K, V>(self: HM.HashMap<K, V>, key: K, f: (v: V) => V) => HM.HashMap<K, V>
405
+ >(3, (self, key, f) => modifyAt(self, key, Option.map(f)))
406
+
407
+ /** @internal */
408
+ export const union = Dual.dual<
409
+ <K1, V1>(
410
+ that: HM.HashMap<K1, V1>
411
+ ) => <K0, V0>(self: HM.HashMap<K0, V0>) => HM.HashMap<K0 | K1, V0 | V1>,
412
+ <K0, V0, K1, V1>(
413
+ self: HM.HashMap<K0, V0>,
414
+ that: HM.HashMap<K1, V1>
415
+ ) => HM.HashMap<K0 | K1, V0 | V1>
416
+ >(2, <K0, V0, K1, V1>(self: HM.HashMap<K0, V0>, that: HM.HashMap<K1, V1>) => {
417
+ const result: HM.HashMap<K0 | K1, V0 | V1> = beginMutation(self)
418
+ forEach(that, (v, k) => set(result, k, v))
419
+ return endMutation(result)
420
+ })
421
+
422
+ /** @internal */
423
+ export const remove = Dual.dual<
424
+ <K>(key: K) => <V>(self: HM.HashMap<K, V>) => HM.HashMap<K, V>,
425
+ <K, V>(self: HM.HashMap<K, V>, key: K) => HM.HashMap<K, V>
426
+ >(2, (self, key) => modifyAt(self, key, Option.none))
427
+
428
+ /** @internal */
429
+ export const removeMany = Dual.dual<
430
+ <K>(keys: Iterable<K>) => <V>(self: HM.HashMap<K, V>) => HM.HashMap<K, V>,
431
+ <K, V>(self: HM.HashMap<K, V>, keys: Iterable<K>) => HM.HashMap<K, V>
432
+ >(2, (self, keys) =>
433
+ mutate(self, (map) => {
434
+ for (const key of keys) {
435
+ remove(key)(map)
436
+ }
437
+ }))
438
+
439
+ /**
440
+ * Maps over the entries of the `HashMap` using the specified function.
441
+ *
442
+ * @since 2.0.0
443
+ * @category mapping
444
+ */
445
+ export const map = Dual.dual<
446
+ <A, V, K>(f: (value: V, key: K) => A) => (self: HM.HashMap<K, V>) => HM.HashMap<K, A>,
447
+ <K, V, A>(self: HM.HashMap<K, V>, f: (value: V, key: K) => A) => HM.HashMap<K, A>
448
+ >(2, (self, f) =>
449
+ reduce(
450
+ self,
451
+ empty(),
452
+ (map, value, key) => set(map, key, f(value, key))
453
+ ))
454
+
455
+ /** @internal */
456
+ export const flatMap = Dual.dual<
457
+ <A, K, B>(
458
+ f: (value: A, key: K) => HM.HashMap<K, B>
459
+ ) => (self: HM.HashMap<K, A>) => HM.HashMap<K, B>,
460
+ <K, A, B>(self: HM.HashMap<K, A>, f: (value: A, key: K) => HM.HashMap<K, B>) => HM.HashMap<K, B>
461
+ >(
462
+ 2,
463
+ (self, f) =>
464
+ reduce(self, empty(), (zero, value, key) =>
465
+ mutate(
466
+ zero,
467
+ (map) => forEach(f(value, key), (value, key) => set(map, key, value))
468
+ ))
469
+ )
470
+
471
+ /** @internal */
472
+ export const forEach = Dual.dual<
473
+ <V, K>(f: (value: V, key: K) => void) => (self: HM.HashMap<K, V>) => void,
474
+ <V, K>(self: HM.HashMap<K, V>, f: (value: V, key: K) => void) => void
475
+ >(2, (self, f) => reduce(self, void 0 as void, (_, value, key) => f(value, key)))
476
+
477
+ /** @internal */
478
+ export const reduce = Dual.dual<
479
+ <Z, V, K>(zero: Z, f: (accumulator: Z, value: V, key: K) => Z) => (self: HM.HashMap<K, V>) => Z,
480
+ <Z, V, K>(self: HM.HashMap<K, V>, zero: Z, f: (accumulator: Z, value: V, key: K) => Z) => Z
481
+ >(3, <Z, V, K>(self: HM.HashMap<K, V>, zero: Z, f: (accumulator: Z, value: V, key: K) => Z) => {
482
+ const root = (self as HashMapImpl<K, V>)._root
483
+ if (root._tag === "LeafNode") {
484
+ return Option.isSome(root.value) ? f(zero, root.value.value, root.key) : zero
485
+ }
486
+ if (root._tag === "EmptyNode") {
487
+ return zero
488
+ }
489
+ const toVisit = [root.children]
490
+ let children
491
+ while ((children = toVisit.pop())) {
492
+ for (let i = 0, len = children.length; i < len;) {
493
+ const child = children[i++]
494
+ if (child && !Node.isEmptyNode(child)) {
495
+ if (child._tag === "LeafNode") {
496
+ if (Option.isSome(child.value)) {
497
+ zero = f(zero, child.value.value, child.key)
498
+ }
499
+ } else {
500
+ toVisit.push(child.children)
501
+ }
502
+ }
503
+ }
504
+ }
505
+ return zero
506
+ })
507
+
508
+ /** @internal */
509
+ export const filter: {
510
+ <K, A, B extends A>(f: (a: NoInfer<A>, k: K) => a is B): (self: HM.HashMap<K, A>) => HM.HashMap<K, B>
511
+ <K, A>(f: (a: NoInfer<A>, k: K) => boolean): (self: HM.HashMap<K, A>) => HM.HashMap<K, A>
512
+ <K, A, B extends A>(self: HM.HashMap<K, A>, f: (a: A, k: K) => a is B): HM.HashMap<K, B>
513
+ <K, A>(self: HM.HashMap<K, A>, f: (a: A, k: K) => boolean): HM.HashMap<K, A>
514
+ } = Dual.dual(
515
+ 2,
516
+ <K, A>(self: HM.HashMap<K, A>, f: (a: A, k: K) => boolean): HM.HashMap<K, A> =>
517
+ mutate(empty(), (map) => {
518
+ for (const [k, a] of self) {
519
+ if (f(a, k)) {
520
+ set(map, k, a)
521
+ }
522
+ }
523
+ })
524
+ )
525
+
526
+ /** @internal */
527
+ export const compact = <K, A>(self: HM.HashMap<K, Option.Option<A>>) => filterMap(self, identity)
528
+
529
+ /** @internal */
530
+ export const filterMap = Dual.dual<
531
+ <A, K, B>(
532
+ f: (value: A, key: K) => Option.Option<B>
533
+ ) => (self: HM.HashMap<K, A>) => HM.HashMap<K, B>,
534
+ <K, A, B>(self: HM.HashMap<K, A>, f: (value: A, key: K) => Option.Option<B>) => HM.HashMap<K, B>
535
+ >(2, (self, f) =>
536
+ mutate(empty(), (map) => {
537
+ for (const [k, a] of self) {
538
+ const option = f(a, k)
539
+ if (Option.isSome(option)) {
540
+ set(map, k, option.value)
541
+ }
542
+ }
543
+ }))
544
+
545
+ /** @internal */
546
+ export const findFirst: {
547
+ <K, A, B extends A>(predicate: (a: NoInfer<A>, k: K) => a is B): (self: HM.HashMap<K, A>) => Option.Option<[K, B]>
548
+ <K, A>(predicate: (a: NoInfer<A>, k: K) => boolean): (self: HM.HashMap<K, A>) => Option.Option<[K, A]>
549
+ <K, A, B extends A>(self: HM.HashMap<K, A>, predicate: (a: A, k: K) => a is B): Option.Option<[K, B]>
550
+ <K, A>(self: HM.HashMap<K, A>, predicate: (a: A, k: K) => boolean): Option.Option<[K, A]>
551
+ } = Dual.dual(
552
+ 2,
553
+ <K, A>(self: HM.HashMap<K, A>, predicate: (a: A, k: K) => boolean): Option.Option<[K, A]> => {
554
+ for (const ka of self) {
555
+ if (predicate(ka[1], ka[0])) {
556
+ return Option.some(ka)
557
+ }
558
+ }
559
+ return Option.none()
560
+ }
561
+ )
562
+
563
+ /** @internal */
564
+ export const some: {
565
+ <K, A>(predicate: (a: NoInfer<A>, k: K) => boolean): (self: HM.HashMap<K, A>) => boolean
566
+ <K, A>(self: HM.HashMap<K, A>, predicate: (a: A, k: K) => boolean): boolean
567
+ } = Dual.dual(
568
+ 2,
569
+ <K, A>(self: HM.HashMap<K, A>, predicate: (a: A, k: K) => boolean): boolean => {
570
+ for (const ka of self) {
571
+ if (predicate(ka[1], ka[0])) {
572
+ return true
573
+ }
574
+ }
575
+ return false
576
+ }
577
+ )
578
+
579
+ /** @internal */
580
+ export const every: {
581
+ <K, A>(predicate: (a: NoInfer<A>, k: K) => boolean): (self: HM.HashMap<K, A>) => boolean
582
+ <K, A>(self: HM.HashMap<K, A>, predicate: (a: A, k: K) => boolean): boolean
583
+ } = Dual.dual(
584
+ 2,
585
+ <K, A>(self: HM.HashMap<K, A>, predicate: (a: A, k: K) => boolean): boolean => !some(self, (a, k) => !predicate(a, k))
586
+ )