effect 2.0.0-next.44 → 2.0.0-next.46

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 (779) hide show
  1. package/Bigint/dist/effect-Bigint.cjs.dev.js +125 -1
  2. package/Bigint/dist/effect-Bigint.cjs.mjs +6 -1
  3. package/Bigint/dist/effect-Bigint.cjs.prod.js +125 -1
  4. package/Bigint/dist/effect-Bigint.esm.js +111 -2
  5. package/Boolean/dist/effect-Boolean.cjs.dev.js +1 -1
  6. package/Boolean/dist/effect-Boolean.cjs.prod.js +1 -1
  7. package/Boolean/dist/effect-Boolean.esm.js +1 -1
  8. package/Brand/dist/effect-Brand.cjs.dev.js +3 -3
  9. package/Brand/dist/effect-Brand.cjs.prod.js +3 -3
  10. package/Cache/dist/effect-Cache.cjs.dev.js +32 -32
  11. package/Cache/dist/effect-Cache.cjs.prod.js +32 -32
  12. package/Cause/dist/effect-Cause.cjs.dev.js +17 -17
  13. package/Cause/dist/effect-Cause.cjs.mjs +1 -1
  14. package/Cause/dist/effect-Cause.cjs.prod.js +17 -17
  15. package/Cause/dist/effect-Cause.esm.js +4 -4
  16. package/Channel/dist/effect-Channel.cjs.dev.js +50 -50
  17. package/Channel/dist/effect-Channel.cjs.mjs +3 -3
  18. package/Channel/dist/effect-Channel.cjs.prod.js +50 -50
  19. package/Channel/dist/effect-Channel.esm.js +8 -8
  20. package/ChannelSingleProducerAsyncInput/dist/effect-ChannelSingleProducerAsyncInput.cjs.dev.js +36 -36
  21. package/ChannelSingleProducerAsyncInput/dist/effect-ChannelSingleProducerAsyncInput.cjs.prod.js +36 -36
  22. package/Chunk/dist/effect-Chunk.cjs.dev.js +3 -3
  23. package/Chunk/dist/effect-Chunk.cjs.prod.js +3 -3
  24. package/Clock/dist/effect-Clock.cjs.dev.js +16 -16
  25. package/Clock/dist/effect-Clock.cjs.prod.js +16 -16
  26. package/Config/dist/effect-Config.cjs.dev.js +11 -11
  27. package/Config/dist/effect-Config.cjs.prod.js +11 -11
  28. package/ConfigError/dist/effect-ConfigError.cjs.dev.js +4 -4
  29. package/ConfigError/dist/effect-ConfigError.cjs.prod.js +4 -4
  30. package/ConfigProvider/dist/effect-ConfigProvider.cjs.dev.js +17 -17
  31. package/ConfigProvider/dist/effect-ConfigProvider.cjs.prod.js +17 -17
  32. package/ConfigProviderPathPatch/dist/effect-ConfigProviderPathPatch.cjs.dev.js +5 -5
  33. package/ConfigProviderPathPatch/dist/effect-ConfigProviderPathPatch.cjs.prod.js +5 -5
  34. package/ConfigSecret/dist/effect-ConfigSecret.cjs.dev.js +4 -4
  35. package/ConfigSecret/dist/effect-ConfigSecret.cjs.prod.js +4 -4
  36. package/Console/dist/effect-Console.cjs.dev.js +35 -35
  37. package/Console/dist/effect-Console.cjs.prod.js +35 -35
  38. package/Context/dist/effect-Context.cjs.dev.js +3 -8
  39. package/Context/dist/effect-Context.cjs.prod.js +3 -8
  40. package/Data/dist/effect-Data.cjs.dev.js +141 -54
  41. package/Data/dist/effect-Data.cjs.mjs +2 -0
  42. package/Data/dist/effect-Data.cjs.prod.js +141 -54
  43. package/Data/dist/effect-Data.esm.js +51 -3
  44. package/DefaultServices/dist/effect-DefaultServices.cjs.dev.js +16 -16
  45. package/DefaultServices/dist/effect-DefaultServices.cjs.prod.js +16 -16
  46. package/Deferred/dist/effect-Deferred.cjs.dev.js +8 -8
  47. package/Deferred/dist/effect-Deferred.cjs.prod.js +8 -8
  48. package/Differ/dist/effect-Differ.cjs.dev.js +11 -11
  49. package/Differ/dist/effect-Differ.cjs.prod.js +11 -11
  50. package/Duration/dist/effect-Duration.cjs.dev.js +3 -3
  51. package/Duration/dist/effect-Duration.cjs.prod.js +3 -3
  52. package/Effect/dist/effect-Effect.cjs.dev.js +44 -44
  53. package/Effect/dist/effect-Effect.cjs.prod.js +44 -44
  54. package/Effectable/dist/effect-Effectable.cjs.dev.js +24 -14
  55. package/Effectable/dist/effect-Effectable.cjs.mjs +5 -4
  56. package/Effectable/dist/effect-Effectable.cjs.prod.js +24 -14
  57. package/Effectable/dist/effect-Effectable.esm.js +15 -5
  58. package/Either/dist/effect-Either.cjs.dev.js +3 -3
  59. package/Either/dist/effect-Either.cjs.prod.js +3 -3
  60. package/Encoding/dist/effect-Encoding.cjs.dev.js +3 -3
  61. package/Encoding/dist/effect-Encoding.cjs.prod.js +3 -3
  62. package/ExecutionStrategy/dist/effect-ExecutionStrategy.cjs.dev.js +2 -2
  63. package/ExecutionStrategy/dist/effect-ExecutionStrategy.cjs.prod.js +2 -2
  64. package/Exit/dist/effect-Exit.cjs.dev.js +8 -8
  65. package/Exit/dist/effect-Exit.cjs.prod.js +8 -8
  66. package/Fiber/dist/effect-Fiber.cjs.dev.js +29 -29
  67. package/Fiber/dist/effect-Fiber.cjs.prod.js +29 -29
  68. package/FiberId/dist/effect-FiberId.cjs.dev.js +5 -5
  69. package/FiberId/dist/effect-FiberId.cjs.prod.js +5 -5
  70. package/FiberRef/dist/effect-FiberRef.cjs.dev.js +29 -29
  71. package/FiberRef/dist/effect-FiberRef.cjs.prod.js +29 -29
  72. package/FiberRefs/dist/effect-FiberRefs.cjs.dev.js +9 -9
  73. package/FiberRefs/dist/effect-FiberRefs.cjs.prod.js +9 -9
  74. package/FiberRefsPatch/dist/effect-FiberRefsPatch.cjs.dev.js +10 -10
  75. package/FiberRefsPatch/dist/effect-FiberRefsPatch.cjs.prod.js +10 -10
  76. package/GroupBy/dist/effect-GroupBy.cjs.dev.js +42 -42
  77. package/GroupBy/dist/effect-GroupBy.cjs.prod.js +42 -42
  78. package/HashMap/dist/effect-HashMap.cjs.dev.js +20 -20
  79. package/HashMap/dist/effect-HashMap.cjs.prod.js +20 -20
  80. package/HashSet/dist/effect-HashSet.cjs.dev.js +20 -20
  81. package/HashSet/dist/effect-HashSet.cjs.prod.js +20 -20
  82. package/KeyedPool/dist/effect-KeyedPool.cjs.dev.js +33 -33
  83. package/KeyedPool/dist/effect-KeyedPool.cjs.prod.js +33 -33
  84. package/Layer/dist/effect-Layer.cjs.dev.js +32 -32
  85. package/Layer/dist/effect-Layer.cjs.prod.js +32 -32
  86. package/List/dist/effect-List.cjs.dev.js +3 -3
  87. package/List/dist/effect-List.cjs.prod.js +3 -3
  88. package/LogLevel/dist/effect-LogLevel.cjs.dev.js +8 -8
  89. package/LogLevel/dist/effect-LogLevel.cjs.prod.js +8 -8
  90. package/Logger/dist/effect-Logger.cjs.dev.js +33 -33
  91. package/Logger/dist/effect-Logger.cjs.prod.js +33 -33
  92. package/Metric/dist/effect-Metric.cjs.dev.js +27 -27
  93. package/Metric/dist/effect-Metric.cjs.prod.js +27 -27
  94. package/MetricBoundaries/dist/effect-MetricBoundaries.cjs.dev.js +4 -4
  95. package/MetricBoundaries/dist/effect-MetricBoundaries.cjs.prod.js +4 -4
  96. package/MetricHook/dist/effect-MetricHook.cjs.dev.js +6 -6
  97. package/MetricHook/dist/effect-MetricHook.cjs.prod.js +6 -6
  98. package/MetricKey/dist/effect-MetricKey.cjs.dev.js +6 -6
  99. package/MetricKey/dist/effect-MetricKey.cjs.prod.js +6 -6
  100. package/MetricKeyType/dist/effect-MetricKeyType.cjs.dev.js +4 -4
  101. package/MetricKeyType/dist/effect-MetricKeyType.cjs.prod.js +4 -4
  102. package/MetricPolling/dist/effect-MetricPolling.cjs.dev.js +30 -30
  103. package/MetricPolling/dist/effect-MetricPolling.cjs.prod.js +30 -30
  104. package/MetricRegistry/dist/effect-MetricRegistry.cjs.dev.js +8 -8
  105. package/MetricRegistry/dist/effect-MetricRegistry.cjs.prod.js +8 -8
  106. package/MetricState/dist/effect-MetricState.cjs.dev.js +1 -1
  107. package/MetricState/dist/effect-MetricState.cjs.prod.js +1 -1
  108. package/MutableHashMap/dist/effect-MutableHashMap.cjs.dev.js +4 -4
  109. package/MutableHashMap/dist/effect-MutableHashMap.cjs.prod.js +4 -4
  110. package/MutableHashSet/dist/effect-MutableHashSet.cjs.dev.js +4 -4
  111. package/MutableHashSet/dist/effect-MutableHashSet.cjs.prod.js +4 -4
  112. package/MutableQueue/dist/effect-MutableQueue.cjs.dev.js +3 -3
  113. package/MutableQueue/dist/effect-MutableQueue.cjs.prod.js +3 -3
  114. package/Number/dist/effect-Number.cjs.dev.js +1 -1
  115. package/Number/dist/effect-Number.cjs.prod.js +1 -1
  116. package/Number/dist/effect-Number.esm.js +1 -1
  117. package/Option/dist/effect-Option.cjs.dev.js +9 -9
  118. package/Option/dist/effect-Option.cjs.prod.js +9 -9
  119. package/Pool/dist/effect-Pool.cjs.dev.js +31 -31
  120. package/Pool/dist/effect-Pool.cjs.prod.js +31 -31
  121. package/PubSub/dist/effect-PubSub.cjs.d.mts +2 -0
  122. package/PubSub/dist/effect-PubSub.cjs.d.mts.map +1 -0
  123. package/PubSub/dist/effect-PubSub.cjs.d.ts +2 -0
  124. package/PubSub/dist/effect-PubSub.cjs.d.ts.map +1 -0
  125. package/{Hub/dist/effect-Hub.cjs.dev.js → PubSub/dist/effect-PubSub.cjs.dev.js} +163 -163
  126. package/PubSub/dist/effect-PubSub.cjs.js +7 -0
  127. package/{Hub/dist/effect-Hub.cjs.mjs → PubSub/dist/effect-PubSub.cjs.mjs} +1 -1
  128. package/{Hub/dist/effect-Hub.cjs.prod.js → PubSub/dist/effect-PubSub.cjs.prod.js} +163 -163
  129. package/{Hub/dist/effect-Hub.esm.js → PubSub/dist/effect-PubSub.esm.js} +15 -15
  130. package/PubSub/package.json +4 -0
  131. package/Queue/dist/effect-Queue.cjs.dev.js +28 -28
  132. package/Queue/dist/effect-Queue.cjs.prod.js +28 -28
  133. package/README.md +5 -5
  134. package/Random/dist/effect-Random.cjs.dev.js +16 -16
  135. package/Random/dist/effect-Random.cjs.prod.js +16 -16
  136. package/ReadonlyArray/dist/effect-ReadonlyArray.cjs.dev.js +3 -3
  137. package/ReadonlyArray/dist/effect-ReadonlyArray.cjs.prod.js +3 -3
  138. package/ReadonlyRecord/dist/effect-ReadonlyRecord.cjs.dev.js +3 -3
  139. package/ReadonlyRecord/dist/effect-ReadonlyRecord.cjs.prod.js +3 -3
  140. package/RedBlackTree/dist/effect-RedBlackTree.cjs.dev.js +4 -4
  141. package/RedBlackTree/dist/effect-RedBlackTree.cjs.prod.js +4 -4
  142. package/Ref/dist/effect-Ref.cjs.dev.js +9 -9
  143. package/Ref/dist/effect-Ref.cjs.prod.js +9 -9
  144. package/Reloadable/dist/effect-Reloadable.cjs.dev.js +44 -44
  145. package/Reloadable/dist/effect-Reloadable.cjs.prod.js +44 -44
  146. package/Request/dist/effect-Request.cjs.dev.js +29 -29
  147. package/Request/dist/effect-Request.cjs.prod.js +29 -29
  148. package/RequestBlock/dist/effect-RequestBlock.cjs.dev.js +36 -36
  149. package/RequestBlock/dist/effect-RequestBlock.cjs.prod.js +36 -36
  150. package/RequestResolver/dist/effect-RequestResolver.cjs.dev.js +38 -38
  151. package/RequestResolver/dist/effect-RequestResolver.cjs.prod.js +38 -38
  152. package/Resource/dist/effect-Resource.cjs.dev.js +34 -34
  153. package/Resource/dist/effect-Resource.cjs.prod.js +34 -34
  154. package/Runtime/dist/effect-Runtime.cjs.dev.js +34 -34
  155. package/Runtime/dist/effect-Runtime.cjs.prod.js +34 -34
  156. package/RuntimeFlags/dist/effect-RuntimeFlags.cjs.dev.js +33 -33
  157. package/RuntimeFlags/dist/effect-RuntimeFlags.cjs.prod.js +33 -33
  158. package/RuntimeFlagsPatch/dist/effect-RuntimeFlagsPatch.cjs.dev.js +6 -6
  159. package/RuntimeFlagsPatch/dist/effect-RuntimeFlagsPatch.cjs.prod.js +6 -6
  160. package/STM/dist/effect-STM.cjs.dev.js +48 -48
  161. package/STM/dist/effect-STM.cjs.prod.js +48 -48
  162. package/Schedule/dist/effect-Schedule.cjs.dev.js +19 -19
  163. package/Schedule/dist/effect-Schedule.cjs.prod.js +19 -19
  164. package/ScheduleDecision/dist/effect-ScheduleDecision.cjs.dev.js +3 -3
  165. package/ScheduleDecision/dist/effect-ScheduleDecision.cjs.prod.js +3 -3
  166. package/ScheduleInterval/dist/effect-ScheduleInterval.cjs.dev.js +3 -3
  167. package/ScheduleInterval/dist/effect-ScheduleInterval.cjs.prod.js +3 -3
  168. package/ScheduleIntervals/dist/effect-ScheduleIntervals.cjs.dev.js +3 -3
  169. package/ScheduleIntervals/dist/effect-ScheduleIntervals.cjs.prod.js +3 -3
  170. package/Scheduler/dist/effect-Scheduler.cjs.dev.js +8 -8
  171. package/Scheduler/dist/effect-Scheduler.cjs.prod.js +8 -8
  172. package/Scope/dist/effect-Scope.cjs.dev.js +27 -27
  173. package/Scope/dist/effect-Scope.cjs.prod.js +27 -27
  174. package/ScopedCache/dist/effect-ScopedCache.cjs.dev.js +78 -61
  175. package/ScopedCache/dist/effect-ScopedCache.cjs.prod.js +78 -61
  176. package/ScopedRef/dist/effect-ScopedRef.cjs.dev.js +34 -34
  177. package/ScopedRef/dist/effect-ScopedRef.cjs.prod.js +34 -34
  178. package/Sink/dist/effect-Sink.cjs.dev.js +43 -43
  179. package/Sink/dist/effect-Sink.cjs.mjs +1 -1
  180. package/Sink/dist/effect-Sink.cjs.prod.js +43 -43
  181. package/Sink/dist/effect-Sink.esm.js +5 -5
  182. package/SortedMap/dist/effect-SortedMap.cjs.dev.js +3 -3
  183. package/SortedMap/dist/effect-SortedMap.cjs.prod.js +3 -3
  184. package/SortedSet/dist/effect-SortedSet.cjs.dev.js +3 -3
  185. package/SortedSet/dist/effect-SortedSet.cjs.prod.js +3 -3
  186. package/Stream/dist/effect-Stream.cjs.dev.js +60 -60
  187. package/Stream/dist/effect-Stream.cjs.mjs +5 -5
  188. package/Stream/dist/effect-Stream.cjs.prod.js +60 -60
  189. package/Stream/dist/effect-Stream.esm.js +15 -15
  190. package/Streamable/dist/effect-Streamable.cjs.d.mts +2 -0
  191. package/Streamable/dist/effect-Streamable.cjs.d.mts.map +1 -0
  192. package/Streamable/dist/effect-Streamable.cjs.d.ts +2 -0
  193. package/Streamable/dist/effect-Streamable.cjs.d.ts.map +1 -0
  194. package/Streamable/dist/effect-Streamable.cjs.dev.js +152 -0
  195. package/Streamable/dist/effect-Streamable.cjs.js +7 -0
  196. package/Streamable/dist/effect-Streamable.cjs.mjs +3 -0
  197. package/Streamable/dist/effect-Streamable.cjs.prod.js +152 -0
  198. package/Streamable/dist/effect-Streamable.esm.js +42 -0
  199. package/Streamable/package.json +4 -0
  200. package/String/dist/effect-String.cjs.dev.js +4 -4
  201. package/String/dist/effect-String.cjs.prod.js +4 -4
  202. package/String/dist/effect-String.esm.js +1 -1
  203. package/SubscriptionRef/dist/effect-SubscriptionRef.cjs.dev.js +48 -48
  204. package/SubscriptionRef/dist/effect-SubscriptionRef.cjs.prod.js +48 -48
  205. package/Supervisor/dist/effect-Supervisor.cjs.dev.js +34 -34
  206. package/Supervisor/dist/effect-Supervisor.cjs.prod.js +34 -34
  207. package/SynchronizedRef/dist/effect-SynchronizedRef.cjs.dev.js +30 -30
  208. package/SynchronizedRef/dist/effect-SynchronizedRef.cjs.prod.js +30 -30
  209. package/TArray/dist/effect-TArray.cjs.dev.js +46 -46
  210. package/TArray/dist/effect-TArray.cjs.prod.js +46 -46
  211. package/TDeferred/dist/effect-TDeferred.cjs.dev.js +45 -45
  212. package/TDeferred/dist/effect-TDeferred.cjs.prod.js +45 -45
  213. package/TMap/dist/effect-TMap.cjs.dev.js +47 -47
  214. package/TMap/dist/effect-TMap.cjs.prod.js +47 -47
  215. package/TPriorityQueue/dist/effect-TPriorityQueue.cjs.dev.js +44 -44
  216. package/TPriorityQueue/dist/effect-TPriorityQueue.cjs.prod.js +44 -44
  217. package/TPubSub/dist/effect-TPubSub.cjs.d.mts +2 -0
  218. package/TPubSub/dist/effect-TPubSub.cjs.d.mts.map +1 -0
  219. package/TPubSub/dist/effect-TPubSub.cjs.d.ts +2 -0
  220. package/TPubSub/dist/effect-TPubSub.cjs.d.ts.map +1 -0
  221. package/{THub/dist/effect-THub.cjs.dev.js → TPubSub/dist/effect-TPubSub.cjs.dev.js} +101 -101
  222. package/TPubSub/dist/effect-TPubSub.cjs.js +7 -0
  223. package/{THub/dist/effect-THub.cjs.mjs → TPubSub/dist/effect-TPubSub.cjs.mjs} +2 -2
  224. package/{THub/dist/effect-THub.cjs.prod.js → TPubSub/dist/effect-TPubSub.cjs.prod.js} +101 -101
  225. package/TPubSub/dist/effect-TPubSub.esm.js +157 -0
  226. package/TPubSub/package.json +4 -0
  227. package/TQueue/dist/effect-TQueue.cjs.dev.js +46 -46
  228. package/TQueue/dist/effect-TQueue.cjs.prod.js +46 -46
  229. package/TRandom/dist/effect-TRandom.cjs.dev.js +50 -50
  230. package/TRandom/dist/effect-TRandom.cjs.prod.js +50 -50
  231. package/TReentrantLock/dist/effect-TReentrantLock.cjs.dev.js +46 -46
  232. package/TReentrantLock/dist/effect-TReentrantLock.cjs.prod.js +46 -46
  233. package/TRef/dist/effect-TRef.cjs.dev.js +44 -44
  234. package/TRef/dist/effect-TRef.cjs.prod.js +44 -44
  235. package/TSemaphore/dist/effect-TSemaphore.cjs.dev.js +45 -45
  236. package/TSemaphore/dist/effect-TSemaphore.cjs.prod.js +45 -45
  237. package/TSet/dist/effect-TSet.cjs.dev.js +47 -47
  238. package/TSet/dist/effect-TSet.cjs.prod.js +47 -47
  239. package/Take/dist/effect-Take.cjs.dev.js +36 -36
  240. package/Take/dist/effect-Take.cjs.prod.js +36 -36
  241. package/TestAnnotation/dist/effect-TestAnnotation.cjs.dev.js +8 -8
  242. package/TestAnnotation/dist/effect-TestAnnotation.cjs.prod.js +8 -8
  243. package/TestAnnotations/dist/effect-TestAnnotations.cjs.dev.js +25 -25
  244. package/TestAnnotations/dist/effect-TestAnnotations.cjs.prod.js +25 -25
  245. package/TestClock/dist/effect-TestClock.cjs.dev.js +46 -46
  246. package/TestClock/dist/effect-TestClock.cjs.prod.js +46 -46
  247. package/TestConfig/dist/effect-TestConfig.cjs.dev.js +3 -8
  248. package/TestConfig/dist/effect-TestConfig.cjs.prod.js +3 -8
  249. package/TestContext/dist/effect-TestContext.cjs.dev.js +37 -37
  250. package/TestContext/dist/effect-TestContext.cjs.prod.js +37 -37
  251. package/TestLive/dist/effect-TestLive.cjs.dev.js +17 -17
  252. package/TestLive/dist/effect-TestLive.cjs.prod.js +17 -17
  253. package/TestServices/dist/effect-TestServices.cjs.dev.js +42 -42
  254. package/TestServices/dist/effect-TestServices.cjs.prod.js +42 -42
  255. package/TestSized/dist/effect-TestSized.cjs.dev.js +11 -11
  256. package/TestSized/dist/effect-TestSized.cjs.prod.js +11 -11
  257. package/Tracer/dist/effect-Tracer.cjs.dev.js +16 -16
  258. package/Tracer/dist/effect-Tracer.cjs.prod.js +16 -16
  259. package/dist/{Context-01a123ac.cjs.prod.js → Context-9fe5eb16.cjs.prod.js} +5 -5
  260. package/dist/{Context-593661f6.cjs.dev.js → Context-da73ddfa.cjs.dev.js} +5 -5
  261. package/dist/{Effectable-2f022879.cjs.dev.js → Effectable-7314aed8.cjs.dev.js} +63 -10
  262. package/dist/{Effectable-cd8f3a96.cjs.prod.js → Effectable-c4c14a2b.cjs.prod.js} +63 -10
  263. package/dist/{Either-7a881c7a.cjs.prod.js → Either-d43f082c.cjs.prod.js} +6 -79
  264. package/dist/{Either-12bbe00c.cjs.dev.js → Either-fa0ef1d9.cjs.dev.js} +6 -79
  265. package/dist/{ExecutionStrategy-14d3053a.cjs.prod.js → ExecutionStrategy-4808fe5d.cjs.prod.js} +2 -2
  266. package/dist/{ExecutionStrategy-70f1a920.cjs.dev.js → ExecutionStrategy-7d9d457b.cjs.dev.js} +2 -2
  267. package/dist/{HashSet-0b4ff1e4.cjs.dev.js → HashSet-5963ad6b.cjs.dev.js} +32 -32
  268. package/dist/{HashSet-6257b66d.cjs.prod.js → HashSet-ac02a3e1.cjs.prod.js} +32 -32
  269. package/dist/Option-463b42e6.cjs.dev.js +81 -0
  270. package/dist/Option-935e5d7c.cjs.prod.js +81 -0
  271. package/dist/{Ref-a3a4e50d.cjs.prod.js → Ref-4014b526.cjs.prod.js} +1 -1
  272. package/dist/{Ref-74b592a4.cjs.dev.js → Ref-acdee7ef.cjs.dev.js} +1 -1
  273. package/dist/{cache-75fbef45.cjs.prod.js → cache-5c7d77e4.cjs.prod.js} +17 -17
  274. package/dist/{cache-e1ea3923.cjs.dev.js → cache-7eed9d33.cjs.dev.js} +17 -17
  275. package/dist/{circular-6f16b226.cjs.prod.js → circular-1f481ffb.cjs.prod.js} +33 -33
  276. package/dist/{circular-f406f9a4.cjs.prod.js → circular-9e10a5a7.cjs.prod.js} +6 -6
  277. package/dist/{circular-58ff5e9c.cjs.dev.js → circular-c2dbce1a.cjs.dev.js} +33 -33
  278. package/dist/{circular-30564534.cjs.dev.js → circular-c8b65bdb.cjs.dev.js} +6 -6
  279. package/dist/{config-80900693.cjs.dev.js → config-3b7935a3.cjs.dev.js} +3 -3
  280. package/dist/{config-d0ddc159.cjs.prod.js → config-5ba54da1.cjs.prod.js} +3 -3
  281. package/dist/{configProvider-93617d6d.cjs.prod.js → configProvider-b6b20998.cjs.prod.js} +29 -29
  282. package/dist/{configProvider-ce43fdbf.cjs.dev.js → configProvider-f34a82f1.cjs.dev.js} +29 -29
  283. package/dist/{core-0b0539de.cjs.prod.js → core-07202cc0.cjs.prod.js} +711 -726
  284. package/dist/{core-60ca562a.cjs.prod.js → core-7411d1e1.cjs.prod.js} +3 -3
  285. package/dist/{core-b4d7b4f5.cjs.dev.js → core-b7401357.cjs.dev.js} +711 -726
  286. package/dist/{core-13f8a866.cjs.dev.js → core-c5747f88.cjs.dev.js} +3 -3
  287. package/dist/{core-effect-892f3686.cjs.dev.js → core-effect-1c564d42.cjs.dev.js} +77 -75
  288. package/dist/{core-effect-c65770cd.cjs.prod.js → core-effect-9201ea63.cjs.prod.js} +77 -75
  289. package/dist/{dataSource-3ba9e4d3.cjs.dev.js → dataSource-b5eda714.cjs.dev.js} +2 -2
  290. package/dist/{dataSource-7df3a5f6.cjs.prod.js → dataSource-b83bc277.cjs.prod.js} +2 -2
  291. package/dist/declarations/src/Bigint.d.ts +92 -1
  292. package/dist/declarations/src/Bigint.d.ts.map +1 -1
  293. package/dist/declarations/src/Boolean.d.ts +1 -1
  294. package/dist/declarations/src/Cause.d.ts +6 -6
  295. package/dist/declarations/src/Cause.d.ts.map +1 -1
  296. package/dist/declarations/src/Channel.d.ts +7 -7
  297. package/dist/declarations/src/Channel.d.ts.map +1 -1
  298. package/dist/declarations/src/Data.d.ts +30 -0
  299. package/dist/declarations/src/Data.d.ts.map +1 -1
  300. package/dist/declarations/src/Effect.d.ts +4 -2
  301. package/dist/declarations/src/Effect.d.ts.map +1 -1
  302. package/dist/declarations/src/Effectable.d.ts +14 -4
  303. package/dist/declarations/src/Effectable.d.ts.map +1 -1
  304. package/dist/declarations/src/Metric.d.ts +31 -7
  305. package/dist/declarations/src/Metric.d.ts.map +1 -1
  306. package/dist/declarations/src/MetricHook.d.ts +7 -4
  307. package/dist/declarations/src/MetricHook.d.ts.map +1 -1
  308. package/dist/declarations/src/MetricKey.d.ts +24 -4
  309. package/dist/declarations/src/MetricKey.d.ts.map +1 -1
  310. package/dist/declarations/src/MetricKeyType.d.ts +9 -6
  311. package/dist/declarations/src/MetricKeyType.d.ts.map +1 -1
  312. package/dist/declarations/src/MetricRegistry.d.ts +2 -2
  313. package/dist/declarations/src/MetricRegistry.d.ts.map +1 -1
  314. package/dist/declarations/src/MetricState.d.ts +15 -9
  315. package/dist/declarations/src/MetricState.d.ts.map +1 -1
  316. package/dist/declarations/src/Number.d.ts +1 -1
  317. package/dist/declarations/src/{Hub.d.ts → PubSub.d.ts} +38 -38
  318. package/dist/declarations/src/PubSub.d.ts.map +1 -0
  319. package/dist/declarations/src/Sink.d.ts +4 -4
  320. package/dist/declarations/src/Sink.d.ts.map +1 -1
  321. package/dist/declarations/src/Stream.d.ts +24 -24
  322. package/dist/declarations/src/Stream.d.ts.map +1 -1
  323. package/dist/declarations/src/Streamable.d.ts +27 -0
  324. package/dist/declarations/src/Streamable.d.ts.map +1 -0
  325. package/dist/declarations/src/String.d.ts +1 -1
  326. package/dist/declarations/src/SubscriptionRef.d.ts.map +1 -1
  327. package/dist/declarations/src/TPubSub.d.ts +146 -0
  328. package/dist/declarations/src/TPubSub.d.ts.map +1 -0
  329. package/dist/declarations/src/index.d.ts +15 -15
  330. package/dist/declarations/src/index.d.ts.map +1 -1
  331. package/dist/{defaultServices-5530ff0e.cjs.dev.js → defaultServices-755d5b46.cjs.dev.js} +6 -6
  332. package/dist/{defaultServices-086b8ac9.cjs.prod.js → defaultServices-9d7ce86f.cjs.prod.js} +6 -6
  333. package/dist/effect.cjs.dev.js +9 -9
  334. package/dist/effect.cjs.mjs +3 -3
  335. package/dist/effect.cjs.prod.js +9 -9
  336. package/dist/effect.esm.js +6 -6
  337. package/dist/{fiber-1bfb4c1d.cjs.dev.js → fiber-5156eff2.cjs.dev.js} +12 -12
  338. package/dist/{fiber-2eb0a4c1.cjs.prod.js → fiber-9519d109.cjs.prod.js} +12 -12
  339. package/dist/{fiberRefs-be6b6a70.cjs.prod.js → fiberRefs-558c17e6.cjs.prod.js} +1 -1
  340. package/dist/{fiberRefs-be4fae6a.cjs.dev.js → fiberRefs-98b71233.cjs.dev.js} +1 -1
  341. package/dist/{fiberRuntime-2d31e120.cjs.prod.js → fiberRuntime-31ae011f.cjs.prod.js} +99 -100
  342. package/dist/{fiberRuntime-c7280769.cjs.dev.js → fiberRuntime-d3872282.cjs.dev.js} +99 -100
  343. package/dist/{groupBy-0702739b.cjs.prod.js → groupBy-724f64ef.cjs.prod.js} +4 -4
  344. package/dist/{groupBy-7f852bf3.cjs.dev.js → groupBy-862cc2da.cjs.dev.js} +4 -4
  345. package/dist/{hook-e72b20fd.cjs.dev.js → hook-8cefc909.cjs.dev.js} +8 -4
  346. package/dist/{hook-470b717e.cjs.prod.js → hook-98ce30e4.cjs.prod.js} +8 -4
  347. package/dist/{key-f0a1408a.cjs.dev.js → key-198b6670.cjs.dev.js} +3 -3
  348. package/dist/{key-378a6a2c.cjs.prod.js → key-eb8a12b2.cjs.prod.js} +3 -3
  349. package/dist/{keyType-cf67c69c.cjs.prod.js → keyType-0c5e6178.cjs.prod.js} +9 -2
  350. package/dist/{keyType-55f27f07.cjs.dev.js → keyType-7c164b82.cjs.dev.js} +9 -2
  351. package/dist/{layer-b42e8022.cjs.dev.js → layer-29574350.cjs.dev.js} +33 -33
  352. package/dist/{layer-d103b49b.cjs.prod.js → layer-51ff4846.cjs.prod.js} +33 -33
  353. package/dist/{patch-a1b2802f.cjs.dev.js → patch-0220a642.cjs.dev.js} +1 -1
  354. package/dist/{patch-c4d6c61e.cjs.prod.js → patch-7c559bb2.cjs.prod.js} +1 -1
  355. package/dist/{pathPatch-15c8d723.cjs.prod.js → pathPatch-b56a4da2.cjs.prod.js} +1 -1
  356. package/dist/{pathPatch-d9d41297.cjs.dev.js → pathPatch-fab016f1.cjs.dev.js} +1 -1
  357. package/dist/{pool-ef44ba82.cjs.dev.js → pool-3211287f.cjs.dev.js} +31 -31
  358. package/dist/{pool-e414eb88.cjs.prod.js → pool-f77d7705.cjs.prod.js} +31 -31
  359. package/dist/{query-1d0157db.cjs.prod.js → query-a52b25f0.cjs.prod.js} +11 -11
  360. package/dist/{query-54337864.cjs.dev.js → query-c36decd5.cjs.dev.js} +11 -11
  361. package/dist/{queue-27ac9d98.cjs.prod.js → queue-315ea45d.cjs.prod.js} +22 -22
  362. package/dist/{queue-533d70d4.cjs.dev.js → queue-7a223c44.cjs.dev.js} +22 -22
  363. package/dist/{registry-1099de3f.cjs.dev.js → registry-62ff192e.cjs.dev.js} +4 -4
  364. package/dist/{registry-013ecdde.cjs.prod.js → registry-d5258dff.cjs.prod.js} +4 -4
  365. package/dist/{runtime-ea174155.cjs.prod.js → runtime-005f8a9b.cjs.prod.js} +7 -7
  366. package/dist/{runtime-afad6a9b.cjs.dev.js → runtime-57c8ddf8.cjs.dev.js} +7 -7
  367. package/dist/{schedule-1d92198c.cjs.prod.js → schedule-8cdf6bf1.cjs.prod.js} +40 -40
  368. package/dist/{schedule-e0f55cab.cjs.dev.js → schedule-e7a9f93f.cjs.dev.js} +40 -40
  369. package/dist/scopedRef-789d7fef.cjs.prod.js +55 -0
  370. package/dist/scopedRef-eb19c7a6.cjs.dev.js +55 -0
  371. package/dist/{singleProducerAsyncInput-4105a342.cjs.dev.js → singleProducerAsyncInput-9ff8389b.cjs.dev.js} +1 -1
  372. package/dist/{singleProducerAsyncInput-21463e16.cjs.prod.js → singleProducerAsyncInput-f9b258b1.cjs.prod.js} +1 -1
  373. package/dist/{sink-9129504b.cjs.prod.js → sink-572d8981.cjs.prod.js} +17 -17
  374. package/dist/{sink-ee393b63.cjs.dev.js → sink-8d3427e7.cjs.dev.js} +17 -17
  375. package/dist/{state-dd1bd066.cjs.prod.js → state-0bdf02b7.cjs.prod.js} +2 -6
  376. package/dist/{state-8fbec044.cjs.dev.js → state-931050c4.cjs.dev.js} +2 -6
  377. package/dist/{stm-537da66b.cjs.dev.js → stm-8aca0022.cjs.dev.js} +3 -3
  378. package/dist/{stm-5043c3cb.cjs.prod.js → stm-f250b596.cjs.prod.js} +3 -3
  379. package/dist/{stream-c7eda5bc.cjs.dev.js → stream-34d80d2c.cjs.dev.js} +31 -28
  380. package/dist/{stream-13637643.cjs.prod.js → stream-ea4f4d44.cjs.prod.js} +31 -28
  381. package/dist/{synchronizedRef-37e32854.cjs.dev.js → synchronizedRef-a12fd967.cjs.dev.js} +6 -6
  382. package/dist/{synchronizedRef-b4cde4de.cjs.prod.js → synchronizedRef-ed8aa6ac.cjs.prod.js} +6 -6
  383. package/dist/{tArray-df1bae1c.cjs.dev.js → tArray-17f078f2.cjs.dev.js} +3 -3
  384. package/dist/{tArray-d5476a2d.cjs.prod.js → tArray-d184e22f.cjs.prod.js} +3 -3
  385. package/dist/{tMap-a3e14c05.cjs.dev.js → tMap-1a5aa78b.cjs.dev.js} +4 -4
  386. package/dist/{tMap-20ef43ea.cjs.prod.js → tMap-e219f30e.cjs.prod.js} +4 -4
  387. package/dist/{tQueue-bd3cf539.cjs.dev.js → tQueue-0a4fc773.cjs.dev.js} +3 -3
  388. package/dist/{tQueue-c02c22bd.cjs.prod.js → tQueue-47129ad0.cjs.prod.js} +3 -3
  389. package/dist/{tRef-49e44dde.cjs.prod.js → tRef-ab4c5713.cjs.prod.js} +1 -1
  390. package/dist/{tRef-75dd04b3.cjs.dev.js → tRef-b860ef05.cjs.dev.js} +1 -1
  391. package/internal/Context.esm.js +4 -4
  392. package/internal/Data.esm.js +4 -1
  393. package/internal/Differ/ChunkPatch.esm.js +1 -1
  394. package/internal/Differ/ContextPatch.esm.js +1 -1
  395. package/internal/Differ/HashMapPatch.esm.js +1 -1
  396. package/internal/Differ/HashSetPatch.esm.js +1 -1
  397. package/internal/Differ/OrPatch.esm.js +1 -1
  398. package/internal/Effectable.esm.js +9 -9
  399. package/internal/Either.esm.js +3 -3
  400. package/internal/Option.esm.js +3 -3
  401. package/internal/cache.esm.js +1 -1
  402. package/internal/cause.esm.js +6 -21
  403. package/internal/channel.esm.js +5 -5
  404. package/internal/core-effect.esm.js +6 -4
  405. package/internal/fiberRuntime.esm.js +3 -3
  406. package/internal/layer.esm.js +1 -1
  407. package/internal/metric/hook.esm.js +7 -3
  408. package/internal/metric/key.esm.js +2 -2
  409. package/internal/metric/keyType.esm.js +9 -2
  410. package/internal/metric/registry.esm.js +2 -2
  411. package/internal/metric/state.esm.js +2 -6
  412. package/internal/metric.esm.js +3 -3
  413. package/internal/{hub.esm.js → pubsub.esm.js} +108 -108
  414. package/internal/request.esm.js +1 -1
  415. package/internal/sink.esm.js +8 -8
  416. package/internal/stm/{tHub.esm.js → tPubSub.esm.js} +30 -30
  417. package/internal/stream.esm.js +23 -20
  418. package/internal/subscriptionRef.esm.js +8 -8
  419. package/package.json +66 -211
  420. package/src/.index.ts +30 -0
  421. package/src/Bigint.ts +497 -0
  422. package/src/Boolean.ts +261 -0
  423. package/src/Brand.ts +336 -0
  424. package/src/Cache.ts +250 -0
  425. package/src/Cause.ts +813 -0
  426. package/src/Channel.ts +2244 -0
  427. package/src/ChannelChildExecutorDecision.ts +138 -0
  428. package/src/ChannelMergeDecision.ts +94 -0
  429. package/src/ChannelMergeState.ts +166 -0
  430. package/src/ChannelMergeStrategy.ts +107 -0
  431. package/src/ChannelSingleProducerAsyncInput.ts +68 -0
  432. package/src/ChannelUpstreamPullRequest.ts +110 -0
  433. package/src/ChannelUpstreamPullStrategy.ts +120 -0
  434. package/src/Chunk.ts +1314 -0
  435. package/src/Clock.ts +111 -0
  436. package/src/Config.ts +447 -0
  437. package/src/ConfigError.ts +267 -0
  438. package/src/ConfigProvider.ts +296 -0
  439. package/src/ConfigProviderPathPatch.ts +100 -0
  440. package/src/ConfigSecret.ts +76 -0
  441. package/src/Console.ts +222 -0
  442. package/src/Context.ts +365 -0
  443. package/src/Data.ts +367 -0
  444. package/src/DefaultServices.ts +34 -0
  445. package/src/Deferred.ts +283 -0
  446. package/src/Differ.ts +406 -0
  447. package/src/Duration.ts +558 -0
  448. package/src/Effect.ts +5177 -0
  449. package/src/Effectable.ts +107 -0
  450. package/src/Either.ts +593 -0
  451. package/src/Encoding.ts +130 -0
  452. package/src/Equal.ts +64 -0
  453. package/src/Equivalence.ts +235 -0
  454. package/src/ExecutionStrategy.ts +111 -0
  455. package/src/Exit.ts +464 -0
  456. package/src/Fiber.ts +650 -0
  457. package/src/FiberId.ts +187 -0
  458. package/src/FiberRef.ts +399 -0
  459. package/src/FiberRefs.ts +160 -0
  460. package/src/FiberRefsPatch.ts +105 -0
  461. package/src/FiberStatus.ts +108 -0
  462. package/src/Function.ts +834 -0
  463. package/src/GlobalValue.ts +20 -0
  464. package/src/GroupBy.ts +102 -0
  465. package/src/HKT.ts +44 -0
  466. package/src/Hash.ts +162 -0
  467. package/src/HashMap.ts +373 -0
  468. package/src/HashSet.ts +300 -0
  469. package/src/Inspectable.ts +45 -0
  470. package/src/KeyedPool.ts +160 -0
  471. package/src/Layer.ts +866 -0
  472. package/src/List.ts +942 -0
  473. package/src/LogLevel.ts +266 -0
  474. package/src/LogSpan.ts +25 -0
  475. package/src/Logger.ts +321 -0
  476. package/src/Metric.ts +657 -0
  477. package/src/MetricBoundaries.ts +70 -0
  478. package/src/MetricHook.ts +139 -0
  479. package/src/MetricKey.ts +227 -0
  480. package/src/MetricKeyType.ts +257 -0
  481. package/src/MetricLabel.ts +47 -0
  482. package/src/MetricPair.ts +70 -0
  483. package/src/MetricPolling.ts +136 -0
  484. package/src/MetricRegistry.ts +47 -0
  485. package/src/MetricState.ts +256 -0
  486. package/src/MutableHashMap.ts +187 -0
  487. package/src/MutableHashSet.ts +118 -0
  488. package/src/MutableList.ts +289 -0
  489. package/src/MutableQueue.ts +227 -0
  490. package/src/MutableRef.ts +204 -0
  491. package/src/NonEmptyIterable.ts +30 -0
  492. package/src/Number.ts +406 -0
  493. package/src/Option.ts +1307 -0
  494. package/src/Order.ts +328 -0
  495. package/src/Ordering.ts +112 -0
  496. package/src/Pipeable.ts +318 -0
  497. package/src/Pool.ts +148 -0
  498. package/src/Predicate.ts +704 -0
  499. package/src/PubSub.ts +175 -0
  500. package/src/Queue.ts +575 -0
  501. package/src/Random.ts +115 -0
  502. package/src/ReadonlyArray.ts +2017 -0
  503. package/src/ReadonlyRecord.ts +641 -0
  504. package/src/RedBlackTree.ts +415 -0
  505. package/src/Ref.ts +159 -0
  506. package/src/Reloadable.ts +136 -0
  507. package/src/Request.ts +285 -0
  508. package/src/RequestBlock.ts +157 -0
  509. package/src/RequestResolver.ts +305 -0
  510. package/src/Resource.ts +97 -0
  511. package/src/Runtime.ts +216 -0
  512. package/src/RuntimeFlags.ts +336 -0
  513. package/src/RuntimeFlagsPatch.ts +183 -0
  514. package/src/STM.ts +2076 -0
  515. package/src/Schedule.ts +1396 -0
  516. package/src/ScheduleDecision.ts +62 -0
  517. package/src/ScheduleInterval.ts +151 -0
  518. package/src/ScheduleIntervals.ts +122 -0
  519. package/src/Scheduler.ts +359 -0
  520. package/src/Scope.ts +171 -0
  521. package/src/ScopedCache.ts +148 -0
  522. package/src/ScopedRef.ts +95 -0
  523. package/src/Sink.ts +1431 -0
  524. package/src/SortedMap.ts +229 -0
  525. package/src/SortedSet.ts +385 -0
  526. package/src/Stream.ts +4540 -0
  527. package/src/StreamEmit.ts +83 -0
  528. package/src/StreamHaltStrategy.ts +111 -0
  529. package/src/Streamable.ts +42 -0
  530. package/src/String.ts +682 -0
  531. package/src/Struct.ts +151 -0
  532. package/src/SubscriptionRef.ts +273 -0
  533. package/src/Supervisor.ts +239 -0
  534. package/src/Symbol.ts +28 -0
  535. package/src/SynchronizedRef.ts +249 -0
  536. package/src/TArray.ts +494 -0
  537. package/src/TDeferred.ts +99 -0
  538. package/src/TMap.ts +510 -0
  539. package/src/TPriorityQueue.ts +223 -0
  540. package/src/TPubSub.ts +187 -0
  541. package/src/TQueue.ts +431 -0
  542. package/src/TRandom.ts +129 -0
  543. package/src/TReentrantLock.ts +224 -0
  544. package/src/TRef.ts +176 -0
  545. package/src/TSemaphore.ts +129 -0
  546. package/src/TSet.ts +349 -0
  547. package/src/Take.ts +257 -0
  548. package/src/TestAnnotation.ts +166 -0
  549. package/src/TestAnnotationMap.ts +124 -0
  550. package/src/TestAnnotations.ts +113 -0
  551. package/src/TestClock.ts +552 -0
  552. package/src/TestConfig.ts +49 -0
  553. package/src/TestContext.ts +35 -0
  554. package/src/TestLive.ts +55 -0
  555. package/src/TestServices.ts +392 -0
  556. package/src/TestSized.ts +55 -0
  557. package/src/Tracer.ts +119 -0
  558. package/src/Tuple.ts +204 -0
  559. package/src/Types.ts +123 -0
  560. package/src/Unify.ts +118 -0
  561. package/src/Utils.ts +699 -0
  562. package/src/index.ts +840 -0
  563. package/src/internal/Common.ts +56 -0
  564. package/src/internal/Context.ts +252 -0
  565. package/src/internal/Data.ts +55 -0
  566. package/src/internal/Differ/ChunkPatch.ts +209 -0
  567. package/src/internal/Differ/ContextPatch.ts +229 -0
  568. package/src/internal/Differ/HashMapPatch.ts +217 -0
  569. package/src/internal/Differ/HashSetPatch.ts +174 -0
  570. package/src/internal/Differ/OrPatch.ts +296 -0
  571. package/src/internal/Differ.ts +184 -0
  572. package/src/internal/Effectable.ts +92 -0
  573. package/src/internal/Either.ts +107 -0
  574. package/src/internal/Encoding/Base64.ts +282 -0
  575. package/src/internal/Encoding/Base64Url.ts +28 -0
  576. package/src/internal/Encoding/Common.ts +24 -0
  577. package/src/internal/Encoding/Hex.ts +315 -0
  578. package/src/internal/HashMap/array.ts +49 -0
  579. package/src/internal/HashMap/bitwise.ts +32 -0
  580. package/src/internal/HashMap/config.ts +14 -0
  581. package/src/internal/HashMap/keySet.ts +8 -0
  582. package/src/internal/HashMap/node.ts +390 -0
  583. package/src/internal/HashMap.ts +533 -0
  584. package/src/internal/HashSet.ts +319 -0
  585. package/src/internal/Iterable.ts +54 -0
  586. package/src/internal/Option.ts +79 -0
  587. package/src/internal/ReadonlyArray.ts +8 -0
  588. package/src/internal/RedBlackTree/iterator.ts +207 -0
  589. package/src/internal/RedBlackTree/node.ts +48 -0
  590. package/src/internal/RedBlackTree.ts +1195 -0
  591. package/src/internal/Stack.ts +4 -0
  592. package/src/internal/blockedRequests.ts +512 -0
  593. package/src/internal/cache.ts +714 -0
  594. package/src/internal/cause.ts +1205 -0
  595. package/src/internal/channel/channelExecutor.ts +1193 -0
  596. package/src/internal/channel/channelState.ts +132 -0
  597. package/src/internal/channel/childExecutorDecision.ts +95 -0
  598. package/src/internal/channel/continuation.ts +171 -0
  599. package/src/internal/channel/mergeDecision.ts +115 -0
  600. package/src/internal/channel/mergeState.ts +120 -0
  601. package/src/internal/channel/mergeStrategy.ts +72 -0
  602. package/src/internal/channel/singleProducerAsyncInput.ts +261 -0
  603. package/src/internal/channel/subexecutor.ts +229 -0
  604. package/src/internal/channel/upstreamPullRequest.ts +83 -0
  605. package/src/internal/channel/upstreamPullStrategy.ts +86 -0
  606. package/src/internal/channel.ts +2516 -0
  607. package/src/internal/clock.ts +97 -0
  608. package/src/internal/completedRequestMap.ts +9 -0
  609. package/src/internal/concurrency.ts +83 -0
  610. package/src/internal/config.ts +598 -0
  611. package/src/internal/configError.ts +291 -0
  612. package/src/internal/configProvider/pathPatch.ts +97 -0
  613. package/src/internal/configProvider.ts +692 -0
  614. package/src/internal/configSecret.ts +71 -0
  615. package/src/internal/console.ts +136 -0
  616. package/src/internal/core-effect.ts +2146 -0
  617. package/src/internal/core-stream.ts +999 -0
  618. package/src/internal/core.ts +2765 -0
  619. package/src/internal/dataSource.ts +258 -0
  620. package/src/internal/defaultServices/console.ts +97 -0
  621. package/src/internal/defaultServices.ts +140 -0
  622. package/src/internal/deferred.ts +44 -0
  623. package/src/internal/effect/circular.ts +664 -0
  624. package/src/internal/executionStrategy.ts +72 -0
  625. package/src/internal/fiber.ts +350 -0
  626. package/src/internal/fiberId.ts +270 -0
  627. package/src/internal/fiberMessage.ts +85 -0
  628. package/src/internal/fiberRefs/patch.ts +144 -0
  629. package/src/internal/fiberRefs.ts +239 -0
  630. package/src/internal/fiberRuntime.ts +3477 -0
  631. package/src/internal/fiberScope.ts +72 -0
  632. package/src/internal/fiberStatus.ts +118 -0
  633. package/src/internal/groupBy.ts +516 -0
  634. package/src/internal/keyedPool.ts +240 -0
  635. package/src/internal/layer/circular.ts +203 -0
  636. package/src/internal/layer.ts +1230 -0
  637. package/src/internal/logSpan.ts +15 -0
  638. package/src/internal/logger-circular.ts +24 -0
  639. package/src/internal/logger.ts +307 -0
  640. package/src/internal/metric/boundaries.ts +72 -0
  641. package/src/internal/metric/hook.ts +459 -0
  642. package/src/internal/metric/key.ts +173 -0
  643. package/src/internal/metric/keyType.ts +263 -0
  644. package/src/internal/metric/label.ts +44 -0
  645. package/src/internal/metric/pair.ts +48 -0
  646. package/src/internal/metric/polling.ts +143 -0
  647. package/src/internal/metric/registry.ts +188 -0
  648. package/src/internal/metric/state.ts +286 -0
  649. package/src/internal/metric.ts +522 -0
  650. package/src/internal/opCodes/cause.ts +35 -0
  651. package/src/internal/opCodes/channel.ts +83 -0
  652. package/src/internal/opCodes/channelChildExecutorDecision.ts +17 -0
  653. package/src/internal/opCodes/channelMergeDecision.ts +11 -0
  654. package/src/internal/opCodes/channelMergeState.ts +17 -0
  655. package/src/internal/opCodes/channelMergeStrategy.ts +11 -0
  656. package/src/internal/opCodes/channelState.ts +23 -0
  657. package/src/internal/opCodes/channelUpstreamPullRequest.ts +11 -0
  658. package/src/internal/opCodes/channelUpstreamPullStrategy.ts +11 -0
  659. package/src/internal/opCodes/config.ts +65 -0
  660. package/src/internal/opCodes/configError.ts +35 -0
  661. package/src/internal/opCodes/continuation.ts +11 -0
  662. package/src/internal/opCodes/deferred.ts +11 -0
  663. package/src/internal/opCodes/effect.ts +83 -0
  664. package/src/internal/opCodes/layer.ts +53 -0
  665. package/src/internal/opCodes/streamHaltStrategy.ts +23 -0
  666. package/src/internal/pool.ts +499 -0
  667. package/src/internal/pubsub.ts +1557 -0
  668. package/src/internal/query.ts +199 -0
  669. package/src/internal/queue.ts +729 -0
  670. package/src/internal/random.ts +88 -0
  671. package/src/internal/ref.ts +164 -0
  672. package/src/internal/reloadable.ts +164 -0
  673. package/src/internal/request.ts +137 -0
  674. package/src/internal/resource.ts +64 -0
  675. package/src/internal/ringBuffer.ts +68 -0
  676. package/src/internal/runtime.ts +348 -0
  677. package/src/internal/runtimeFlags.ts +176 -0
  678. package/src/internal/runtimeFlagsPatch.ts +103 -0
  679. package/src/internal/schedule/decision.ts +47 -0
  680. package/src/internal/schedule/interval.ts +101 -0
  681. package/src/internal/schedule/intervals.ts +179 -0
  682. package/src/internal/schedule.ts +2096 -0
  683. package/src/internal/scopedCache.ts +634 -0
  684. package/src/internal/scopedRef.ts +133 -0
  685. package/src/internal/singleShotGen.ts +35 -0
  686. package/src/internal/sink.ts +2118 -0
  687. package/src/internal/stm/core.ts +804 -0
  688. package/src/internal/stm/opCodes/stm.ts +71 -0
  689. package/src/internal/stm/opCodes/stmState.ts +17 -0
  690. package/src/internal/stm/opCodes/strategy.ts +17 -0
  691. package/src/internal/stm/opCodes/tExit.ts +29 -0
  692. package/src/internal/stm/opCodes/tryCommit.ts +11 -0
  693. package/src/internal/stm/stm/entry.ts +59 -0
  694. package/src/internal/stm/stm/journal.ts +123 -0
  695. package/src/internal/stm/stm/opCodes/stm.ts +71 -0
  696. package/src/internal/stm/stm/opCodes/stmState.ts +17 -0
  697. package/src/internal/stm/stm/opCodes/strategy.ts +17 -0
  698. package/src/internal/stm/stm/opCodes/tExit.ts +29 -0
  699. package/src/internal/stm/stm/opCodes/tryCommit.ts +11 -0
  700. package/src/internal/stm/stm/stmState.ts +130 -0
  701. package/src/internal/stm/stm/tExit.ts +180 -0
  702. package/src/internal/stm/stm/tryCommit.ts +34 -0
  703. package/src/internal/stm/stm/txnId.ts +14 -0
  704. package/src/internal/stm/stm/versioned.ts +4 -0
  705. package/src/internal/stm/stm.ts +1491 -0
  706. package/src/internal/stm/tArray.ts +550 -0
  707. package/src/internal/stm/tDeferred.ts +79 -0
  708. package/src/internal/stm/tMap.ts +824 -0
  709. package/src/internal/stm/tPriorityQueue.ts +259 -0
  710. package/src/internal/stm/tPubSub.ts +542 -0
  711. package/src/internal/stm/tQueue.ts +400 -0
  712. package/src/internal/stm/tRandom.ts +140 -0
  713. package/src/internal/stm/tReentrantLock.ts +352 -0
  714. package/src/internal/stm/tRef.ts +190 -0
  715. package/src/internal/stm/tSemaphore.ts +113 -0
  716. package/src/internal/stm/tSet.ts +237 -0
  717. package/src/internal/stream/debounceState.ts +57 -0
  718. package/src/internal/stream/emit.ts +46 -0
  719. package/src/internal/stream/haltStrategy.ts +85 -0
  720. package/src/internal/stream/handoff.ts +185 -0
  721. package/src/internal/stream/handoffSignal.ts +59 -0
  722. package/src/internal/stream/pull.ts +35 -0
  723. package/src/internal/stream/sinkEndReason.ts +30 -0
  724. package/src/internal/stream/zipAllState.ts +88 -0
  725. package/src/internal/stream/zipChunksState.ts +56 -0
  726. package/src/internal/stream.ts +8089 -0
  727. package/src/internal/string-utils.ts +107 -0
  728. package/src/internal/subscriptionRef.ts +133 -0
  729. package/src/internal/supervisor/patch.ts +190 -0
  730. package/src/internal/supervisor.ts +301 -0
  731. package/src/internal/synchronizedRef.ts +115 -0
  732. package/src/internal/take.ts +198 -0
  733. package/src/internal/testing/sleep.ts +27 -0
  734. package/src/internal/testing/suspendedWarningData.ts +85 -0
  735. package/src/internal/testing/warningData.ts +94 -0
  736. package/src/internal/timeout.ts +23 -0
  737. package/src/internal/tracer.ts +74 -0
  738. package/Error/dist/effect-Error.cjs.d.mts +0 -2
  739. package/Error/dist/effect-Error.cjs.d.mts.map +0 -1
  740. package/Error/dist/effect-Error.cjs.d.ts +0 -2
  741. package/Error/dist/effect-Error.cjs.d.ts.map +0 -1
  742. package/Error/dist/effect-Error.cjs.dev.js +0 -140
  743. package/Error/dist/effect-Error.cjs.js +0 -7
  744. package/Error/dist/effect-Error.cjs.mjs +0 -4
  745. package/Error/dist/effect-Error.cjs.prod.js +0 -140
  746. package/Error/dist/effect-Error.esm.js +0 -47
  747. package/Error/package.json +0 -4
  748. package/Hub/dist/effect-Hub.cjs.d.mts +0 -2
  749. package/Hub/dist/effect-Hub.cjs.d.mts.map +0 -1
  750. package/Hub/dist/effect-Hub.cjs.d.ts +0 -2
  751. package/Hub/dist/effect-Hub.cjs.d.ts.map +0 -1
  752. package/Hub/dist/effect-Hub.cjs.js +0 -7
  753. package/Hub/package.json +0 -4
  754. package/THub/dist/effect-THub.cjs.d.mts +0 -2
  755. package/THub/dist/effect-THub.cjs.d.mts.map +0 -1
  756. package/THub/dist/effect-THub.cjs.d.ts +0 -2
  757. package/THub/dist/effect-THub.cjs.d.ts.map +0 -1
  758. package/THub/dist/effect-THub.cjs.js +0 -7
  759. package/THub/dist/effect-THub.esm.js +0 -157
  760. package/THub/package.json +0 -4
  761. package/dist/declarations/src/Error.d.ts +0 -37
  762. package/dist/declarations/src/Error.d.ts.map +0 -1
  763. package/dist/declarations/src/Hub.d.ts.map +0 -1
  764. package/dist/declarations/src/THub.d.ts +0 -146
  765. package/dist/declarations/src/THub.d.ts.map +0 -1
  766. package/dist/scopedRef-1c2c9acf.cjs.prod.js +0 -55
  767. package/dist/scopedRef-ab4c58b0.cjs.dev.js +0 -55
  768. /package/dist/{FiberId-e594f6e8.cjs.prod.js → FiberId-1d7ac632.cjs.prod.js} +0 -0
  769. /package/dist/{FiberId-557db880.cjs.dev.js → FiberId-d88ddce6.cjs.dev.js} +0 -0
  770. /package/dist/{RuntimeFlagsPatch-ea268c50.cjs.dev.js → RuntimeFlagsPatch-69102b03.cjs.dev.js} +0 -0
  771. /package/dist/{RuntimeFlagsPatch-e2769b87.cjs.prod.js → RuntimeFlagsPatch-866fa259.cjs.prod.js} +0 -0
  772. /package/dist/{boundaries-20cfad9d.cjs.prod.js → boundaries-9af538e3.cjs.prod.js} +0 -0
  773. /package/dist/{boundaries-3810d885.cjs.dev.js → boundaries-f212e414.cjs.dev.js} +0 -0
  774. /package/dist/{configError-33e55472.cjs.prod.js → configError-b43723af.cjs.prod.js} +0 -0
  775. /package/dist/{configError-240e9b61.cjs.dev.js → configError-d5efe9c0.cjs.dev.js} +0 -0
  776. /package/dist/{configSecret-e34c1b14.cjs.dev.js → configSecret-3e8ae336.cjs.dev.js} +0 -0
  777. /package/dist/{configSecret-d1caca55.cjs.prod.js → configSecret-e2faa181.cjs.prod.js} +0 -0
  778. /package/dist/{take-2af6e92a.cjs.prod.js → take-85daaf79.cjs.prod.js} +0 -0
  779. /package/dist/{take-df9480a8.cjs.dev.js → take-f9ef9e2e.cjs.dev.js} +0 -0
