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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (452) hide show
  1. package/SourceLocation/package.json +6 -0
  2. package/dist/cjs/Effect.js +2 -28
  3. package/dist/cjs/Effect.js.map +1 -1
  4. package/dist/cjs/FiberRef.js +12 -1
  5. package/dist/cjs/FiberRef.js.map +1 -1
  6. package/dist/cjs/Layer.js +2 -24
  7. package/dist/cjs/Layer.js.map +1 -1
  8. package/dist/cjs/RuntimeFlags.js +1 -29
  9. package/dist/cjs/RuntimeFlags.js.map +1 -1
  10. package/dist/cjs/SourceLocation.js +60 -0
  11. package/dist/cjs/SourceLocation.js.map +1 -0
  12. package/dist/cjs/Tracer.js +1 -15
  13. package/dist/cjs/Tracer.js.map +1 -1
  14. package/dist/cjs/Utils.js +1 -1
  15. package/dist/cjs/Utils.js.map +1 -1
  16. package/dist/cjs/index.js +3 -1
  17. package/dist/cjs/index.js.map +1 -1
  18. package/dist/cjs/internal/clock.js +1 -1
  19. package/dist/cjs/internal/clock.js.map +1 -1
  20. package/dist/cjs/internal/core.js +17 -50
  21. package/dist/cjs/internal/core.js.map +1 -1
  22. package/dist/cjs/internal/effect/circular.js +18 -30
  23. package/dist/cjs/internal/effect/circular.js.map +1 -1
  24. package/dist/cjs/internal/fiberRuntime.js +16 -65
  25. package/dist/cjs/internal/fiberRuntime.js.map +1 -1
  26. package/dist/cjs/internal/layer/circular.js +1 -5
  27. package/dist/cjs/internal/layer/circular.js.map +1 -1
  28. package/dist/cjs/internal/layer.js +1 -3
  29. package/dist/cjs/internal/layer.js.map +1 -1
  30. package/dist/cjs/internal/logger.js +25 -2
  31. package/dist/cjs/internal/logger.js.map +1 -1
  32. package/dist/cjs/internal/runtimeFlags.js +2 -11
  33. package/dist/cjs/internal/runtimeFlags.js.map +1 -1
  34. package/dist/cjs/internal/tracer.js +1 -114
  35. package/dist/cjs/internal/tracer.js.map +1 -1
  36. package/dist/dts/Config.d.ts +2 -2
  37. package/dist/dts/Config.d.ts.map +1 -1
  38. package/dist/dts/Effect.d.ts +8 -29
  39. package/dist/dts/Effect.d.ts.map +1 -1
  40. package/dist/dts/FiberRef.d.ts +12 -0
  41. package/dist/dts/FiberRef.d.ts.map +1 -1
  42. package/dist/dts/Layer.d.ts +0 -22
  43. package/dist/dts/Layer.d.ts.map +1 -1
  44. package/dist/dts/RuntimeFlags.d.ts +0 -28
  45. package/dist/dts/RuntimeFlags.d.ts.map +1 -1
  46. package/dist/dts/SourceLocation.d.ts +88 -0
  47. package/dist/dts/SourceLocation.d.ts.map +1 -0
  48. package/dist/dts/Tracer.d.ts +0 -15
  49. package/dist/dts/Tracer.d.ts.map +1 -1
  50. package/dist/dts/index.d.ts +6 -0
  51. package/dist/dts/index.d.ts.map +1 -1
  52. package/dist/dts/internal/core.d.ts.map +1 -1
  53. package/dist/dts/internal/layer.d.ts.map +1 -1
  54. package/dist/dts/internal/runtimeFlags.d.ts.map +1 -1
  55. package/dist/esm/Effect.js +0 -26
  56. package/dist/esm/Effect.js.map +1 -1
  57. package/dist/esm/FiberRef.js +11 -0
  58. package/dist/esm/FiberRef.js.map +1 -1
  59. package/dist/esm/Layer.js +0 -22
  60. package/dist/esm/Layer.js.map +1 -1
  61. package/dist/esm/RuntimeFlags.js +0 -28
  62. package/dist/esm/RuntimeFlags.js.map +1 -1
  63. package/dist/esm/SourceLocation.js +51 -0
  64. package/dist/esm/SourceLocation.js.map +1 -0
  65. package/dist/esm/Tracer.js +0 -14
  66. package/dist/esm/Tracer.js.map +1 -1
  67. package/dist/esm/Utils.js +1 -1
  68. package/dist/esm/Utils.js.map +1 -1
  69. package/dist/esm/index.js +6 -0
  70. package/dist/esm/index.js.map +1 -1
  71. package/dist/esm/internal/clock.js +1 -1
  72. package/dist/esm/internal/clock.js.map +1 -1
  73. package/dist/esm/internal/core.js +12 -45
  74. package/dist/esm/internal/core.js.map +1 -1
  75. package/dist/esm/internal/effect/circular.js +18 -30
  76. package/dist/esm/internal/effect/circular.js.map +1 -1
  77. package/dist/esm/internal/fiberRuntime.js +13 -60
  78. package/dist/esm/internal/fiberRuntime.js.map +1 -1
  79. package/dist/esm/internal/layer/circular.js +0 -4
  80. package/dist/esm/internal/layer/circular.js.map +1 -1
  81. package/dist/esm/internal/layer.js +0 -2
  82. package/dist/esm/internal/layer.js.map +1 -1
  83. package/dist/esm/internal/logger.js +25 -2
  84. package/dist/esm/internal/logger.js.map +1 -1
  85. package/dist/esm/internal/runtimeFlags.js +1 -9
  86. package/dist/esm/internal/runtimeFlags.js.map +1 -1
  87. package/dist/esm/internal/tracer.js +0 -111
  88. package/dist/esm/internal/tracer.js.map +1 -1
  89. package/package.json +12 -1
  90. package/src/Arbitrary.ts +1101 -0
  91. package/src/Array.ts +3589 -0
  92. package/src/BigDecimal.ts +1349 -0
  93. package/src/BigInt.ts +643 -0
  94. package/src/Boolean.ts +287 -0
  95. package/src/Brand.ts +360 -0
  96. package/src/Cache.ts +281 -0
  97. package/src/Cause.ts +1555 -0
  98. package/src/Channel.ts +2355 -0
  99. package/src/ChildExecutorDecision.ts +146 -0
  100. package/src/Chunk.ts +1495 -0
  101. package/src/Clock.ts +111 -0
  102. package/src/Config.ts +542 -0
  103. package/src/ConfigError.ts +270 -0
  104. package/src/ConfigProvider.ts +333 -0
  105. package/src/ConfigProviderPathPatch.ts +100 -0
  106. package/src/Console.ts +226 -0
  107. package/src/Context.ts +585 -0
  108. package/src/Cron.ts +706 -0
  109. package/src/Data.ts +596 -0
  110. package/src/DateTime.ts +1686 -0
  111. package/src/DefaultServices.ts +34 -0
  112. package/src/Deferred.ts +301 -0
  113. package/src/Differ.ts +450 -0
  114. package/src/Duration.ts +1000 -0
  115. package/src/Effect.ts +14817 -0
  116. package/src/Effectable.ts +107 -0
  117. package/src/Either.ts +1040 -0
  118. package/src/Encoding.ts +195 -0
  119. package/src/Equal.ts +98 -0
  120. package/src/Equivalence.ts +235 -0
  121. package/src/ExecutionPlan.ts +308 -0
  122. package/src/ExecutionStrategy.ts +119 -0
  123. package/src/Exit.ts +467 -0
  124. package/src/FastCheck.ts +9 -0
  125. package/src/Fiber.ts +744 -0
  126. package/src/FiberHandle.ts +540 -0
  127. package/src/FiberId.ts +195 -0
  128. package/src/FiberMap.ts +656 -0
  129. package/src/FiberRef.ts +444 -0
  130. package/src/FiberRefs.ts +204 -0
  131. package/src/FiberRefsPatch.ts +105 -0
  132. package/src/FiberSet.ts +491 -0
  133. package/src/FiberStatus.ts +108 -0
  134. package/src/Function.ts +1222 -0
  135. package/src/GlobalValue.ts +53 -0
  136. package/src/Graph.ts +3732 -0
  137. package/src/GroupBy.ts +103 -0
  138. package/src/HKT.ts +45 -0
  139. package/src/Hash.ts +195 -0
  140. package/src/HashMap.ts +519 -0
  141. package/src/HashRing.ts +317 -0
  142. package/src/HashSet.ts +2346 -0
  143. package/src/Inspectable.ts +287 -0
  144. package/src/Iterable.ts +1119 -0
  145. package/src/JSONSchema.ts +1044 -0
  146. package/src/KeyedPool.ts +167 -0
  147. package/src/Layer.ts +1228 -0
  148. package/src/LayerMap.ts +436 -0
  149. package/src/List.ts +977 -0
  150. package/src/LogLevel.ts +285 -0
  151. package/src/LogSpan.ts +25 -0
  152. package/src/Logger.ts +702 -0
  153. package/src/Mailbox.ts +268 -0
  154. package/src/ManagedRuntime.ts +180 -0
  155. package/src/Match.ts +1477 -0
  156. package/src/MergeDecision.ts +95 -0
  157. package/src/MergeState.ts +172 -0
  158. package/src/MergeStrategy.ts +107 -0
  159. package/src/Metric.ts +780 -0
  160. package/src/MetricBoundaries.ts +69 -0
  161. package/src/MetricHook.ts +151 -0
  162. package/src/MetricKey.ts +224 -0
  163. package/src/MetricKeyType.ts +262 -0
  164. package/src/MetricLabel.ts +47 -0
  165. package/src/MetricPair.ts +71 -0
  166. package/src/MetricPolling.ts +148 -0
  167. package/src/MetricRegistry.ts +48 -0
  168. package/src/MetricState.ts +257 -0
  169. package/src/Micro.ts +4405 -0
  170. package/src/ModuleVersion.ts +18 -0
  171. package/src/MutableHashMap.ts +411 -0
  172. package/src/MutableHashSet.ts +706 -0
  173. package/src/MutableList.ts +297 -0
  174. package/src/MutableQueue.ts +227 -0
  175. package/src/MutableRef.ts +202 -0
  176. package/src/NonEmptyIterable.ts +32 -0
  177. package/src/Number.ts +1071 -0
  178. package/src/Option.ts +2170 -0
  179. package/src/Order.ts +373 -0
  180. package/src/Ordering.ts +111 -0
  181. package/src/ParseResult.ts +2031 -0
  182. package/src/PartitionedSemaphore.ts +200 -0
  183. package/src/Pipeable.ts +566 -0
  184. package/src/Pool.ts +204 -0
  185. package/src/Predicate.ts +1405 -0
  186. package/src/Pretty.ts +205 -0
  187. package/src/PrimaryKey.ts +23 -0
  188. package/src/PubSub.ts +182 -0
  189. package/src/Queue.ts +644 -0
  190. package/src/Random.ts +204 -0
  191. package/src/RateLimiter.ts +138 -0
  192. package/src/RcMap.ts +141 -0
  193. package/src/RcRef.ts +122 -0
  194. package/src/Readable.ts +93 -0
  195. package/src/Record.ts +1274 -0
  196. package/src/RedBlackTree.ts +421 -0
  197. package/src/Redacted.ts +144 -0
  198. package/src/Ref.ts +180 -0
  199. package/src/RegExp.ts +38 -0
  200. package/src/Reloadable.ts +127 -0
  201. package/src/Request.ts +347 -0
  202. package/src/RequestBlock.ts +118 -0
  203. package/src/RequestResolver.ts +366 -0
  204. package/src/Resource.ts +119 -0
  205. package/src/Runtime.ts +383 -0
  206. package/src/RuntimeFlags.ts +336 -0
  207. package/src/RuntimeFlagsPatch.ts +183 -0
  208. package/src/STM.ts +2045 -0
  209. package/src/Schedule.ts +2219 -0
  210. package/src/ScheduleDecision.ts +62 -0
  211. package/src/ScheduleInterval.ts +151 -0
  212. package/src/ScheduleIntervals.ts +122 -0
  213. package/src/Scheduler.ts +353 -0
  214. package/src/Schema.ts +10914 -0
  215. package/src/SchemaAST.ts +3043 -0
  216. package/src/Scope.ts +204 -0
  217. package/src/ScopedCache.ts +151 -0
  218. package/src/ScopedRef.ts +117 -0
  219. package/src/Secret.ts +88 -0
  220. package/src/SingleProducerAsyncInput.ts +67 -0
  221. package/src/Sink.ts +1461 -0
  222. package/src/SortedMap.ts +287 -0
  223. package/src/SortedSet.ts +390 -0
  224. package/src/SourceLocation.ts +108 -0
  225. package/src/Stream.ts +6468 -0
  226. package/src/StreamEmit.ts +136 -0
  227. package/src/StreamHaltStrategy.ts +123 -0
  228. package/src/Streamable.ts +45 -0
  229. package/src/String.ts +778 -0
  230. package/src/Struct.ts +243 -0
  231. package/src/Subscribable.ts +100 -0
  232. package/src/SubscriptionRef.ts +298 -0
  233. package/src/Supervisor.ts +240 -0
  234. package/src/Symbol.ts +29 -0
  235. package/src/SynchronizedRef.ts +270 -0
  236. package/src/TArray.ts +495 -0
  237. package/src/TDeferred.ts +100 -0
  238. package/src/TMap.ts +515 -0
  239. package/src/TPriorityQueue.ts +223 -0
  240. package/src/TPubSub.ts +200 -0
  241. package/src/TQueue.ts +432 -0
  242. package/src/TRandom.ts +129 -0
  243. package/src/TReentrantLock.ts +224 -0
  244. package/src/TRef.ts +178 -0
  245. package/src/TSemaphore.ts +129 -0
  246. package/src/TSet.ts +365 -0
  247. package/src/TSubscriptionRef.ts +192 -0
  248. package/src/Take.ts +258 -0
  249. package/src/TestAnnotation.ts +158 -0
  250. package/src/TestAnnotationMap.ts +119 -0
  251. package/src/TestAnnotations.ts +117 -0
  252. package/src/TestClock.ts +556 -0
  253. package/src/TestConfig.ts +47 -0
  254. package/src/TestContext.ts +36 -0
  255. package/src/TestLive.ts +53 -0
  256. package/src/TestServices.ts +390 -0
  257. package/src/TestSized.ts +55 -0
  258. package/src/Tracer.ts +182 -0
  259. package/src/Trie.ts +840 -0
  260. package/src/Tuple.ts +305 -0
  261. package/src/Types.ts +353 -0
  262. package/src/Unify.ts +113 -0
  263. package/src/UpstreamPullRequest.ts +117 -0
  264. package/src/UpstreamPullStrategy.ts +121 -0
  265. package/src/Utils.ts +809 -0
  266. package/src/index.ts +1568 -0
  267. package/src/internal/array.ts +8 -0
  268. package/src/internal/blockedRequests.ts +520 -0
  269. package/src/internal/cache.ts +733 -0
  270. package/src/internal/cause.ts +1050 -0
  271. package/src/internal/channel/channelExecutor.ts +1200 -0
  272. package/src/internal/channel/channelState.ts +134 -0
  273. package/src/internal/channel/childExecutorDecision.ts +96 -0
  274. package/src/internal/channel/continuation.ts +200 -0
  275. package/src/internal/channel/mergeDecision.ts +113 -0
  276. package/src/internal/channel/mergeState.ts +120 -0
  277. package/src/internal/channel/mergeStrategy.ts +72 -0
  278. package/src/internal/channel/singleProducerAsyncInput.ts +259 -0
  279. package/src/internal/channel/subexecutor.ts +229 -0
  280. package/src/internal/channel/upstreamPullRequest.ts +84 -0
  281. package/src/internal/channel/upstreamPullStrategy.ts +87 -0
  282. package/src/internal/channel.ts +2603 -0
  283. package/src/internal/clock.ts +95 -0
  284. package/src/internal/completedRequestMap.ts +9 -0
  285. package/src/internal/concurrency.ts +54 -0
  286. package/src/internal/config.ts +716 -0
  287. package/src/internal/configError.ts +304 -0
  288. package/src/internal/configProvider/pathPatch.ts +97 -0
  289. package/src/internal/configProvider.ts +799 -0
  290. package/src/internal/console.ts +153 -0
  291. package/src/internal/context.ts +337 -0
  292. package/src/internal/core-effect.ts +2293 -0
  293. package/src/internal/core-stream.ts +998 -0
  294. package/src/internal/core.ts +3189 -0
  295. package/src/internal/data.ts +36 -0
  296. package/src/internal/dataSource.ts +327 -0
  297. package/src/internal/dateTime.ts +1277 -0
  298. package/src/internal/defaultServices/console.ts +100 -0
  299. package/src/internal/defaultServices.ts +163 -0
  300. package/src/internal/deferred.ts +46 -0
  301. package/src/internal/differ/chunkPatch.ts +211 -0
  302. package/src/internal/differ/contextPatch.ts +232 -0
  303. package/src/internal/differ/hashMapPatch.ts +220 -0
  304. package/src/internal/differ/hashSetPatch.ts +176 -0
  305. package/src/internal/differ/orPatch.ts +311 -0
  306. package/src/internal/differ/readonlyArrayPatch.ts +210 -0
  307. package/src/internal/differ.ts +200 -0
  308. package/src/internal/doNotation.ts +80 -0
  309. package/src/internal/effect/circular.ts +895 -0
  310. package/src/internal/effectable.ts +131 -0
  311. package/src/internal/either.ts +110 -0
  312. package/src/internal/encoding/base64.ts +286 -0
  313. package/src/internal/encoding/base64Url.ts +29 -0
  314. package/src/internal/encoding/common.ts +51 -0
  315. package/src/internal/encoding/hex.ts +315 -0
  316. package/src/internal/errors.ts +7 -0
  317. package/src/internal/executionPlan.ts +114 -0
  318. package/src/internal/executionStrategy.ts +74 -0
  319. package/src/internal/fiber.ts +388 -0
  320. package/src/internal/fiberId.ts +267 -0
  321. package/src/internal/fiberMessage.ts +82 -0
  322. package/src/internal/fiberRefs/patch.ts +144 -0
  323. package/src/internal/fiberRefs.ts +297 -0
  324. package/src/internal/fiberRuntime.ts +3842 -0
  325. package/src/internal/fiberScope.ts +71 -0
  326. package/src/internal/fiberStatus.ts +119 -0
  327. package/src/internal/groupBy.ts +530 -0
  328. package/src/internal/hashMap/array.ts +49 -0
  329. package/src/internal/hashMap/bitwise.ts +32 -0
  330. package/src/internal/hashMap/config.ts +14 -0
  331. package/src/internal/hashMap/keySet.ts +8 -0
  332. package/src/internal/hashMap/node.ts +391 -0
  333. package/src/internal/hashMap.ts +586 -0
  334. package/src/internal/hashSet.ts +323 -0
  335. package/src/internal/keyedPool.ts +244 -0
  336. package/src/internal/layer/circular.ts +214 -0
  337. package/src/internal/layer.ts +1483 -0
  338. package/src/internal/logSpan.ts +20 -0
  339. package/src/internal/logger-circular.ts +24 -0
  340. package/src/internal/logger.ts +522 -0
  341. package/src/internal/mailbox.ts +561 -0
  342. package/src/internal/managedRuntime/circular.ts +6 -0
  343. package/src/internal/managedRuntime.ts +134 -0
  344. package/src/internal/matcher.ts +652 -0
  345. package/src/internal/metric/boundaries.ts +75 -0
  346. package/src/internal/metric/hook.ts +483 -0
  347. package/src/internal/metric/key.ts +167 -0
  348. package/src/internal/metric/keyType.ts +238 -0
  349. package/src/internal/metric/label.ts +41 -0
  350. package/src/internal/metric/pair.ts +48 -0
  351. package/src/internal/metric/polling.ts +149 -0
  352. package/src/internal/metric/registry.ts +187 -0
  353. package/src/internal/metric/state.ts +290 -0
  354. package/src/internal/metric.ts +577 -0
  355. package/src/internal/opCodes/cause.ts +35 -0
  356. package/src/internal/opCodes/channel.ts +83 -0
  357. package/src/internal/opCodes/channelChildExecutorDecision.ts +17 -0
  358. package/src/internal/opCodes/channelMergeDecision.ts +11 -0
  359. package/src/internal/opCodes/channelMergeState.ts +17 -0
  360. package/src/internal/opCodes/channelMergeStrategy.ts +11 -0
  361. package/src/internal/opCodes/channelState.ts +23 -0
  362. package/src/internal/opCodes/channelUpstreamPullRequest.ts +11 -0
  363. package/src/internal/opCodes/channelUpstreamPullStrategy.ts +11 -0
  364. package/src/internal/opCodes/config.ts +65 -0
  365. package/src/internal/opCodes/configError.ts +35 -0
  366. package/src/internal/opCodes/continuation.ts +11 -0
  367. package/src/internal/opCodes/deferred.ts +11 -0
  368. package/src/internal/opCodes/effect.ts +89 -0
  369. package/src/internal/opCodes/layer.ts +59 -0
  370. package/src/internal/opCodes/streamHaltStrategy.ts +23 -0
  371. package/src/internal/option.ts +80 -0
  372. package/src/internal/pool.ts +432 -0
  373. package/src/internal/pubsub.ts +1762 -0
  374. package/src/internal/query.ts +204 -0
  375. package/src/internal/queue.ts +766 -0
  376. package/src/internal/random.ts +161 -0
  377. package/src/internal/rateLimiter.ts +93 -0
  378. package/src/internal/rcMap.ts +285 -0
  379. package/src/internal/rcRef.ts +192 -0
  380. package/src/internal/redBlackTree/iterator.ts +200 -0
  381. package/src/internal/redBlackTree/node.ts +68 -0
  382. package/src/internal/redBlackTree.ts +1245 -0
  383. package/src/internal/redacted.ts +73 -0
  384. package/src/internal/ref.ts +171 -0
  385. package/src/internal/reloadable.ts +140 -0
  386. package/src/internal/request.ts +177 -0
  387. package/src/internal/resource.ts +76 -0
  388. package/src/internal/ringBuffer.ts +68 -0
  389. package/src/internal/runtime.ts +558 -0
  390. package/src/internal/runtimeFlags.ts +178 -0
  391. package/src/internal/runtimeFlagsPatch.ts +103 -0
  392. package/src/internal/schedule/decision.ts +47 -0
  393. package/src/internal/schedule/interval.ts +101 -0
  394. package/src/internal/schedule/intervals.ts +180 -0
  395. package/src/internal/schedule.ts +2199 -0
  396. package/src/internal/schema/errors.ts +191 -0
  397. package/src/internal/schema/schemaId.ts +106 -0
  398. package/src/internal/schema/util.ts +50 -0
  399. package/src/internal/scopedCache.ts +644 -0
  400. package/src/internal/scopedRef.ts +118 -0
  401. package/src/internal/secret.ts +89 -0
  402. package/src/internal/singleShotGen.ts +35 -0
  403. package/src/internal/sink.ts +2120 -0
  404. package/src/internal/stack.ts +10 -0
  405. package/src/internal/stm/core.ts +817 -0
  406. package/src/internal/stm/entry.ts +59 -0
  407. package/src/internal/stm/journal.ts +123 -0
  408. package/src/internal/stm/opCodes/stm.ts +71 -0
  409. package/src/internal/stm/opCodes/stmState.ts +17 -0
  410. package/src/internal/stm/opCodes/strategy.ts +17 -0
  411. package/src/internal/stm/opCodes/tExit.ts +29 -0
  412. package/src/internal/stm/opCodes/tryCommit.ts +11 -0
  413. package/src/internal/stm/stm.ts +1453 -0
  414. package/src/internal/stm/stmState.ts +136 -0
  415. package/src/internal/stm/tArray.ts +550 -0
  416. package/src/internal/stm/tDeferred.ts +81 -0
  417. package/src/internal/stm/tExit.ts +190 -0
  418. package/src/internal/stm/tMap.ts +824 -0
  419. package/src/internal/stm/tPriorityQueue.ts +267 -0
  420. package/src/internal/stm/tPubSub.ts +551 -0
  421. package/src/internal/stm/tQueue.ts +393 -0
  422. package/src/internal/stm/tRandom.ts +140 -0
  423. package/src/internal/stm/tReentrantLock.ts +352 -0
  424. package/src/internal/stm/tRef.ts +195 -0
  425. package/src/internal/stm/tSemaphore.ts +113 -0
  426. package/src/internal/stm/tSet.ts +259 -0
  427. package/src/internal/stm/tSubscriptionRef.ts +286 -0
  428. package/src/internal/stm/tryCommit.ts +34 -0
  429. package/src/internal/stm/txnId.ts +14 -0
  430. package/src/internal/stm/versioned.ts +4 -0
  431. package/src/internal/stream/debounceState.ts +57 -0
  432. package/src/internal/stream/emit.ts +123 -0
  433. package/src/internal/stream/haltStrategy.ts +94 -0
  434. package/src/internal/stream/handoff.ts +187 -0
  435. package/src/internal/stream/handoffSignal.ts +59 -0
  436. package/src/internal/stream/pull.ts +34 -0
  437. package/src/internal/stream/sinkEndReason.ts +30 -0
  438. package/src/internal/stream/zipAllState.ts +88 -0
  439. package/src/internal/stream/zipChunksState.ts +56 -0
  440. package/src/internal/stream.ts +8801 -0
  441. package/src/internal/string-utils.ts +107 -0
  442. package/src/internal/subscriptionRef.ts +138 -0
  443. package/src/internal/supervisor/patch.ts +190 -0
  444. package/src/internal/supervisor.ts +303 -0
  445. package/src/internal/synchronizedRef.ts +114 -0
  446. package/src/internal/take.ts +199 -0
  447. package/src/internal/testing/sleep.ts +27 -0
  448. package/src/internal/testing/suspendedWarningData.ts +85 -0
  449. package/src/internal/testing/warningData.ts +94 -0
  450. package/src/internal/tracer.ts +150 -0
  451. package/src/internal/trie.ts +722 -0
  452. package/src/internal/version.ts +7 -0
