@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,1050 @@
1
+ import * as Arr from "../Array.js"
2
+ import type * as Cause from "../Cause.js"
3
+ import * as Chunk from "../Chunk.js"
4
+ import * as Either from "../Either.js"
5
+ import * as Equal from "../Equal.js"
6
+ import type * as FiberId from "../FiberId.js"
7
+ import { constFalse, constTrue, dual, identity, pipe } from "../Function.js"
8
+ import { globalValue } from "../GlobalValue.js"
9
+ import * as Hash from "../Hash.js"
10
+ import * as HashSet from "../HashSet.js"
11
+ import { NodeInspectSymbol, stringifyCircular, toJSON } from "../Inspectable.js"
12
+ import * as Option from "../Option.js"
13
+ import { pipeArguments } from "../Pipeable.js"
14
+ import type { Predicate, Refinement } from "../Predicate.js"
15
+ import { hasProperty, isFunction } from "../Predicate.js"
16
+ import type { AnySpan, Span } from "../Tracer.js"
17
+ import type { NoInfer } from "../Types.js"
18
+ import { getBugErrorMessage } from "./errors.js"
19
+ import * as OpCodes from "./opCodes/cause.js"
20
+
21
+ // -----------------------------------------------------------------------------
22
+ // Models
23
+ // -----------------------------------------------------------------------------
24
+
25
+ /** @internal */
26
+ const CauseSymbolKey = "effect/Cause"
27
+
28
+ /** @internal */
29
+ export const CauseTypeId: Cause.CauseTypeId = Symbol.for(
30
+ CauseSymbolKey
31
+ ) as Cause.CauseTypeId
32
+
33
+ const variance = {
34
+ /* c8 ignore next */
35
+ _E: (_: never) => _
36
+ }
37
+
38
+ /** @internal */
39
+ const proto = {
40
+ [CauseTypeId]: variance,
41
+ [Hash.symbol](this: Cause.Cause<any>): number {
42
+ return pipe(
43
+ Hash.hash(CauseSymbolKey),
44
+ Hash.combine(Hash.hash(flattenCause(this))),
45
+ Hash.cached(this)
46
+ )
47
+ },
48
+ [Equal.symbol](this: Cause.Cause<any>, that: unknown): boolean {
49
+ return isCause(that) && causeEquals(this, that)
50
+ },
51
+ pipe() {
52
+ return pipeArguments(this, arguments)
53
+ },
54
+ toJSON<E>(this: Cause.Cause<E>) {
55
+ switch (this._tag) {
56
+ case "Empty":
57
+ return { _id: "Cause", _tag: this._tag }
58
+ case "Die":
59
+ return { _id: "Cause", _tag: this._tag, defect: toJSON(this.defect) }
60
+ case "Interrupt":
61
+ return { _id: "Cause", _tag: this._tag, fiberId: this.fiberId.toJSON() }
62
+ case "Fail":
63
+ return { _id: "Cause", _tag: this._tag, failure: toJSON(this.error) }
64
+ case "Sequential":
65
+ case "Parallel":
66
+ return { _id: "Cause", _tag: this._tag, left: toJSON(this.left), right: toJSON(this.right) }
67
+ }
68
+ },
69
+ toString<E>(this: Cause.Cause<E>) {
70
+ return pretty(this)
71
+ },
72
+ [NodeInspectSymbol]<E>(this: Cause.Cause<E>) {
73
+ return this.toJSON()
74
+ }
75
+ }
76
+
77
+ // -----------------------------------------------------------------------------
78
+ // Constructors
79
+ // -----------------------------------------------------------------------------
80
+
81
+ /** @internal */
82
+ export const empty: Cause.Cause<never> = (() => {
83
+ const o = Object.create(proto)
84
+ o._tag = OpCodes.OP_EMPTY
85
+ return o
86
+ })()
87
+
88
+ /** @internal */
89
+ export const fail = <E>(error: E): Cause.Cause<E> => {
90
+ const o = Object.create(proto)
91
+ o._tag = OpCodes.OP_FAIL
92
+ o.error = error
93
+ return o
94
+ }
95
+
96
+ /** @internal */
97
+ export const die = (defect: unknown): Cause.Cause<never> => {
98
+ const o = Object.create(proto)
99
+ o._tag = OpCodes.OP_DIE
100
+ o.defect = defect
101
+ return o
102
+ }
103
+
104
+ /** @internal */
105
+ export const interrupt = (fiberId: FiberId.FiberId): Cause.Cause<never> => {
106
+ const o = Object.create(proto)
107
+ o._tag = OpCodes.OP_INTERRUPT
108
+ o.fiberId = fiberId
109
+ return o
110
+ }
111
+
112
+ /** @internal */
113
+ export const parallel = <E, E2>(left: Cause.Cause<E>, right: Cause.Cause<E2>): Cause.Cause<E | E2> => {
114
+ const o = Object.create(proto)
115
+ o._tag = OpCodes.OP_PARALLEL
116
+ o.left = left
117
+ o.right = right
118
+ return o
119
+ }
120
+
121
+ /** @internal */
122
+ export const sequential = <E, E2>(left: Cause.Cause<E>, right: Cause.Cause<E2>): Cause.Cause<E | E2> => {
123
+ const o = Object.create(proto)
124
+ o._tag = OpCodes.OP_SEQUENTIAL
125
+ o.left = left
126
+ o.right = right
127
+ return o
128
+ }
129
+
130
+ // -----------------------------------------------------------------------------
131
+ // Refinements
132
+ // -----------------------------------------------------------------------------
133
+
134
+ /** @internal */
135
+ export const isCause = (u: unknown): u is Cause.Cause<unknown> => hasProperty(u, CauseTypeId)
136
+
137
+ /** @internal */
138
+ export const isEmptyType = <E>(self: Cause.Cause<E>): self is Cause.Empty => self._tag === OpCodes.OP_EMPTY
139
+
140
+ /** @internal */
141
+ export const isFailType = <E>(self: Cause.Cause<E>): self is Cause.Fail<E> => self._tag === OpCodes.OP_FAIL
142
+
143
+ /** @internal */
144
+ export const isDieType = <E>(self: Cause.Cause<E>): self is Cause.Die => self._tag === OpCodes.OP_DIE
145
+
146
+ /** @internal */
147
+ export const isInterruptType = <E>(self: Cause.Cause<E>): self is Cause.Interrupt => self._tag === OpCodes.OP_INTERRUPT
148
+
149
+ /** @internal */
150
+ export const isSequentialType = <E>(self: Cause.Cause<E>): self is Cause.Sequential<E> =>
151
+ self._tag === OpCodes.OP_SEQUENTIAL
152
+
153
+ /** @internal */
154
+ export const isParallelType = <E>(self: Cause.Cause<E>): self is Cause.Parallel<E> => self._tag === OpCodes.OP_PARALLEL
155
+
156
+ // -----------------------------------------------------------------------------
157
+ // Getters
158
+ // -----------------------------------------------------------------------------
159
+
160
+ /** @internal */
161
+ export const size = <E>(self: Cause.Cause<E>): number => reduceWithContext(self, void 0, SizeCauseReducer)
162
+
163
+ /** @internal */
164
+ export const isEmpty = <E>(self: Cause.Cause<E>): boolean => {
165
+ if (self._tag === OpCodes.OP_EMPTY) {
166
+ return true
167
+ }
168
+ return reduce(self, true, (acc, cause) => {
169
+ switch (cause._tag) {
170
+ case OpCodes.OP_EMPTY: {
171
+ return Option.some(acc)
172
+ }
173
+ case OpCodes.OP_DIE:
174
+ case OpCodes.OP_FAIL:
175
+ case OpCodes.OP_INTERRUPT: {
176
+ return Option.some(false)
177
+ }
178
+ default: {
179
+ return Option.none()
180
+ }
181
+ }
182
+ })
183
+ }
184
+
185
+ /** @internal */
186
+ export const isFailure = <E>(self: Cause.Cause<E>): boolean => Option.isSome(failureOption(self))
187
+
188
+ /** @internal */
189
+ export const isDie = <E>(self: Cause.Cause<E>): boolean => Option.isSome(dieOption(self))
190
+
191
+ /** @internal */
192
+ export const isInterrupted = <E>(self: Cause.Cause<E>): boolean => Option.isSome(interruptOption(self))
193
+
194
+ /** @internal */
195
+ export const isInterruptedOnly = <E>(self: Cause.Cause<E>): boolean =>
196
+ reduceWithContext(undefined, IsInterruptedOnlyCauseReducer)(self)
197
+
198
+ /** @internal */
199
+ export const failures = <E>(self: Cause.Cause<E>): Chunk.Chunk<E> =>
200
+ Chunk.reverse(
201
+ reduce<Chunk.Chunk<E>, E>(
202
+ self,
203
+ Chunk.empty<E>(),
204
+ (list, cause) =>
205
+ cause._tag === OpCodes.OP_FAIL ?
206
+ Option.some(pipe(list, Chunk.prepend(cause.error))) :
207
+ Option.none()
208
+ )
209
+ )
210
+
211
+ /** @internal */
212
+ export const defects = <E>(self: Cause.Cause<E>): Chunk.Chunk<unknown> =>
213
+ Chunk.reverse(
214
+ reduce<Chunk.Chunk<unknown>, E>(
215
+ self,
216
+ Chunk.empty<unknown>(),
217
+ (list, cause) =>
218
+ cause._tag === OpCodes.OP_DIE ?
219
+ Option.some(pipe(list, Chunk.prepend(cause.defect))) :
220
+ Option.none()
221
+ )
222
+ )
223
+
224
+ /** @internal */
225
+ export const interruptors = <E>(self: Cause.Cause<E>): HashSet.HashSet<FiberId.FiberId> =>
226
+ reduce(self, HashSet.empty<FiberId.FiberId>(), (set, cause) =>
227
+ cause._tag === OpCodes.OP_INTERRUPT ?
228
+ Option.some(pipe(set, HashSet.add(cause.fiberId))) :
229
+ Option.none())
230
+
231
+ /** @internal */
232
+ export const failureOption = <E>(self: Cause.Cause<E>): Option.Option<E> =>
233
+ find<E, E>(self, (cause) =>
234
+ cause._tag === OpCodes.OP_FAIL ?
235
+ Option.some(cause.error) :
236
+ Option.none())
237
+
238
+ /** @internal */
239
+ export const failureOrCause = <E>(self: Cause.Cause<E>): Either.Either<Cause.Cause<never>, E> => {
240
+ const option = failureOption(self)
241
+ switch (option._tag) {
242
+ case "None": {
243
+ // no `E` inside this `Cause`, so it can be safely cast to `never`
244
+ return Either.right(self as Cause.Cause<never>)
245
+ }
246
+ case "Some": {
247
+ return Either.left(option.value)
248
+ }
249
+ }
250
+ }
251
+
252
+ /** @internal */
253
+ export const dieOption = <E>(self: Cause.Cause<E>): Option.Option<unknown> =>
254
+ find(self, (cause) =>
255
+ cause._tag === OpCodes.OP_DIE ?
256
+ Option.some(cause.defect) :
257
+ Option.none())
258
+
259
+ /** @internal */
260
+ export const flipCauseOption = <E>(self: Cause.Cause<Option.Option<E>>): Option.Option<Cause.Cause<E>> =>
261
+ match(self, {
262
+ onEmpty: Option.some<Cause.Cause<E>>(empty),
263
+ onFail: Option.map(fail),
264
+ onDie: (defect) => Option.some(die(defect)),
265
+ onInterrupt: (fiberId) => Option.some(interrupt(fiberId)),
266
+ onSequential: Option.mergeWith(sequential),
267
+ onParallel: Option.mergeWith(parallel)
268
+ })
269
+
270
+ /** @internal */
271
+ export const interruptOption = <E>(self: Cause.Cause<E>): Option.Option<FiberId.FiberId> =>
272
+ find(self, (cause) =>
273
+ cause._tag === OpCodes.OP_INTERRUPT ?
274
+ Option.some(cause.fiberId) :
275
+ Option.none())
276
+
277
+ /** @internal */
278
+ export const keepDefects = <E>(self: Cause.Cause<E>): Option.Option<Cause.Cause<never>> =>
279
+ match(self, {
280
+ onEmpty: Option.none(),
281
+ onFail: () => Option.none(),
282
+ onDie: (defect) => Option.some(die(defect)),
283
+ onInterrupt: () => Option.none(),
284
+ onSequential: Option.mergeWith(sequential),
285
+ onParallel: Option.mergeWith(parallel)
286
+ })
287
+
288
+ /** @internal */
289
+ export const keepDefectsAndElectFailures = <E>(self: Cause.Cause<E>): Option.Option<Cause.Cause<never>> =>
290
+ match(self, {
291
+ onEmpty: Option.none(),
292
+ onFail: (failure) => Option.some(die(failure)),
293
+ onDie: (defect) => Option.some(die(defect)),
294
+ onInterrupt: () => Option.none(),
295
+ onSequential: Option.mergeWith(sequential),
296
+ onParallel: Option.mergeWith(parallel)
297
+ })
298
+
299
+ /** @internal */
300
+ export const linearize = <E>(self: Cause.Cause<E>): HashSet.HashSet<Cause.Cause<E>> =>
301
+ match(self, {
302
+ onEmpty: HashSet.empty(),
303
+ onFail: (error) => HashSet.make(fail(error)),
304
+ onDie: (defect) => HashSet.make(die(defect)),
305
+ onInterrupt: (fiberId) => HashSet.make(interrupt(fiberId)),
306
+ onSequential: (leftSet, rightSet) =>
307
+ HashSet.flatMap(leftSet, (leftCause) => HashSet.map(rightSet, (rightCause) => sequential(leftCause, rightCause))),
308
+ onParallel: (leftSet, rightSet) =>
309
+ HashSet.flatMap(leftSet, (leftCause) => HashSet.map(rightSet, (rightCause) => parallel(leftCause, rightCause)))
310
+ })
311
+
312
+ /** @internal */
313
+ export const stripFailures = <E>(self: Cause.Cause<E>): Cause.Cause<never> =>
314
+ match(self, {
315
+ onEmpty: empty,
316
+ onFail: () => empty,
317
+ onDie: die,
318
+ onInterrupt: interrupt,
319
+ onSequential: sequential,
320
+ onParallel: parallel
321
+ })
322
+
323
+ /** @internal */
324
+ export const electFailures = <E>(self: Cause.Cause<E>): Cause.Cause<never> =>
325
+ match(self, {
326
+ onEmpty: empty,
327
+ onFail: die,
328
+ onDie: die,
329
+ onInterrupt: interrupt,
330
+ onSequential: sequential,
331
+ onParallel: parallel
332
+ })
333
+
334
+ /** @internal */
335
+ export const stripSomeDefects = dual<
336
+ (pf: (defect: unknown) => Option.Option<unknown>) => <E>(self: Cause.Cause<E>) => Option.Option<Cause.Cause<E>>,
337
+ <E>(self: Cause.Cause<E>, pf: (defect: unknown) => Option.Option<unknown>) => Option.Option<Cause.Cause<E>>
338
+ >(
339
+ 2,
340
+ <E>(self: Cause.Cause<E>, pf: (defect: unknown) => Option.Option<unknown>): Option.Option<Cause.Cause<E>> =>
341
+ match(self, {
342
+ onEmpty: Option.some<Cause.Cause<E>>(empty),
343
+ onFail: (error) => Option.some(fail(error)),
344
+ onDie: (defect) => {
345
+ const option = pf(defect)
346
+ return Option.isSome(option) ? Option.none() : Option.some(die(defect))
347
+ },
348
+ onInterrupt: (fiberId) => Option.some(interrupt(fiberId)),
349
+ onSequential: Option.mergeWith(sequential),
350
+ onParallel: Option.mergeWith(parallel)
351
+ })
352
+ )
353
+
354
+ // -----------------------------------------------------------------------------
355
+ // Mapping
356
+ // -----------------------------------------------------------------------------
357
+
358
+ /** @internal */
359
+ export const as = dual<
360
+ <E2>(error: E2) => <E>(self: Cause.Cause<E>) => Cause.Cause<E2>,
361
+ <E, E2>(self: Cause.Cause<E>, error: E2) => Cause.Cause<E2>
362
+ >(2, (self, error) => map(self, () => error))
363
+
364
+ /** @internal */
365
+ export const map = dual<
366
+ <E, E2>(f: (e: E) => E2) => (self: Cause.Cause<E>) => Cause.Cause<E2>,
367
+ <E, E2>(self: Cause.Cause<E>, f: (e: E) => E2) => Cause.Cause<E2>
368
+ >(2, (self, f) => flatMap(self, (e) => fail(f(e))))
369
+
370
+ // -----------------------------------------------------------------------------
371
+ // Sequencing
372
+ // -----------------------------------------------------------------------------
373
+
374
+ /** @internal */
375
+ export const flatMap = dual<
376
+ <E, E2>(f: (e: E) => Cause.Cause<E2>) => (self: Cause.Cause<E>) => Cause.Cause<E2>,
377
+ <E, E2>(self: Cause.Cause<E>, f: (e: E) => Cause.Cause<E2>) => Cause.Cause<E2>
378
+ >(2, (self, f) =>
379
+ match(self, {
380
+ onEmpty: empty,
381
+ onFail: (error) => f(error),
382
+ onDie: (defect) => die(defect),
383
+ onInterrupt: (fiberId) => interrupt(fiberId),
384
+ onSequential: (left, right) => sequential(left, right),
385
+ onParallel: (left, right) => parallel(left, right)
386
+ }))
387
+
388
+ /** @internal */
389
+ export const flatten = <E>(self: Cause.Cause<Cause.Cause<E>>): Cause.Cause<E> => flatMap(self, identity)
390
+
391
+ /** @internal */
392
+ export const andThen: {
393
+ <E, E2>(f: (e: E) => Cause.Cause<E2>): (self: Cause.Cause<E>) => Cause.Cause<E2>
394
+ <E2>(f: Cause.Cause<E2>): <E>(self: Cause.Cause<E>) => Cause.Cause<E2>
395
+ <E, E2>(self: Cause.Cause<E>, f: (e: E) => Cause.Cause<E2>): Cause.Cause<E2>
396
+ <E, E2>(self: Cause.Cause<E>, f: Cause.Cause<E2>): Cause.Cause<E2>
397
+ } = dual(
398
+ 2,
399
+ <E, E2>(self: Cause.Cause<E>, f: ((e: E) => Cause.Cause<E2>) | Cause.Cause<E2>): Cause.Cause<E2> =>
400
+ isFunction(f) ? flatMap(self, f) : flatMap(self, () => f)
401
+ )
402
+
403
+ // -----------------------------------------------------------------------------
404
+ // Equality
405
+ // -----------------------------------------------------------------------------
406
+
407
+ /** @internal */
408
+ export const contains = dual<
409
+ <E2>(that: Cause.Cause<E2>) => <E>(self: Cause.Cause<E>) => boolean,
410
+ <E, E2>(self: Cause.Cause<E>, that: Cause.Cause<E2>) => boolean
411
+ >(2, (self, that) => {
412
+ if (that._tag === OpCodes.OP_EMPTY || self === that) {
413
+ return true
414
+ }
415
+ return reduce(self, false, (accumulator, cause) => {
416
+ return Option.some(accumulator || causeEquals(cause, that))
417
+ })
418
+ })
419
+
420
+ /** @internal */
421
+ const causeEquals = (left: Cause.Cause<unknown>, right: Cause.Cause<unknown>): boolean => {
422
+ let leftStack: Chunk.Chunk<Cause.Cause<unknown>> = Chunk.of(left)
423
+ let rightStack: Chunk.Chunk<Cause.Cause<unknown>> = Chunk.of(right)
424
+ while (Chunk.isNonEmpty(leftStack) && Chunk.isNonEmpty(rightStack)) {
425
+ const [leftParallel, leftSequential] = pipe(
426
+ Chunk.headNonEmpty(leftStack),
427
+ reduce(
428
+ [HashSet.empty<unknown>(), Chunk.empty<Cause.Cause<unknown>>()] as const,
429
+ ([parallel, sequential], cause) => {
430
+ const [par, seq] = evaluateCause(cause)
431
+ return Option.some(
432
+ [
433
+ pipe(parallel, HashSet.union(par)),
434
+ pipe(sequential, Chunk.appendAll(seq))
435
+ ] as const
436
+ )
437
+ }
438
+ )
439
+ )
440
+ const [rightParallel, rightSequential] = pipe(
441
+ Chunk.headNonEmpty(rightStack),
442
+ reduce(
443
+ [HashSet.empty<unknown>(), Chunk.empty<Cause.Cause<unknown>>()] as const,
444
+ ([parallel, sequential], cause) => {
445
+ const [par, seq] = evaluateCause(cause)
446
+ return Option.some(
447
+ [
448
+ pipe(parallel, HashSet.union(par)),
449
+ pipe(sequential, Chunk.appendAll(seq))
450
+ ] as const
451
+ )
452
+ }
453
+ )
454
+ )
455
+ if (!Equal.equals(leftParallel, rightParallel)) {
456
+ return false
457
+ }
458
+ leftStack = leftSequential
459
+ rightStack = rightSequential
460
+ }
461
+ return true
462
+ }
463
+
464
+ // -----------------------------------------------------------------------------
465
+ // Flattening
466
+ // -----------------------------------------------------------------------------
467
+
468
+ /**
469
+ * Flattens a cause to a sequence of sets of causes, where each set represents
470
+ * causes that fail in parallel and sequential sets represent causes that fail
471
+ * after each other.
472
+ *
473
+ * @internal
474
+ */
475
+ const flattenCause = (cause: Cause.Cause<unknown>): Chunk.Chunk<HashSet.HashSet<unknown>> => {
476
+ return flattenCauseLoop(Chunk.of(cause), Chunk.empty())
477
+ }
478
+
479
+ /** @internal */
480
+ const flattenCauseLoop = (
481
+ causes: Chunk.Chunk<Cause.Cause<unknown>>,
482
+ flattened: Chunk.Chunk<HashSet.HashSet<unknown>>
483
+ ): Chunk.Chunk<HashSet.HashSet<unknown>> => {
484
+ // eslint-disable-next-line no-constant-condition
485
+ while (1) {
486
+ const [parallel, sequential] = pipe(
487
+ causes,
488
+ Arr.reduce(
489
+ [HashSet.empty<unknown>(), Chunk.empty<Cause.Cause<unknown>>()] as const,
490
+ ([parallel, sequential], cause) => {
491
+ const [par, seq] = evaluateCause(cause)
492
+ return [
493
+ pipe(parallel, HashSet.union(par)),
494
+ pipe(sequential, Chunk.appendAll(seq))
495
+ ]
496
+ }
497
+ )
498
+ )
499
+ const updated = HashSet.size(parallel) > 0 ?
500
+ pipe(flattened, Chunk.prepend(parallel)) :
501
+ flattened
502
+ if (Chunk.isEmpty(sequential)) {
503
+ return Chunk.reverse(updated)
504
+ }
505
+ causes = sequential
506
+ flattened = updated
507
+ }
508
+ throw new Error(getBugErrorMessage("Cause.flattenCauseLoop"))
509
+ }
510
+
511
+ // -----------------------------------------------------------------------------
512
+ // Finding
513
+ // -----------------------------------------------------------------------------
514
+
515
+ /** @internal */
516
+ export const find = dual<
517
+ <E, Z>(pf: (cause: Cause.Cause<E>) => Option.Option<Z>) => (self: Cause.Cause<E>) => Option.Option<Z>,
518
+ <E, Z>(self: Cause.Cause<E>, pf: (cause: Cause.Cause<E>) => Option.Option<Z>) => Option.Option<Z>
519
+ >(2, <E, Z>(self: Cause.Cause<E>, pf: (cause: Cause.Cause<E>) => Option.Option<Z>) => {
520
+ const stack: Array<Cause.Cause<E>> = [self]
521
+ while (stack.length > 0) {
522
+ const item = stack.pop()!
523
+ const option = pf(item)
524
+ switch (option._tag) {
525
+ case "None": {
526
+ switch (item._tag) {
527
+ case OpCodes.OP_SEQUENTIAL:
528
+ case OpCodes.OP_PARALLEL: {
529
+ stack.push(item.right)
530
+ stack.push(item.left)
531
+ break
532
+ }
533
+ }
534
+ break
535
+ }
536
+ case "Some": {
537
+ return option
538
+ }
539
+ }
540
+ }
541
+ return Option.none()
542
+ })
543
+
544
+ // -----------------------------------------------------------------------------
545
+ // Filtering
546
+ // -----------------------------------------------------------------------------
547
+
548
+ /** @internal */
549
+ export const filter: {
550
+ <E, EB extends E>(
551
+ refinement: Refinement<Cause.Cause<NoInfer<E>>, Cause.Cause<EB>>
552
+ ): (self: Cause.Cause<E>) => Cause.Cause<EB>
553
+ <E>(predicate: Predicate<Cause.Cause<NoInfer<E>>>): (self: Cause.Cause<E>) => Cause.Cause<E>
554
+ <E, EB extends E>(self: Cause.Cause<E>, refinement: Refinement<Cause.Cause<E>, Cause.Cause<EB>>): Cause.Cause<EB>
555
+ <E>(self: Cause.Cause<E>, predicate: Predicate<Cause.Cause<E>>): Cause.Cause<E>
556
+ } = dual(
557
+ 2,
558
+ <E>(self: Cause.Cause<E>, predicate: Predicate<Cause.Cause<E>>): Cause.Cause<E> =>
559
+ reduceWithContext(self, void 0, FilterCauseReducer(predicate))
560
+ )
561
+
562
+ // -----------------------------------------------------------------------------
563
+ // Evaluation
564
+ // -----------------------------------------------------------------------------
565
+
566
+ /**
567
+ * Takes one step in evaluating a cause, returning a set of causes that fail
568
+ * in parallel and a list of causes that fail sequentially after those causes.
569
+ *
570
+ * @internal
571
+ */
572
+ const evaluateCause = (
573
+ self: Cause.Cause<unknown>
574
+ ): [HashSet.HashSet<unknown>, Chunk.Chunk<Cause.Cause<unknown>>] => {
575
+ let cause: Cause.Cause<unknown> | undefined = self
576
+ const stack: Array<Cause.Cause<unknown>> = []
577
+ let _parallel = HashSet.empty<unknown>()
578
+ let _sequential = Chunk.empty<Cause.Cause<unknown>>()
579
+ while (cause !== undefined) {
580
+ switch (cause._tag) {
581
+ case OpCodes.OP_EMPTY: {
582
+ if (stack.length === 0) {
583
+ return [_parallel, _sequential]
584
+ }
585
+ cause = stack.pop()
586
+ break
587
+ }
588
+ case OpCodes.OP_FAIL: {
589
+ _parallel = HashSet.add(_parallel, Chunk.make(cause._tag, cause.error))
590
+ if (stack.length === 0) {
591
+ return [_parallel, _sequential]
592
+ }
593
+ cause = stack.pop()
594
+ break
595
+ }
596
+ case OpCodes.OP_DIE: {
597
+ _parallel = HashSet.add(_parallel, Chunk.make(cause._tag, cause.defect))
598
+ if (stack.length === 0) {
599
+ return [_parallel, _sequential]
600
+ }
601
+ cause = stack.pop()
602
+ break
603
+ }
604
+ case OpCodes.OP_INTERRUPT: {
605
+ _parallel = HashSet.add(_parallel, Chunk.make(cause._tag, cause.fiberId as unknown))
606
+ if (stack.length === 0) {
607
+ return [_parallel, _sequential]
608
+ }
609
+ cause = stack.pop()
610
+ break
611
+ }
612
+ case OpCodes.OP_SEQUENTIAL: {
613
+ switch (cause.left._tag) {
614
+ case OpCodes.OP_EMPTY: {
615
+ cause = cause.right
616
+ break
617
+ }
618
+ case OpCodes.OP_SEQUENTIAL: {
619
+ cause = sequential(cause.left.left, sequential(cause.left.right, cause.right))
620
+ break
621
+ }
622
+ case OpCodes.OP_PARALLEL: {
623
+ cause = parallel(
624
+ sequential(cause.left.left, cause.right),
625
+ sequential(cause.left.right, cause.right)
626
+ )
627
+ break
628
+ }
629
+ default: {
630
+ _sequential = Chunk.prepend(_sequential, cause.right)
631
+ cause = cause.left
632
+ break
633
+ }
634
+ }
635
+ break
636
+ }
637
+ case OpCodes.OP_PARALLEL: {
638
+ stack.push(cause.right)
639
+ cause = cause.left
640
+ break
641
+ }
642
+ }
643
+ }
644
+ throw new Error(getBugErrorMessage("Cause.evaluateCauseLoop"))
645
+ }
646
+
647
+ // -----------------------------------------------------------------------------
648
+ // Reducing
649
+ // -----------------------------------------------------------------------------
650
+
651
+ /** @internal */
652
+ const SizeCauseReducer: Cause.CauseReducer<unknown, unknown, number> = {
653
+ emptyCase: () => 0,
654
+ failCase: () => 1,
655
+ dieCase: () => 1,
656
+ interruptCase: () => 1,
657
+ sequentialCase: (_, left, right) => left + right,
658
+ parallelCase: (_, left, right) => left + right
659
+ }
660
+
661
+ /** @internal */
662
+ const IsInterruptedOnlyCauseReducer: Cause.CauseReducer<unknown, unknown, boolean> = {
663
+ emptyCase: constTrue,
664
+ failCase: constFalse,
665
+ dieCase: constFalse,
666
+ interruptCase: constTrue,
667
+ sequentialCase: (_, left, right) => left && right,
668
+ parallelCase: (_, left, right) => left && right
669
+ }
670
+
671
+ /** @internal */
672
+ const FilterCauseReducer = <E>(
673
+ predicate: Predicate<Cause.Cause<E>>
674
+ ): Cause.CauseReducer<unknown, E, Cause.Cause<E>> => ({
675
+ emptyCase: () => empty,
676
+ failCase: (_, error) => fail(error),
677
+ dieCase: (_, defect) => die(defect),
678
+ interruptCase: (_, fiberId) => interrupt(fiberId),
679
+ sequentialCase: (_, left, right) => {
680
+ if (predicate(left)) {
681
+ if (predicate(right)) {
682
+ return sequential(left, right)
683
+ }
684
+ return left
685
+ }
686
+ if (predicate(right)) {
687
+ return right
688
+ }
689
+ return empty
690
+ },
691
+ parallelCase: (_, left, right) => {
692
+ if (predicate(left)) {
693
+ if (predicate(right)) {
694
+ return parallel(left, right)
695
+ }
696
+ return left
697
+ }
698
+ if (predicate(right)) {
699
+ return right
700
+ }
701
+ return empty
702
+ }
703
+ })
704
+
705
+ /** @internal */
706
+ type CauseCase = SequentialCase | ParallelCase
707
+
708
+ const OP_SEQUENTIAL_CASE = "SequentialCase"
709
+
710
+ const OP_PARALLEL_CASE = "ParallelCase"
711
+
712
+ /** @internal */
713
+ interface SequentialCase {
714
+ readonly _tag: typeof OP_SEQUENTIAL_CASE
715
+ }
716
+
717
+ /** @internal */
718
+ interface ParallelCase {
719
+ readonly _tag: typeof OP_PARALLEL_CASE
720
+ }
721
+
722
+ /** @internal */
723
+ export const match = dual<
724
+ <Z, E>(
725
+ options: {
726
+ readonly onEmpty: Z
727
+ readonly onFail: (error: E) => Z
728
+ readonly onDie: (defect: unknown) => Z
729
+ readonly onInterrupt: (fiberId: FiberId.FiberId) => Z
730
+ readonly onSequential: (left: Z, right: Z) => Z
731
+ readonly onParallel: (left: Z, right: Z) => Z
732
+ }
733
+ ) => (self: Cause.Cause<E>) => Z,
734
+ <Z, E>(
735
+ self: Cause.Cause<E>,
736
+ options: {
737
+ readonly onEmpty: Z
738
+ readonly onFail: (error: E) => Z
739
+ readonly onDie: (defect: unknown) => Z
740
+ readonly onInterrupt: (fiberId: FiberId.FiberId) => Z
741
+ readonly onSequential: (left: Z, right: Z) => Z
742
+ readonly onParallel: (left: Z, right: Z) => Z
743
+ }
744
+ ) => Z
745
+ >(2, (self, { onDie, onEmpty, onFail, onInterrupt, onParallel, onSequential }) => {
746
+ return reduceWithContext(self, void 0, {
747
+ emptyCase: () => onEmpty,
748
+ failCase: (_, error) => onFail(error),
749
+ dieCase: (_, defect) => onDie(defect),
750
+ interruptCase: (_, fiberId) => onInterrupt(fiberId),
751
+ sequentialCase: (_, left, right) => onSequential(left, right),
752
+ parallelCase: (_, left, right) => onParallel(left, right)
753
+ })
754
+ })
755
+
756
+ /** @internal */
757
+ export const reduce = dual<
758
+ <Z, E>(zero: Z, pf: (accumulator: Z, cause: Cause.Cause<E>) => Option.Option<Z>) => (self: Cause.Cause<E>) => Z,
759
+ <Z, E>(self: Cause.Cause<E>, zero: Z, pf: (accumulator: Z, cause: Cause.Cause<E>) => Option.Option<Z>) => Z
760
+ >(3, <Z, E>(self: Cause.Cause<E>, zero: Z, pf: (accumulator: Z, cause: Cause.Cause<E>) => Option.Option<Z>) => {
761
+ let accumulator: Z = zero
762
+ let cause: Cause.Cause<E> | undefined = self
763
+ const causes: Array<Cause.Cause<E>> = []
764
+ while (cause !== undefined) {
765
+ const option = pf(accumulator, cause)
766
+ accumulator = Option.isSome(option) ? option.value : accumulator
767
+ switch (cause._tag) {
768
+ case OpCodes.OP_SEQUENTIAL: {
769
+ causes.push(cause.right)
770
+ cause = cause.left
771
+ break
772
+ }
773
+ case OpCodes.OP_PARALLEL: {
774
+ causes.push(cause.right)
775
+ cause = cause.left
776
+ break
777
+ }
778
+ default: {
779
+ cause = undefined
780
+ break
781
+ }
782
+ }
783
+ if (cause === undefined && causes.length > 0) {
784
+ cause = causes.pop()!
785
+ }
786
+ }
787
+ return accumulator
788
+ })
789
+
790
+ /** @internal */
791
+ export const reduceWithContext = dual<
792
+ <C, E, Z>(context: C, reducer: Cause.CauseReducer<C, E, Z>) => (self: Cause.Cause<E>) => Z,
793
+ <C, E, Z>(self: Cause.Cause<E>, context: C, reducer: Cause.CauseReducer<C, E, Z>) => Z
794
+ >(3, <C, E, Z>(self: Cause.Cause<E>, context: C, reducer: Cause.CauseReducer<C, E, Z>) => {
795
+ const input: Array<Cause.Cause<E>> = [self]
796
+ const output: Array<Either.Either<Z, CauseCase>> = []
797
+ while (input.length > 0) {
798
+ const cause = input.pop()!
799
+ switch (cause._tag) {
800
+ case OpCodes.OP_EMPTY: {
801
+ output.push(Either.right(reducer.emptyCase(context)))
802
+ break
803
+ }
804
+ case OpCodes.OP_FAIL: {
805
+ output.push(Either.right(reducer.failCase(context, cause.error)))
806
+ break
807
+ }
808
+ case OpCodes.OP_DIE: {
809
+ output.push(Either.right(reducer.dieCase(context, cause.defect)))
810
+ break
811
+ }
812
+ case OpCodes.OP_INTERRUPT: {
813
+ output.push(Either.right(reducer.interruptCase(context, cause.fiberId)))
814
+ break
815
+ }
816
+ case OpCodes.OP_SEQUENTIAL: {
817
+ input.push(cause.right)
818
+ input.push(cause.left)
819
+ output.push(Either.left({ _tag: OP_SEQUENTIAL_CASE }))
820
+ break
821
+ }
822
+ case OpCodes.OP_PARALLEL: {
823
+ input.push(cause.right)
824
+ input.push(cause.left)
825
+ output.push(Either.left({ _tag: OP_PARALLEL_CASE }))
826
+ break
827
+ }
828
+ }
829
+ }
830
+ const accumulator: Array<Z> = []
831
+ while (output.length > 0) {
832
+ const either = output.pop()!
833
+ switch (either._tag) {
834
+ case "Left": {
835
+ switch (either.left._tag) {
836
+ case OP_SEQUENTIAL_CASE: {
837
+ const left = accumulator.pop()!
838
+ const right = accumulator.pop()!
839
+ const value = reducer.sequentialCase(context, left, right)
840
+ accumulator.push(value)
841
+ break
842
+ }
843
+ case OP_PARALLEL_CASE: {
844
+ const left = accumulator.pop()!
845
+ const right = accumulator.pop()!
846
+ const value = reducer.parallelCase(context, left, right)
847
+ accumulator.push(value)
848
+ break
849
+ }
850
+ }
851
+ break
852
+ }
853
+ case "Right": {
854
+ accumulator.push(either.right)
855
+ break
856
+ }
857
+ }
858
+ }
859
+ if (accumulator.length === 0) {
860
+ throw new Error(
861
+ "BUG: Cause.reduceWithContext - please report an issue at https://github.com/Effect-TS/effect/issues"
862
+ )
863
+ }
864
+ return accumulator.pop()!
865
+ })
866
+
867
+ // -----------------------------------------------------------------------------
868
+ // Pretty Printing
869
+ // -----------------------------------------------------------------------------
870
+
871
+ /** @internal */
872
+ export const pretty = <E>(cause: Cause.Cause<E>, options?: {
873
+ readonly renderErrorCause?: boolean | undefined
874
+ }): string => {
875
+ if (isInterruptedOnly(cause)) {
876
+ return "All fibers interrupted without errors."
877
+ }
878
+ return prettyErrors<E>(cause).map(function(e) {
879
+ if (options?.renderErrorCause !== true || e.cause === undefined) {
880
+ return e.stack
881
+ }
882
+ return `${e.stack} {\n${renderErrorCause(e.cause as PrettyError, " ")}\n}`
883
+ }).join("\n")
884
+ }
885
+
886
+ const renderErrorCause = (cause: PrettyError, prefix: string) => {
887
+ const lines = cause.stack!.split("\n")
888
+ let stack = `${prefix}[cause]: ${lines[0]}`
889
+ for (let i = 1, len = lines.length; i < len; i++) {
890
+ stack += `\n${prefix}${lines[i]}`
891
+ }
892
+ if (cause.cause) {
893
+ stack += ` {\n${renderErrorCause(cause.cause as PrettyError, `${prefix} `)}\n${prefix}}`
894
+ }
895
+ return stack
896
+ }
897
+
898
+ /** @internal */
899
+ export class PrettyError extends globalThis.Error implements Cause.PrettyError {
900
+ span: undefined | Span = undefined
901
+ constructor(originalError: unknown) {
902
+ const originalErrorIsObject = typeof originalError === "object" && originalError !== null
903
+ const prevLimit = Error.stackTraceLimit
904
+ Error.stackTraceLimit = 1
905
+ super(
906
+ prettyErrorMessage(originalError),
907
+ originalErrorIsObject && "cause" in originalError && typeof originalError.cause !== "undefined"
908
+ ? { cause: new PrettyError(originalError.cause) }
909
+ : undefined
910
+ )
911
+ if (this.message === "") {
912
+ this.message = "An error has occurred"
913
+ }
914
+ Error.stackTraceLimit = prevLimit
915
+ this.name = originalError instanceof Error ? originalError.name : "Error"
916
+ if (originalErrorIsObject) {
917
+ if (spanSymbol in originalError) {
918
+ this.span = originalError[spanSymbol] as Span
919
+ }
920
+ Object.keys(originalError).forEach((key) => {
921
+ if (!(key in this)) {
922
+ // @ts-expect-error
923
+ this[key] = originalError[key]
924
+ }
925
+ })
926
+ }
927
+ this.stack = prettyErrorStack(
928
+ `${this.name}: ${this.message}`,
929
+ originalError instanceof Error && originalError.stack
930
+ ? originalError.stack
931
+ : "",
932
+ this.span
933
+ )
934
+ }
935
+ }
936
+
937
+ /**
938
+ * A utility function for generating human-readable error messages from a generic error of type `unknown`.
939
+ *
940
+ * Rules:
941
+ *
942
+ * 1) If the input `u` is already a string, it's considered a message.
943
+ * 2) If `u` is an Error instance with a message defined, it uses the message.
944
+ * 3) If `u` has a user-defined `toString()` method, it uses that method.
945
+ * 4) Otherwise, it uses `Inspectable.stringifyCircular` to produce a string representation and uses it as the error message,
946
+ * with "Error" added as a prefix.
947
+ *
948
+ * @internal
949
+ */
950
+ export const prettyErrorMessage = (u: unknown): string => {
951
+ // 1)
952
+ if (typeof u === "string") {
953
+ return u
954
+ }
955
+ // 2)
956
+ if (typeof u === "object" && u !== null && u instanceof Error) {
957
+ return u.message
958
+ }
959
+ // 3)
960
+ try {
961
+ if (
962
+ hasProperty(u, "toString") &&
963
+ isFunction(u["toString"]) &&
964
+ u["toString"] !== Object.prototype.toString &&
965
+ u["toString"] !== globalThis.Array.prototype.toString
966
+ ) {
967
+ return u["toString"]()
968
+ }
969
+ } catch {
970
+ // something's off, rollback to json
971
+ }
972
+ // 4)
973
+ return stringifyCircular(u)
974
+ }
975
+
976
+ const locationRegex = /\((.*)\)/g
977
+
978
+ /** @internal */
979
+ export const spanToTrace = globalValue("effect/Tracer/spanToTrace", () => new WeakMap())
980
+
981
+ const prettyErrorStack = (message: string, stack: string, span?: Span | undefined): string => {
982
+ const out: Array<string> = [message]
983
+ const lines = stack.startsWith(message) ? stack.slice(message.length).split("\n") : stack.split("\n")
984
+
985
+ for (let i = 1; i < lines.length; i++) {
986
+ if (lines[i].includes(" at new BaseEffectError") || lines[i].includes(" at new YieldableError")) {
987
+ i++
988
+ continue
989
+ }
990
+ if (lines[i].includes("Generator.next")) {
991
+ break
992
+ }
993
+ if (lines[i].includes("effect_internal_function")) {
994
+ break
995
+ }
996
+ out.push(
997
+ lines[i]
998
+ .replace(/at .*effect_instruction_i.*\((.*)\)/, "at $1")
999
+ .replace(/EffectPrimitive\.\w+/, "<anonymous>")
1000
+ )
1001
+ }
1002
+
1003
+ if (span) {
1004
+ let current: Span | AnySpan | undefined = span
1005
+ let i = 0
1006
+ while (current && current._tag === "Span" && i < 10) {
1007
+ const stackFn = spanToTrace.get(current)
1008
+ if (typeof stackFn === "function") {
1009
+ const stack = stackFn()
1010
+ if (typeof stack === "string") {
1011
+ const locationMatchAll = stack.matchAll(locationRegex)
1012
+ let match = false
1013
+ for (const [, location] of locationMatchAll) {
1014
+ match = true
1015
+ out.push(` at ${current.name} (${location})`)
1016
+ }
1017
+ if (!match) {
1018
+ out.push(` at ${current.name} (${stack.replace(/^at /, "")})`)
1019
+ }
1020
+ } else {
1021
+ out.push(` at ${current.name}`)
1022
+ }
1023
+ } else {
1024
+ out.push(` at ${current.name}`)
1025
+ }
1026
+ current = Option.getOrUndefined(current.parent)
1027
+ i++
1028
+ }
1029
+ }
1030
+
1031
+ return out.join("\n")
1032
+ }
1033
+
1034
+ /** @internal */
1035
+ export const spanSymbol = Symbol.for("effect/SpanAnnotation")
1036
+
1037
+ /** @internal */
1038
+ export const prettyErrors = <E>(cause: Cause.Cause<E>): Array<PrettyError> =>
1039
+ reduceWithContext(cause, void 0, {
1040
+ emptyCase: (): Array<PrettyError> => [],
1041
+ dieCase: (_, unknownError) => {
1042
+ return [new PrettyError(unknownError)]
1043
+ },
1044
+ failCase: (_, error) => {
1045
+ return [new PrettyError(error)]
1046
+ },
1047
+ interruptCase: () => [],
1048
+ parallelCase: (_, l, r) => [...l, ...r],
1049
+ sequentialCase: (_, l, r) => [...l, ...r]
1050
+ })