@@ -0,0 +1,1195 @@
1
+ import * as Chunk from "../Chunk"
2
+ import * as Equal from "../Equal"
3
+ import * as Dual from "../Function"
4
+ import * as Hash from "../Hash"
5
+ import { NodeInspectSymbol, toJSON, toString } from "../Inspectable"
6
+ import { Direction, RedBlackTreeIterator } from "../internal/RedBlackTree/iterator"
7
+ import * as Node from "../internal/RedBlackTree/node"
8
+ import { Stack } from "../internal/Stack"
9
+ import * as Option from "../Option"
10
+ import type * as Order from "../Order"
11
+ import type * as Ordering from "../Ordering"
12
+ import { pipeArguments } from "../Pipeable"
13
+ import { isObject } from "../Predicate"
14
+ import type * as RBT from "../RedBlackTree"
15
+
16
+ const RedBlackTreeSymbolKey = "effect/RedBlackTree"
17
+
18
+ /** @internal */
19
+ export const RedBlackTreeTypeId: RBT.TypeId = Symbol.for(RedBlackTreeSymbolKey) as RBT.TypeId
20
+
21
+ /** @internal */
22
+ export interface RedBlackTreeImpl<K, V> extends RBT.RedBlackTree<K, V> {
23
+ readonly _ord: Order.Order<K>
24
+ readonly _root: Node.Node<K, V> | undefined
25
+ }
26
+
27
+ const RedBlackTreeProto: RBT.RedBlackTree<unknown, unknown> = {
28
+ [RedBlackTreeTypeId]: RedBlackTreeTypeId,
29
+ [Hash.symbol](): number {
30
+ return Hash.combine(Hash.hash(RedBlackTreeSymbolKey))(Hash.array(Array.from(this)))
31
+ },
32
+ [Equal.symbol]<K, V>(this: RedBlackTreeImpl<K, V>, that: unknown): boolean {
33
+ if (isRedBlackTree(that)) {
34
+ if ((this._root?.count ?? 0) !== ((that as RedBlackTreeImpl<K, V>)._root?.count ?? 0)) {
35
+ return false
36
+ }
37
+ return Equal.equals(Array.from(this), Array.from(that))
38
+ }
39
+ return false
40
+ },
41
+ [Symbol.iterator]<K, V>(this: RedBlackTreeImpl<K, V>): RedBlackTreeIterator<K, V> {
42
+ const stack: Array<Node.Node<K, V>> = []
43
+ let n = this._root
44
+ while (n != null) {
45
+ stack.push(n)
46
+ n = n.left
47
+ }
48
+ return new RedBlackTreeIterator(this, stack, Direction.Forward)
49
+ },
50
+ toString() {
51
+ return toString(this.toJSON())
52
+ },
53
+ toJSON() {
54
+ return {
55
+ _id: "RedBlackTree",
56
+ values: Array.from(this).map(toJSON)
57
+ }
58
+ },
59
+ [NodeInspectSymbol]() {
60
+ return this.toJSON()
61
+ },
62
+ pipe() {
63
+ return pipeArguments(this, arguments)
64
+ }
65
+ }
66
+
67
+ const makeImpl = <K, V>(ord: Order.Order<K>, root: Node.Node<K, V> | undefined): RedBlackTreeImpl<K, V> => {
68
+ const tree = Object.create(RedBlackTreeProto)
69
+ tree._ord = ord
70
+ tree._root = root
71
+ return tree
72
+ }
73
+
74
+ /** @internal */
75
+ export const isRedBlackTree: {
76
+ <K, V>(u: Iterable<readonly [K, V]>): u is RBT.RedBlackTree<K, V>
77
+ (u: unknown): u is RBT.RedBlackTree<unknown, unknown>
78
+ } = (u: unknown): u is RBT.RedBlackTree<unknown, unknown> => isObject(u) && RedBlackTreeTypeId in u
79
+
80
+ /** @internal */
81
+ export const empty = <K, V = never>(ord: Order.Order<K>): RBT.RedBlackTree<K, V> => makeImpl<K, V>(ord, undefined)
82
+
83
+ /** @internal */
84
+ export const fromIterable =
85
+ <K, V>(ord: Order.Order<K>) => (entries: Iterable<readonly [K, V]>): RBT.RedBlackTree<K, V> => {
86
+ let tree = empty<K, V>(ord)
87
+ for (const [key, value] of entries) {
88
+ tree = insert(tree, key, value)
89
+ }
90
+ return tree
91
+ }
92
+
93
+ /** @internal */
94
+ export const make =
95
+ <K>(ord: Order.Order<K>) =>
96
+ <Entries extends Array<readonly [K, any]>>(...entries: Entries): RBT.RedBlackTree<
97
+ K,
98
+ Entries[number] extends readonly [any, infer V] ? V : never
99
+ > => {
100
+ return fromIterable<K, Entries[number] extends readonly [any, infer V] ? V : never>(ord)(
101
+ entries
102
+ )
103
+ }
104
+
105
+ /** @internal */
106
+ export const atBackwards = Dual.dual<
107
+ (index: number) => <K, V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
108
+ <K, V>(self: RBT.RedBlackTree<K, V>, index: number) => Iterable<readonly [K, V]>
109
+ >(2, (self, index) => at(self, index, Direction.Backward))
110
+
111
+ /** @internal */
112
+ export const atForwards = Dual.dual<
113
+ (index: number) => <K, V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
114
+ <K, V>(self: RBT.RedBlackTree<K, V>, index: number) => Iterable<readonly [K, V]>
115
+ >(2, (self, index) => at(self, index, Direction.Forward))
116
+
117
+ const at = <K, V>(
118
+ self: RBT.RedBlackTree<K, V>,
119
+ index: number,
120
+ direction: RBT.RedBlackTree.Direction
121
+ ): Iterable<readonly [K, V]> => {
122
+ return {
123
+ [Symbol.iterator]: () => {
124
+ if (index < 0) {
125
+ return new RedBlackTreeIterator(self, [], direction)
126
+ }
127
+ let node = (self as RedBlackTreeImpl<K, V>)._root
128
+ const stack: Array<Node.Node<K, V>> = []
129
+ while (node !== undefined) {
130
+ stack.push(node)
131
+ if (node.left !== undefined) {
132
+ if (index < node.left.count) {
133
+ node = node.left
134
+ continue
135
+ }
136
+ index -= node.left.count
137
+ }
138
+ if (!index) {
139
+ return new RedBlackTreeIterator(self, stack, direction)
140
+ }
141
+ index -= 1
142
+ if (node.right !== undefined) {
143
+ if (index >= node.right.count) {
144
+ break
145
+ }
146
+ node = node.right
147
+ } else {
148
+ break
149
+ }
150
+ }
151
+ return new RedBlackTreeIterator(self, [], direction)
152
+ }
153
+ }
154
+ }
155
+
156
+ /** @internal */
157
+ export const findAll = Dual.dual<
158
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Chunk.Chunk<V>,
159
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Chunk.Chunk<V>
160
+ >(2, <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => {
161
+ const stack: Array<Node.Node<K, V>> = []
162
+ let node = (self as RedBlackTreeImpl<K, V>)._root
163
+ let result = Chunk.empty<V>()
164
+ while (node !== undefined || stack.length > 0) {
165
+ if (node) {
166
+ stack.push(node)
167
+ node = node.left
168
+ } else {
169
+ const current = stack.pop()!
170
+ if (Equal.equals(key, current.key)) {
171
+ result = Chunk.prepend(current.value)(result)
172
+ }
173
+ node = current.right
174
+ }
175
+ }
176
+ return result
177
+ })
178
+
179
+ /** @internal */
180
+ export const findFirst = Dual.dual<
181
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Option.Option<V>,
182
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Option.Option<V>
183
+ >(2, <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => {
184
+ const cmp = (self as RedBlackTreeImpl<K, V>)._ord
185
+ let node = (self as RedBlackTreeImpl<K, V>)._root
186
+ while (node !== undefined) {
187
+ const d = cmp(key, node.key)
188
+ if (Equal.equals(key, node.key)) {
189
+ return Option.some(node.value)
190
+ }
191
+ if (d <= 0) {
192
+ node = node.left
193
+ } else {
194
+ node = node.right
195
+ }
196
+ }
197
+ return Option.none()
198
+ })
199
+
200
+ /** @internal */
201
+ export const first = <K, V>(self: RBT.RedBlackTree<K, V>): Option.Option<readonly [K, V]> => {
202
+ let node: Node.Node<K, V> | undefined = (self as RedBlackTreeImpl<K, V>)._root
203
+ let current: Node.Node<K, V> | undefined = (self as RedBlackTreeImpl<K, V>)._root
204
+ while (node !== undefined) {
205
+ current = node
206
+ node = node.left
207
+ }
208
+ return current ? Option.some([current.key, current.value]) : Option.none()
209
+ }
210
+
211
+ /** @internal */
212
+ export const getAt = Dual.dual<
213
+ (index: number) => <K, V>(self: RBT.RedBlackTree<K, V>) => Option.Option<readonly [K, V]>,
214
+ <K, V>(self: RBT.RedBlackTree<K, V>, index: number) => Option.Option<readonly [K, V]>
215
+ >(2, <K, V>(self: RBT.RedBlackTree<K, V>, index: number) => {
216
+ if (index < 0) {
217
+ return Option.none()
218
+ }
219
+ let root = (self as RedBlackTreeImpl<K, V>)._root
220
+ let node: Node.Node<K, V> | undefined = undefined
221
+ while (root !== undefined) {
222
+ node = root
223
+ if (root.left) {
224
+ if (index < root.left.count) {
225
+ root = root.left
226
+ continue
227
+ }
228
+ index -= root.left.count
229
+ }
230
+ if (!index) {
231
+ return Option.some([node.key, node.value])
232
+ }
233
+ index -= 1
234
+ if (root.right) {
235
+ if (index >= root.right.count) {
236
+ break
237
+ }
238
+ root = root.right
239
+ } else {
240
+ break
241
+ }
242
+ }
243
+ return Option.none()
244
+ })
245
+
246
+ /** @internal */
247
+ export const getOrder = <K, V>(tree: RBT.RedBlackTree<K, V>): Order.Order<K> => (tree as RedBlackTreeImpl<K, V>)._ord
248
+
249
+ /** @internal */
250
+ export const has = Dual.dual<
251
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => boolean,
252
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => boolean
253
+ >(2, (self, key) => Option.isSome(findFirst(self, key)))
254
+
255
+ /** @internal */
256
+ export const insert = Dual.dual<
257
+ <K, V>(key: K, value: V) => (self: RBT.RedBlackTree<K, V>) => RBT.RedBlackTree<K, V>,
258
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K, value: V) => RBT.RedBlackTree<K, V>
259
+ >(3, <K, V>(self: RBT.RedBlackTree<K, V>, key: K, value: V) => {
260
+ const cmp = (self as RedBlackTreeImpl<K, V>)._ord
261
+ // Find point to insert new node at
262
+ let n: Node.Node<K, V> | undefined = (self as RedBlackTreeImpl<K, V>)._root
263
+ const n_stack: Array<Node.Node<K, V>> = []
264
+ const d_stack: Array<Ordering.Ordering> = []
265
+ while (n != null) {
266
+ const d = cmp(key, n.key)
267
+ n_stack.push(n)
268
+ d_stack.push(d)
269
+ if (d <= 0) {
270
+ n = n.left
271
+ } else {
272
+ n = n.right
273
+ }
274
+ }
275
+ // Rebuild path to leaf node
276
+ n_stack.push(new Node.Node(Node.Color.Red, key, value, undefined, undefined, 1))
277
+ for (let s = n_stack.length - 2; s >= 0; --s) {
278
+ const n2 = n_stack[s]!
279
+ if (d_stack[s]! <= 0) {
280
+ n_stack[s] = new Node.Node(
281
+ n2.color,
282
+ n2.key,
283
+ n2.value,
284
+ n_stack[s + 1],
285
+ n2.right,
286
+ n2.count + 1
287
+ )
288
+ } else {
289
+ n_stack[s] = new Node.Node(
290
+ n2.color,
291
+ n2.key,
292
+ n2.value,
293
+ n2.left,
294
+ n_stack[s + 1],
295
+ n2.count + 1
296
+ )
297
+ }
298
+ }
299
+ // Rebalance tree using rotations
300
+ for (let s = n_stack.length - 1; s > 1; --s) {
301
+ const p = n_stack[s - 1]!
302
+ const n3 = n_stack[s]!
303
+ if (p.color === Node.Color.Black || n3.color === Node.Color.Black) {
304
+ break
305
+ }
306
+ const pp = n_stack[s - 2]!
307
+ if (pp.left === p) {
308
+ if (p.left === n3) {
309
+ const y = pp.right
310
+ if (y && y.color === Node.Color.Red) {
311
+ p.color = Node.Color.Black
312
+ pp.right = Node.repaint(y, Node.Color.Black)
313
+ pp.color = Node.Color.Red
314
+ s -= 1
315
+ } else {
316
+ pp.color = Node.Color.Red
317
+ pp.left = p.right
318
+ p.color = Node.Color.Black
319
+ p.right = pp
320
+ n_stack[s - 2] = p
321
+ n_stack[s - 1] = n3
322
+ Node.recount(pp)
323
+ Node.recount(p)
324
+ if (s >= 3) {
325
+ const ppp = n_stack[s - 3]!
326
+ if (ppp.left === pp) {
327
+ ppp.left = p
328
+ } else {
329
+ ppp.right = p
330
+ }
331
+ }
332
+ break
333
+ }
334
+ } else {
335
+ const y = pp.right
336
+ if (y && y.color === Node.Color.Red) {
337
+ p.color = Node.Color.Black
338
+ pp.right = Node.repaint(y, Node.Color.Black)
339
+ pp.color = Node.Color.Red
340
+ s -= 1
341
+ } else {
342
+ p.right = n3.left
343
+ pp.color = Node.Color.Red
344
+ pp.left = n3.right
345
+ n3.color = Node.Color.Black
346
+ n3.left = p
347
+ n3.right = pp
348
+ n_stack[s - 2] = n3
349
+ n_stack[s - 1] = p
350
+ Node.recount(pp)
351
+ Node.recount(p)
352
+ Node.recount(n3)
353
+ if (s >= 3) {
354
+ const ppp = n_stack[s - 3]!
355
+ if (ppp.left === pp) {
356
+ ppp.left = n3
357
+ } else {
358
+ ppp.right = n3
359
+ }
360
+ }
361
+ break
362
+ }
363
+ }
364
+ } else {
365
+ if (p.right === n3) {
366
+ const y = pp.left
367
+ if (y && y.color === Node.Color.Red) {
368
+ p.color = Node.Color.Black
369
+ pp.left = Node.repaint(y, Node.Color.Black)
370
+ pp.color = Node.Color.Red
371
+ s -= 1
372
+ } else {
373
+ pp.color = Node.Color.Red
374
+ pp.right = p.left
375
+ p.color = Node.Color.Black
376
+ p.left = pp
377
+ n_stack[s - 2] = p
378
+ n_stack[s - 1] = n3
379
+ Node.recount(pp)
380
+ Node.recount(p)
381
+ if (s >= 3) {
382
+ const ppp = n_stack[s - 3]!
383
+ if (ppp.right === pp) {
384
+ ppp.right = p
385
+ } else {
386
+ ppp.left = p
387
+ }
388
+ }
389
+ break
390
+ }
391
+ } else {
392
+ const y = pp.left
393
+ if (y && y.color === Node.Color.Red) {
394
+ p.color = Node.Color.Black
395
+ pp.left = Node.repaint(y, Node.Color.Black)
396
+ pp.color = Node.Color.Red
397
+ s -= 1
398
+ } else {
399
+ p.left = n3.right
400
+ pp.color = Node.Color.Red
401
+ pp.right = n3.left
402
+ n3.color = Node.Color.Black
403
+ n3.right = p
404
+ n3.left = pp
405
+ n_stack[s - 2] = n3
406
+ n_stack[s - 1] = p
407
+ Node.recount(pp)
408
+ Node.recount(p)
409
+ Node.recount(n3)
410
+ if (s >= 3) {
411
+ const ppp = n_stack[s - 3]!
412
+ if (ppp.right === pp) {
413
+ ppp.right = n3
414
+ } else {
415
+ ppp.left = n3
416
+ }
417
+ }
418
+ break
419
+ }
420
+ }
421
+ }
422
+ }
423
+ // Return new tree
424
+ n_stack[0]!.color = Node.Color.Black
425
+ return makeImpl((self as RedBlackTreeImpl<K, V>)._ord, n_stack[0])
426
+ })
427
+
428
+ /** @internal */
429
+ export const keysForward = <K, V>(self: RBT.RedBlackTree<K, V>): IterableIterator<K> => keys(self, Direction.Forward)
430
+
431
+ /** @internal */
432
+ export const keysBackward = <K, V>(self: RBT.RedBlackTree<K, V>): IterableIterator<K> => keys(self, Direction.Backward)
433
+
434
+ const keys = <K, V>(
435
+ self: RBT.RedBlackTree<K, V>,
436
+ direction: RBT.RedBlackTree.Direction
437
+ ): IterableIterator<K> => {
438
+ const begin: RedBlackTreeIterator<K, V> = self[Symbol.iterator]() as RedBlackTreeIterator<K, V>
439
+ let count = 0
440
+ return {
441
+ [Symbol.iterator]: () => keys(self, direction),
442
+ next: (): IteratorResult<K, number> => {
443
+ count++
444
+ const entry = begin.key
445
+ if (direction === Direction.Forward) {
446
+ begin.moveNext()
447
+ } else {
448
+ begin.movePrev()
449
+ }
450
+ switch (entry._tag) {
451
+ case "None": {
452
+ return { done: true, value: count }
453
+ }
454
+ case "Some": {
455
+ return { done: false, value: entry.value }
456
+ }
457
+ }
458
+ }
459
+ }
460
+ }
461
+
462
+ /** @internal */
463
+ export const last = <K, V>(self: RBT.RedBlackTree<K, V>): Option.Option<readonly [K, V]> => {
464
+ let node: Node.Node<K, V> | undefined = (self as RedBlackTreeImpl<K, V>)._root
465
+ let current: Node.Node<K, V> | undefined = (self as RedBlackTreeImpl<K, V>)._root
466
+ while (node !== undefined) {
467
+ current = node
468
+ node = node.right
469
+ }
470
+ return current ? Option.some([current.key, current.value]) : Option.none()
471
+ }
472
+
473
+ /** @internal */
474
+ export const reversed = <K, V>(self: RBT.RedBlackTree<K, V>): Iterable<readonly [K, V]> => {
475
+ return {
476
+ [Symbol.iterator]: () => {
477
+ const stack: Array<Node.Node<K, V>> = []
478
+ let node = (self as RedBlackTreeImpl<K, V>)._root
479
+ while (node !== undefined) {
480
+ stack.push(node)
481
+ node = node.right
482
+ }
483
+ return new RedBlackTreeIterator(self, stack, Direction.Backward)
484
+ }
485
+ }
486
+ }
487
+
488
+ /** @internal */
489
+ export const greaterThanBackwards = Dual.dual<
490
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
491
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Iterable<readonly [K, V]>
492
+ >(2, (self, key) => greaterThan(self, key, Direction.Backward))
493
+
494
+ /** @internal */
495
+ export const greaterThanForwards = Dual.dual<
496
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
497
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Iterable<readonly [K, V]>
498
+ >(2, (self, key) => greaterThan(self, key, Direction.Forward))
499
+
500
+ const greaterThan = <K, V>(
501
+ self: RBT.RedBlackTree<K, V>,
502
+ key: K,
503
+ direction: RBT.RedBlackTree.Direction
504
+ ): Iterable<readonly [K, V]> => {
505
+ return {
506
+ [Symbol.iterator]: () => {
507
+ const cmp = (self as RedBlackTreeImpl<K, V>)._ord
508
+ let node = (self as RedBlackTreeImpl<K, V>)._root
509
+ const stack = []
510
+ let last_ptr = 0
511
+ while (node !== undefined) {
512
+ const d = cmp(key, node.key)
513
+ stack.push(node)
514
+ if (d < 0) {
515
+ last_ptr = stack.length
516
+ }
517
+ if (d < 0) {
518
+ node = node.left
519
+ } else {
520
+ node = node.right
521
+ }
522
+ }
523
+ stack.length = last_ptr
524
+ return new RedBlackTreeIterator(self, stack, direction)
525
+ }
526
+ }
527
+ }
528
+
529
+ /** @internal */
530
+ export const greaterThanEqualBackwards = Dual.dual<
531
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
532
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Iterable<readonly [K, V]>
533
+ >(2, (self, key) => greaterThanEqual(self, key, Direction.Backward))
534
+
535
+ /** @internal */
536
+ export const greaterThanEqualForwards = Dual.dual<
537
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
538
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Iterable<readonly [K, V]>
539
+ >(2, (self, key) => greaterThanEqual(self, key, Direction.Forward))
540
+
541
+ const greaterThanEqual = <K, V>(
542
+ self: RBT.RedBlackTree<K, V>,
543
+ key: K,
544
+ direction: RBT.RedBlackTree.Direction = Direction.Forward
545
+ ): Iterable<readonly [K, V]> => {
546
+ return {
547
+ [Symbol.iterator]: () => {
548
+ const cmp = (self as RedBlackTreeImpl<K, V>)._ord
549
+ let node = (self as RedBlackTreeImpl<K, V>)._root
550
+ const stack = []
551
+ let last_ptr = 0
552
+ while (node !== undefined) {
553
+ const d = cmp(key, node.key)
554
+ stack.push(node)
555
+ if (d <= 0) {
556
+ last_ptr = stack.length
557
+ }
558
+ if (d <= 0) {
559
+ node = node.left
560
+ } else {
561
+ node = node.right
562
+ }
563
+ }
564
+ stack.length = last_ptr
565
+ return new RedBlackTreeIterator(self, stack, direction)
566
+ }
567
+ }
568
+ }
569
+
570
+ /** @internal */
571
+ export const lessThanBackwards = Dual.dual<
572
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
573
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Iterable<readonly [K, V]>
574
+ >(2, (self, key) => lessThan(self, key, Direction.Backward))
575
+
576
+ /** @internal */
577
+ export const lessThanForwards = Dual.dual<
578
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
579
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Iterable<readonly [K, V]>
580
+ >(2, (self, key) => lessThan(self, key, Direction.Forward))
581
+
582
+ const lessThan = <K, V>(
583
+ self: RBT.RedBlackTree<K, V>,
584
+ key: K,
585
+ direction: RBT.RedBlackTree.Direction
586
+ ): Iterable<readonly [K, V]> => {
587
+ return {
588
+ [Symbol.iterator]: () => {
589
+ const cmp = (self as RedBlackTreeImpl<K, V>)._ord
590
+ let node = (self as RedBlackTreeImpl<K, V>)._root
591
+ const stack = []
592
+ let last_ptr = 0
593
+ while (node !== undefined) {
594
+ const d = cmp(key, node.key)
595
+ stack.push(node)
596
+ if (d > 0) {
597
+ last_ptr = stack.length
598
+ }
599
+ if (d <= 0) {
600
+ node = node.left
601
+ } else {
602
+ node = node.right
603
+ }
604
+ }
605
+ stack.length = last_ptr
606
+ return new RedBlackTreeIterator(self, stack, direction)
607
+ }
608
+ }
609
+ }
610
+
611
+ /** @internal */
612
+ export const lessThanEqualBackwards = Dual.dual<
613
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
614
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Iterable<readonly [K, V]>
615
+ >(2, (self, key) => lessThanEqual(self, key, Direction.Backward))
616
+
617
+ /** @internal */
618
+ export const lessThanEqualForwards = Dual.dual<
619
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => Iterable<readonly [K, V]>,
620
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => Iterable<readonly [K, V]>
621
+ >(2, (self, key) => lessThanEqual(self, key, Direction.Forward))
622
+
623
+ const lessThanEqual = <K, V>(
624
+ self: RBT.RedBlackTree<K, V>,
625
+ key: K,
626
+ direction: RBT.RedBlackTree.Direction
627
+ ): Iterable<readonly [K, V]> => {
628
+ return {
629
+ [Symbol.iterator]: () => {
630
+ const cmp = (self as RedBlackTreeImpl<K, V>)._ord
631
+ let node = (self as RedBlackTreeImpl<K, V>)._root
632
+ const stack = []
633
+ let last_ptr = 0
634
+ while (node !== undefined) {
635
+ const d = cmp(key, node.key)
636
+ stack.push(node)
637
+ if (d >= 0) {
638
+ last_ptr = stack.length
639
+ }
640
+ if (d < 0) {
641
+ node = node.left
642
+ } else {
643
+ node = node.right
644
+ }
645
+ }
646
+ stack.length = last_ptr
647
+ return new RedBlackTreeIterator(self, stack, direction)
648
+ }
649
+ }
650
+ }
651
+
652
+ /** @internal */
653
+ export const forEach = Dual.dual<
654
+ <K, V>(f: (key: K, value: V) => void) => (self: RBT.RedBlackTree<K, V>) => void,
655
+ <K, V>(self: RBT.RedBlackTree<K, V>, f: (key: K, value: V) => void) => void
656
+ >(2, <K, V>(self: RBT.RedBlackTree<K, V>, f: (key: K, value: V) => void) => {
657
+ const root = (self as RedBlackTreeImpl<K, V>)._root
658
+ if (root !== undefined) {
659
+ visitFull(root, (key, value) => {
660
+ f(key, value)
661
+ return Option.none()
662
+ })
663
+ }
664
+ })
665
+
666
+ /** @internal */
667
+ export const forEachGreaterThanEqual = Dual.dual<
668
+ <K, V>(min: K, f: (key: K, value: V) => void) => (self: RBT.RedBlackTree<K, V>) => void,
669
+ <K, V>(self: RBT.RedBlackTree<K, V>, min: K, f: (key: K, value: V) => void) => void
670
+ >(3, <K, V>(self: RBT.RedBlackTree<K, V>, min: K, f: (key: K, value: V) => void) => {
671
+ const root = (self as RedBlackTreeImpl<K, V>)._root
672
+ const ord = (self as RedBlackTreeImpl<K, V>)._ord
673
+ if (root !== undefined) {
674
+ visitGreaterThanEqual(root, min, ord, (key, value) => {
675
+ f(key, value)
676
+ return Option.none()
677
+ })
678
+ }
679
+ })
680
+
681
+ /** @internal */
682
+ export const forEachLessThan = Dual.dual<
683
+ <K, V>(max: K, f: (key: K, value: V) => void) => (self: RBT.RedBlackTree<K, V>) => void,
684
+ <K, V>(self: RBT.RedBlackTree<K, V>, max: K, f: (key: K, value: V) => void) => void
685
+ >(3, <K, V>(self: RBT.RedBlackTree<K, V>, max: K, f: (key: K, value: V) => void) => {
686
+ const root = (self as RedBlackTreeImpl<K, V>)._root
687
+ const ord = (self as RedBlackTreeImpl<K, V>)._ord
688
+ if (root !== undefined) {
689
+ visitLessThan(root, max, ord, (key, value) => {
690
+ f(key, value)
691
+ return Option.none()
692
+ })
693
+ }
694
+ })
695
+
696
+ /** @internal */
697
+ export const forEachBetween = Dual.dual<
698
+ <K, V>(options: {
699
+ readonly min: K
700
+ readonly max: K
701
+ readonly body: (key: K, value: V) => void
702
+ }) => (self: RBT.RedBlackTree<K, V>) => void,
703
+ <K, V>(self: RBT.RedBlackTree<K, V>, options: {
704
+ readonly min: K
705
+ readonly max: K
706
+ readonly body: (key: K, value: V) => void
707
+ }) => void
708
+ >(2, <K, V>(self: RBT.RedBlackTree<K, V>, { body, max, min }: {
709
+ readonly min: K
710
+ readonly max: K
711
+ readonly body: (key: K, value: V) => void
712
+ }) => {
713
+ const root = (self as RedBlackTreeImpl<K, V>)._root
714
+ const ord = (self as RedBlackTreeImpl<K, V>)._ord
715
+ if (root) {
716
+ visitBetween(root, min, max, ord, (key, value) => {
717
+ body(key, value)
718
+ return Option.none()
719
+ })
720
+ }
721
+ })
722
+
723
+ /** @internal */
724
+ export const reduce = Dual.dual<
725
+ <Z, V, K>(
726
+ zero: Z,
727
+ f: (accumulator: Z, value: V, key: K) => Z
728
+ ) => (self: RBT.RedBlackTree<K, V>) => Z,
729
+ <Z, V, K>(self: RBT.RedBlackTree<K, V>, zero: Z, f: (accumulator: Z, value: V, key: K) => Z) => Z
730
+ >(3, (self, zero, f) => {
731
+ let accumulator = zero
732
+ for (const entry of self) {
733
+ accumulator = f(accumulator, entry[1], entry[0])
734
+ }
735
+ return accumulator
736
+ })
737
+
738
+ /** @internal */
739
+ export const removeFirst = Dual.dual<
740
+ <K>(key: K) => <V>(self: RBT.RedBlackTree<K, V>) => RBT.RedBlackTree<K, V>,
741
+ <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => RBT.RedBlackTree<K, V>
742
+ >(2, <K, V>(self: RBT.RedBlackTree<K, V>, key: K) => {
743
+ if (!has(self, key)) {
744
+ return self
745
+ }
746
+ const ord = (self as RedBlackTreeImpl<K, V>)._ord
747
+ const cmp = ord
748
+ let node: Node.Node<K, V> | undefined = (self as RedBlackTreeImpl<K, V>)._root
749
+ const stack = []
750
+ while (node !== undefined) {
751
+ const d = cmp(key, node.key)
752
+ stack.push(node)
753
+ if (Equal.equals(key, node.key)) {
754
+ node = undefined
755
+ } else if (d <= 0) {
756
+ node = node.left
757
+ } else {
758
+ node = node.right
759
+ }
760
+ }
761
+ if (stack.length === 0) {
762
+ return self
763
+ }
764
+ const cstack = new Array<Node.Node<K, V>>(stack.length)
765
+ let n = stack[stack.length - 1]!
766
+ cstack[cstack.length - 1] = new Node.Node(
767
+ n.color,
768
+ n.key,
769
+ n.value,
770
+ n.left,
771
+ n.right,
772
+ n.count
773
+ )
774
+ for (let i = stack.length - 2; i >= 0; --i) {
775
+ n = stack[i]!
776
+ if (n.left === stack[i + 1]) {
777
+ cstack[i] = new Node.Node(n.color, n.key, n.value, cstack[i + 1], n.right, n.count)
778
+ } else {
779
+ cstack[i] = new Node.Node(n.color, n.key, n.value, n.left, cstack[i + 1], n.count)
780
+ }
781
+ }
782
+ // Get node
783
+ n = cstack[cstack.length - 1]!
784
+ // If not leaf, then swap with previous node
785
+ if (n.left !== undefined && n.right !== undefined) {
786
+ // First walk to previous leaf
787
+ const split = cstack.length
788
+ n = n.left
789
+ while (n.right != null) {
790
+ cstack.push(n)
791
+ n = n.right
792
+ }
793
+ // Copy path to leaf
794
+ const v = cstack[split - 1]
795
+ cstack.push(new Node.Node(n.color, v!.key, v!.value, n.left, n.right, n.count))
796
+ cstack[split - 1]!.key = n.key
797
+ cstack[split - 1]!.value = n.value
798
+ // Fix up stack
799
+ for (let i = cstack.length - 2; i >= split; --i) {
800
+ n = cstack[i]!
801
+ cstack[i] = new Node.Node(n.color, n.key, n.value, n.left, cstack[i + 1], n.count)
802
+ }
803
+ cstack[split - 1]!.left = cstack[split]
804
+ }
805
+
806
+ // Remove leaf node
807
+ n = cstack[cstack.length - 1]!
808
+ if (n.color === Node.Color.Red) {
809
+ // Easy case: removing red leaf
810
+ const p = cstack[cstack.length - 2]!
811
+ if (p.left === n) {
812
+ p.left = undefined
813
+ } else if (p.right === n) {
814
+ p.right = undefined
815
+ }
816
+ cstack.pop()
817
+ for (let i = 0; i < cstack.length; ++i) {
818
+ cstack[i]!.count--
819
+ }
820
+ return makeImpl(ord, cstack[0])
821
+ } else {
822
+ if (n.left !== undefined || n.right !== undefined) {
823
+ // Second easy case: Single child black parent
824
+ if (n.left !== undefined) {
825
+ Node.swap(n, n.left)
826
+ } else if (n.right !== undefined) {
827
+ Node.swap(n, n.right)
828
+ }
829
+ // Child must be red, so repaint it black to balance color
830
+ n.color = Node.Color.Black
831
+ for (let i = 0; i < cstack.length - 1; ++i) {
832
+ cstack[i]!.count--
833
+ }
834
+ return makeImpl(ord, cstack[0])
835
+ } else if (cstack.length === 1) {
836
+ // Third easy case: root
837
+ return makeImpl(ord, undefined)
838
+ } else {
839
+ // Hard case: Repaint n, and then do some nasty stuff
840
+ for (let i = 0; i < cstack.length; ++i) {
841
+ cstack[i]!.count--
842
+ }
843
+ const parent = cstack[cstack.length - 2]
844
+ fixDoubleBlack(cstack)
845
+ // Fix up links
846
+ if (parent!.left === n) {
847
+ parent!.left = undefined
848
+ } else {
849
+ parent!.right = undefined
850
+ }
851
+ }
852
+ }
853
+ return makeImpl(ord, cstack[0])
854
+ })
855
+
856
+ /** @internal */
857
+ export const size = <K, V>(self: RBT.RedBlackTree<K, V>): number => (self as RedBlackTreeImpl<K, V>)._root?.count ?? 0
858
+
859
+ /** @internal */
860
+ export const valuesForward = <K, V>(self: RBT.RedBlackTree<K, V>): IterableIterator<V> =>
861
+ values(self, Direction.Forward)
862
+
863
+ /** @internal */
864
+ export const valuesBackward = <K, V>(self: RBT.RedBlackTree<K, V>): IterableIterator<V> =>
865
+ values(self, Direction.Backward)
866
+
867
+ /** @internal */
868
+ const values = <K, V>(
869
+ self: RBT.RedBlackTree<K, V>,
870
+ direction: RBT.RedBlackTree.Direction
871
+ ): IterableIterator<V> => {
872
+ const begin: RedBlackTreeIterator<K, V> = self[Symbol.iterator]() as RedBlackTreeIterator<K, V>
873
+ let count = 0
874
+ return {
875
+ [Symbol.iterator]: () => values(self, direction),
876
+ next: (): IteratorResult<V, number> => {
877
+ count++
878
+ const entry = begin.value
879
+ if (direction === Direction.Forward) {
880
+ begin.moveNext()
881
+ } else {
882
+ begin.movePrev()
883
+ }
884
+ switch (entry._tag) {
885
+ case "None": {
886
+ return { done: true, value: count }
887
+ }
888
+ case "Some": {
889
+ return { done: false, value: entry.value }
890
+ }
891
+ }
892
+ }
893
+ }
894
+ }
895
+
896
+ const visitFull = <K, V, A>(
897
+ node: Node.Node<K, V>,
898
+ visit: (key: K, value: V) => Option.Option<A>
899
+ ): Option.Option<A> => {
900
+ let current: Node.Node<K, V> | undefined = node
901
+ let stack: Stack<Node.Node<K, V>> | undefined = undefined
902
+ let done = false
903
+ while (!done) {
904
+ if (current != null) {
905
+ stack = new Stack(current, stack)
906
+ current = current.left
907
+ } else if (stack != null) {
908
+ const value = visit(stack.value.key, stack.value.value)
909
+ if (Option.isSome(value)) {
910
+ return value
911
+ }
912
+ current = stack.value.right
913
+ stack = stack.previous
914
+ } else {
915
+ done = true
916
+ }
917
+ }
918
+ return Option.none()
919
+ }
920
+
921
+ const visitGreaterThanEqual = <K, V, A>(
922
+ node: Node.Node<K, V>,
923
+ min: K,
924
+ ord: Order.Order<K>,
925
+ visit: (key: K, value: V) => Option.Option<A>
926
+ ): Option.Option<A> => {
927
+ let current: Node.Node<K, V> | undefined = node
928
+ let stack: Stack<Node.Node<K, V>> | undefined = undefined
929
+ let done = false
930
+ while (!done) {
931
+ if (current !== undefined) {
932
+ stack = new Stack(current, stack)
933
+ if (ord(min, current.key) <= 0) {
934
+ current = current.left
935
+ } else {
936
+ current = undefined
937
+ }
938
+ } else if (stack !== undefined) {
939
+ if (ord(min, stack.value.key) <= 0) {
940
+ const value = visit(stack.value.key, stack.value.value)
941
+ if (Option.isSome(value)) {
942
+ return value
943
+ }
944
+ }
945
+ current = stack.value.right
946
+ stack = stack.previous
947
+ } else {
948
+ done = true
949
+ }
950
+ }
951
+ return Option.none()
952
+ }
953
+
954
+ const visitLessThan = <K, V, A>(
955
+ node: Node.Node<K, V>,
956
+ max: K,
957
+ ord: Order.Order<K>,
958
+ visit: (key: K, value: V) => Option.Option<A>
959
+ ): Option.Option<A> => {
960
+ let current: Node.Node<K, V> | undefined = node
961
+ let stack: Stack<Node.Node<K, V>> | undefined = undefined
962
+ let done = false
963
+ while (!done) {
964
+ if (current !== undefined) {
965
+ stack = new Stack(current, stack)
966
+ current = current.left
967
+ } else if (stack !== undefined && ord(max, stack.value.key) > 0) {
968
+ const value = visit(stack.value.key, stack.value.value)
969
+ if (Option.isSome(value)) {
970
+ return value
971
+ }
972
+ current = stack.value.right
973
+ stack = stack.previous
974
+ } else {
975
+ done = true
976
+ }
977
+ }
978
+ return Option.none()
979
+ }
980
+
981
+ const visitBetween = <K, V, A>(
982
+ node: Node.Node<K, V>,
983
+ min: K,
984
+ max: K,
985
+ ord: Order.Order<K>,
986
+ visit: (key: K, value: V) => Option.Option<A>
987
+ ): Option.Option<A> => {
988
+ let current: Node.Node<K, V> | undefined = node
989
+ let stack: Stack<Node.Node<K, V>> | undefined = undefined
990
+ let done = false
991
+ while (!done) {
992
+ if (current !== undefined) {
993
+ stack = new Stack(current, stack)
994
+ if (ord(min, current.key) <= 0) {
995
+ current = current.left
996
+ } else {
997
+ current = undefined
998
+ }
999
+ } else if (stack !== undefined && ord(max, stack.value.key) > 0) {
1000
+ if (ord(min, stack.value.key) <= 0) {
1001
+ const value = visit(stack.value.key, stack.value.value)
1002
+ if (Option.isSome(value)) {
1003
+ return value
1004
+ }
1005
+ }
1006
+ current = stack.value.right
1007
+ stack = stack.previous
1008
+ } else {
1009
+ done = true
1010
+ }
1011
+ }
1012
+ return Option.none()
1013
+ }
1014
+
1015
+ /**
1016
+ * Fix up a double black node in a Red-Black Tree.
1017
+ */
1018
+ const fixDoubleBlack = <K, V>(stack: Array<Node.Node<K, V>>) => {
1019
+ let n, p, s, z
1020
+ for (let i = stack.length - 1; i >= 0; --i) {
1021
+ n = stack[i]!
1022
+ if (i === 0) {
1023
+ n.color = Node.Color.Black
1024
+ return
1025
+ }
1026
+ p = stack[i - 1]!
1027
+ if (p.left === n) {
1028
+ s = p.right
1029
+ if (s !== undefined && s.right !== undefined && s.right.color === Node.Color.Red) {
1030
+ s = p.right = Node.clone(s)
1031
+ z = s.right = Node.clone(s.right!)
1032
+ p.right = s.left
1033
+ s.left = p
1034
+ s.right = z
1035
+ s.color = p.color
1036
+ n.color = Node.Color.Black
1037
+ p.color = Node.Color.Black
1038
+ z.color = Node.Color.Black
1039
+ Node.recount(p)
1040
+ Node.recount(s)
1041
+ if (i > 1) {
1042
+ const pp = stack[i - 2]!
1043
+ if (pp.left === p) {
1044
+ pp.left = s
1045
+ } else {
1046
+ pp.right = s
1047
+ }
1048
+ }
1049
+ stack[i - 1] = s
1050
+ return
1051
+ } else if (s !== undefined && s.left !== undefined && s.left.color === Node.Color.Red) {
1052
+ s = p.right = Node.clone(s)
1053
+ z = s.left = Node.clone(s.left!)
1054
+ p.right = z.left
1055
+ s.left = z.right
1056
+ z.left = p
1057
+ z.right = s
1058
+ z.color = p.color
1059
+ p.color = Node.Color.Black
1060
+ s.color = Node.Color.Black
1061
+ n.color = Node.Color.Black
1062
+ Node.recount(p)
1063
+ Node.recount(s)
1064
+ Node.recount(z)
1065
+ if (i > 1) {
1066
+ const pp = stack[i - 2]!
1067
+ if (pp.left === p) {
1068
+ pp.left = z
1069
+ } else {
1070
+ pp.right = z
1071
+ }
1072
+ }
1073
+ stack[i - 1] = z
1074
+ return
1075
+ }
1076
+ if (s !== undefined && s.color === Node.Color.Black) {
1077
+ if (p.color === Node.Color.Red) {
1078
+ p.color = Node.Color.Black
1079
+ p.right = Node.repaint(s, Node.Color.Red)
1080
+ return
1081
+ } else {
1082
+ p.right = Node.repaint(s, Node.Color.Red)
1083
+ continue
1084
+ }
1085
+ } else if (s !== undefined) {
1086
+ s = Node.clone(s)
1087
+ p.right = s.left
1088
+ s.left = p
1089
+ s.color = p.color
1090
+ p.color = Node.Color.Red
1091
+ Node.recount(p)
1092
+ Node.recount(s)
1093
+ if (i > 1) {
1094
+ const pp = stack[i - 2]!
1095
+ if (pp.left === p) {
1096
+ pp.left = s
1097
+ } else {
1098
+ pp.right = s
1099
+ }
1100
+ }
1101
+ stack[i - 1] = s
1102
+ stack[i] = p
1103
+ if (i + 1 < stack.length) {
1104
+ stack[i + 1] = n
1105
+ } else {
1106
+ stack.push(n)
1107
+ }
1108
+ i = i + 2
1109
+ }
1110
+ } else {
1111
+ s = p.left
1112
+ if (s !== undefined && s.left !== undefined && s.left.color === Node.Color.Red) {
1113
+ s = p.left = Node.clone(s)
1114
+ z = s.left = Node.clone(s.left!)
1115
+ p.left = s.right
1116
+ s.right = p
1117
+ s.left = z
1118
+ s.color = p.color
1119
+ n.color = Node.Color.Black
1120
+ p.color = Node.Color.Black
1121
+ z.color = Node.Color.Black
1122
+ Node.recount(p)
1123
+ Node.recount(s)
1124
+ if (i > 1) {
1125
+ const pp = stack[i - 2]!
1126
+ if (pp.right === p) {
1127
+ pp.right = s
1128
+ } else {
1129
+ pp.left = s
1130
+ }
1131
+ }
1132
+ stack[i - 1] = s
1133
+ return
1134
+ } else if (s !== undefined && s.right !== undefined && s.right.color === Node.Color.Red) {
1135
+ s = p.left = Node.clone(s)
1136
+ z = s.right = Node.clone(s.right!)
1137
+ p.left = z.right
1138
+ s.right = z.left
1139
+ z.right = p
1140
+ z.left = s
1141
+ z.color = p.color
1142
+ p.color = Node.Color.Black
1143
+ s.color = Node.Color.Black
1144
+ n.color = Node.Color.Black
1145
+ Node.recount(p)
1146
+ Node.recount(s)
1147
+ Node.recount(z)
1148
+ if (i > 1) {
1149
+ const pp = stack[i - 2]!
1150
+ if (pp.right === p) {
1151
+ pp.right = z
1152
+ } else {
1153
+ pp.left = z
1154
+ }
1155
+ }
1156
+ stack[i - 1] = z
1157
+ return
1158
+ }
1159
+ if (s !== undefined && s.color === Node.Color.Black) {
1160
+ if (p.color === Node.Color.Red) {
1161
+ p.color = Node.Color.Black
1162
+ p.left = Node.repaint(s, Node.Color.Red)
1163
+ return
1164
+ } else {
1165
+ p.left = Node.repaint(s, Node.Color.Red)
1166
+ continue
1167
+ }
1168
+ } else if (s !== undefined) {
1169
+ s = Node.clone(s)
1170
+ p.left = s.right
1171
+ s.right = p
1172
+ s.color = p.color
1173
+ p.color = Node.Color.Red
1174
+ Node.recount(p)
1175
+ Node.recount(s)
1176
+ if (i > 1) {
1177
+ const pp = stack[i - 2]!
1178
+ if (pp.right === p) {
1179
+ pp.right = s
1180
+ } else {
1181
+ pp.left = s
1182
+ }
1183
+ }
1184
+ stack[i - 1] = s
1185
+ stack[i] = p
1186
+ if (i + 1 < stack.length) {
1187
+ stack[i + 1] = n
1188
+ } else {
1189
+ stack.push(n)
1190
+ }
1191
+ i = i + 2
1192
+ }
1193
+ }
1194
+ }
1195
+ }