@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,733 @@
1
+ import type * as Cache from "../Cache.js"
2
+ import type * as Clock from "../Clock.js"
3
+ import * as Context from "../Context.js"
4
+ import * as Deferred from "../Deferred.js"
5
+ import * as Duration from "../Duration.js"
6
+ import type * as Effect from "../Effect.js"
7
+ import * as Either from "../Either.js"
8
+ import * as Equal from "../Equal.js"
9
+ import * as Exit from "../Exit.js"
10
+ import type * as FiberId from "../FiberId.js"
11
+ import { pipe } from "../Function.js"
12
+ import * as Hash from "../Hash.js"
13
+ import * as MutableHashMap from "../MutableHashMap.js"
14
+ import * as MutableQueue from "../MutableQueue.js"
15
+ import * as MutableRef from "../MutableRef.js"
16
+ import * as Option from "../Option.js"
17
+ import { hasProperty } from "../Predicate.js"
18
+ import * as effect from "./core-effect.js"
19
+ import * as core from "./core.js"
20
+ import * as Data from "./data.js"
21
+ import { none } from "./fiberId.js"
22
+ import * as fiberRuntime from "./fiberRuntime.js"
23
+
24
+ /**
25
+ * A `MapValue` represents a value in the cache. A value may either be
26
+ * `Pending` with a `Promise` that will contain the result of computing the
27
+ * lookup function, when it is available, or `Complete` with an `Exit` value
28
+ * that contains the result of computing the lookup function.
29
+ *
30
+ * @internal
31
+ */
32
+ export type MapValue<Key, Value, Error> =
33
+ | Complete<Key, Value, Error>
34
+ | Pending<Key, Value, Error>
35
+ | Refreshing<Key, Value, Error>
36
+
37
+ /** @internal */
38
+ export interface Complete<out Key, out Value, out Error> {
39
+ readonly _tag: "Complete"
40
+ readonly key: MapKey<Key>
41
+ readonly exit: Exit.Exit<Value, Error>
42
+ readonly entryStats: Cache.EntryStats
43
+ readonly timeToLiveMillis: number
44
+ }
45
+
46
+ /** @internal */
47
+ export interface Pending<out Key, in out Value, in out Error> {
48
+ readonly _tag: "Pending"
49
+ readonly key: MapKey<Key>
50
+ readonly deferred: Deferred.Deferred<Value, Error>
51
+ }
52
+
53
+ /** @internal */
54
+ export interface Refreshing<out Key, in out Value, in out Error> {
55
+ readonly _tag: "Refreshing"
56
+ readonly deferred: Deferred.Deferred<Value, Error>
57
+ readonly complete: Complete<Key, Value, Error>
58
+ }
59
+
60
+ /** @internal */
61
+ export const complete = <Key, Value, Error>(
62
+ key: MapKey<Key>,
63
+ exit: Exit.Exit<Value, Error>,
64
+ entryStats: Cache.EntryStats,
65
+ timeToLiveMillis: number
66
+ ): MapValue<Key, Value, Error> =>
67
+ Data.struct({
68
+ _tag: "Complete" as const,
69
+ key,
70
+ exit,
71
+ entryStats,
72
+ timeToLiveMillis
73
+ })
74
+
75
+ /** @internal */
76
+ export const pending = <Key, Value, Error>(
77
+ key: MapKey<Key>,
78
+ deferred: Deferred.Deferred<Value, Error>
79
+ ): MapValue<Key, Value, Error> =>
80
+ Data.struct({
81
+ _tag: "Pending" as const,
82
+ key,
83
+ deferred
84
+ })
85
+
86
+ /** @internal */
87
+ export const refreshing = <Key, Value, Error>(
88
+ deferred: Deferred.Deferred<Value, Error>,
89
+ complete: Complete<Key, Value, Error>
90
+ ): MapValue<Key, Value, Error> =>
91
+ Data.struct({
92
+ _tag: "Refreshing" as const,
93
+ deferred,
94
+ complete
95
+ })
96
+
97
+ /** @internal */
98
+ export const MapKeyTypeId = Symbol.for("effect/Cache/MapKey")
99
+
100
+ /** @internal */
101
+ export type MapKeyTypeId = typeof MapKeyTypeId
102
+
103
+ /**
104
+ * A `MapKey` represents a key in the cache. It contains mutable references
105
+ * to the previous key and next key in the `KeySet` to support an efficient
106
+ * implementation of a sorted set of keys.
107
+ *
108
+ * @internal
109
+ */
110
+ export interface MapKey<out K> extends Equal.Equal {
111
+ readonly [MapKeyTypeId]: MapKeyTypeId
112
+ readonly current: K
113
+ previous: MapKey<K> | undefined // mutable by design
114
+ next: MapKey<K> | undefined // mutable by design
115
+ }
116
+
117
+ class MapKeyImpl<out K> implements MapKey<K> {
118
+ readonly [MapKeyTypeId]: MapKeyTypeId = MapKeyTypeId
119
+ previous: MapKey<K> | undefined = undefined
120
+ next: MapKey<K> | undefined = undefined
121
+ constructor(readonly current: K) {}
122
+ [Hash.symbol](): number {
123
+ return pipe(
124
+ Hash.hash(this.current),
125
+ Hash.combine(Hash.hash(this.previous)),
126
+ Hash.combine(Hash.hash(this.next)),
127
+ Hash.cached(this)
128
+ )
129
+ }
130
+ [Equal.symbol](that: unknown): boolean {
131
+ if (this === that) {
132
+ return true
133
+ }
134
+ return isMapKey(that) &&
135
+ Equal.equals(this.current, that.current) &&
136
+ Equal.equals(this.previous, that.previous) &&
137
+ Equal.equals(this.next, that.next)
138
+ }
139
+ }
140
+
141
+ /** @internal */
142
+ export const makeMapKey = <K>(current: K): MapKey<K> => new MapKeyImpl(current)
143
+
144
+ /** @internal */
145
+ export const isMapKey = (u: unknown): u is MapKey<unknown> => hasProperty(u, MapKeyTypeId)
146
+
147
+ /**
148
+ * A `KeySet` is a sorted set of keys in the cache ordered by last access.
149
+ * For efficiency, the set is implemented in terms of a doubly linked list
150
+ * and is not safe for concurrent access.
151
+ *
152
+ * @internal
153
+ */
154
+ export interface KeySet<in out K> {
155
+ head: MapKey<K> | undefined // mutable by design
156
+ tail: MapKey<K> | undefined // mutable by design
157
+ /**
158
+ * Adds the specified key to the set.
159
+ */
160
+ add(key: MapKey<K>): void
161
+ /**
162
+ * Removes the lowest priority key from the set.
163
+ */
164
+ remove(): MapKey<K> | undefined
165
+ }
166
+
167
+ class KeySetImpl<in out K> implements KeySet<K> {
168
+ head: MapKey<K> | undefined = undefined
169
+ tail: MapKey<K> | undefined = undefined
170
+ add(key: MapKey<K>): void {
171
+ if (key !== this.tail) {
172
+ if (this.tail === undefined) {
173
+ this.head = key
174
+ this.tail = key
175
+ } else {
176
+ const previous = key.previous
177
+ const next = key.next
178
+ if (next !== undefined) {
179
+ key.next = undefined
180
+ if (previous !== undefined) {
181
+ previous.next = next
182
+ next.previous = previous
183
+ } else {
184
+ this.head = next
185
+ this.head.previous = undefined
186
+ }
187
+ }
188
+ this.tail.next = key
189
+ key.previous = this.tail
190
+ this.tail = key
191
+ }
192
+ }
193
+ }
194
+ remove(): MapKey<K> | undefined {
195
+ const key = this.head
196
+ if (key !== undefined) {
197
+ const next = key.next
198
+ if (next !== undefined) {
199
+ key.next = undefined
200
+ this.head = next
201
+ this.head.previous = undefined
202
+ } else {
203
+ this.head = undefined
204
+ this.tail = undefined
205
+ }
206
+ }
207
+ return key
208
+ }
209
+ }
210
+
211
+ /** @internal */
212
+ export const makeKeySet = <K>(): KeySet<K> => new KeySetImpl<K>()
213
+
214
+ /**
215
+ * The `CacheState` represents the mutable state underlying the cache.
216
+ *
217
+ * @internal
218
+ */
219
+ export interface CacheState<in out Key, in out Value, in out Error> {
220
+ map: MutableHashMap.MutableHashMap<Key, MapValue<Key, Value, Error>> // mutable by design
221
+ keys: KeySet<Key> // mutable by design
222
+ accesses: MutableQueue.MutableQueue<MapKey<Key>> // mutable by design
223
+ updating: MutableRef.MutableRef<boolean> // mutable by design
224
+ hits: number // mutable by design
225
+ misses: number // mutable by design
226
+ }
227
+
228
+ /**
229
+ * Constructs a new `CacheState` from the specified values.
230
+ *
231
+ * @internal
232
+ */
233
+ export const makeCacheState = <Key, Value, Error>(
234
+ map: MutableHashMap.MutableHashMap<Key, MapValue<Key, Value, Error>>,
235
+ keys: KeySet<Key>,
236
+ accesses: MutableQueue.MutableQueue<MapKey<Key>>,
237
+ updating: MutableRef.MutableRef<boolean>,
238
+ hits: number,
239
+ misses: number
240
+ ): CacheState<Key, Value, Error> => ({
241
+ map,
242
+ keys,
243
+ accesses,
244
+ updating,
245
+ hits,
246
+ misses
247
+ })
248
+
249
+ /**
250
+ * Constructs an initial cache state.
251
+ *
252
+ * @internal
253
+ */
254
+ export const initialCacheState = <Key, Value, Error>(): CacheState<Key, Value, Error> =>
255
+ makeCacheState(
256
+ MutableHashMap.empty(),
257
+ makeKeySet(),
258
+ MutableQueue.unbounded(),
259
+ MutableRef.make(false),
260
+ 0,
261
+ 0
262
+ )
263
+
264
+ /** @internal */
265
+ const CacheSymbolKey = "effect/Cache"
266
+
267
+ /** @internal */
268
+ export const CacheTypeId: Cache.CacheTypeId = Symbol.for(
269
+ CacheSymbolKey
270
+ ) as Cache.CacheTypeId
271
+
272
+ const cacheVariance = {
273
+ /* c8 ignore next */
274
+ _Key: (_: any) => _,
275
+ /* c8 ignore next */
276
+ _Error: (_: never) => _,
277
+ /* c8 ignore next */
278
+ _Value: (_: any) => _
279
+ }
280
+
281
+ /** @internal */
282
+ const ConsumerCacheSymbolKey = "effect/ConsumerCache"
283
+
284
+ /** @internal */
285
+ export const ConsumerCacheTypeId: Cache.ConsumerCacheTypeId = Symbol.for(
286
+ ConsumerCacheSymbolKey
287
+ ) as Cache.ConsumerCacheTypeId
288
+
289
+ const consumerCacheVariance = {
290
+ /* c8 ignore next */
291
+ _Key: (_: any) => _,
292
+ /* c8 ignore next */
293
+ _Error: (_: never) => _,
294
+ /* c8 ignore next */
295
+ _Value: (_: never) => _
296
+ }
297
+
298
+ /** @internal */
299
+ export const makeCacheStats = (
300
+ options: {
301
+ readonly hits: number
302
+ readonly misses: number
303
+ readonly size: number
304
+ }
305
+ ): Cache.CacheStats => options
306
+
307
+ /** @internal */
308
+ export const makeEntryStats = (loadedMillis: number): Cache.EntryStats => ({
309
+ loadedMillis
310
+ })
311
+
312
+ class CacheImpl<in out Key, in out Value, in out Error> implements Cache.Cache<Key, Value, Error> {
313
+ readonly [CacheTypeId] = cacheVariance
314
+ readonly [ConsumerCacheTypeId] = consumerCacheVariance
315
+ readonly cacheState: CacheState<Key, Value, Error>
316
+ constructor(
317
+ readonly capacity: number,
318
+ readonly context: Context.Context<any>,
319
+ readonly fiberId: FiberId.FiberId,
320
+ readonly lookup: Cache.Lookup<Key, Value, Error, any>,
321
+ readonly timeToLive: (exit: Exit.Exit<Value, Error>) => Duration.DurationInput
322
+ ) {
323
+ this.cacheState = initialCacheState()
324
+ }
325
+
326
+ get(key: Key): Effect.Effect<Value, Error> {
327
+ return core.map(this.getEither(key), Either.merge)
328
+ }
329
+
330
+ get cacheStats(): Effect.Effect<Cache.CacheStats> {
331
+ return core.sync(() =>
332
+ makeCacheStats({
333
+ hits: this.cacheState.hits,
334
+ misses: this.cacheState.misses,
335
+ size: MutableHashMap.size(this.cacheState.map)
336
+ })
337
+ )
338
+ }
339
+
340
+ getOption(key: Key): Effect.Effect<Option.Option<Value>, Error> {
341
+ return core.suspend(() =>
342
+ Option.match(MutableHashMap.get(this.cacheState.map, key), {
343
+ onNone: () => {
344
+ const mapKey = makeMapKey(key)
345
+ this.trackAccess(mapKey)
346
+ this.trackMiss()
347
+ return core.succeed(Option.none<Value>())
348
+ },
349
+ onSome: (value) => this.resolveMapValue(value)
350
+ })
351
+ )
352
+ }
353
+
354
+ getOptionComplete(key: Key): Effect.Effect<Option.Option<Value>> {
355
+ return core.suspend(() =>
356
+ Option.match(MutableHashMap.get(this.cacheState.map, key), {
357
+ onNone: () => {
358
+ const mapKey = makeMapKey(key)
359
+ this.trackAccess(mapKey)
360
+ this.trackMiss()
361
+ return core.succeed(Option.none<Value>())
362
+ },
363
+ onSome: (value) => this.resolveMapValue(value, true) as Effect.Effect<Option.Option<Value>>
364
+ })
365
+ )
366
+ }
367
+
368
+ contains(key: Key): Effect.Effect<boolean> {
369
+ return core.sync(() => MutableHashMap.has(this.cacheState.map, key))
370
+ }
371
+
372
+ entryStats(key: Key): Effect.Effect<Option.Option<Cache.EntryStats>> {
373
+ return core.sync(() => {
374
+ const option = MutableHashMap.get(this.cacheState.map, key)
375
+ if (Option.isSome(option)) {
376
+ switch (option.value._tag) {
377
+ case "Complete": {
378
+ const loaded = option.value.entryStats.loadedMillis
379
+ return Option.some(makeEntryStats(loaded))
380
+ }
381
+ case "Pending": {
382
+ return Option.none()
383
+ }
384
+ case "Refreshing": {
385
+ const loaded = option.value.complete.entryStats.loadedMillis
386
+ return Option.some(makeEntryStats(loaded))
387
+ }
388
+ }
389
+ }
390
+ return Option.none()
391
+ })
392
+ }
393
+
394
+ getEither(key: Key): Effect.Effect<Either.Either<Value, Value>, Error> {
395
+ return core.suspend((): Effect.Effect<Either.Either<Value, Value>, Error> => {
396
+ const k = key
397
+ let mapKey: MapKey<Key> | undefined = undefined
398
+ let deferred: Deferred.Deferred<Value, Error> | undefined = undefined
399
+ let value = Option.getOrUndefined(MutableHashMap.get(this.cacheState.map, k))
400
+ if (value === undefined) {
401
+ deferred = Deferred.unsafeMake<Value, Error>(this.fiberId)
402
+ mapKey = makeMapKey(k)
403
+ if (MutableHashMap.has(this.cacheState.map, k)) {
404
+ value = Option.getOrUndefined(MutableHashMap.get(this.cacheState.map, k))
405
+ } else {
406
+ MutableHashMap.set(this.cacheState.map, k, pending(mapKey, deferred))
407
+ }
408
+ }
409
+ if (value === undefined) {
410
+ this.trackAccess(mapKey!)
411
+ this.trackMiss()
412
+ return core.map(this.lookupValueOf(key, deferred!), Either.right)
413
+ } else {
414
+ return core.flatMap(
415
+ this.resolveMapValue(value),
416
+ Option.match({
417
+ onNone: () => this.getEither(key),
418
+ onSome: (value) => core.succeed(Either.left(value))
419
+ })
420
+ )
421
+ }
422
+ })
423
+ }
424
+
425
+ invalidate(key: Key): Effect.Effect<void> {
426
+ return core.sync(() => {
427
+ MutableHashMap.remove(this.cacheState.map, key)
428
+ })
429
+ }
430
+
431
+ invalidateWhen(key: Key, when: (value: Value) => boolean): Effect.Effect<void> {
432
+ return core.sync(() => {
433
+ const value = MutableHashMap.get(this.cacheState.map, key)
434
+ if (Option.isSome(value) && value.value._tag === "Complete") {
435
+ if (value.value.exit._tag === "Success") {
436
+ if (when(value.value.exit.value)) {
437
+ MutableHashMap.remove(this.cacheState.map, key)
438
+ }
439
+ }
440
+ }
441
+ })
442
+ }
443
+
444
+ get invalidateAll(): Effect.Effect<void> {
445
+ return core.sync(() => {
446
+ this.cacheState.map = MutableHashMap.empty()
447
+ })
448
+ }
449
+
450
+ refresh(key: Key): Effect.Effect<void, Error> {
451
+ return effect.clockWith((clock) =>
452
+ core.suspend(() => {
453
+ const k = key
454
+ const deferred: Deferred.Deferred<Value, Error> = Deferred.unsafeMake(this.fiberId)
455
+ let value = Option.getOrUndefined(MutableHashMap.get(this.cacheState.map, k))
456
+ if (value === undefined) {
457
+ if (MutableHashMap.has(this.cacheState.map, k)) {
458
+ value = Option.getOrUndefined(MutableHashMap.get(this.cacheState.map, k))
459
+ } else {
460
+ MutableHashMap.set(this.cacheState.map, k, pending(makeMapKey(k), deferred))
461
+ }
462
+ }
463
+ if (value === undefined) {
464
+ return core.asVoid(this.lookupValueOf(key, deferred))
465
+ } else {
466
+ switch (value._tag) {
467
+ case "Complete": {
468
+ if (this.hasExpired(clock, value.timeToLiveMillis)) {
469
+ const found = Option.getOrUndefined(MutableHashMap.get(this.cacheState.map, k))
470
+ if (Equal.equals(found, value)) {
471
+ MutableHashMap.remove(this.cacheState.map, k)
472
+ }
473
+ return core.asVoid(this.get(key))
474
+ }
475
+ // Only trigger the lookup if we're still the current value, `completedResult`
476
+ return pipe(
477
+ this.lookupValueOf(key, deferred),
478
+ effect.when(() => {
479
+ const current = Option.getOrUndefined(MutableHashMap.get(this.cacheState.map, k))
480
+ if (Equal.equals(current, value)) {
481
+ const mapValue = refreshing(deferred, value as Complete<Key, Value, Error>)
482
+ MutableHashMap.set(this.cacheState.map, k, mapValue)
483
+ return true
484
+ }
485
+ return false
486
+ }),
487
+ core.asVoid
488
+ )
489
+ }
490
+ case "Pending": {
491
+ return Deferred.await(value.deferred)
492
+ }
493
+ case "Refreshing": {
494
+ return Deferred.await(value.deferred)
495
+ }
496
+ }
497
+ }
498
+ })
499
+ )
500
+ }
501
+
502
+ set(key: Key, value: Value): Effect.Effect<void> {
503
+ return effect.clockWith((clock) =>
504
+ core.sync(() => {
505
+ const now = clock.unsafeCurrentTimeMillis()
506
+ const k = key
507
+ const lookupResult = Exit.succeed(value)
508
+ const mapValue = complete(
509
+ makeMapKey(k),
510
+ lookupResult,
511
+ makeEntryStats(now),
512
+ now + Duration.toMillis(Duration.decode(this.timeToLive(lookupResult)))
513
+ )
514
+ MutableHashMap.set(
515
+ this.cacheState.map,
516
+ k,
517
+ mapValue as Complete<Key, Value, Error>
518
+ )
519
+ })
520
+ )
521
+ }
522
+
523
+ get size(): Effect.Effect<number> {
524
+ return core.sync(() => {
525
+ return MutableHashMap.size(this.cacheState.map)
526
+ })
527
+ }
528
+
529
+ get values(): Effect.Effect<Array<Value>> {
530
+ return core.sync(() => {
531
+ const values: Array<Value> = []
532
+ for (const entry of this.cacheState.map) {
533
+ if (entry[1]._tag === "Complete" && entry[1].exit._tag === "Success") {
534
+ values.push(entry[1].exit.value)
535
+ }
536
+ }
537
+ return values
538
+ })
539
+ }
540
+
541
+ get entries(): Effect.Effect<Array<[Key, Value]>> {
542
+ return core.sync(() => {
543
+ const values: Array<[Key, Value]> = []
544
+ for (const entry of this.cacheState.map) {
545
+ if (entry[1]._tag === "Complete" && entry[1].exit._tag === "Success") {
546
+ values.push([entry[0], entry[1].exit.value])
547
+ }
548
+ }
549
+ return values
550
+ })
551
+ }
552
+
553
+ get keys(): Effect.Effect<Array<Key>> {
554
+ return core.sync(() => {
555
+ const keys: Array<Key> = []
556
+ for (const entry of this.cacheState.map) {
557
+ if (entry[1]._tag === "Complete" && entry[1].exit._tag === "Success") {
558
+ keys.push(entry[0])
559
+ }
560
+ }
561
+ return keys
562
+ })
563
+ }
564
+
565
+ resolveMapValue(
566
+ value: MapValue<Key, Value, Error>,
567
+ ignorePending = false
568
+ ): Effect.Effect<Option.Option<Value>, Error> {
569
+ return effect.clockWith((clock) => {
570
+ switch (value._tag) {
571
+ case "Complete": {
572
+ this.trackAccess(value.key)
573
+ if (this.hasExpired(clock, value.timeToLiveMillis)) {
574
+ MutableHashMap.remove(this.cacheState.map, value.key.current)
575
+ return core.succeed(Option.none<Value>())
576
+ }
577
+ this.trackHit()
578
+ return core.map(value.exit, Option.some)
579
+ }
580
+ case "Pending": {
581
+ this.trackAccess(value.key)
582
+ this.trackHit()
583
+ if (ignorePending) {
584
+ return core.succeed(Option.none<Value>())
585
+ }
586
+ return core.map(Deferred.await(value.deferred), Option.some)
587
+ }
588
+ case "Refreshing": {
589
+ this.trackAccess(value.complete.key)
590
+ this.trackHit()
591
+ if (this.hasExpired(clock, value.complete.timeToLiveMillis)) {
592
+ if (ignorePending) {
593
+ return core.succeed(Option.none<Value>())
594
+ }
595
+ return core.map(Deferred.await(value.deferred), Option.some)
596
+ }
597
+ return core.map(value.complete.exit, Option.some)
598
+ }
599
+ }
600
+ })
601
+ }
602
+
603
+ trackHit(): void {
604
+ this.cacheState.hits = this.cacheState.hits + 1
605
+ }
606
+
607
+ trackMiss(): void {
608
+ this.cacheState.misses = this.cacheState.misses + 1
609
+ }
610
+
611
+ trackAccess(key: MapKey<Key>): void {
612
+ MutableQueue.offer(this.cacheState.accesses, key)
613
+ if (MutableRef.compareAndSet(this.cacheState.updating, false, true)) {
614
+ let loop = true
615
+ while (loop) {
616
+ const key = MutableQueue.poll(this.cacheState.accesses, MutableQueue.EmptyMutableQueue)
617
+ if (key === MutableQueue.EmptyMutableQueue) {
618
+ loop = false
619
+ } else {
620
+ this.cacheState.keys.add(key)
621
+ }
622
+ }
623
+ let size = MutableHashMap.size(this.cacheState.map)
624
+ loop = size > this.capacity
625
+ while (loop) {
626
+ const key = this.cacheState.keys.remove()
627
+ if (key !== undefined) {
628
+ if (MutableHashMap.has(this.cacheState.map, key.current)) {
629
+ MutableHashMap.remove(this.cacheState.map, key.current)
630
+ size = size - 1
631
+ loop = size > this.capacity
632
+ }
633
+ } else {
634
+ loop = false
635
+ }
636
+ }
637
+ MutableRef.set(this.cacheState.updating, false)
638
+ }
639
+ }
640
+
641
+ hasExpired(clock: Clock.Clock, timeToLiveMillis: number): boolean {
642
+ return clock.unsafeCurrentTimeMillis() > timeToLiveMillis
643
+ }
644
+
645
+ lookupValueOf(
646
+ input: Key,
647
+ deferred: Deferred.Deferred<Value, Error>
648
+ ): Effect.Effect<Value, Error> {
649
+ return effect.clockWith((clock) =>
650
+ core.suspend(() => {
651
+ const key = input
652
+ return pipe(
653
+ this.lookup(input),
654
+ core.provideContext(this.context),
655
+ core.exit,
656
+ core.flatMap((exit) => {
657
+ const now = clock.unsafeCurrentTimeMillis()
658
+ const stats = makeEntryStats(now)
659
+ const value = complete(
660
+ makeMapKey(key),
661
+ exit,
662
+ stats,
663
+ now + Duration.toMillis(Duration.decode(this.timeToLive(exit)))
664
+ )
665
+ MutableHashMap.set(this.cacheState.map, key, value)
666
+ return core.zipRight(
667
+ Deferred.done(deferred, exit),
668
+ exit
669
+ )
670
+ }),
671
+ core.onInterrupt(() =>
672
+ core.zipRight(
673
+ Deferred.interrupt(deferred),
674
+ core.sync(() => {
675
+ MutableHashMap.remove(this.cacheState.map, key)
676
+ })
677
+ )
678
+ )
679
+ )
680
+ })
681
+ )
682
+ }
683
+ }
684
+
685
+ /** @internal */
686
+ export const make = <Key, Value, Error = never, Environment = never>(
687
+ options: {
688
+ readonly capacity: number
689
+ readonly timeToLive: Duration.DurationInput
690
+ readonly lookup: Cache.Lookup<Key, Value, Error, Environment>
691
+ }
692
+ ): Effect.Effect<Cache.Cache<Key, Value, Error>, never, Environment> => {
693
+ const timeToLive = Duration.decode(options.timeToLive)
694
+ return makeWith({
695
+ capacity: options.capacity,
696
+ lookup: options.lookup,
697
+ timeToLive: () => timeToLive
698
+ })
699
+ }
700
+
701
+ /** @internal */
702
+ export const makeWith = <Key, Value, Error = never, Environment = never>(
703
+ options: {
704
+ readonly capacity: number
705
+ readonly lookup: Cache.Lookup<Key, Value, Error, Environment>
706
+ readonly timeToLive: (exit: Exit.Exit<Value, Error>) => Duration.DurationInput
707
+ }
708
+ ): Effect.Effect<Cache.Cache<Key, Value, Error>, never, Environment> =>
709
+ core.map(
710
+ fiberRuntime.all([core.context<Environment>(), core.fiberId]),
711
+ ([context, fiberId]) =>
712
+ new CacheImpl(
713
+ options.capacity,
714
+ context,
715
+ fiberId,
716
+ options.lookup,
717
+ (exit) => Duration.decode(options.timeToLive(exit))
718
+ )
719
+ )
720
+
721
+ /** @internal */
722
+ export const unsafeMakeWith = <Key, Value, Error = never>(
723
+ capacity: number,
724
+ lookup: Cache.Lookup<Key, Value, Error>,
725
+ timeToLive: (exit: Exit.Exit<Value, Error>) => Duration.DurationInput
726
+ ): Cache.Cache<Key, Value, Error> =>
727
+ new CacheImpl<Key, Value, Error>(
728
+ capacity,
729
+ Context.empty() as Context.Context<any>,
730
+ none,
731
+ lookup,
732
+ (exit) => Duration.decode(timeToLive(exit))
733
+ )