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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (452) hide show
  1. package/SourceLocation/package.json +6 -0
  2. package/dist/cjs/Effect.js +2 -28
  3. package/dist/cjs/Effect.js.map +1 -1
  4. package/dist/cjs/FiberRef.js +12 -1
  5. package/dist/cjs/FiberRef.js.map +1 -1
  6. package/dist/cjs/Layer.js +2 -24
  7. package/dist/cjs/Layer.js.map +1 -1
  8. package/dist/cjs/RuntimeFlags.js +1 -29
  9. package/dist/cjs/RuntimeFlags.js.map +1 -1
  10. package/dist/cjs/SourceLocation.js +60 -0
  11. package/dist/cjs/SourceLocation.js.map +1 -0
  12. package/dist/cjs/Tracer.js +1 -15
  13. package/dist/cjs/Tracer.js.map +1 -1
  14. package/dist/cjs/Utils.js +1 -1
  15. package/dist/cjs/Utils.js.map +1 -1
  16. package/dist/cjs/index.js +3 -1
  17. package/dist/cjs/index.js.map +1 -1
  18. package/dist/cjs/internal/clock.js +1 -1
  19. package/dist/cjs/internal/clock.js.map +1 -1
  20. package/dist/cjs/internal/core.js +17 -50
  21. package/dist/cjs/internal/core.js.map +1 -1
  22. package/dist/cjs/internal/effect/circular.js +18 -30
  23. package/dist/cjs/internal/effect/circular.js.map +1 -1
  24. package/dist/cjs/internal/fiberRuntime.js +16 -65
  25. package/dist/cjs/internal/fiberRuntime.js.map +1 -1
  26. package/dist/cjs/internal/layer/circular.js +1 -5
  27. package/dist/cjs/internal/layer/circular.js.map +1 -1
  28. package/dist/cjs/internal/layer.js +1 -3
  29. package/dist/cjs/internal/layer.js.map +1 -1
  30. package/dist/cjs/internal/logger.js +25 -2
  31. package/dist/cjs/internal/logger.js.map +1 -1
  32. package/dist/cjs/internal/runtimeFlags.js +2 -11
  33. package/dist/cjs/internal/runtimeFlags.js.map +1 -1
  34. package/dist/cjs/internal/tracer.js +1 -114
  35. package/dist/cjs/internal/tracer.js.map +1 -1
  36. package/dist/dts/Config.d.ts +2 -2
  37. package/dist/dts/Config.d.ts.map +1 -1
  38. package/dist/dts/Effect.d.ts +8 -29
  39. package/dist/dts/Effect.d.ts.map +1 -1
  40. package/dist/dts/FiberRef.d.ts +12 -0
  41. package/dist/dts/FiberRef.d.ts.map +1 -1
  42. package/dist/dts/Layer.d.ts +0 -22
  43. package/dist/dts/Layer.d.ts.map +1 -1
  44. package/dist/dts/RuntimeFlags.d.ts +0 -28
  45. package/dist/dts/RuntimeFlags.d.ts.map +1 -1
  46. package/dist/dts/SourceLocation.d.ts +88 -0
  47. package/dist/dts/SourceLocation.d.ts.map +1 -0
  48. package/dist/dts/Tracer.d.ts +0 -15
  49. package/dist/dts/Tracer.d.ts.map +1 -1
  50. package/dist/dts/index.d.ts +6 -0
  51. package/dist/dts/index.d.ts.map +1 -1
  52. package/dist/dts/internal/core.d.ts.map +1 -1
  53. package/dist/dts/internal/layer.d.ts.map +1 -1
  54. package/dist/dts/internal/runtimeFlags.d.ts.map +1 -1
  55. package/dist/esm/Effect.js +0 -26
  56. package/dist/esm/Effect.js.map +1 -1
  57. package/dist/esm/FiberRef.js +11 -0
  58. package/dist/esm/FiberRef.js.map +1 -1
  59. package/dist/esm/Layer.js +0 -22
  60. package/dist/esm/Layer.js.map +1 -1
  61. package/dist/esm/RuntimeFlags.js +0 -28
  62. package/dist/esm/RuntimeFlags.js.map +1 -1
  63. package/dist/esm/SourceLocation.js +51 -0
  64. package/dist/esm/SourceLocation.js.map +1 -0
  65. package/dist/esm/Tracer.js +0 -14
  66. package/dist/esm/Tracer.js.map +1 -1
  67. package/dist/esm/Utils.js +1 -1
  68. package/dist/esm/Utils.js.map +1 -1
  69. package/dist/esm/index.js +6 -0
  70. package/dist/esm/index.js.map +1 -1
  71. package/dist/esm/internal/clock.js +1 -1
  72. package/dist/esm/internal/clock.js.map +1 -1
  73. package/dist/esm/internal/core.js +12 -45
  74. package/dist/esm/internal/core.js.map +1 -1
  75. package/dist/esm/internal/effect/circular.js +18 -30
  76. package/dist/esm/internal/effect/circular.js.map +1 -1
  77. package/dist/esm/internal/fiberRuntime.js +13 -60
  78. package/dist/esm/internal/fiberRuntime.js.map +1 -1
  79. package/dist/esm/internal/layer/circular.js +0 -4
  80. package/dist/esm/internal/layer/circular.js.map +1 -1
  81. package/dist/esm/internal/layer.js +0 -2
  82. package/dist/esm/internal/layer.js.map +1 -1
  83. package/dist/esm/internal/logger.js +25 -2
  84. package/dist/esm/internal/logger.js.map +1 -1
  85. package/dist/esm/internal/runtimeFlags.js +1 -9
  86. package/dist/esm/internal/runtimeFlags.js.map +1 -1
  87. package/dist/esm/internal/tracer.js +0 -111
  88. package/dist/esm/internal/tracer.js.map +1 -1
  89. package/package.json +12 -1
  90. package/src/Arbitrary.ts +1101 -0
  91. package/src/Array.ts +3589 -0
  92. package/src/BigDecimal.ts +1349 -0
  93. package/src/BigInt.ts +643 -0
  94. package/src/Boolean.ts +287 -0
  95. package/src/Brand.ts +360 -0
  96. package/src/Cache.ts +281 -0
  97. package/src/Cause.ts +1555 -0
  98. package/src/Channel.ts +2355 -0
  99. package/src/ChildExecutorDecision.ts +146 -0
  100. package/src/Chunk.ts +1495 -0
  101. package/src/Clock.ts +111 -0
  102. package/src/Config.ts +542 -0
  103. package/src/ConfigError.ts +270 -0
  104. package/src/ConfigProvider.ts +333 -0
  105. package/src/ConfigProviderPathPatch.ts +100 -0
  106. package/src/Console.ts +226 -0
  107. package/src/Context.ts +585 -0
  108. package/src/Cron.ts +706 -0
  109. package/src/Data.ts +596 -0
  110. package/src/DateTime.ts +1686 -0
  111. package/src/DefaultServices.ts +34 -0
  112. package/src/Deferred.ts +301 -0
  113. package/src/Differ.ts +450 -0
  114. package/src/Duration.ts +1000 -0
  115. package/src/Effect.ts +14817 -0
  116. package/src/Effectable.ts +107 -0
  117. package/src/Either.ts +1040 -0
  118. package/src/Encoding.ts +195 -0
  119. package/src/Equal.ts +98 -0
  120. package/src/Equivalence.ts +235 -0
  121. package/src/ExecutionPlan.ts +308 -0
  122. package/src/ExecutionStrategy.ts +119 -0
  123. package/src/Exit.ts +467 -0
  124. package/src/FastCheck.ts +9 -0
  125. package/src/Fiber.ts +744 -0
  126. package/src/FiberHandle.ts +540 -0
  127. package/src/FiberId.ts +195 -0
  128. package/src/FiberMap.ts +656 -0
  129. package/src/FiberRef.ts +444 -0
  130. package/src/FiberRefs.ts +204 -0
  131. package/src/FiberRefsPatch.ts +105 -0
  132. package/src/FiberSet.ts +491 -0
  133. package/src/FiberStatus.ts +108 -0
  134. package/src/Function.ts +1222 -0
  135. package/src/GlobalValue.ts +53 -0
  136. package/src/Graph.ts +3732 -0
  137. package/src/GroupBy.ts +103 -0
  138. package/src/HKT.ts +45 -0
  139. package/src/Hash.ts +195 -0
  140. package/src/HashMap.ts +519 -0
  141. package/src/HashRing.ts +317 -0
  142. package/src/HashSet.ts +2346 -0
  143. package/src/Inspectable.ts +287 -0
  144. package/src/Iterable.ts +1119 -0
  145. package/src/JSONSchema.ts +1044 -0
  146. package/src/KeyedPool.ts +167 -0
  147. package/src/Layer.ts +1228 -0
  148. package/src/LayerMap.ts +436 -0
  149. package/src/List.ts +977 -0
  150. package/src/LogLevel.ts +285 -0
  151. package/src/LogSpan.ts +25 -0
  152. package/src/Logger.ts +702 -0
  153. package/src/Mailbox.ts +268 -0
  154. package/src/ManagedRuntime.ts +180 -0
  155. package/src/Match.ts +1477 -0
  156. package/src/MergeDecision.ts +95 -0
  157. package/src/MergeState.ts +172 -0
  158. package/src/MergeStrategy.ts +107 -0
  159. package/src/Metric.ts +780 -0
  160. package/src/MetricBoundaries.ts +69 -0
  161. package/src/MetricHook.ts +151 -0
  162. package/src/MetricKey.ts +224 -0
  163. package/src/MetricKeyType.ts +262 -0
  164. package/src/MetricLabel.ts +47 -0
  165. package/src/MetricPair.ts +71 -0
  166. package/src/MetricPolling.ts +148 -0
  167. package/src/MetricRegistry.ts +48 -0
  168. package/src/MetricState.ts +257 -0
  169. package/src/Micro.ts +4405 -0
  170. package/src/ModuleVersion.ts +18 -0
  171. package/src/MutableHashMap.ts +411 -0
  172. package/src/MutableHashSet.ts +706 -0
  173. package/src/MutableList.ts +297 -0
  174. package/src/MutableQueue.ts +227 -0
  175. package/src/MutableRef.ts +202 -0
  176. package/src/NonEmptyIterable.ts +32 -0
  177. package/src/Number.ts +1071 -0
  178. package/src/Option.ts +2170 -0
  179. package/src/Order.ts +373 -0
  180. package/src/Ordering.ts +111 -0
  181. package/src/ParseResult.ts +2031 -0
  182. package/src/PartitionedSemaphore.ts +200 -0
  183. package/src/Pipeable.ts +566 -0
  184. package/src/Pool.ts +204 -0
  185. package/src/Predicate.ts +1405 -0
  186. package/src/Pretty.ts +205 -0
  187. package/src/PrimaryKey.ts +23 -0
  188. package/src/PubSub.ts +182 -0
  189. package/src/Queue.ts +644 -0
  190. package/src/Random.ts +204 -0
  191. package/src/RateLimiter.ts +138 -0
  192. package/src/RcMap.ts +141 -0
  193. package/src/RcRef.ts +122 -0
  194. package/src/Readable.ts +93 -0
  195. package/src/Record.ts +1274 -0
  196. package/src/RedBlackTree.ts +421 -0
  197. package/src/Redacted.ts +144 -0
  198. package/src/Ref.ts +180 -0
  199. package/src/RegExp.ts +38 -0
  200. package/src/Reloadable.ts +127 -0
  201. package/src/Request.ts +347 -0
  202. package/src/RequestBlock.ts +118 -0
  203. package/src/RequestResolver.ts +366 -0
  204. package/src/Resource.ts +119 -0
  205. package/src/Runtime.ts +383 -0
  206. package/src/RuntimeFlags.ts +336 -0
  207. package/src/RuntimeFlagsPatch.ts +183 -0
  208. package/src/STM.ts +2045 -0
  209. package/src/Schedule.ts +2219 -0
  210. package/src/ScheduleDecision.ts +62 -0
  211. package/src/ScheduleInterval.ts +151 -0
  212. package/src/ScheduleIntervals.ts +122 -0
  213. package/src/Scheduler.ts +353 -0
  214. package/src/Schema.ts +10914 -0
  215. package/src/SchemaAST.ts +3043 -0
  216. package/src/Scope.ts +204 -0
  217. package/src/ScopedCache.ts +151 -0
  218. package/src/ScopedRef.ts +117 -0
  219. package/src/Secret.ts +88 -0
  220. package/src/SingleProducerAsyncInput.ts +67 -0
  221. package/src/Sink.ts +1461 -0
  222. package/src/SortedMap.ts +287 -0
  223. package/src/SortedSet.ts +390 -0
  224. package/src/SourceLocation.ts +108 -0
  225. package/src/Stream.ts +6468 -0
  226. package/src/StreamEmit.ts +136 -0
  227. package/src/StreamHaltStrategy.ts +123 -0
  228. package/src/Streamable.ts +45 -0
  229. package/src/String.ts +778 -0
  230. package/src/Struct.ts +243 -0
  231. package/src/Subscribable.ts +100 -0
  232. package/src/SubscriptionRef.ts +298 -0
  233. package/src/Supervisor.ts +240 -0
  234. package/src/Symbol.ts +29 -0
  235. package/src/SynchronizedRef.ts +270 -0
  236. package/src/TArray.ts +495 -0
  237. package/src/TDeferred.ts +100 -0
  238. package/src/TMap.ts +515 -0
  239. package/src/TPriorityQueue.ts +223 -0
  240. package/src/TPubSub.ts +200 -0
  241. package/src/TQueue.ts +432 -0
  242. package/src/TRandom.ts +129 -0
  243. package/src/TReentrantLock.ts +224 -0
  244. package/src/TRef.ts +178 -0
  245. package/src/TSemaphore.ts +129 -0
  246. package/src/TSet.ts +365 -0
  247. package/src/TSubscriptionRef.ts +192 -0
  248. package/src/Take.ts +258 -0
  249. package/src/TestAnnotation.ts +158 -0
  250. package/src/TestAnnotationMap.ts +119 -0
  251. package/src/TestAnnotations.ts +117 -0
  252. package/src/TestClock.ts +556 -0
  253. package/src/TestConfig.ts +47 -0
  254. package/src/TestContext.ts +36 -0
  255. package/src/TestLive.ts +53 -0
  256. package/src/TestServices.ts +390 -0
  257. package/src/TestSized.ts +55 -0
  258. package/src/Tracer.ts +182 -0
  259. package/src/Trie.ts +840 -0
  260. package/src/Tuple.ts +305 -0
  261. package/src/Types.ts +353 -0
  262. package/src/Unify.ts +113 -0
  263. package/src/UpstreamPullRequest.ts +117 -0
  264. package/src/UpstreamPullStrategy.ts +121 -0
  265. package/src/Utils.ts +809 -0
  266. package/src/index.ts +1568 -0
  267. package/src/internal/array.ts +8 -0
  268. package/src/internal/blockedRequests.ts +520 -0
  269. package/src/internal/cache.ts +733 -0
  270. package/src/internal/cause.ts +1050 -0
  271. package/src/internal/channel/channelExecutor.ts +1200 -0
  272. package/src/internal/channel/channelState.ts +134 -0
  273. package/src/internal/channel/childExecutorDecision.ts +96 -0
  274. package/src/internal/channel/continuation.ts +200 -0
  275. package/src/internal/channel/mergeDecision.ts +113 -0
  276. package/src/internal/channel/mergeState.ts +120 -0
  277. package/src/internal/channel/mergeStrategy.ts +72 -0
  278. package/src/internal/channel/singleProducerAsyncInput.ts +259 -0
  279. package/src/internal/channel/subexecutor.ts +229 -0
  280. package/src/internal/channel/upstreamPullRequest.ts +84 -0
  281. package/src/internal/channel/upstreamPullStrategy.ts +87 -0
  282. package/src/internal/channel.ts +2603 -0
  283. package/src/internal/clock.ts +95 -0
  284. package/src/internal/completedRequestMap.ts +9 -0
  285. package/src/internal/concurrency.ts +54 -0
  286. package/src/internal/config.ts +716 -0
  287. package/src/internal/configError.ts +304 -0
  288. package/src/internal/configProvider/pathPatch.ts +97 -0
  289. package/src/internal/configProvider.ts +799 -0
  290. package/src/internal/console.ts +153 -0
  291. package/src/internal/context.ts +337 -0
  292. package/src/internal/core-effect.ts +2293 -0
  293. package/src/internal/core-stream.ts +998 -0
  294. package/src/internal/core.ts +3189 -0
  295. package/src/internal/data.ts +36 -0
  296. package/src/internal/dataSource.ts +327 -0
  297. package/src/internal/dateTime.ts +1277 -0
  298. package/src/internal/defaultServices/console.ts +100 -0
  299. package/src/internal/defaultServices.ts +163 -0
  300. package/src/internal/deferred.ts +46 -0
  301. package/src/internal/differ/chunkPatch.ts +211 -0
  302. package/src/internal/differ/contextPatch.ts +232 -0
  303. package/src/internal/differ/hashMapPatch.ts +220 -0
  304. package/src/internal/differ/hashSetPatch.ts +176 -0
  305. package/src/internal/differ/orPatch.ts +311 -0
  306. package/src/internal/differ/readonlyArrayPatch.ts +210 -0
  307. package/src/internal/differ.ts +200 -0
  308. package/src/internal/doNotation.ts +80 -0
  309. package/src/internal/effect/circular.ts +895 -0
  310. package/src/internal/effectable.ts +131 -0
  311. package/src/internal/either.ts +110 -0
  312. package/src/internal/encoding/base64.ts +286 -0
  313. package/src/internal/encoding/base64Url.ts +29 -0
  314. package/src/internal/encoding/common.ts +51 -0
  315. package/src/internal/encoding/hex.ts +315 -0
  316. package/src/internal/errors.ts +7 -0
  317. package/src/internal/executionPlan.ts +114 -0
  318. package/src/internal/executionStrategy.ts +74 -0
  319. package/src/internal/fiber.ts +388 -0
  320. package/src/internal/fiberId.ts +267 -0
  321. package/src/internal/fiberMessage.ts +82 -0
  322. package/src/internal/fiberRefs/patch.ts +144 -0
  323. package/src/internal/fiberRefs.ts +297 -0
  324. package/src/internal/fiberRuntime.ts +3842 -0
  325. package/src/internal/fiberScope.ts +71 -0
  326. package/src/internal/fiberStatus.ts +119 -0
  327. package/src/internal/groupBy.ts +530 -0
  328. package/src/internal/hashMap/array.ts +49 -0
  329. package/src/internal/hashMap/bitwise.ts +32 -0
  330. package/src/internal/hashMap/config.ts +14 -0
  331. package/src/internal/hashMap/keySet.ts +8 -0
  332. package/src/internal/hashMap/node.ts +391 -0
  333. package/src/internal/hashMap.ts +586 -0
  334. package/src/internal/hashSet.ts +323 -0
  335. package/src/internal/keyedPool.ts +244 -0
  336. package/src/internal/layer/circular.ts +214 -0
  337. package/src/internal/layer.ts +1483 -0
  338. package/src/internal/logSpan.ts +20 -0
  339. package/src/internal/logger-circular.ts +24 -0
  340. package/src/internal/logger.ts +522 -0
  341. package/src/internal/mailbox.ts +561 -0
  342. package/src/internal/managedRuntime/circular.ts +6 -0
  343. package/src/internal/managedRuntime.ts +134 -0
  344. package/src/internal/matcher.ts +652 -0
  345. package/src/internal/metric/boundaries.ts +75 -0
  346. package/src/internal/metric/hook.ts +483 -0
  347. package/src/internal/metric/key.ts +167 -0
  348. package/src/internal/metric/keyType.ts +238 -0
  349. package/src/internal/metric/label.ts +41 -0
  350. package/src/internal/metric/pair.ts +48 -0
  351. package/src/internal/metric/polling.ts +149 -0
  352. package/src/internal/metric/registry.ts +187 -0
  353. package/src/internal/metric/state.ts +290 -0
  354. package/src/internal/metric.ts +577 -0
  355. package/src/internal/opCodes/cause.ts +35 -0
  356. package/src/internal/opCodes/channel.ts +83 -0
  357. package/src/internal/opCodes/channelChildExecutorDecision.ts +17 -0
  358. package/src/internal/opCodes/channelMergeDecision.ts +11 -0
  359. package/src/internal/opCodes/channelMergeState.ts +17 -0
  360. package/src/internal/opCodes/channelMergeStrategy.ts +11 -0
  361. package/src/internal/opCodes/channelState.ts +23 -0
  362. package/src/internal/opCodes/channelUpstreamPullRequest.ts +11 -0
  363. package/src/internal/opCodes/channelUpstreamPullStrategy.ts +11 -0
  364. package/src/internal/opCodes/config.ts +65 -0
  365. package/src/internal/opCodes/configError.ts +35 -0
  366. package/src/internal/opCodes/continuation.ts +11 -0
  367. package/src/internal/opCodes/deferred.ts +11 -0
  368. package/src/internal/opCodes/effect.ts +89 -0
  369. package/src/internal/opCodes/layer.ts +59 -0
  370. package/src/internal/opCodes/streamHaltStrategy.ts +23 -0
  371. package/src/internal/option.ts +80 -0
  372. package/src/internal/pool.ts +432 -0
  373. package/src/internal/pubsub.ts +1762 -0
  374. package/src/internal/query.ts +204 -0
  375. package/src/internal/queue.ts +766 -0
  376. package/src/internal/random.ts +161 -0
  377. package/src/internal/rateLimiter.ts +93 -0
  378. package/src/internal/rcMap.ts +285 -0
  379. package/src/internal/rcRef.ts +192 -0
  380. package/src/internal/redBlackTree/iterator.ts +200 -0
  381. package/src/internal/redBlackTree/node.ts +68 -0
  382. package/src/internal/redBlackTree.ts +1245 -0
  383. package/src/internal/redacted.ts +73 -0
  384. package/src/internal/ref.ts +171 -0
  385. package/src/internal/reloadable.ts +140 -0
  386. package/src/internal/request.ts +177 -0
  387. package/src/internal/resource.ts +76 -0
  388. package/src/internal/ringBuffer.ts +68 -0
  389. package/src/internal/runtime.ts +558 -0
  390. package/src/internal/runtimeFlags.ts +178 -0
  391. package/src/internal/runtimeFlagsPatch.ts +103 -0
  392. package/src/internal/schedule/decision.ts +47 -0
  393. package/src/internal/schedule/interval.ts +101 -0
  394. package/src/internal/schedule/intervals.ts +180 -0
  395. package/src/internal/schedule.ts +2199 -0
  396. package/src/internal/schema/errors.ts +191 -0
  397. package/src/internal/schema/schemaId.ts +106 -0
  398. package/src/internal/schema/util.ts +50 -0
  399. package/src/internal/scopedCache.ts +644 -0
  400. package/src/internal/scopedRef.ts +118 -0
  401. package/src/internal/secret.ts +89 -0
  402. package/src/internal/singleShotGen.ts +35 -0
  403. package/src/internal/sink.ts +2120 -0
  404. package/src/internal/stack.ts +10 -0
  405. package/src/internal/stm/core.ts +817 -0
  406. package/src/internal/stm/entry.ts +59 -0
  407. package/src/internal/stm/journal.ts +123 -0
  408. package/src/internal/stm/opCodes/stm.ts +71 -0
  409. package/src/internal/stm/opCodes/stmState.ts +17 -0
  410. package/src/internal/stm/opCodes/strategy.ts +17 -0
  411. package/src/internal/stm/opCodes/tExit.ts +29 -0
  412. package/src/internal/stm/opCodes/tryCommit.ts +11 -0
  413. package/src/internal/stm/stm.ts +1453 -0
  414. package/src/internal/stm/stmState.ts +136 -0
  415. package/src/internal/stm/tArray.ts +550 -0
  416. package/src/internal/stm/tDeferred.ts +81 -0
  417. package/src/internal/stm/tExit.ts +190 -0
  418. package/src/internal/stm/tMap.ts +824 -0
  419. package/src/internal/stm/tPriorityQueue.ts +267 -0
  420. package/src/internal/stm/tPubSub.ts +551 -0
  421. package/src/internal/stm/tQueue.ts +393 -0
  422. package/src/internal/stm/tRandom.ts +140 -0
  423. package/src/internal/stm/tReentrantLock.ts +352 -0
  424. package/src/internal/stm/tRef.ts +195 -0
  425. package/src/internal/stm/tSemaphore.ts +113 -0
  426. package/src/internal/stm/tSet.ts +259 -0
  427. package/src/internal/stm/tSubscriptionRef.ts +286 -0
  428. package/src/internal/stm/tryCommit.ts +34 -0
  429. package/src/internal/stm/txnId.ts +14 -0
  430. package/src/internal/stm/versioned.ts +4 -0
  431. package/src/internal/stream/debounceState.ts +57 -0
  432. package/src/internal/stream/emit.ts +123 -0
  433. package/src/internal/stream/haltStrategy.ts +94 -0
  434. package/src/internal/stream/handoff.ts +187 -0
  435. package/src/internal/stream/handoffSignal.ts +59 -0
  436. package/src/internal/stream/pull.ts +34 -0
  437. package/src/internal/stream/sinkEndReason.ts +30 -0
  438. package/src/internal/stream/zipAllState.ts +88 -0
  439. package/src/internal/stream/zipChunksState.ts +56 -0
  440. package/src/internal/stream.ts +8801 -0
  441. package/src/internal/string-utils.ts +107 -0
  442. package/src/internal/subscriptionRef.ts +138 -0
  443. package/src/internal/supervisor/patch.ts +190 -0
  444. package/src/internal/supervisor.ts +303 -0
  445. package/src/internal/synchronizedRef.ts +114 -0
  446. package/src/internal/take.ts +199 -0
  447. package/src/internal/testing/sleep.ts +27 -0
  448. package/src/internal/testing/suspendedWarningData.ts +85 -0
  449. package/src/internal/testing/warningData.ts +94 -0
  450. package/src/internal/tracer.ts +150 -0
  451. package/src/internal/trie.ts +722 -0
  452. package/src/internal/version.ts +7 -0
