@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,178 @@
1
+ import type * as Differ from "../Differ.js"
2
+ import { dual } from "../Function.js"
3
+ import type * as RuntimeFlags from "../RuntimeFlags.js"
4
+ import type * as RuntimeFlagsPatch from "../RuntimeFlagsPatch.js"
5
+ import * as internalDiffer from "./differ.js"
6
+ import * as runtimeFlagsPatch from "./runtimeFlagsPatch.js"
7
+
8
+ /** @internal */
9
+ export const None: RuntimeFlags.RuntimeFlag = 0 as RuntimeFlags.RuntimeFlag
10
+
11
+ /** @internal */
12
+ export const Interruption: RuntimeFlags.RuntimeFlag = 1 << 0 as RuntimeFlags.RuntimeFlag
13
+
14
+ /** @internal */
15
+ export const OpSupervision: RuntimeFlags.RuntimeFlag = 1 << 1 as RuntimeFlags.RuntimeFlag
16
+
17
+ /** @internal */
18
+ export const RuntimeMetrics: RuntimeFlags.RuntimeFlag = 1 << 2 as RuntimeFlags.RuntimeFlag
19
+
20
+ /** @internal */
21
+ export const WindDown: RuntimeFlags.RuntimeFlag = 1 << 4 as RuntimeFlags.RuntimeFlag
22
+
23
+ /** @internal */
24
+ export const CooperativeYielding: RuntimeFlags.RuntimeFlag = 1 << 5 as RuntimeFlags.RuntimeFlag
25
+
26
+ /** @internal */
27
+ export const allFlags: ReadonlyArray<RuntimeFlags.RuntimeFlag> = [
28
+ None,
29
+ Interruption,
30
+ OpSupervision,
31
+ RuntimeMetrics,
32
+ WindDown,
33
+ CooperativeYielding
34
+ ]
35
+
36
+ const print = (flag: RuntimeFlags.RuntimeFlag) => {
37
+ switch (flag) {
38
+ case CooperativeYielding: {
39
+ return "CooperativeYielding"
40
+ }
41
+ case WindDown: {
42
+ return "WindDown"
43
+ }
44
+ case RuntimeMetrics: {
45
+ return "RuntimeMetrics"
46
+ }
47
+ case OpSupervision: {
48
+ return "OpSupervision"
49
+ }
50
+ case Interruption: {
51
+ return "Interruption"
52
+ }
53
+ case None: {
54
+ return "None"
55
+ }
56
+ }
57
+ }
58
+
59
+ /** @internal */
60
+ export const cooperativeYielding = (self: RuntimeFlags.RuntimeFlags): boolean => isEnabled(self, CooperativeYielding)
61
+
62
+ /** @internal */
63
+ export const disable = dual<
64
+ (flag: RuntimeFlags.RuntimeFlag) => (self: RuntimeFlags.RuntimeFlags) => RuntimeFlags.RuntimeFlags,
65
+ (self: RuntimeFlags.RuntimeFlags, flag: RuntimeFlags.RuntimeFlag) => RuntimeFlags.RuntimeFlags
66
+ >(2, (self, flag) => (self & ~flag) as RuntimeFlags.RuntimeFlags)
67
+
68
+ /** @internal */
69
+ export const disableAll = dual<
70
+ (flags: RuntimeFlags.RuntimeFlags) => (self: RuntimeFlags.RuntimeFlags) => RuntimeFlags.RuntimeFlags,
71
+ (self: RuntimeFlags.RuntimeFlags, flags: RuntimeFlags.RuntimeFlags) => RuntimeFlags.RuntimeFlags
72
+ >(2, (self, flags) => (self & ~flags) as RuntimeFlags.RuntimeFlags)
73
+
74
+ /** @internal */
75
+ export const enable = dual<
76
+ (flag: RuntimeFlags.RuntimeFlag) => (self: RuntimeFlags.RuntimeFlags) => RuntimeFlags.RuntimeFlags,
77
+ (self: RuntimeFlags.RuntimeFlags, flag: RuntimeFlags.RuntimeFlag) => RuntimeFlags.RuntimeFlags
78
+ >(2, (self, flag) => (self | flag) as RuntimeFlags.RuntimeFlags)
79
+
80
+ /** @internal */
81
+ export const enableAll = dual<
82
+ (flags: RuntimeFlags.RuntimeFlags) => (self: RuntimeFlags.RuntimeFlags) => RuntimeFlags.RuntimeFlags,
83
+ (self: RuntimeFlags.RuntimeFlags, flags: RuntimeFlags.RuntimeFlags) => RuntimeFlags.RuntimeFlags
84
+ >(2, (self, flags) => (self | flags) as RuntimeFlags.RuntimeFlags)
85
+
86
+ /** @internal */
87
+ export const interruptible = (self: RuntimeFlags.RuntimeFlags): boolean => interruption(self) && !windDown(self)
88
+
89
+ /** @internal */
90
+ export const interruption = (self: RuntimeFlags.RuntimeFlags): boolean => isEnabled(self, Interruption)
91
+
92
+ /** @internal */
93
+ export const isDisabled = dual<
94
+ (flag: RuntimeFlags.RuntimeFlag) => (self: RuntimeFlags.RuntimeFlags) => boolean,
95
+ (self: RuntimeFlags.RuntimeFlags, flag: RuntimeFlags.RuntimeFlag) => boolean
96
+ >(2, (self, flag) => !isEnabled(self, flag))
97
+
98
+ /** @internal */
99
+ export const isEnabled = dual<
100
+ (flag: RuntimeFlags.RuntimeFlag) => (self: RuntimeFlags.RuntimeFlags) => boolean,
101
+ (self: RuntimeFlags.RuntimeFlags, flag: RuntimeFlags.RuntimeFlag) => boolean
102
+ >(2, (self, flag) => (self & flag) !== 0)
103
+
104
+ /** @internal */
105
+ export const make = (...flags: ReadonlyArray<RuntimeFlags.RuntimeFlag>): RuntimeFlags.RuntimeFlags =>
106
+ flags.reduce((a, b) => a | b, 0) as RuntimeFlags.RuntimeFlags
107
+
108
+ /** @internal */
109
+ export const none: RuntimeFlags.RuntimeFlags = make(None)
110
+
111
+ /** @internal */
112
+ export const opSupervision = (self: RuntimeFlags.RuntimeFlags): boolean => isEnabled(self, OpSupervision)
113
+
114
+ /** @internal */
115
+ export const render = (self: RuntimeFlags.RuntimeFlags): string => {
116
+ const active: Array<string> = []
117
+ allFlags.forEach((flag) => {
118
+ if (isEnabled(self, flag)) {
119
+ active.push(`${print(flag)}`)
120
+ }
121
+ })
122
+ return `RuntimeFlags(${active.join(", ")})`
123
+ }
124
+
125
+ /** @internal */
126
+ export const runtimeMetrics = (self: RuntimeFlags.RuntimeFlags): boolean => isEnabled(self, RuntimeMetrics)
127
+
128
+ /** @internal */
129
+ export const toSet = (self: RuntimeFlags.RuntimeFlags): ReadonlySet<RuntimeFlags.RuntimeFlag> =>
130
+ new Set(allFlags.filter((flag) => isEnabled(self, flag)))
131
+
132
+ export const windDown = (self: RuntimeFlags.RuntimeFlags): boolean => isEnabled(self, WindDown)
133
+
134
+ // circular with RuntimeFlagsPatch
135
+
136
+ /** @internal */
137
+ export const enabledSet = (self: RuntimeFlagsPatch.RuntimeFlagsPatch): ReadonlySet<RuntimeFlags.RuntimeFlag> =>
138
+ toSet((runtimeFlagsPatch.active(self) & runtimeFlagsPatch.enabled(self)) as RuntimeFlags.RuntimeFlags)
139
+
140
+ /** @internal */
141
+ export const disabledSet = (self: RuntimeFlagsPatch.RuntimeFlagsPatch): ReadonlySet<RuntimeFlags.RuntimeFlag> =>
142
+ toSet((runtimeFlagsPatch.active(self) & ~runtimeFlagsPatch.enabled(self)) as RuntimeFlags.RuntimeFlags)
143
+
144
+ /** @internal */
145
+ export const diff = dual<
146
+ (that: RuntimeFlags.RuntimeFlags) => (self: RuntimeFlags.RuntimeFlags) => RuntimeFlagsPatch.RuntimeFlagsPatch,
147
+ (self: RuntimeFlags.RuntimeFlags, that: RuntimeFlags.RuntimeFlags) => RuntimeFlagsPatch.RuntimeFlagsPatch
148
+ >(2, (self, that) => runtimeFlagsPatch.make(self ^ that, that))
149
+
150
+ /** @internal */
151
+ export const patch = dual<
152
+ (patch: RuntimeFlagsPatch.RuntimeFlagsPatch) => (self: RuntimeFlags.RuntimeFlags) => RuntimeFlags.RuntimeFlags,
153
+ (self: RuntimeFlags.RuntimeFlags, patch: RuntimeFlagsPatch.RuntimeFlagsPatch) => RuntimeFlags.RuntimeFlags
154
+ >(2, (self, patch) =>
155
+ (
156
+ (self & (runtimeFlagsPatch.invert(runtimeFlagsPatch.active(patch)) | runtimeFlagsPatch.enabled(patch))) |
157
+ (runtimeFlagsPatch.active(patch) & runtimeFlagsPatch.enabled(patch))
158
+ ) as RuntimeFlags.RuntimeFlags)
159
+
160
+ /** @internal */
161
+ export const renderPatch = (self: RuntimeFlagsPatch.RuntimeFlagsPatch): string => {
162
+ const enabled = Array.from(enabledSet(self))
163
+ .map((flag) => print(flag))
164
+ .join(", ")
165
+ const disabled = Array.from(disabledSet(self))
166
+ .map((flag) => print(flag))
167
+ .join(", ")
168
+ return `RuntimeFlagsPatch(enabled = (${enabled}), disabled = (${disabled}))`
169
+ }
170
+
171
+ /** @internal */
172
+ export const differ: Differ.Differ<RuntimeFlags.RuntimeFlags, RuntimeFlagsPatch.RuntimeFlagsPatch> = internalDiffer
173
+ .make({
174
+ empty: runtimeFlagsPatch.empty,
175
+ diff: (oldValue, newValue) => diff(oldValue, newValue),
176
+ combine: (first, second) => runtimeFlagsPatch.andThen(second)(first),
177
+ patch: (_patch, oldValue) => patch(oldValue, _patch)
178
+ })
@@ -0,0 +1,103 @@
1
+ import { dual } from "../Function.js"
2
+ import type * as RuntimeFlags from "../RuntimeFlags.js"
3
+ import type * as RuntimeFlagsPatch from "../RuntimeFlagsPatch.js"
4
+
5
+ /** @internal */
6
+ const BIT_MASK = 0xff
7
+
8
+ /** @internal */
9
+ const BIT_SHIFT = 0x08
10
+
11
+ /** @internal */
12
+ export const active = (patch: RuntimeFlagsPatch.RuntimeFlagsPatch): number => patch & BIT_MASK
13
+
14
+ /** @internal */
15
+ export const enabled = (patch: RuntimeFlagsPatch.RuntimeFlagsPatch): number => (patch >> BIT_SHIFT) & BIT_MASK
16
+
17
+ /** @internal */
18
+ export const make = (active: number, enabled: number): RuntimeFlagsPatch.RuntimeFlagsPatch =>
19
+ ((active & BIT_MASK) + (((enabled & active) & BIT_MASK) << BIT_SHIFT)) as RuntimeFlagsPatch.RuntimeFlagsPatch
20
+
21
+ /** @internal */
22
+ export const empty = make(0, 0)
23
+
24
+ /** @internal */
25
+ export const enable = (flag: RuntimeFlags.RuntimeFlag): RuntimeFlagsPatch.RuntimeFlagsPatch => make(flag, flag)
26
+
27
+ /** @internal */
28
+ export const disable = (flag: RuntimeFlags.RuntimeFlag): RuntimeFlagsPatch.RuntimeFlagsPatch => make(flag, 0)
29
+
30
+ /** @internal */
31
+ export const isEmpty = (patch: RuntimeFlagsPatch.RuntimeFlagsPatch): boolean => patch === 0
32
+
33
+ /** @internal */
34
+ export const isActive = dual<
35
+ (flag: RuntimeFlagsPatch.RuntimeFlagsPatch) => (self: RuntimeFlagsPatch.RuntimeFlagsPatch) => boolean,
36
+ (self: RuntimeFlagsPatch.RuntimeFlagsPatch, flag: RuntimeFlagsPatch.RuntimeFlagsPatch) => boolean
37
+ >(2, (self, flag) => (active(self) & flag) !== 0)
38
+
39
+ /** @internal */
40
+ export const isEnabled = dual<
41
+ (flag: RuntimeFlags.RuntimeFlag) => (self: RuntimeFlagsPatch.RuntimeFlagsPatch) => boolean,
42
+ (self: RuntimeFlagsPatch.RuntimeFlagsPatch, flag: RuntimeFlags.RuntimeFlag) => boolean
43
+ >(2, (self, flag) => (enabled(self) & flag) !== 0)
44
+
45
+ /** @internal */
46
+ export const isDisabled = dual<
47
+ (flag: RuntimeFlags.RuntimeFlag) => (self: RuntimeFlagsPatch.RuntimeFlagsPatch) => boolean,
48
+ (self: RuntimeFlagsPatch.RuntimeFlagsPatch, flag: RuntimeFlags.RuntimeFlag) => boolean
49
+ >(2, (self, flag) => ((active(self) & flag) !== 0) && ((enabled(self) & flag) === 0))
50
+
51
+ /** @internal */
52
+ export const exclude = dual<
53
+ (
54
+ flag: RuntimeFlags.RuntimeFlag
55
+ ) => (self: RuntimeFlagsPatch.RuntimeFlagsPatch) => RuntimeFlagsPatch.RuntimeFlagsPatch,
56
+ (self: RuntimeFlagsPatch.RuntimeFlagsPatch, flag: RuntimeFlags.RuntimeFlag) => RuntimeFlagsPatch.RuntimeFlagsPatch
57
+ >(2, (self, flag) => make(active(self) & ~flag, enabled(self)))
58
+
59
+ /** @internal */
60
+ export const both = dual<
61
+ (
62
+ that: RuntimeFlagsPatch.RuntimeFlagsPatch
63
+ ) => (
64
+ self: RuntimeFlagsPatch.RuntimeFlagsPatch
65
+ ) => RuntimeFlagsPatch.RuntimeFlagsPatch,
66
+ (
67
+ self: RuntimeFlagsPatch.RuntimeFlagsPatch,
68
+ that: RuntimeFlagsPatch.RuntimeFlagsPatch
69
+ ) => RuntimeFlagsPatch.RuntimeFlagsPatch
70
+ >(2, (self, that) => make(active(self) | active(that), enabled(self) & enabled(that)))
71
+
72
+ /** @internal */
73
+ export const either = dual<
74
+ (
75
+ that: RuntimeFlagsPatch.RuntimeFlagsPatch
76
+ ) => (
77
+ self: RuntimeFlagsPatch.RuntimeFlagsPatch
78
+ ) => RuntimeFlagsPatch.RuntimeFlagsPatch,
79
+ (
80
+ self: RuntimeFlagsPatch.RuntimeFlagsPatch,
81
+ that: RuntimeFlagsPatch.RuntimeFlagsPatch
82
+ ) => RuntimeFlagsPatch.RuntimeFlagsPatch
83
+ >(2, (self, that) => make(active(self) | active(that), enabled(self) | enabled(that)))
84
+
85
+ /** @internal */
86
+ export const andThen = dual<
87
+ (
88
+ that: RuntimeFlagsPatch.RuntimeFlagsPatch
89
+ ) => (
90
+ self: RuntimeFlagsPatch.RuntimeFlagsPatch
91
+ ) => RuntimeFlagsPatch.RuntimeFlagsPatch,
92
+ (
93
+ self: RuntimeFlagsPatch.RuntimeFlagsPatch,
94
+ that: RuntimeFlagsPatch.RuntimeFlagsPatch
95
+ ) => RuntimeFlagsPatch.RuntimeFlagsPatch
96
+ >(2, (self, that) => (self | that) as RuntimeFlagsPatch.RuntimeFlagsPatch)
97
+
98
+ /** @internal */
99
+ export const inverse = (patch: RuntimeFlagsPatch.RuntimeFlagsPatch): RuntimeFlagsPatch.RuntimeFlagsPatch =>
100
+ make(enabled(patch), invert(active(patch)))
101
+
102
+ /** @internal */
103
+ export const invert = (n: number): number => (~n >>> 0) & BIT_MASK
@@ -0,0 +1,47 @@
1
+ import * as Chunk from "../../Chunk.js"
2
+ import type * as ScheduleDecision from "../../ScheduleDecision.js"
3
+ import type * as Interval from "../../ScheduleInterval.js"
4
+ import * as Intervals from "../../ScheduleIntervals.js"
5
+
6
+ /** @internal */
7
+ export const OP_CONTINUE = "Continue" as const
8
+
9
+ /** @internal */
10
+ export type OP_CONTINUE = typeof OP_CONTINUE
11
+
12
+ /** @internal */
13
+ export const OP_DONE = "Done" as const
14
+
15
+ /** @internal */
16
+ export type OP_DONE = typeof OP_DONE
17
+
18
+ /** @internal */
19
+ export const _continue = (intervals: Intervals.Intervals): ScheduleDecision.ScheduleDecision => {
20
+ return {
21
+ _tag: OP_CONTINUE,
22
+ intervals
23
+ }
24
+ }
25
+
26
+ /** @internal */
27
+ export const continueWith = (interval: Interval.Interval): ScheduleDecision.ScheduleDecision => {
28
+ return {
29
+ _tag: OP_CONTINUE,
30
+ intervals: Intervals.make(Chunk.of(interval))
31
+ }
32
+ }
33
+
34
+ /** @internal */
35
+ export const done: ScheduleDecision.ScheduleDecision = {
36
+ _tag: OP_DONE
37
+ }
38
+
39
+ /** @internal */
40
+ export const isContinue = (self: ScheduleDecision.ScheduleDecision): self is ScheduleDecision.Continue => {
41
+ return self._tag === OP_CONTINUE
42
+ }
43
+
44
+ /** @internal */
45
+ export const isDone = (self: ScheduleDecision.ScheduleDecision): self is ScheduleDecision.Done => {
46
+ return self._tag === OP_DONE
47
+ }
@@ -0,0 +1,101 @@
1
+ import * as Duration from "../../Duration.js"
2
+ import { dual } from "../../Function.js"
3
+ import * as Option from "../../Option.js"
4
+ import type * as Interval from "../../ScheduleInterval.js"
5
+
6
+ /** @internal */
7
+ const IntervalSymbolKey = "effect/ScheduleInterval"
8
+
9
+ /** @internal */
10
+ export const IntervalTypeId: Interval.IntervalTypeId = Symbol.for(
11
+ IntervalSymbolKey
12
+ ) as Interval.IntervalTypeId
13
+
14
+ /** @internal */
15
+ export const empty: Interval.Interval = {
16
+ [IntervalTypeId]: IntervalTypeId,
17
+ startMillis: 0,
18
+ endMillis: 0
19
+ }
20
+
21
+ /** @internal */
22
+ export const make = (startMillis: number, endMillis: number): Interval.Interval => {
23
+ if (startMillis > endMillis) {
24
+ return empty
25
+ }
26
+ return {
27
+ [IntervalTypeId]: IntervalTypeId,
28
+ startMillis,
29
+ endMillis
30
+ }
31
+ }
32
+
33
+ /** @internal */
34
+ export const lessThan = dual<
35
+ (that: Interval.Interval) => (self: Interval.Interval) => boolean,
36
+ (self: Interval.Interval, that: Interval.Interval) => boolean
37
+ >(2, (self, that) => min(self, that) === self)
38
+
39
+ /** @internal */
40
+ export const min = dual<
41
+ (that: Interval.Interval) => (self: Interval.Interval) => Interval.Interval,
42
+ (self: Interval.Interval, that: Interval.Interval) => Interval.Interval
43
+ >(2, (self, that) => {
44
+ if (self.endMillis <= that.startMillis) return self
45
+ if (that.endMillis <= self.startMillis) return that
46
+ if (self.startMillis < that.startMillis) return self
47
+ if (that.startMillis < self.startMillis) return that
48
+ if (self.endMillis <= that.endMillis) return self
49
+ return that
50
+ })
51
+
52
+ /** @internal */
53
+ export const max = dual<
54
+ (that: Interval.Interval) => (self: Interval.Interval) => Interval.Interval,
55
+ (self: Interval.Interval, that: Interval.Interval) => Interval.Interval
56
+ >(2, (self, that) => min(self, that) === self ? that : self)
57
+
58
+ /** @internal */
59
+ export const isEmpty = (self: Interval.Interval): boolean => {
60
+ return self.startMillis >= self.endMillis
61
+ }
62
+
63
+ /** @internal */
64
+ export const isNonEmpty = (self: Interval.Interval): boolean => {
65
+ return !isEmpty(self)
66
+ }
67
+
68
+ /** @internal */
69
+ export const intersect = dual<
70
+ (that: Interval.Interval) => (self: Interval.Interval) => Interval.Interval,
71
+ (self: Interval.Interval, that: Interval.Interval) => Interval.Interval
72
+ >(2, (self, that) => {
73
+ const start = Math.max(self.startMillis, that.startMillis)
74
+ const end = Math.min(self.endMillis, that.endMillis)
75
+ return make(start, end)
76
+ })
77
+
78
+ /** @internal */
79
+ export const size = (self: Interval.Interval): Duration.Duration => {
80
+ return Duration.millis(self.endMillis - self.startMillis)
81
+ }
82
+
83
+ /** @internal */
84
+ export const union = dual<
85
+ (that: Interval.Interval) => (self: Interval.Interval) => Option.Option<Interval.Interval>,
86
+ (self: Interval.Interval, that: Interval.Interval) => Option.Option<Interval.Interval>
87
+ >(2, (self, that) => {
88
+ const start = Math.max(self.startMillis, that.startMillis)
89
+ const end = Math.min(self.endMillis, that.endMillis)
90
+ return start < end ? Option.none() : Option.some(make(start, end))
91
+ })
92
+
93
+ /** @internal */
94
+ export const after = (startMilliseconds: number): Interval.Interval => {
95
+ return make(startMilliseconds, Number.POSITIVE_INFINITY)
96
+ }
97
+
98
+ /** @internal */
99
+ export const before = (endMilliseconds: number): Interval.Interval => {
100
+ return make(Number.NEGATIVE_INFINITY, endMilliseconds)
101
+ }
@@ -0,0 +1,180 @@
1
+ import * as Chunk from "../../Chunk.js"
2
+ import { dual, pipe } from "../../Function.js"
3
+ import * as Option from "../../Option.js"
4
+ import * as Interval from "../../ScheduleInterval.js"
5
+ import type * as Intervals from "../../ScheduleIntervals.js"
6
+ import { getBugErrorMessage } from "../errors.js"
7
+
8
+ /** @internal */
9
+ const IntervalsSymbolKey = "effect/ScheduleIntervals"
10
+
11
+ /** @internal */
12
+ export const IntervalsTypeId: Intervals.IntervalsTypeId = Symbol.for(
13
+ IntervalsSymbolKey
14
+ ) as Intervals.IntervalsTypeId
15
+
16
+ /** @internal */
17
+ export const make = (intervals: Chunk.Chunk<Interval.Interval>): Intervals.Intervals => {
18
+ return {
19
+ [IntervalsTypeId]: IntervalsTypeId,
20
+ intervals
21
+ }
22
+ }
23
+ /** @internal */
24
+ export const empty: Intervals.Intervals = make(Chunk.empty())
25
+
26
+ /** @internal */
27
+ export const fromIterable = (intervals: Iterable<Interval.Interval>): Intervals.Intervals =>
28
+ Array.from(intervals).reduce(
29
+ (intervals, interval) => pipe(intervals, union(make(Chunk.of(interval)))),
30
+ empty
31
+ )
32
+
33
+ /** @internal */
34
+ export const union = dual<
35
+ (that: Intervals.Intervals) => (self: Intervals.Intervals) => Intervals.Intervals,
36
+ (self: Intervals.Intervals, that: Intervals.Intervals) => Intervals.Intervals
37
+ >(2, (self, that) => {
38
+ if (!Chunk.isNonEmpty(that.intervals)) {
39
+ return self
40
+ }
41
+ if (!Chunk.isNonEmpty(self.intervals)) {
42
+ return that
43
+ }
44
+ if (Chunk.headNonEmpty(self.intervals).startMillis < Chunk.headNonEmpty(that.intervals).startMillis) {
45
+ return unionLoop(
46
+ Chunk.tailNonEmpty(self.intervals),
47
+ that.intervals,
48
+ Chunk.headNonEmpty(self.intervals),
49
+ Chunk.empty()
50
+ )
51
+ }
52
+ return unionLoop(
53
+ self.intervals,
54
+ Chunk.tailNonEmpty(that.intervals),
55
+ Chunk.headNonEmpty(that.intervals),
56
+ Chunk.empty()
57
+ )
58
+ })
59
+
60
+ /** @internal */
61
+ const unionLoop = (
62
+ _self: Chunk.Chunk<Interval.Interval>,
63
+ _that: Chunk.Chunk<Interval.Interval>,
64
+ _interval: Interval.Interval,
65
+ _acc: Chunk.Chunk<Interval.Interval>
66
+ ): Intervals.Intervals => {
67
+ let self = _self
68
+ let that = _that
69
+ let interval = _interval
70
+ let acc = _acc
71
+ while (Chunk.isNonEmpty(self) || Chunk.isNonEmpty(that)) {
72
+ if (!Chunk.isNonEmpty(self) && Chunk.isNonEmpty(that)) {
73
+ if (interval.endMillis < Chunk.headNonEmpty(that).startMillis) {
74
+ acc = pipe(acc, Chunk.prepend(interval))
75
+ interval = Chunk.headNonEmpty(that)
76
+ that = Chunk.tailNonEmpty(that)
77
+ self = Chunk.empty()
78
+ } else {
79
+ interval = Interval.make(interval.startMillis, Chunk.headNonEmpty(that).endMillis)
80
+ that = Chunk.tailNonEmpty(that)
81
+ self = Chunk.empty()
82
+ }
83
+ } else if (Chunk.isNonEmpty(self) && Chunk.isEmpty(that)) {
84
+ if (interval.endMillis < Chunk.headNonEmpty(self).startMillis) {
85
+ acc = pipe(acc, Chunk.prepend(interval))
86
+ interval = Chunk.headNonEmpty(self)
87
+ that = Chunk.empty()
88
+ self = Chunk.tailNonEmpty(self)
89
+ } else {
90
+ interval = Interval.make(interval.startMillis, Chunk.headNonEmpty(self).endMillis)
91
+ that = Chunk.empty()
92
+ self = Chunk.tailNonEmpty(self)
93
+ }
94
+ } else if (Chunk.isNonEmpty(self) && Chunk.isNonEmpty(that)) {
95
+ if (Chunk.headNonEmpty(self).startMillis < Chunk.headNonEmpty(that).startMillis) {
96
+ if (interval.endMillis < Chunk.headNonEmpty(self).startMillis) {
97
+ acc = pipe(acc, Chunk.prepend(interval))
98
+ interval = Chunk.headNonEmpty(self)
99
+ self = Chunk.tailNonEmpty(self)
100
+ } else {
101
+ interval = Interval.make(interval.startMillis, Chunk.headNonEmpty(self).endMillis)
102
+ self = Chunk.tailNonEmpty(self)
103
+ }
104
+ } else if (interval.endMillis < Chunk.headNonEmpty(that).startMillis) {
105
+ acc = pipe(acc, Chunk.prepend(interval))
106
+ interval = Chunk.headNonEmpty(that)
107
+ that = Chunk.tailNonEmpty(that)
108
+ } else {
109
+ interval = Interval.make(interval.startMillis, Chunk.headNonEmpty(that).endMillis)
110
+ that = Chunk.tailNonEmpty(that)
111
+ }
112
+ } else {
113
+ throw new Error(getBugErrorMessage("Intervals.unionLoop"))
114
+ }
115
+ }
116
+ return make(pipe(acc, Chunk.prepend(interval), Chunk.reverse))
117
+ }
118
+
119
+ /** @internal */
120
+ export const intersect = dual<
121
+ (that: Intervals.Intervals) => (self: Intervals.Intervals) => Intervals.Intervals,
122
+ (self: Intervals.Intervals, that: Intervals.Intervals) => Intervals.Intervals
123
+ >(2, (self, that) => intersectLoop(self.intervals, that.intervals, Chunk.empty()))
124
+
125
+ /** @internal */
126
+ const intersectLoop = (
127
+ _left: Chunk.Chunk<Interval.Interval>,
128
+ _right: Chunk.Chunk<Interval.Interval>,
129
+ _acc: Chunk.Chunk<Interval.Interval>
130
+ ): Intervals.Intervals => {
131
+ let left = _left
132
+ let right = _right
133
+ let acc = _acc
134
+ while (Chunk.isNonEmpty(left) && Chunk.isNonEmpty(right)) {
135
+ const interval = pipe(Chunk.headNonEmpty(left), Interval.intersect(Chunk.headNonEmpty(right)))
136
+ const intervals = Interval.isEmpty(interval) ? acc : pipe(acc, Chunk.prepend(interval))
137
+ if (pipe(Chunk.headNonEmpty(left), Interval.lessThan(Chunk.headNonEmpty(right)))) {
138
+ left = Chunk.tailNonEmpty(left)
139
+ } else {
140
+ right = Chunk.tailNonEmpty(right)
141
+ }
142
+ acc = intervals
143
+ }
144
+ return make(Chunk.reverse(acc))
145
+ }
146
+
147
+ /** @internal */
148
+ export const start = (self: Intervals.Intervals): number => {
149
+ return pipe(
150
+ self.intervals,
151
+ Chunk.head,
152
+ Option.getOrElse(() => Interval.empty)
153
+ ).startMillis
154
+ }
155
+
156
+ /** @internal */
157
+ export const end = (self: Intervals.Intervals): number => {
158
+ return pipe(
159
+ self.intervals,
160
+ Chunk.head,
161
+ Option.getOrElse(() => Interval.empty)
162
+ ).endMillis
163
+ }
164
+
165
+ /** @internal */
166
+ export const lessThan = dual<
167
+ (that: Intervals.Intervals) => (self: Intervals.Intervals) => boolean,
168
+ (self: Intervals.Intervals, that: Intervals.Intervals) => boolean
169
+ >(2, (self, that) => start(self) < start(that))
170
+
171
+ /** @internal */
172
+ export const isNonEmpty = (self: Intervals.Intervals): boolean => {
173
+ return Chunk.isNonEmpty(self.intervals)
174
+ }
175
+
176
+ /** @internal */
177
+ export const max = dual<
178
+ (that: Intervals.Intervals) => (self: Intervals.Intervals) => Intervals.Intervals,
179
+ (self: Intervals.Intervals, that: Intervals.Intervals) => Intervals.Intervals
180
+ >(2, (self, that) => lessThan(self, that) ? that : self)