@@ -0,0 +1,287 @@
1
+ /**
2
+ * @since 2.0.0
3
+ */
4
+ import * as Equal from "./Equal.js"
5
+ import * as Dual from "./Function.js"
6
+ import { pipe } from "./Function.js"
7
+ import * as Hash from "./Hash.js"
8
+ import { format, type Inspectable, NodeInspectSymbol, toJSON } from "./Inspectable.js"
9
+ import * as Option from "./Option.js"
10
+ import type { Order } from "./Order.js"
11
+ import type { Pipeable } from "./Pipeable.js"
12
+ import { pipeArguments } from "./Pipeable.js"
13
+ import { hasProperty } from "./Predicate.js"
14
+ import * as RBT from "./RedBlackTree.js"
15
+ import type * as Types from "./Types.js"
16
+
17
+ const TypeId: unique symbol = Symbol.for("effect/SortedMap")
18
+
19
+ /**
20
+ * @since 2.0.0
21
+ * @category symbol
22
+ */
23
+ export type TypeId = typeof TypeId
24
+
25
+ /**
26
+ * @since 2.0.0
27
+ * @category models
28
+ */
29
+ export interface SortedMap<in out K, out V> extends Iterable<[K, V]>, Equal.Equal, Pipeable, Inspectable {
30
+ readonly [TypeId]: {
31
+ readonly _K: Types.Invariant<K>
32
+ readonly _V: Types.Covariant<V>
33
+ }
34
+ /** @internal */
35
+ readonly tree: RBT.RedBlackTree<K, V>
36
+ }
37
+
38
+ const SortedMapProto: Omit<SortedMap<unknown, unknown>, "tree"> = {
39
+ [TypeId]: {
40
+ _K: (_: any) => _,
41
+ _V: (_: never) => _
42
+ },
43
+ [Hash.symbol]<K, V>(this: SortedMap<K, V>): number {
44
+ return pipe(
45
+ Hash.hash(this.tree),
46
+ Hash.combine(Hash.hash("effect/SortedMap")),
47
+ Hash.cached(this)
48
+ )
49
+ },
50
+ [Equal.symbol]<K, V>(this: SortedMap<K, V>, that: unknown): boolean {
51
+ return isSortedMap(that) && Equal.equals(this.tree, that.tree)
52
+ },
53
+ [Symbol.iterator]<K, V>(this: SortedMap<K, V>): Iterator<[K, V]> {
54
+ return this.tree[Symbol.iterator]()
55
+ },
56
+ toString() {
57
+ return format(this.toJSON())
58
+ },
59
+ toJSON() {
60
+ return {
61
+ _id: "SortedMap",
62
+ values: Array.from(this).map(toJSON)
63
+ }
64
+ },
65
+ [NodeInspectSymbol]() {
66
+ return this.toJSON()
67
+ },
68
+ pipe() {
69
+ return pipeArguments(this, arguments)
70
+ }
71
+ }
72
+
73
+ const makeImpl = <K, V>(tree: RBT.RedBlackTree<K, V>): SortedMap<K, V> => {
74
+ const self = Object.create(SortedMapProto)
75
+ self.tree = tree
76
+ return self
77
+ }
78
+
79
+ /**
80
+ * @since 2.0.0
81
+ * @category refinements
82
+ */
83
+ export const isSortedMap: {
84
+ <K, V>(u: Iterable<readonly [K, V]>): u is SortedMap<K, V>
85
+ (u: unknown): u is SortedMap<unknown, unknown>
86
+ } = (u: unknown): u is SortedMap<unknown, unknown> => hasProperty(u, TypeId)
87
+
88
+ /**
89
+ * @since 2.0.0
90
+ * @category constructors
91
+ */
92
+ export const empty = <K, V = never>(ord: Order<K>): SortedMap<K, V> => makeImpl<K, V>(RBT.empty<K, V>(ord))
93
+
94
+ /**
95
+ * Creates a new `SortedMap` from an iterable collection of key/value pairs.
96
+ *
97
+ * @since 2.0.0
98
+ * @category constructors
99
+ */
100
+ export const fromIterable: {
101
+ <B>(ord: Order<B>): <K extends B, V>(iterable: Iterable<readonly [K, V]>) => SortedMap<K, V>
102
+ <K extends B, V, B>(iterable: Iterable<readonly [K, V]>, ord: Order<B>): SortedMap<K, V>
103
+ } = Dual.dual(
104
+ 2,
105
+ <K extends B, V, B>(iterable: Iterable<readonly [K, V]>, ord: Order<B>): SortedMap<K, V> =>
106
+ makeImpl(RBT.fromIterable(iterable, ord))
107
+ )
108
+
109
+ /**
110
+ * @since 2.0.0
111
+ * @category constructors
112
+ */
113
+ export const make =
114
+ <K>(ord: Order<K>) =>
115
+ <Entries extends ReadonlyArray<readonly [K, any]>>(...entries: Entries): SortedMap<
116
+ K,
117
+ Entries[number] extends (readonly [any, infer V]) ? V : never
118
+ > => fromIterable(ord)(entries)
119
+
120
+ /**
121
+ * @since 2.0.0
122
+ * @category predicates
123
+ */
124
+ export const isEmpty = <K, V>(self: SortedMap<K, V>): boolean => size(self) === 0
125
+
126
+ /**
127
+ * @since 2.0.0
128
+ * @category predicates
129
+ */
130
+ export const isNonEmpty = <K, V>(self: SortedMap<K, V>): boolean => size(self) > 0
131
+
132
+ /**
133
+ * @since 2.0.0
134
+ * @category elements
135
+ */
136
+ export const get: {
137
+ <K>(key: K): <V>(self: SortedMap<K, V>) => Option.Option<V>
138
+ <K, V>(self: SortedMap<K, V>, key: K): Option.Option<V>
139
+ } = Dual.dual<
140
+ <K>(key: K) => <V>(self: SortedMap<K, V>) => Option.Option<V>,
141
+ <K, V>(self: SortedMap<K, V>, key: K) => Option.Option<V>
142
+ >(2, (self, key) => RBT.findFirst(self.tree, key))
143
+
144
+ /**
145
+ * Gets the `Order<K>` that the `SortedMap<K, V>` is using.
146
+ *
147
+ * @since 2.0.0
148
+ * @category getters
149
+ */
150
+ export const getOrder = <K, V>(self: SortedMap<K, V>): Order<K> => RBT.getOrder(self.tree)
151
+
152
+ /**
153
+ * @since 2.0.0
154
+ * @category elements
155
+ */
156
+ export const has: {
157
+ <K>(key: K): <V>(self: SortedMap<K, V>) => boolean
158
+ <K, V>(self: SortedMap<K, V>, key: K): boolean
159
+ } = Dual.dual<
160
+ <K>(key: K) => <V>(self: SortedMap<K, V>) => boolean,
161
+ <K, V>(self: SortedMap<K, V>, key: K) => boolean
162
+ >(2, (self, key) => Option.isSome(get(self, key)))
163
+
164
+ /**
165
+ * @since 2.0.0
166
+ * @category elements
167
+ */
168
+ export const headOption = <K, V>(self: SortedMap<K, V>): Option.Option<[K, V]> => RBT.first(self.tree)
169
+
170
+ /**
171
+ * @since 2.0.0
172
+ * @category mapping
173
+ */
174
+ export const map: {
175
+ <A, K, B>(f: (a: A, k: K) => B): (self: SortedMap<K, A>) => SortedMap<K, B>
176
+ <K, A, B>(self: SortedMap<K, A>, f: (a: A, k: K) => B): SortedMap<K, B>
177
+ } = Dual.dual<
178
+ <A, K, B>(f: (a: A, k: K) => B) => (self: SortedMap<K, A>) => SortedMap<K, B>,
179
+ <K, A, B>(self: SortedMap<K, A>, f: (a: A, k: K) => B) => SortedMap<K, B>
180
+ >(2, <K, A, B>(self: SortedMap<K, A>, f: (a: A, k: K) => B) =>
181
+ reduce(
182
+ self,
183
+ empty<K, B>(RBT.getOrder(self.tree)),
184
+ (acc, v, k) => set(acc, k, f(v, k))
185
+ ))
186
+
187
+ /**
188
+ * @since 2.0.0
189
+ * @category folding
190
+ */
191
+ export const reduce: {
192
+ <B, A, K>(zero: B, f: (acc: B, value: A, key: K) => B): (self: SortedMap<K, A>) => B
193
+ <K, A, B>(self: SortedMap<K, A>, zero: B, f: (acc: B, value: A, key: K) => B): B
194
+ } = Dual.dual<
195
+ <B, A, K>(zero: B, f: (acc: B, value: A, key: K) => B) => (self: SortedMap<K, A>) => B,
196
+ <K, A, B>(self: SortedMap<K, A>, zero: B, f: (acc: B, value: A, key: K) => B) => B
197
+ >(3, (self, zero, f) => RBT.reduce(self.tree, zero, f))
198
+
199
+ /**
200
+ * @since 2.0.0
201
+ * @category elements
202
+ */
203
+ export const remove: {
204
+ <K>(key: K): <V>(self: SortedMap<K, V>) => SortedMap<K, V>
205
+ <K, V>(self: SortedMap<K, V>, key: K): SortedMap<K, V>
206
+ } = Dual.dual<
207
+ <K>(key: K) => <V>(self: SortedMap<K, V>) => SortedMap<K, V>,
208
+ <K, V>(self: SortedMap<K, V>, key: K) => SortedMap<K, V>
209
+ >(2, (self, key) => makeImpl(RBT.removeFirst(self.tree, key)))
210
+
211
+ /**
212
+ * @since 2.0.0
213
+ * @category elements
214
+ */
215
+ export const set: {
216
+ <K, V>(key: K, value: V): (self: SortedMap<K, V>) => SortedMap<K, V>
217
+ <K, V>(self: SortedMap<K, V>, key: K, value: V): SortedMap<K, V>
218
+ } = Dual.dual<
219
+ <K, V>(key: K, value: V) => (self: SortedMap<K, V>) => SortedMap<K, V>,
220
+ <K, V>(self: SortedMap<K, V>, key: K, value: V) => SortedMap<K, V>
221
+ >(3, (self, key, value) =>
222
+ RBT.has(self.tree, key)
223
+ ? makeImpl(RBT.insert(RBT.removeFirst(self.tree, key), key, value))
224
+ : makeImpl(RBT.insert(self.tree, key, value)))
225
+
226
+ /**
227
+ * @since 2.0.0
228
+ * @category getters
229
+ */
230
+ export const size = <K, V>(self: SortedMap<K, V>): number => RBT.size(self.tree)
231
+
232
+ /**
233
+ * @since 2.0.0
234
+ * @category getters
235
+ */
236
+ export const keys = <K, V>(self: SortedMap<K, V>): IterableIterator<K> => RBT.keys(self.tree)
237
+
238
+ /**
239
+ * @since 2.0.0
240
+ * @category getters
241
+ */
242
+ export const values = <K, V>(self: SortedMap<K, V>): IterableIterator<V> => RBT.values(self.tree)
243
+
244
+ /**
245
+ * @since 2.0.0
246
+ * @category getters
247
+ */
248
+ export const entries = <K, V>(self: SortedMap<K, V>): IterableIterator<[K, V]> => {
249
+ const iterator: any = self.tree[Symbol.iterator]()
250
+ iterator[Symbol.iterator] = () => entries(self)
251
+ return iterator
252
+ }
253
+
254
+ /**
255
+ * @since 3.1.0
256
+ * @category elements
257
+ */
258
+ export const lastOption = <K, V>(self: SortedMap<K, V>): Option.Option<[K, V]> => RBT.last(self.tree)
259
+
260
+ /**
261
+ * @since 3.1.0
262
+ * @category filtering
263
+ */
264
+ export const partition: {
265
+ <K, V>(
266
+ predicate: (a: Types.NoInfer<K>) => boolean
267
+ ): (self: SortedMap<K, V>) => [excluded: SortedMap<K, V>, satisfying: SortedMap<K, V>]
268
+ <K, V>(self: SortedMap<K, V>, predicate: (a: K) => boolean): [excluded: SortedMap<K, V>, satisfying: SortedMap<K, V>]
269
+ } = Dual.dual(
270
+ 2,
271
+ <K, V>(
272
+ self: SortedMap<K, V>,
273
+ predicate: (a: K) => boolean
274
+ ): [excluded: SortedMap<K, V>, satisfying: SortedMap<K, V>] => {
275
+ const ord = RBT.getOrder(self.tree)
276
+ let right = empty<K, V>(ord)
277
+ let left = empty<K, V>(ord)
278
+ for (const value of self) {
279
+ if (predicate(value[0])) {
280
+ right = set(right, value[0], value[1])
281
+ } else {
282
+ left = set(left, value[0], value[1])
283
+ }
284
+ }
285
+ return [left, right]
286
+ }
287
+ )
@@ -0,0 +1,390 @@
1
+ /**
2
+ * @since 2.0.0
3
+ */
4
+ import * as Equal from "./Equal.js"
5
+ import type * as Equivalence from "./Equivalence.js"
6
+ import * as Dual from "./Function.js"
7
+ import { pipe } from "./Function.js"
8
+ import * as Hash from "./Hash.js"
9
+ import type { Inspectable } from "./Inspectable.js"
10
+ import { format, NodeInspectSymbol, toJSON } from "./Inspectable.js"
11
+ import type { Order } from "./Order.js"
12
+ import type { Pipeable } from "./Pipeable.js"
13
+ import { pipeArguments } from "./Pipeable.js"
14
+ import type { Predicate } from "./Predicate.js"
15
+ import { hasProperty } from "./Predicate.js"
16
+ import * as RBT from "./RedBlackTree.js"
17
+ import type { Invariant, NoInfer } from "./Types.js"
18
+
19
+ const TypeId: unique symbol = Symbol.for("effect/SortedSet")
20
+
21
+ /**
22
+ * @since 2.0.0
23
+ * @category symbol
24
+ */
25
+ export type TypeId = typeof TypeId
26
+
27
+ /**
28
+ * @since 2.0.0
29
+ * @category models
30
+ */
31
+ export interface SortedSet<in out A> extends Iterable<A>, Equal.Equal, Pipeable, Inspectable {
32
+ readonly [TypeId]: {
33
+ readonly _A: Invariant<A>
34
+ }
35
+ /** @internal */
36
+ readonly keyTree: RBT.RedBlackTree<A, boolean>
37
+ }
38
+
39
+ const SortedSetProto: Omit<SortedSet<unknown>, "keyTree"> = {
40
+ [TypeId]: {
41
+ _A: (_: any) => _
42
+ },
43
+ [Hash.symbol]<A>(this: SortedSet<A>): number {
44
+ return pipe(
45
+ Hash.hash(this.keyTree),
46
+ Hash.combine(Hash.hash(TypeId)),
47
+ Hash.cached(this)
48
+ )
49
+ },
50
+ [Equal.symbol]<A>(this: SortedSet<A>, that: unknown): boolean {
51
+ return isSortedSet(that) && Equal.equals(this.keyTree, that.keyTree)
52
+ },
53
+ [Symbol.iterator]<A>(this: SortedSet<A>): Iterator<A> {
54
+ return RBT.keys(this.keyTree)
55
+ },
56
+ toString<A>(this: SortedSet<A>) {
57
+ return format(this.toJSON())
58
+ },
59
+ toJSON() {
60
+ return {
61
+ _id: "SortedSet",
62
+ values: Array.from(this).map(toJSON)
63
+ }
64
+ },
65
+ [NodeInspectSymbol]() {
66
+ return this.toJSON()
67
+ },
68
+ pipe() {
69
+ return pipeArguments(this, arguments)
70
+ }
71
+ }
72
+
73
+ const fromTree = <A>(keyTree: RBT.RedBlackTree<A, boolean>): SortedSet<A> => {
74
+ const a = Object.create(SortedSetProto)
75
+ a.keyTree = keyTree
76
+ return a
77
+ }
78
+
79
+ /**
80
+ * @since 2.0.0
81
+ * @category refinements
82
+ */
83
+ export const isSortedSet: {
84
+ <A>(u: Iterable<A>): u is SortedSet<A>
85
+ (u: unknown): u is SortedSet<unknown>
86
+ } = (u: unknown): u is SortedSet<unknown> => hasProperty(u, TypeId)
87
+
88
+ /**
89
+ * @since 2.0.0
90
+ * @category constructors
91
+ */
92
+ export const empty = <A>(O: Order<A>): SortedSet<A> => fromTree(RBT.empty(O))
93
+
94
+ /**
95
+ * Creates a new `SortedSet` from an iterable collection of values.
96
+ *
97
+ * @since 2.0.0
98
+ * @category constructors
99
+ */
100
+ export const fromIterable: {
101
+ <B>(ord: Order<B>): <A extends B>(iterable: Iterable<A>) => SortedSet<A>
102
+ <A extends B, B>(iterable: Iterable<A>, ord: Order<B>): SortedSet<A>
103
+ } = Dual.dual(
104
+ 2,
105
+ <A extends B, B>(iterable: Iterable<A>, ord: Order<B>): SortedSet<A> =>
106
+ fromTree(RBT.fromIterable(Array.from(iterable).map((k) => [k, true]), ord))
107
+ )
108
+
109
+ /**
110
+ * @since 2.0.0
111
+ * @category constructors
112
+ */
113
+ export const make =
114
+ <K>(ord: Order<K>) => <Entries extends ReadonlyArray<K>>(...entries: Entries): SortedSet<Entries[number]> =>
115
+ fromIterable(entries, ord)
116
+
117
+ /**
118
+ * @since 2.0.0
119
+ * @category elements
120
+ */
121
+ export const add: {
122
+ <A>(value: A): (self: SortedSet<A>) => SortedSet<A>
123
+ <A>(self: SortedSet<A>, value: A): SortedSet<A>
124
+ } = Dual.dual<
125
+ <A>(value: A) => (self: SortedSet<A>) => SortedSet<A>,
126
+ <A>(self: SortedSet<A>, value: A) => SortedSet<A>
127
+ >(2, (self, value) =>
128
+ RBT.has(self.keyTree, value)
129
+ ? self
130
+ : fromTree(RBT.insert(self.keyTree, value, true)))
131
+
132
+ /**
133
+ * @since 2.0.0
134
+ */
135
+ export const difference: {
136
+ <A, B extends A>(that: Iterable<B>): (self: SortedSet<A>) => SortedSet<A>
137
+ <A, B extends A>(self: SortedSet<A>, that: Iterable<B>): SortedSet<A>
138
+ } = Dual.dual<
139
+ <A, B extends A>(that: Iterable<B>) => (self: SortedSet<A>) => SortedSet<A>,
140
+ <A, B extends A>(self: SortedSet<A>, that: Iterable<B>) => SortedSet<A>
141
+ >(2, <A, B extends A>(self: SortedSet<A>, that: Iterable<B>) => {
142
+ let out = self
143
+ for (const value of that) {
144
+ out = remove<A | B>(out, value)
145
+ }
146
+ return out
147
+ })
148
+
149
+ /**
150
+ * Check if a predicate holds true for every `SortedSet` element.
151
+ *
152
+ * @since 2.0.0
153
+ * @category elements
154
+ */
155
+ export const every: {
156
+ <A>(predicate: Predicate<A>): (self: SortedSet<A>) => boolean
157
+ <A>(self: SortedSet<A>, predicate: Predicate<A>): boolean
158
+ } = Dual.dual(2, <A>(self: SortedSet<A>, predicate: Predicate<A>): boolean => {
159
+ for (const value of self) {
160
+ if (!predicate(value)) {
161
+ return false
162
+ }
163
+ }
164
+ return true
165
+ })
166
+
167
+ /**
168
+ * @since 2.0.0
169
+ * @category filtering
170
+ */
171
+ export const filter: {
172
+ <A, B extends A>(predicate: Predicate<B>): (self: SortedSet<A>) => SortedSet<A>
173
+ <A>(self: SortedSet<A>, predicate: Predicate<A>): SortedSet<A>
174
+ } = Dual.dual(2, <A>(self: SortedSet<A>, predicate: Predicate<A>): SortedSet<A> => {
175
+ const ord = RBT.getOrder(self.keyTree)
176
+ let out = empty<A>(ord)
177
+ for (const value of self) {
178
+ if (predicate(value)) {
179
+ out = add(out, value)
180
+ }
181
+ }
182
+ return out
183
+ })
184
+
185
+ /**
186
+ * @since 2.0.0
187
+ * @category sequencing
188
+ */
189
+ export const flatMap: {
190
+ <B, A>(O: Order<B>, f: (a: A) => Iterable<B>): (self: SortedSet<A>) => SortedSet<B>
191
+ <A, B>(self: SortedSet<A>, O: Order<B>, f: (a: A) => Iterable<B>): SortedSet<B>
192
+ } = Dual.dual<
193
+ <B, A>(O: Order<B>, f: (a: A) => Iterable<B>) => (self: SortedSet<A>) => SortedSet<B>,
194
+ <A, B>(self: SortedSet<A>, O: Order<B>, f: (a: A) => Iterable<B>) => SortedSet<B>
195
+ >(3, (self, O, f) => {
196
+ let out = empty(O)
197
+ forEach(self, (a) => {
198
+ for (const b of f(a)) {
199
+ out = add(out, b)
200
+ }
201
+ })
202
+ return out
203
+ })
204
+
205
+ /**
206
+ * @since 2.0.0
207
+ * @category traversing
208
+ */
209
+ export const forEach: {
210
+ <A>(f: (a: A) => void): (self: SortedSet<A>) => void
211
+ <A>(self: SortedSet<A>, f: (a: A) => void): void
212
+ } = Dual.dual<
213
+ <A>(f: (a: A) => void) => (self: SortedSet<A>) => void,
214
+ <A>(self: SortedSet<A>, f: (a: A) => void) => void
215
+ >(2, (self, f) => RBT.forEach(self.keyTree, f))
216
+
217
+ /**
218
+ * @since 2.0.0
219
+ * @category elements
220
+ */
221
+ export const has: {
222
+ <A>(value: A): (self: SortedSet<A>) => boolean
223
+ <A>(self: SortedSet<A>, value: A): boolean
224
+ } = Dual.dual<
225
+ <A>(value: A) => (self: SortedSet<A>) => boolean,
226
+ <A>(self: SortedSet<A>, value: A) => boolean
227
+ >(2, (self, value) => RBT.has(self.keyTree, value))
228
+
229
+ /**
230
+ * @since 2.0.0
231
+ */
232
+ export const intersection: {
233
+ <A>(that: Iterable<A>): (self: SortedSet<A>) => SortedSet<A>
234
+ <A>(self: SortedSet<A>, that: Iterable<A>): SortedSet<A>
235
+ } = Dual.dual<
236
+ <A>(that: Iterable<A>) => (self: SortedSet<A>) => SortedSet<A>,
237
+ <A>(self: SortedSet<A>, that: Iterable<A>) => SortedSet<A>
238
+ >(2, (self, that) => {
239
+ const ord = RBT.getOrder(self.keyTree)
240
+ let out = empty(ord)
241
+ for (const value of that) {
242
+ if (has(self, value)) {
243
+ out = add(out, value)
244
+ }
245
+ }
246
+ return out
247
+ })
248
+
249
+ /**
250
+ * @since 2.0.0
251
+ * @category elements
252
+ */
253
+ export const isSubset: {
254
+ <A>(that: SortedSet<A>): (self: SortedSet<A>) => boolean
255
+ <A>(self: SortedSet<A>, that: SortedSet<A>): boolean
256
+ } = Dual.dual<
257
+ <A>(that: SortedSet<A>) => (self: SortedSet<A>) => boolean,
258
+ <A>(self: SortedSet<A>, that: SortedSet<A>) => boolean
259
+ >(2, (self, that) => every(self, (a) => has(that, a)))
260
+
261
+ /**
262
+ * @since 2.0.0
263
+ * @category mapping
264
+ */
265
+ export const map: {
266
+ <B, A>(O: Order<B>, f: (a: A) => B): (self: SortedSet<A>) => SortedSet<B>
267
+ <B, A>(self: SortedSet<A>, O: Order<B>, f: (a: A) => B): SortedSet<B>
268
+ } = Dual.dual<
269
+ <B, A>(O: Order<B>, f: (a: A) => B) => (self: SortedSet<A>) => SortedSet<B>,
270
+ <B, A>(self: SortedSet<A>, O: Order<B>, f: (a: A) => B) => SortedSet<B>
271
+ >(3, (self, O, f) => {
272
+ let out = empty(O)
273
+ forEach(self, (a) => {
274
+ const b = f(a)
275
+ if (!has(out, b)) {
276
+ out = add(out, b)
277
+ }
278
+ })
279
+ return out
280
+ })
281
+
282
+ /**
283
+ * @since 2.0.0
284
+ * @category filtering
285
+ */
286
+ export const partition: {
287
+ <A>(
288
+ predicate: (a: NoInfer<A>) => boolean
289
+ ): (self: SortedSet<A>) => [excluded: SortedSet<A>, satisfying: SortedSet<A>]
290
+ <A>(self: SortedSet<A>, predicate: (a: A) => boolean): [excluded: SortedSet<A>, satisfying: SortedSet<A>]
291
+ } = Dual.dual(
292
+ 2,
293
+ <A>(self: SortedSet<A>, predicate: (a: A) => boolean): [excluded: SortedSet<A>, satisfying: SortedSet<A>] => {
294
+ const ord = RBT.getOrder(self.keyTree)
295
+ let right = empty(ord)
296
+ let left = empty(ord)
297
+ for (const value of self) {
298
+ if (predicate(value)) {
299
+ right = add(right, value)
300
+ } else {
301
+ left = add(left, value)
302
+ }
303
+ }
304
+ return [left, right]
305
+ }
306
+ )
307
+
308
+ /**
309
+ * @since 2.0.0
310
+ * @category elements
311
+ */
312
+ export const remove: {
313
+ <A>(value: A): (self: SortedSet<A>) => SortedSet<A>
314
+ <A>(self: SortedSet<A>, value: A): SortedSet<A>
315
+ } = Dual.dual<
316
+ <A>(value: A) => (self: SortedSet<A>) => SortedSet<A>,
317
+ <A>(self: SortedSet<A>, value: A) => SortedSet<A>
318
+ >(2, (self, value) => fromTree(RBT.removeFirst(self.keyTree, value)))
319
+
320
+ /**
321
+ * @since 2.0.0
322
+ * @category getters
323
+ */
324
+ export const size = <A>(self: SortedSet<A>): number => RBT.size(self.keyTree)
325
+
326
+ /**
327
+ * Check if a predicate holds true for some `SortedSet` element.
328
+ *
329
+ * @since 2.0.0
330
+ * @category elements
331
+ */
332
+ export const some: {
333
+ <A>(predicate: Predicate<A>): (self: SortedSet<A>) => boolean
334
+ <A>(self: SortedSet<A>, predicate: Predicate<A>): boolean
335
+ } = Dual.dual<
336
+ <A>(predicate: Predicate<A>) => (self: SortedSet<A>) => boolean,
337
+ <A>(self: SortedSet<A>, predicate: Predicate<A>) => boolean
338
+ >(2, (self, predicate) => {
339
+ for (const value of self) {
340
+ if (predicate(value)) {
341
+ return true
342
+ }
343
+ }
344
+ return false
345
+ })
346
+
347
+ /**
348
+ * @since 2.0.0
349
+ * @category elements
350
+ */
351
+ export const toggle: {
352
+ <A>(value: A): (self: SortedSet<A>) => SortedSet<A>
353
+ <A>(self: SortedSet<A>, value: A): SortedSet<A>
354
+ } = Dual.dual<
355
+ <A>(value: A) => (self: SortedSet<A>) => SortedSet<A>,
356
+ <A>(self: SortedSet<A>, value: A) => SortedSet<A>
357
+ >(2, (self, value) => has(self, value) ? remove(self, value) : add(self, value))
358
+
359
+ /**
360
+ * @since 2.0.0
361
+ */
362
+ export const union: {
363
+ <A>(that: Iterable<A>): (self: SortedSet<A>) => SortedSet<A>
364
+ <A>(self: SortedSet<A>, that: Iterable<A>): SortedSet<A>
365
+ } = Dual.dual<
366
+ <A>(that: Iterable<A>) => (self: SortedSet<A>) => SortedSet<A>,
367
+ <A>(self: SortedSet<A>, that: Iterable<A>) => SortedSet<A>
368
+ >(2, <A>(self: SortedSet<A>, that: Iterable<A>) => {
369
+ const ord = RBT.getOrder(self.keyTree)
370
+ let out = empty<A>(ord)
371
+ for (const value of self) {
372
+ out = add(value)(out)
373
+ }
374
+ for (const value of that) {
375
+ out = add(value)(out)
376
+ }
377
+ return out
378
+ })
379
+
380
+ /**
381
+ * @since 2.0.0
382
+ * @category getters
383
+ */
384
+ export const values = <A>(self: SortedSet<A>): IterableIterator<A> => RBT.keys(self.keyTree)
385
+
386
+ /**
387
+ * @since 2.0.0
388
+ * @category equivalence
389
+ */
390
+ export const getEquivalence = <A>(): Equivalence.Equivalence<SortedSet<A>> => (a, b) => isSubset(a, b) && isSubset(b, a)