@@ -0,0 +1,20 @@
1
+ import type * as LogSpan from "../LogSpan.js"
2
+
3
+ /** @internal */
4
+ export const make = (label: string, startTime: number): LogSpan.LogSpan => ({
5
+ label,
6
+ startTime
7
+ })
8
+
9
+ /**
10
+ * Sanitize a given string by replacing spaces, equal signs, and double quotes with underscores.
11
+ *
12
+ * @internal
13
+ */
14
+ export const formatLabel = (key: string) => key.replace(/[\s="]/g, "_")
15
+
16
+ /** @internal */
17
+ export const render = (now: number) => (self: LogSpan.LogSpan): string => {
18
+ const label = formatLabel(self.label)
19
+ return `${label}=${now - self.startTime}ms`
20
+ }
@@ -0,0 +1,24 @@
1
+ import * as Cause from "../Cause.js"
2
+ import { dual } from "../Function.js"
3
+ import * as HashMap from "../HashMap.js"
4
+ import * as List from "../List.js"
5
+ import type * as Logger from "../Logger.js"
6
+ import * as core from "./core.js"
7
+ import * as fiberId_ from "./fiberId.js"
8
+ import * as fiberRefs from "./fiberRefs.js"
9
+
10
+ /** @internal */
11
+ export const test = dual<
12
+ <Message>(input: Message) => <Output>(self: Logger.Logger<Message, Output>) => Output,
13
+ <Message, Output>(self: Logger.Logger<Message, Output>, input: Message) => Output
14
+ >(2, (self, input) =>
15
+ self.log({
16
+ fiberId: fiberId_.none,
17
+ logLevel: core.logLevelInfo,
18
+ message: input,
19
+ cause: Cause.empty,
20
+ context: fiberRefs.empty(),
21
+ spans: List.empty(),
22
+ annotations: HashMap.empty(),
23
+ date: new Date()
24
+ }))
@@ -0,0 +1,522 @@
1
+ import * as Arr from "../Array.js"
2
+ import * as Context from "../Context.js"
3
+ import * as FiberRefs from "../FiberRefs.js"
4
+ import type { LazyArg } from "../Function.js"
5
+ import { constVoid, dual } from "../Function.js"
6
+ import { globalValue } from "../GlobalValue.js"
7
+ import * as HashMap from "../HashMap.js"
8
+ import * as Inspectable from "../Inspectable.js"
9
+ import * as List from "../List.js"
10
+ import type * as Logger from "../Logger.js"
11
+ import type * as LogLevel from "../LogLevel.js"
12
+ import * as Option from "../Option.js"
13
+ import { pipeArguments } from "../Pipeable.js"
14
+ import * as SourceLocation from "../SourceLocation.js"
15
+ import * as Cause from "./cause.js"
16
+ import * as core from "./core.js"
17
+ import * as defaultServices from "./defaultServices.js"
18
+ import { consoleTag } from "./defaultServices/console.js"
19
+ import * as fiberId_ from "./fiberId.js"
20
+ import * as logSpan_ from "./logSpan.js"
21
+
22
+ /** @internal */
23
+ const LoggerSymbolKey = "effect/Logger"
24
+
25
+ /** @internal */
26
+ export const LoggerTypeId: Logger.LoggerTypeId = Symbol.for(
27
+ LoggerSymbolKey
28
+ ) as Logger.LoggerTypeId
29
+
30
+ const loggerVariance = {
31
+ /* c8 ignore next */
32
+ _Message: (_: unknown) => _,
33
+ /* c8 ignore next */
34
+ _Output: (_: never) => _
35
+ }
36
+
37
+ /** @internal */
38
+ export const makeLogger = <Message, Output>(
39
+ log: (options: Logger.Logger.Options<Message>) => Output
40
+ ): Logger.Logger<Message, Output> => ({
41
+ [LoggerTypeId]: loggerVariance,
42
+ log,
43
+ pipe() {
44
+ return pipeArguments(this, arguments)
45
+ }
46
+ })
47
+
48
+ /** @internal */
49
+ export const mapInput = dual<
50
+ <Message, Message2>(
51
+ f: (message: Message2) => Message
52
+ ) => <Output>(self: Logger.Logger<Message, Output>) => Logger.Logger<Message2, Output>,
53
+ <Output, Message, Message2>(
54
+ self: Logger.Logger<Message, Output>,
55
+ f: (message: Message2) => Message
56
+ ) => Logger.Logger<Message2, Output>
57
+ >(2, (self, f) =>
58
+ makeLogger(
59
+ (options) => self.log({ ...options, message: f(options.message) })
60
+ ))
61
+
62
+ /** @internal */
63
+ export const mapInputOptions = dual<
64
+ <Message, Message2>(
65
+ f: (options: Logger.Logger.Options<Message2>) => Logger.Logger.Options<Message>
66
+ ) => <Output>(self: Logger.Logger<Message, Output>) => Logger.Logger<Message2, Output>,
67
+ <Output, Message, Message2>(
68
+ self: Logger.Logger<Message, Output>,
69
+ f: (options: Logger.Logger.Options<Message2>) => Logger.Logger.Options<Message>
70
+ ) => Logger.Logger<Message2, Output>
71
+ >(2, (self, f) => makeLogger((options) => self.log(f(options))))
72
+
73
+ /** @internal */
74
+ export const filterLogLevel = dual<
75
+ (
76
+ f: (logLevel: LogLevel.LogLevel) => boolean
77
+ ) => <Message, Output>(self: Logger.Logger<Message, Output>) => Logger.Logger<Message, Option.Option<Output>>,
78
+ <Message, Output>(
79
+ self: Logger.Logger<Message, Output>,
80
+ f: (logLevel: LogLevel.LogLevel) => boolean
81
+ ) => Logger.Logger<Message, Option.Option<Output>>
82
+ >(2, (self, f) =>
83
+ makeLogger((options) =>
84
+ f(options.logLevel)
85
+ ? Option.some(self.log(options))
86
+ : Option.none()
87
+ ))
88
+
89
+ /** @internal */
90
+ export const map = dual<
91
+ <Output, Output2>(
92
+ f: (output: Output) => Output2
93
+ ) => <Message>(self: Logger.Logger<Message, Output>) => Logger.Logger<Message, Output2>,
94
+ <Message, Output, Output2>(
95
+ self: Logger.Logger<Message, Output>,
96
+ f: (output: Output) => Output2
97
+ ) => Logger.Logger<Message, Output2>
98
+ >(2, (self, f) => makeLogger((options) => f(self.log(options))))
99
+
100
+ /** @internal */
101
+ export const none: Logger.Logger<unknown, void> = {
102
+ [LoggerTypeId]: loggerVariance,
103
+ log: constVoid,
104
+ pipe() {
105
+ return pipeArguments(this, arguments)
106
+ }
107
+ } as Logger.Logger<unknown, void>
108
+
109
+ /** @internal */
110
+ export const simple = <A, B>(log: (a: A) => B): Logger.Logger<A, B> => ({
111
+ [LoggerTypeId]: loggerVariance,
112
+ log: ({ message }) => log(message),
113
+ pipe() {
114
+ return pipeArguments(this, arguments)
115
+ }
116
+ })
117
+
118
+ /** @internal */
119
+ export const succeed = <A>(value: A): Logger.Logger<unknown, A> => {
120
+ return simple(() => value)
121
+ }
122
+
123
+ /** @internal */
124
+ export const sync = <A>(evaluate: LazyArg<A>): Logger.Logger<unknown, A> => {
125
+ return simple(evaluate)
126
+ }
127
+
128
+ /** @internal */
129
+ export const zip = dual<
130
+ <Message2, Output2>(
131
+ that: Logger.Logger<Message2, Output2>
132
+ ) => <Message, Output>(
133
+ self: Logger.Logger<Message, Output>
134
+ ) => Logger.Logger<Message & Message2, [Output, Output2]>,
135
+ <Message, Output, Message2, Output2>(
136
+ self: Logger.Logger<Message, Output>,
137
+ that: Logger.Logger<Message2, Output2>
138
+ ) => Logger.Logger<Message & Message2, [Output, Output2]>
139
+ >(2, (self, that) => makeLogger((options) => [self.log(options), that.log(options)]))
140
+
141
+ /** @internal */
142
+ export const zipLeft = dual<
143
+ <Message2, Output2>(
144
+ that: Logger.Logger<Message2, Output2>
145
+ ) => <Message, Output>(
146
+ self: Logger.Logger<Message, Output>
147
+ ) => Logger.Logger<Message & Message2, Output>,
148
+ <Message, Output, Message2, Output2>(
149
+ self: Logger.Logger<Message, Output>,
150
+ that: Logger.Logger<Message2, Output2>
151
+ ) => Logger.Logger<Message & Message2, Output>
152
+ >(2, (self, that) => map(zip(self, that), (tuple) => tuple[0]))
153
+
154
+ /** @internal */
155
+ export const zipRight = dual<
156
+ <Message2, Output2>(
157
+ that: Logger.Logger<Message2, Output2>
158
+ ) => <Message, Output>(
159
+ self: Logger.Logger<Message, Output>
160
+ ) => Logger.Logger<Message & Message2, Output2>,
161
+ <Message, Output, Message2, Output2>(
162
+ self: Logger.Logger<Message, Output>,
163
+ that: Logger.Logger<Message2, Output2>
164
+ ) => Logger.Logger<Message & Message2, Output2>
165
+ >(2, (self, that) => map(zip(self, that), (tuple) => tuple[1]))
166
+
167
+ /**
168
+ * Match strings that do not contain any whitespace characters, double quotes,
169
+ * or equal signs.
170
+ *
171
+ * @internal
172
+ */
173
+ const textOnly = /^[^\s"=]*$/
174
+
175
+ /**
176
+ * Used by both {@link stringLogger} and {@link logfmtLogger} to render a log
177
+ * message.
178
+ *
179
+ * @internal
180
+ */
181
+ const format = (quoteValue: (s: string) => string, whitespace?: number | string | undefined) =>
182
+ (
183
+ { annotations, cause, context, date, fiberId, logLevel, message, spans }: Logger.Logger.Options<unknown>
184
+ ): string => {
185
+ const formatValue = (value: string): string => value.match(textOnly) ? value : quoteValue(value)
186
+ const format = (label: string, value: string): string => `${logSpan_.formatLabel(label)}=${formatValue(value)}`
187
+ const append = (label: string, value: string): string => " " + format(label, value)
188
+
189
+ let out = format("timestamp", date.toISOString())
190
+ out += append("level", logLevel.label)
191
+ out += append("fiber", fiberId_.threadName(fiberId))
192
+
193
+ // Include source trace if available
194
+ const sourceTrace = FiberRefs.getOrDefault(context, core.currentSourceTrace)
195
+ if (sourceTrace !== undefined) {
196
+ out += append("source", SourceLocation.format(sourceTrace))
197
+ }
198
+
199
+ const messages = Arr.ensure(message)
200
+ for (let i = 0; i < messages.length; i++) {
201
+ out += append("message", Inspectable.toStringUnknown(messages[i], whitespace))
202
+ }
203
+
204
+ if (!Cause.isEmptyType(cause)) {
205
+ out += append("cause", Cause.pretty(cause, { renderErrorCause: true }))
206
+ }
207
+
208
+ for (const span of spans) {
209
+ out += " " + logSpan_.render(date.getTime())(span)
210
+ }
211
+
212
+ for (const [label, value] of annotations) {
213
+ out += append(label, Inspectable.toStringUnknown(value, whitespace))
214
+ }
215
+
216
+ return out
217
+ }
218
+
219
+ /** @internal */
220
+ const escapeDoubleQuotes = (s: string) => `"${s.replace(/\\([\s\S])|(")/g, "\\$1$2")}"`
221
+
222
+ /** @internal */
223
+ export const stringLogger: Logger.Logger<unknown, string> = makeLogger(format(escapeDoubleQuotes))
224
+
225
+ /** @internal */
226
+ export const logfmtLogger: Logger.Logger<unknown, string> = makeLogger(format(JSON.stringify, 0))
227
+
228
+ /** @internal */
229
+ export const structuredLogger = makeLogger<unknown, {
230
+ readonly logLevel: string
231
+ readonly fiberId: string
232
+ readonly timestamp: string
233
+ readonly message: unknown
234
+ readonly cause: string | undefined
235
+ readonly annotations: Record<string, unknown>
236
+ readonly spans: Record<string, number>
237
+ readonly source:
238
+ | { readonly path: string; readonly line: number; readonly column: number; readonly label?: string }
239
+ | undefined
240
+ }>(
241
+ ({ annotations, cause, context, date, fiberId, logLevel, message, spans }) => {
242
+ const now = date.getTime()
243
+ const annotationsObj: Record<string, unknown> = {}
244
+ const spansObj: Record<string, number> = {}
245
+
246
+ if (HashMap.size(annotations) > 0) {
247
+ for (const [k, v] of annotations) {
248
+ annotationsObj[k] = structuredMessage(v)
249
+ }
250
+ }
251
+
252
+ if (List.isCons(spans)) {
253
+ for (const span of spans) {
254
+ spansObj[span.label] = now - span.startTime
255
+ }
256
+ }
257
+
258
+ const messageArr = Arr.ensure(message)
259
+ const sourceTrace = FiberRefs.getOrDefault(context, core.currentSourceTrace)
260
+
261
+ const result: {
262
+ message: unknown
263
+ logLevel: string
264
+ timestamp: string
265
+ cause: string | undefined
266
+ annotations: Record<string, unknown>
267
+ spans: Record<string, number>
268
+ fiberId: string
269
+ source: { path: string; line: number; column: number; label?: string } | undefined
270
+ } = {
271
+ message: messageArr.length === 1 ? structuredMessage(messageArr[0]) : messageArr.map(structuredMessage),
272
+ logLevel: logLevel.label,
273
+ timestamp: date.toISOString(),
274
+ cause: Cause.isEmpty(cause) ? undefined : Cause.pretty(cause, { renderErrorCause: true }),
275
+ annotations: annotationsObj,
276
+ spans: spansObj,
277
+ fiberId: fiberId_.threadName(fiberId),
278
+ source: undefined
279
+ }
280
+
281
+ if (sourceTrace !== undefined) {
282
+ const sourceObj: { path: string; line: number; column: number; label?: string } = {
283
+ path: sourceTrace.path,
284
+ line: sourceTrace.line,
285
+ column: sourceTrace.column
286
+ }
287
+ if (sourceTrace.label !== undefined) {
288
+ sourceObj.label = sourceTrace.label
289
+ }
290
+ result.source = sourceObj
291
+ }
292
+
293
+ return result
294
+ }
295
+ )
296
+
297
+ /** @internal */
298
+ export const structuredMessage = (u: unknown): unknown => {
299
+ switch (typeof u) {
300
+ case "bigint":
301
+ case "function":
302
+ case "symbol": {
303
+ return String(u)
304
+ }
305
+ default: {
306
+ return Inspectable.toJSON(u)
307
+ }
308
+ }
309
+ }
310
+
311
+ /** @internal */
312
+ export const jsonLogger = map(structuredLogger, Inspectable.stringifyCircular)
313
+
314
+ /** @internal */
315
+ export const isLogger = (u: unknown): u is Logger.Logger<unknown, unknown> => {
316
+ return typeof u === "object" && u != null && LoggerTypeId in u
317
+ }
318
+
319
+ const withColor = (text: string, ...colors: ReadonlyArray<string>) => {
320
+ let out = ""
321
+ for (let i = 0; i < colors.length; i++) {
322
+ out += `\x1b[${colors[i]}m`
323
+ }
324
+ return out + text + "\x1b[0m"
325
+ }
326
+ const withColorNoop = (text: string, ..._colors: ReadonlyArray<string>) => text
327
+ const colors = {
328
+ bold: "1",
329
+ red: "31",
330
+ green: "32",
331
+ yellow: "33",
332
+ blue: "34",
333
+ cyan: "36",
334
+ white: "37",
335
+ gray: "90",
336
+ black: "30",
337
+ bgBrightRed: "101"
338
+ } as const
339
+
340
+ const logLevelColors: Record<LogLevel.LogLevel["_tag"], ReadonlyArray<string>> = {
341
+ None: [],
342
+ All: [],
343
+ Trace: [colors.gray],
344
+ Debug: [colors.blue],
345
+ Info: [colors.green],
346
+ Warning: [colors.yellow],
347
+ Error: [colors.red],
348
+ Fatal: [colors.bgBrightRed, colors.black]
349
+ }
350
+ const logLevelStyle: Record<LogLevel.LogLevel["_tag"], string> = {
351
+ None: "",
352
+ All: "",
353
+ Trace: "color:gray",
354
+ Debug: "color:blue",
355
+ Info: "color:green",
356
+ Warning: "color:orange",
357
+ Error: "color:red",
358
+ Fatal: "background-color:red;color:white"
359
+ }
360
+
361
+ const defaultDateFormat = (date: Date): string =>
362
+ `${date.getHours().toString().padStart(2, "0")}:${date.getMinutes().toString().padStart(2, "0")}:${
363
+ date.getSeconds().toString().padStart(2, "0")
364
+ }.${date.getMilliseconds().toString().padStart(3, "0")}`
365
+
366
+ const hasProcessStdout = typeof process === "object" &&
367
+ process !== null &&
368
+ typeof process.stdout === "object" &&
369
+ process.stdout !== null
370
+ const processStdoutIsTTY = hasProcessStdout &&
371
+ process.stdout.isTTY === true
372
+ const hasProcessStdoutOrDeno = hasProcessStdout || "Deno" in globalThis
373
+
374
+ /** @internal */
375
+ export const prettyLogger = (options?: {
376
+ readonly colors?: "auto" | boolean | undefined
377
+ readonly stderr?: boolean | undefined
378
+ readonly formatDate?: ((date: Date) => string) | undefined
379
+ readonly mode?: "browser" | "tty" | "auto" | undefined
380
+ }) => {
381
+ const mode_ = options?.mode ?? "auto"
382
+ const mode = mode_ === "auto" ? (hasProcessStdoutOrDeno ? "tty" : "browser") : mode_
383
+ const isBrowser = mode === "browser"
384
+ const showColors = typeof options?.colors === "boolean" ? options.colors : processStdoutIsTTY || isBrowser
385
+ const formatDate = options?.formatDate ?? defaultDateFormat
386
+ return isBrowser
387
+ ? prettyLoggerBrowser({ colors: showColors, formatDate })
388
+ : prettyLoggerTty({ colors: showColors, formatDate, stderr: options?.stderr === true })
389
+ }
390
+
391
+ const prettyLoggerTty = (options: {
392
+ readonly colors: boolean
393
+ readonly stderr: boolean
394
+ readonly formatDate: (date: Date) => string
395
+ }) => {
396
+ const color = options.colors ? withColor : withColorNoop
397
+ return makeLogger<unknown, void>(
398
+ ({ annotations, cause, context, date, fiberId, logLevel, message: message_, spans }) => {
399
+ const services = FiberRefs.getOrDefault(context, defaultServices.currentServices)
400
+ const console = Context.get(services, consoleTag).unsafe
401
+ const log = options.stderr === true ? console.error : console.log
402
+
403
+ const message = Arr.ensure(message_)
404
+
405
+ let firstLine = color(`[${options.formatDate(date)}]`, colors.white)
406
+ + ` ${color(logLevel.label, ...logLevelColors[logLevel._tag])}`
407
+ + ` (${fiberId_.threadName(fiberId)})`
408
+
409
+ if (List.isCons(spans)) {
410
+ const now = date.getTime()
411
+ const render = logSpan_.render(now)
412
+ for (const span of spans) {
413
+ firstLine += " " + render(span)
414
+ }
415
+ }
416
+
417
+ firstLine += ":"
418
+ let messageIndex = 0
419
+ if (message.length > 0) {
420
+ const firstMaybeString = structuredMessage(message[0])
421
+ if (typeof firstMaybeString === "string") {
422
+ firstLine += " " + color(firstMaybeString, colors.bold, colors.cyan)
423
+ messageIndex++
424
+ }
425
+ }
426
+
427
+ log(firstLine)
428
+ console.group()
429
+
430
+ if (!Cause.isEmpty(cause)) {
431
+ log(Cause.pretty(cause, { renderErrorCause: true }))
432
+ }
433
+
434
+ if (messageIndex < message.length) {
435
+ for (; messageIndex < message.length; messageIndex++) {
436
+ log(Inspectable.redact(message[messageIndex]))
437
+ }
438
+ }
439
+
440
+ if (HashMap.size(annotations) > 0) {
441
+ for (const [key, value] of annotations) {
442
+ log(color(`${key}:`, colors.bold, colors.white), Inspectable.redact(value))
443
+ }
444
+ }
445
+
446
+ console.groupEnd()
447
+ }
448
+ )
449
+ }
450
+
451
+ const prettyLoggerBrowser = (options: {
452
+ readonly colors: boolean
453
+ readonly formatDate: (date: Date) => string
454
+ }) => {
455
+ const color = options.colors ? "%c" : ""
456
+ return makeLogger<unknown, void>(
457
+ ({ annotations, cause, context, date, fiberId, logLevel, message: message_, spans }) => {
458
+ const services = FiberRefs.getOrDefault(context, defaultServices.currentServices)
459
+ const console = Context.get(services, consoleTag).unsafe
460
+ const message = Arr.ensure(message_)
461
+
462
+ let firstLine = `${color}[${options.formatDate(date)}]`
463
+ const firstParams = []
464
+ if (options.colors) {
465
+ firstParams.push("color:gray")
466
+ }
467
+ firstLine += ` ${color}${logLevel.label}${color} (${fiberId_.threadName(fiberId)})`
468
+ if (options.colors) {
469
+ firstParams.push(logLevelStyle[logLevel._tag], "")
470
+ }
471
+ if (List.isCons(spans)) {
472
+ const now = date.getTime()
473
+ const render = logSpan_.render(now)
474
+ for (const span of spans) {
475
+ firstLine += " " + render(span)
476
+ }
477
+ }
478
+
479
+ firstLine += ":"
480
+
481
+ let messageIndex = 0
482
+ if (message.length > 0) {
483
+ const firstMaybeString = structuredMessage(message[0])
484
+ if (typeof firstMaybeString === "string") {
485
+ firstLine += ` ${color}${firstMaybeString}`
486
+ if (options.colors) {
487
+ firstParams.push("color:deepskyblue")
488
+ }
489
+ messageIndex++
490
+ }
491
+ }
492
+
493
+ console.groupCollapsed(firstLine, ...firstParams)
494
+
495
+ if (!Cause.isEmpty(cause)) {
496
+ console.error(Cause.pretty(cause, { renderErrorCause: true }))
497
+ }
498
+
499
+ if (messageIndex < message.length) {
500
+ for (; messageIndex < message.length; messageIndex++) {
501
+ console.log(Inspectable.redact(message[messageIndex]))
502
+ }
503
+ }
504
+
505
+ if (HashMap.size(annotations) > 0) {
506
+ for (const [key, value] of annotations) {
507
+ const redacted = Inspectable.redact(value)
508
+ if (options.colors) {
509
+ console.log(`%c${key}:`, "color:gray", redacted)
510
+ } else {
511
+ console.log(`${key}:`, redacted)
512
+ }
513
+ }
514
+ }
515
+
516
+ console.groupEnd()
517
+ }
518
+ )
519
+ }
520
+
521
+ /** @internal */
522
+ export const prettyLoggerDefault = globalValue("effect/Logger/prettyLoggerDefault", () => prettyLogger())