@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,136 @@
1
+ import * as Equal from "../../Equal.js"
2
+ import * as Exit from "../../Exit.js"
3
+ import { pipe } from "../../Function.js"
4
+ import * as Hash from "../../Hash.js"
5
+ import { hasProperty } from "../../Predicate.js"
6
+ import * as OpCodes from "./opCodes/stmState.js"
7
+ import * as TExitOpCodes from "./opCodes/tExit.js"
8
+ import type * as TExit from "./tExit.js"
9
+
10
+ /** @internal */
11
+ const STMStateSymbolKey = "effect/STM/State"
12
+
13
+ /** @internal */
14
+ export const STMStateTypeId = Symbol.for(STMStateSymbolKey)
15
+
16
+ /** @internal */
17
+ export type STMStateTypeId = typeof STMStateTypeId
18
+
19
+ /** @internal */
20
+ export type STMState<A, E = never> = Done<A, E> | Interrupted | Running
21
+
22
+ /** @internal */
23
+ export interface Done<out A, out E = never> extends Equal.Equal {
24
+ readonly [STMStateTypeId]: STMStateTypeId
25
+ readonly _tag: OpCodes.OP_DONE
26
+ readonly exit: Exit.Exit<A, E>
27
+ }
28
+
29
+ /** @internal */
30
+ export interface Interrupted extends Equal.Equal {
31
+ readonly [STMStateTypeId]: STMStateTypeId
32
+ readonly _tag: OpCodes.OP_INTERRUPTED
33
+ }
34
+
35
+ /** @internal */
36
+ export interface Running extends Equal.Equal {
37
+ readonly [STMStateTypeId]: STMStateTypeId
38
+ readonly _tag: OpCodes.OP_RUNNING
39
+ }
40
+
41
+ /** @internal */
42
+ export const isSTMState = (u: unknown): u is STMState<unknown, unknown> => hasProperty(u, STMStateTypeId)
43
+
44
+ /** @internal */
45
+ export const isRunning = <A, E>(self: STMState<A, E>): self is Running => {
46
+ return self._tag === OpCodes.OP_RUNNING
47
+ }
48
+
49
+ /** @internal */
50
+ export const isDone = <A, E>(self: STMState<A, E>): self is Done<A, E> => {
51
+ return self._tag === OpCodes.OP_DONE
52
+ }
53
+
54
+ /** @internal */
55
+ export const isInterrupted = <A, E>(self: STMState<A, E>): self is Interrupted => {
56
+ return self._tag === OpCodes.OP_INTERRUPTED
57
+ }
58
+
59
+ /** @internal */
60
+ export const done = <A, E>(exit: Exit.Exit<A, E>): STMState<A, E> => {
61
+ return {
62
+ [STMStateTypeId]: STMStateTypeId,
63
+ _tag: OpCodes.OP_DONE,
64
+ exit,
65
+ [Hash.symbol](): number {
66
+ return pipe(
67
+ Hash.hash(STMStateSymbolKey),
68
+ Hash.combine(Hash.hash(OpCodes.OP_DONE)),
69
+ Hash.combine(Hash.hash(exit)),
70
+ Hash.cached(this)
71
+ )
72
+ },
73
+ [Equal.symbol](that: unknown): boolean {
74
+ return isSTMState(that) && that._tag === OpCodes.OP_DONE && Equal.equals(exit, that.exit)
75
+ }
76
+ }
77
+ }
78
+
79
+ const interruptedHash = pipe(
80
+ Hash.hash(STMStateSymbolKey),
81
+ Hash.combine(Hash.hash(OpCodes.OP_INTERRUPTED)),
82
+ Hash.combine(Hash.hash("interrupted"))
83
+ )
84
+
85
+ /** @internal */
86
+ export const interrupted: STMState<never> = {
87
+ [STMStateTypeId]: STMStateTypeId,
88
+ _tag: OpCodes.OP_INTERRUPTED,
89
+ [Hash.symbol](): number {
90
+ return interruptedHash
91
+ },
92
+ [Equal.symbol](that: unknown): boolean {
93
+ return isSTMState(that) && that._tag === OpCodes.OP_INTERRUPTED
94
+ }
95
+ }
96
+
97
+ const runningHash = pipe(
98
+ Hash.hash(STMStateSymbolKey),
99
+ Hash.combine(Hash.hash(OpCodes.OP_RUNNING)),
100
+ Hash.combine(Hash.hash("running"))
101
+ )
102
+
103
+ /** @internal */
104
+ export const running: STMState<never> = {
105
+ [STMStateTypeId]: STMStateTypeId,
106
+ _tag: OpCodes.OP_RUNNING,
107
+ [Hash.symbol](): number {
108
+ return runningHash
109
+ },
110
+ [Equal.symbol](that: unknown): boolean {
111
+ return isSTMState(that) && that._tag === OpCodes.OP_RUNNING
112
+ }
113
+ }
114
+
115
+ /** @internal */
116
+ export const fromTExit = <A, E>(tExit: TExit.TExit<A, E>): STMState<A, E> => {
117
+ switch (tExit._tag) {
118
+ case TExitOpCodes.OP_FAIL: {
119
+ return done(Exit.fail(tExit.error))
120
+ }
121
+ case TExitOpCodes.OP_DIE: {
122
+ return done(Exit.die(tExit.defect))
123
+ }
124
+ case TExitOpCodes.OP_INTERRUPT: {
125
+ return done(Exit.interrupt(tExit.fiberId))
126
+ }
127
+ case TExitOpCodes.OP_SUCCEED: {
128
+ return done(Exit.succeed(tExit.value))
129
+ }
130
+ case TExitOpCodes.OP_RETRY: {
131
+ throw new Error(
132
+ "BUG: STM.STMState.fromTExit - please report an issue at https://github.com/Effect-TS/effect/issues"
133
+ )
134
+ }
135
+ }
136
+ }
@@ -0,0 +1,550 @@
1
+ import * as Equal from "../../Equal.js"
2
+ import { dual, pipe } from "../../Function.js"
3
+ import * as Option from "../../Option.js"
4
+ import * as Order from "../../Order.js"
5
+ import type { Predicate } from "../../Predicate.js"
6
+ import type * as STM from "../../STM.js"
7
+ import type * as TArray from "../../TArray.js"
8
+ import type * as TRef from "../../TRef.js"
9
+ import * as core from "./core.js"
10
+ import * as stm from "./stm.js"
11
+ import * as tRef from "./tRef.js"
12
+
13
+ /** @internal */
14
+ const TArraySymbolKey = "effect/TArray"
15
+
16
+ /** @internal */
17
+ export const TArrayTypeId: TArray.TArrayTypeId = Symbol.for(TArraySymbolKey) as TArray.TArrayTypeId
18
+
19
+ const tArrayVariance = {
20
+ /* c8 ignore next */
21
+ _A: (_: any) => _
22
+ }
23
+
24
+ /** @internal */
25
+ export class TArrayImpl<in out A> implements TArray.TArray<A> {
26
+ readonly [TArrayTypeId] = tArrayVariance
27
+ constructor(readonly chunk: Array<TRef.TRef<A>>) {}
28
+ }
29
+
30
+ /** @internal */
31
+ export const collectFirst = dual<
32
+ <A, B>(pf: (a: A) => Option.Option<B>) => (self: TArray.TArray<A>) => STM.STM<Option.Option<B>>,
33
+ <A, B>(self: TArray.TArray<A>, pf: (a: A) => Option.Option<B>) => STM.STM<Option.Option<B>>
34
+ >(2, (self, pf) =>
35
+ collectFirstSTM(
36
+ self,
37
+ (a) => pipe(pf(a), Option.map(core.succeed))
38
+ ))
39
+
40
+ /** @internal */
41
+ export const collectFirstSTM = dual<
42
+ <A, B, E, R>(
43
+ pf: (a: A) => Option.Option<STM.STM<B, E, R>>
44
+ ) => (
45
+ self: TArray.TArray<A>
46
+ ) => STM.STM<Option.Option<B>, E, R>,
47
+ <A, B, E, R>(
48
+ self: TArray.TArray<A>,
49
+ pf: (a: A) => Option.Option<STM.STM<B, E, R>>
50
+ ) => STM.STM<Option.Option<B>, E, R>
51
+ >(
52
+ 2,
53
+ <A, B, E, R>(self: TArray.TArray<A>, pf: (a: A) => Option.Option<STM.STM<B, E, R>>) =>
54
+ core.withSTMRuntime((runtime) => {
55
+ let index = 0
56
+ let result: Option.Option<STM.STM<B, E, R>> = Option.none()
57
+ while (Option.isNone(result) && index < self.chunk.length) {
58
+ const element = pipe(self.chunk[index], tRef.unsafeGet(runtime.journal))
59
+ const option = pf(element)
60
+ if (Option.isSome(option)) {
61
+ result = option
62
+ }
63
+ index = index + 1
64
+ }
65
+ return pipe(
66
+ result,
67
+ Option.match({
68
+ onNone: () => stm.succeedNone,
69
+ onSome: core.map(Option.some)
70
+ })
71
+ )
72
+ })
73
+ )
74
+
75
+ /** @internal */
76
+ export const contains = dual<
77
+ <A>(value: A) => (self: TArray.TArray<A>) => STM.STM<boolean>,
78
+ <A>(self: TArray.TArray<A>, value: A) => STM.STM<boolean>
79
+ >(2, (self, value) => some(self, (a) => Equal.equals(a)(value)))
80
+
81
+ /** @internal */
82
+ export const count = dual<
83
+ <A>(predicate: Predicate<A>) => (self: TArray.TArray<A>) => STM.STM<number>,
84
+ <A>(self: TArray.TArray<A>, predicate: Predicate<A>) => STM.STM<number>
85
+ >(2, (self, predicate) =>
86
+ reduce(
87
+ self,
88
+ 0,
89
+ (n, a) => predicate(a) ? n + 1 : n
90
+ ))
91
+
92
+ /** @internal */
93
+ export const countSTM = dual<
94
+ <A, R, E>(predicate: (value: A) => STM.STM<boolean, E, R>) => (self: TArray.TArray<A>) => STM.STM<number, E, R>,
95
+ <A, R, E>(self: TArray.TArray<A>, predicate: (value: A) => STM.STM<boolean, E, R>) => STM.STM<number, E, R>
96
+ >(2, (self, predicate) =>
97
+ reduceSTM(
98
+ self,
99
+ 0,
100
+ (n, a) => core.map(predicate(a), (bool) => bool ? n + 1 : n)
101
+ ))
102
+
103
+ /** @internal */
104
+ export const empty = <A>(): STM.STM<TArray.TArray<A>> => fromIterable<A>([])
105
+
106
+ /** @internal */
107
+ export const every = dual<
108
+ <A>(predicate: Predicate<A>) => (self: TArray.TArray<A>) => STM.STM<boolean>,
109
+ <A>(self: TArray.TArray<A>, predicate: Predicate<A>) => STM.STM<boolean>
110
+ >(2, (self, predicate) => stm.negate(some(self, (a) => !predicate(a))))
111
+
112
+ /** @internal */
113
+ export const everySTM = dual<
114
+ <A, R, E>(predicate: (value: A) => STM.STM<boolean, E, R>) => (self: TArray.TArray<A>) => STM.STM<boolean, E, R>,
115
+ <A, R, E>(self: TArray.TArray<A>, predicate: (value: A) => STM.STM<boolean, E, R>) => STM.STM<boolean, E, R>
116
+ >(2, (self, predicate) =>
117
+ core.map(
118
+ countSTM(self, predicate),
119
+ (count) => count === self.chunk.length
120
+ ))
121
+
122
+ /** @internal */
123
+ export const findFirst = dual<
124
+ <A>(predicate: Predicate<A>) => (self: TArray.TArray<A>) => STM.STM<Option.Option<A>>,
125
+ <A>(self: TArray.TArray<A>, predicate: Predicate<A>) => STM.STM<Option.Option<A>>
126
+ >(2, (self, predicate) =>
127
+ collectFirst(self, (a) =>
128
+ predicate(a)
129
+ ? Option.some(a)
130
+ : Option.none()))
131
+
132
+ /** @internal */
133
+ export const findFirstIndex = dual<
134
+ <A>(value: A) => (self: TArray.TArray<A>) => STM.STM<Option.Option<number>>,
135
+ <A>(self: TArray.TArray<A>, value: A) => STM.STM<Option.Option<number>>
136
+ >(2, (self, value) => findFirstIndexFrom(self, value, 0))
137
+
138
+ /** @internal */
139
+ export const findFirstIndexFrom = dual<
140
+ <A>(value: A, from: number) => (self: TArray.TArray<A>) => STM.STM<Option.Option<number>>,
141
+ <A>(self: TArray.TArray<A>, value: A, from: number) => STM.STM<Option.Option<number>>
142
+ >(3, (self, value, from) =>
143
+ findFirstIndexWhereFrom(
144
+ self,
145
+ (a) => Equal.equals(a)(value),
146
+ from
147
+ ))
148
+
149
+ /** @internal */
150
+ export const findFirstIndexWhere = dual<
151
+ <A>(predicate: Predicate<A>) => (self: TArray.TArray<A>) => STM.STM<Option.Option<number>>,
152
+ <A>(self: TArray.TArray<A>, predicate: Predicate<A>) => STM.STM<Option.Option<number>>
153
+ >(2, (self, predicate) => findFirstIndexWhereFrom(self, predicate, 0))
154
+
155
+ /** @internal */
156
+ export const findFirstIndexWhereFrom = dual<
157
+ <A>(
158
+ predicate: Predicate<A>,
159
+ from: number
160
+ ) => (self: TArray.TArray<A>) => STM.STM<Option.Option<number>>,
161
+ <A>(self: TArray.TArray<A>, predicate: Predicate<A>, from: number) => STM.STM<Option.Option<number>>
162
+ >(3, (self, predicate, from) => {
163
+ if (from < 0) {
164
+ return stm.succeedNone
165
+ }
166
+ return core.effect<never, Option.Option<number>>((journal) => {
167
+ let index: number = from
168
+ let found = false
169
+ while (!found && index < self.chunk.length) {
170
+ const element = tRef.unsafeGet(self.chunk[index], journal)
171
+ found = predicate(element)
172
+ index = index + 1
173
+ }
174
+ if (found) {
175
+ return Option.some(index - 1)
176
+ }
177
+ return Option.none()
178
+ })
179
+ })
180
+
181
+ /** @internal */
182
+ export const findFirstIndexWhereSTM = dual<
183
+ <A, R, E>(
184
+ predicate: (value: A) => STM.STM<boolean, E, R>
185
+ ) => (self: TArray.TArray<A>) => STM.STM<Option.Option<number>, E, R>,
186
+ <A, R, E>(
187
+ self: TArray.TArray<A>,
188
+ predicate: (value: A) => STM.STM<boolean, E, R>
189
+ ) => STM.STM<Option.Option<number>, E, R>
190
+ >(2, (self, predicate) => findFirstIndexWhereFromSTM(self, predicate, 0))
191
+
192
+ /** @internal */
193
+ export const findFirstIndexWhereFromSTM = dual<
194
+ <A, R, E>(
195
+ predicate: (value: A) => STM.STM<boolean, E, R>,
196
+ from: number
197
+ ) => (self: TArray.TArray<A>) => STM.STM<Option.Option<number>, E, R>,
198
+ <A, R, E>(
199
+ self: TArray.TArray<A>,
200
+ predicate: (value: A) => STM.STM<boolean, E, R>,
201
+ from: number
202
+ ) => STM.STM<Option.Option<number>, E, R>
203
+ >(3, <A, R, E>(
204
+ self: TArray.TArray<A>,
205
+ predicate: (value: A) => STM.STM<boolean, E, R>,
206
+ from: number
207
+ ) => {
208
+ const forIndex = (index: number): STM.STM<Option.Option<number>, E, R> =>
209
+ index < self.chunk.length
210
+ ? pipe(
211
+ tRef.get(self.chunk[index]),
212
+ core.flatMap(predicate),
213
+ core.flatMap((bool) =>
214
+ bool ?
215
+ core.succeed(Option.some(index)) :
216
+ forIndex(index + 1)
217
+ )
218
+ )
219
+ : stm.succeedNone
220
+ return from < 0
221
+ ? stm.succeedNone
222
+ : forIndex(from)
223
+ })
224
+
225
+ /** @internal */
226
+ export const findFirstSTM = dual<
227
+ <A, R, E>(
228
+ predicate: (value: A) => STM.STM<boolean, E, R>
229
+ ) => (
230
+ self: TArray.TArray<A>
231
+ ) => STM.STM<Option.Option<A>, E, R>,
232
+ <A, R, E>(
233
+ self: TArray.TArray<A>,
234
+ predicate: (value: A) => STM.STM<boolean, E, R>
235
+ ) => STM.STM<Option.Option<A>, E, R>
236
+ >(2, <A, R, E>(self: TArray.TArray<A>, predicate: (value: A) => STM.STM<boolean, E, R>) => {
237
+ const init = [Option.none() as Option.Option<A>, 0 as number] as const
238
+ const cont = (state: readonly [Option.Option<A>, number]) =>
239
+ Option.isNone(state[0]) && state[1] < self.chunk.length - 1
240
+ return core.map(
241
+ stm.iterate(init, {
242
+ while: cont,
243
+ body: (state) => {
244
+ const index = state[1]
245
+ return pipe(
246
+ tRef.get(self.chunk[index]),
247
+ core.flatMap((value) =>
248
+ core.map(
249
+ predicate(value),
250
+ (bool) => [bool ? Option.some(value) : Option.none(), index + 1] as const
251
+ )
252
+ )
253
+ )
254
+ }
255
+ }),
256
+ (state) => state[0]
257
+ )
258
+ })
259
+
260
+ /** @internal */
261
+ export const findLast = dual<
262
+ <A>(predicate: Predicate<A>) => (self: TArray.TArray<A>) => STM.STM<Option.Option<A>>,
263
+ <A>(self: TArray.TArray<A>, predicate: Predicate<A>) => STM.STM<Option.Option<A>>
264
+ >(2, <A>(self: TArray.TArray<A>, predicate: Predicate<A>) =>
265
+ core.effect<never, Option.Option<A>>((journal) => {
266
+ let index = self.chunk.length - 1
267
+ let result: Option.Option<A> = Option.none()
268
+ while (Option.isNone(result) && index >= 0) {
269
+ const element = tRef.unsafeGet(self.chunk[index], journal)
270
+ if (predicate(element)) {
271
+ result = Option.some(element)
272
+ }
273
+ index = index - 1
274
+ }
275
+ return result
276
+ }))
277
+
278
+ /** @internal */
279
+ export const findLastIndex = dual<
280
+ <A>(value: A) => (self: TArray.TArray<A>) => STM.STM<Option.Option<number>>,
281
+ <A>(self: TArray.TArray<A>, value: A) => STM.STM<Option.Option<number>>
282
+ >(2, (self, value) => findLastIndexFrom(self, value, self.chunk.length - 1))
283
+
284
+ /** @internal */
285
+ export const findLastIndexFrom = dual<
286
+ <A>(value: A, end: number) => (self: TArray.TArray<A>) => STM.STM<Option.Option<number>>,
287
+ <A>(self: TArray.TArray<A>, value: A, end: number) => STM.STM<Option.Option<number>>
288
+ >(3, (self, value, end) => {
289
+ if (end >= self.chunk.length) {
290
+ return stm.succeedNone
291
+ }
292
+ return core.effect<never, Option.Option<number>>((journal) => {
293
+ let index: number = end
294
+ let found = false
295
+ while (!found && index >= 0) {
296
+ const element = tRef.unsafeGet(self.chunk[index], journal)
297
+ found = Equal.equals(element)(value)
298
+ index = index - 1
299
+ }
300
+ if (found) {
301
+ return Option.some(index + 1)
302
+ }
303
+ return Option.none()
304
+ })
305
+ })
306
+
307
+ /** @internal */
308
+ export const findLastSTM = dual<
309
+ <A, R, E>(
310
+ predicate: (value: A) => STM.STM<boolean, E, R>
311
+ ) => (self: TArray.TArray<A>) => STM.STM<Option.Option<A>, E, R>,
312
+ <A, R, E>(
313
+ self: TArray.TArray<A>,
314
+ predicate: (value: A) => STM.STM<boolean, E, R>
315
+ ) => STM.STM<Option.Option<A>, E, R>
316
+ >(2, <A, R, E>(self: TArray.TArray<A>, predicate: (value: A) => STM.STM<boolean, E, R>) => {
317
+ const init = [Option.none() as Option.Option<A>, self.chunk.length - 1] as const
318
+ const cont = (state: readonly [Option.Option<A>, number]) => Option.isNone(state[0]) && state[1] >= 0
319
+ return core.map(
320
+ stm.iterate(init, {
321
+ while: cont,
322
+ body: (state) => {
323
+ const index = state[1]
324
+ return pipe(
325
+ tRef.get(self.chunk[index]),
326
+ core.flatMap((value) =>
327
+ core.map(
328
+ predicate(value),
329
+ (bool) => [bool ? Option.some(value) : Option.none(), index - 1] as const
330
+ )
331
+ )
332
+ )
333
+ }
334
+ }),
335
+ (state) => state[0]
336
+ )
337
+ })
338
+
339
+ /** @internal */
340
+ export const forEach = dual<
341
+ <A, R, E>(f: (value: A) => STM.STM<void, E, R>) => (self: TArray.TArray<A>) => STM.STM<void, E, R>,
342
+ <A, R, E>(self: TArray.TArray<A>, f: (value: A) => STM.STM<void, E, R>) => STM.STM<void, E, R>
343
+ >(2, (self, f) => reduceSTM(self, void 0 as void, (_, a) => f(a)))
344
+
345
+ /** @internal */
346
+ export const fromIterable = <A>(iterable: Iterable<A>): STM.STM<TArray.TArray<A>> =>
347
+ core.map(
348
+ stm.forEach(iterable, tRef.make),
349
+ (chunk) => new TArrayImpl(chunk)
350
+ )
351
+
352
+ /** @internal */
353
+ export const get = dual<
354
+ (index: number) => <A>(self: TArray.TArray<A>) => STM.STM<A>,
355
+ <A>(self: TArray.TArray<A>, index: number) => STM.STM<A>
356
+ >(2, (self, index) => {
357
+ if (index < 0 || index >= self.chunk.length) {
358
+ return core.dieMessage("Index out of bounds")
359
+ }
360
+ return tRef.get(self.chunk[index])
361
+ })
362
+
363
+ /** @internal */
364
+ export const headOption = <A>(self: TArray.TArray<A>): STM.STM<Option.Option<A>> =>
365
+ self.chunk.length === 0 ?
366
+ core.succeed(Option.none()) :
367
+ core.map(tRef.get(self.chunk[0]), Option.some)
368
+
369
+ /** @internal */
370
+ export const lastOption = <A>(self: TArray.TArray<A>): STM.STM<Option.Option<A>> =>
371
+ self.chunk.length === 0 ?
372
+ stm.succeedNone :
373
+ core.map(tRef.get(self.chunk[self.chunk.length - 1]), Option.some)
374
+
375
+ /** @internal */
376
+ export const make = <Elements extends [any, ...Array<any>]>(
377
+ ...elements: Elements
378
+ ): STM.STM<TArray.TArray<Elements[number]>> => fromIterable(elements)
379
+
380
+ /** @internal */
381
+ export const maxOption = dual<
382
+ <A>(order: Order.Order<A>) => (self: TArray.TArray<A>) => STM.STM<Option.Option<A>>,
383
+ <A>(self: TArray.TArray<A>, order: Order.Order<A>) => STM.STM<Option.Option<A>>
384
+ >(2, (self, order) => {
385
+ const greaterThan = Order.greaterThan(order)
386
+ return reduceOption(self, (acc, curr) => greaterThan(acc)(curr) ? curr : acc)
387
+ })
388
+
389
+ /** @internal */
390
+ export const minOption = dual<
391
+ <A>(order: Order.Order<A>) => (self: TArray.TArray<A>) => STM.STM<Option.Option<A>>,
392
+ <A>(self: TArray.TArray<A>, order: Order.Order<A>) => STM.STM<Option.Option<A>>
393
+ >(2, (self, order) => {
394
+ const lessThan = Order.lessThan(order)
395
+ return reduceOption(self, (acc, curr) => lessThan(acc)(curr) ? curr : acc)
396
+ })
397
+
398
+ /** @internal */
399
+ export const reduce = dual<
400
+ <Z, A>(zero: Z, f: (accumulator: Z, current: A) => Z) => (self: TArray.TArray<A>) => STM.STM<Z>,
401
+ <Z, A>(self: TArray.TArray<A>, zero: Z, f: (accumulator: Z, current: A) => Z) => STM.STM<Z>
402
+ >(
403
+ 3,
404
+ <Z, A>(self: TArray.TArray<A>, zero: Z, f: (accumulator: Z, current: A) => Z) =>
405
+ core.effect<never, Z>((journal) => {
406
+ let index = 0
407
+ let result = zero
408
+ while (index < self.chunk.length) {
409
+ const element = tRef.unsafeGet(self.chunk[index], journal)
410
+ result = f(result, element)
411
+ index = index + 1
412
+ }
413
+ return result
414
+ })
415
+ )
416
+
417
+ /** @internal */
418
+ export const reduceOption = dual<
419
+ <A>(f: (x: A, y: A) => A) => (self: TArray.TArray<A>) => STM.STM<Option.Option<A>>,
420
+ <A>(self: TArray.TArray<A>, f: (x: A, y: A) => A) => STM.STM<Option.Option<A>>
421
+ >(
422
+ 2,
423
+ <A>(self: TArray.TArray<A>, f: (x: A, y: A) => A) =>
424
+ core.effect<never, Option.Option<A>>((journal) => {
425
+ let index = 0
426
+ let result: A | undefined = undefined
427
+ while (index < self.chunk.length) {
428
+ const element = tRef.unsafeGet(self.chunk[index], journal)
429
+ result = result === undefined ? element : f(result, element)
430
+ index = index + 1
431
+ }
432
+ return Option.fromNullable(result)
433
+ })
434
+ )
435
+
436
+ /** @internal */
437
+ export const reduceOptionSTM = dual<
438
+ <A, R, E>(f: (x: A, y: A) => STM.STM<A, E, R>) => (self: TArray.TArray<A>) => STM.STM<Option.Option<A>, E, R>,
439
+ <A, R, E>(self: TArray.TArray<A>, f: (x: A, y: A) => STM.STM<A, E, R>) => STM.STM<Option.Option<A>, E, R>
440
+ >(
441
+ 2,
442
+ <A, R, E>(self: TArray.TArray<A>, f: (x: A, y: A) => STM.STM<A, E, R>) =>
443
+ reduceSTM(self, Option.none<A>(), (acc, curr) =>
444
+ Option.isSome(acc)
445
+ ? core.map(f(acc.value, curr), Option.some)
446
+ : stm.succeedSome(curr))
447
+ )
448
+
449
+ /** @internal */
450
+ export const reduceSTM = dual<
451
+ <Z, A, R, E>(
452
+ zero: Z,
453
+ f: (accumulator: Z, current: A) => STM.STM<Z, E, R>
454
+ ) => (self: TArray.TArray<A>) => STM.STM<Z, E, R>,
455
+ <Z, A, R, E>(
456
+ self: TArray.TArray<A>,
457
+ zero: Z,
458
+ f: (accumulator: Z, current: A) => STM.STM<Z, E, R>
459
+ ) => STM.STM<Z, E, R>
460
+ >(3, (self, zero, f) =>
461
+ core.flatMap(
462
+ toArray(self),
463
+ stm.reduce(zero, f)
464
+ ))
465
+
466
+ /** @internal */
467
+ export const size = <A>(self: TArray.TArray<A>): number => self.chunk.length
468
+
469
+ /** @internal */
470
+ export const some = dual<
471
+ <A>(predicate: Predicate<A>) => (self: TArray.TArray<A>) => STM.STM<boolean>,
472
+ <A>(self: TArray.TArray<A>, predicate: Predicate<A>) => STM.STM<boolean>
473
+ >(2, (self, predicate) =>
474
+ core.map(
475
+ findFirst(self, predicate),
476
+ Option.isSome
477
+ ))
478
+
479
+ /** @internal */
480
+ export const someSTM = dual<
481
+ <A, R, E>(predicate: (value: A) => STM.STM<boolean, E, R>) => (self: TArray.TArray<A>) => STM.STM<boolean, E, R>,
482
+ <A, R, E>(self: TArray.TArray<A>, predicate: (value: A) => STM.STM<boolean, E, R>) => STM.STM<boolean, E, R>
483
+ >(2, (self, predicate) => core.map(countSTM(self, predicate), (n) => n > 0))
484
+
485
+ /** @internal */
486
+ export const toArray = <A>(self: TArray.TArray<A>): STM.STM<Array<A>> => stm.forEach(self.chunk, tRef.get)
487
+
488
+ /** @internal */
489
+ export const transform = dual<
490
+ <A>(f: (value: A) => A) => (self: TArray.TArray<A>) => STM.STM<void>,
491
+ <A>(self: TArray.TArray<A>, f: (value: A) => A) => STM.STM<void>
492
+ >(2, (self, f) =>
493
+ core.effect<never, void>((journal) => {
494
+ let index = 0
495
+ while (index < self.chunk.length) {
496
+ const ref = self.chunk[index]
497
+ tRef.unsafeSet(ref, f(tRef.unsafeGet(ref, journal)), journal)
498
+ index = index + 1
499
+ }
500
+ return void 0
501
+ }))
502
+
503
+ /** @internal */
504
+ export const transformSTM = dual<
505
+ <A, R, E>(f: (value: A) => STM.STM<A, E, R>) => (self: TArray.TArray<A>) => STM.STM<void, E, R>,
506
+ <A, R, E>(self: TArray.TArray<A>, f: (value: A) => STM.STM<A, E, R>) => STM.STM<void, E, R>
507
+ >(2, <A, R, E>(self: TArray.TArray<A>, f: (value: A) => STM.STM<A, E, R>) =>
508
+ core.flatMap(
509
+ stm.forEach(
510
+ self.chunk,
511
+ (ref) => core.flatMap(tRef.get(ref), f)
512
+ ),
513
+ (chunk) =>
514
+ core.effect<never, void>((journal) => {
515
+ const iterator = chunk[Symbol.iterator]()
516
+ let index = 0
517
+ let next: IteratorResult<A>
518
+ while ((next = iterator.next()) && !next.done) {
519
+ tRef.unsafeSet(self.chunk[index], next.value, journal)
520
+ index = index + 1
521
+ }
522
+ return void 0
523
+ })
524
+ ))
525
+
526
+ /** @internal */
527
+ export const update = dual<
528
+ <A>(index: number, f: (value: A) => A) => (self: TArray.TArray<A>) => STM.STM<void>,
529
+ <A>(self: TArray.TArray<A>, index: number, f: (value: A) => A) => STM.STM<void>
530
+ >(3, (self, index, f) => {
531
+ if (index < 0 || index >= self.chunk.length) {
532
+ return core.dieMessage("Index out of bounds")
533
+ }
534
+ return tRef.update(self.chunk[index], f)
535
+ })
536
+
537
+ /** @internal */
538
+ export const updateSTM = dual<
539
+ <A, R, E>(index: number, f: (value: A) => STM.STM<A, E, R>) => (self: TArray.TArray<A>) => STM.STM<void, E, R>,
540
+ <A, R, E>(self: TArray.TArray<A>, index: number, f: (value: A) => STM.STM<A, E, R>) => STM.STM<void, E, R>
541
+ >(3, (self, index, f) => {
542
+ if (index < 0 || index >= self.chunk.length) {
543
+ return core.dieMessage("Index out of bounds")
544
+ }
545
+ return pipe(
546
+ tRef.get(self.chunk[index]),
547
+ core.flatMap(f),
548
+ core.flatMap((updated) => tRef.set(self.chunk[index], updated))
549
+ )
550
+ })