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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (452) hide show
  1. package/SourceLocation/package.json +6 -0
  2. package/dist/cjs/Effect.js +2 -28
  3. package/dist/cjs/Effect.js.map +1 -1
  4. package/dist/cjs/FiberRef.js +12 -1
  5. package/dist/cjs/FiberRef.js.map +1 -1
  6. package/dist/cjs/Layer.js +2 -24
  7. package/dist/cjs/Layer.js.map +1 -1
  8. package/dist/cjs/RuntimeFlags.js +1 -29
  9. package/dist/cjs/RuntimeFlags.js.map +1 -1
  10. package/dist/cjs/SourceLocation.js +60 -0
  11. package/dist/cjs/SourceLocation.js.map +1 -0
  12. package/dist/cjs/Tracer.js +1 -15
  13. package/dist/cjs/Tracer.js.map +1 -1
  14. package/dist/cjs/Utils.js +1 -1
  15. package/dist/cjs/Utils.js.map +1 -1
  16. package/dist/cjs/index.js +3 -1
  17. package/dist/cjs/index.js.map +1 -1
  18. package/dist/cjs/internal/clock.js +1 -1
  19. package/dist/cjs/internal/clock.js.map +1 -1
  20. package/dist/cjs/internal/core.js +17 -50
  21. package/dist/cjs/internal/core.js.map +1 -1
  22. package/dist/cjs/internal/effect/circular.js +18 -30
  23. package/dist/cjs/internal/effect/circular.js.map +1 -1
  24. package/dist/cjs/internal/fiberRuntime.js +16 -65
  25. package/dist/cjs/internal/fiberRuntime.js.map +1 -1
  26. package/dist/cjs/internal/layer/circular.js +1 -5
  27. package/dist/cjs/internal/layer/circular.js.map +1 -1
  28. package/dist/cjs/internal/layer.js +1 -3
  29. package/dist/cjs/internal/layer.js.map +1 -1
  30. package/dist/cjs/internal/logger.js +25 -2
  31. package/dist/cjs/internal/logger.js.map +1 -1
  32. package/dist/cjs/internal/runtimeFlags.js +2 -11
  33. package/dist/cjs/internal/runtimeFlags.js.map +1 -1
  34. package/dist/cjs/internal/tracer.js +1 -114
  35. package/dist/cjs/internal/tracer.js.map +1 -1
  36. package/dist/dts/Config.d.ts +2 -2
  37. package/dist/dts/Config.d.ts.map +1 -1
  38. package/dist/dts/Effect.d.ts +8 -29
  39. package/dist/dts/Effect.d.ts.map +1 -1
  40. package/dist/dts/FiberRef.d.ts +12 -0
  41. package/dist/dts/FiberRef.d.ts.map +1 -1
  42. package/dist/dts/Layer.d.ts +0 -22
  43. package/dist/dts/Layer.d.ts.map +1 -1
  44. package/dist/dts/RuntimeFlags.d.ts +0 -28
  45. package/dist/dts/RuntimeFlags.d.ts.map +1 -1
  46. package/dist/dts/SourceLocation.d.ts +88 -0
  47. package/dist/dts/SourceLocation.d.ts.map +1 -0
  48. package/dist/dts/Tracer.d.ts +0 -15
  49. package/dist/dts/Tracer.d.ts.map +1 -1
  50. package/dist/dts/index.d.ts +6 -0
  51. package/dist/dts/index.d.ts.map +1 -1
  52. package/dist/dts/internal/core.d.ts.map +1 -1
  53. package/dist/dts/internal/layer.d.ts.map +1 -1
  54. package/dist/dts/internal/runtimeFlags.d.ts.map +1 -1
  55. package/dist/esm/Effect.js +0 -26
  56. package/dist/esm/Effect.js.map +1 -1
  57. package/dist/esm/FiberRef.js +11 -0
  58. package/dist/esm/FiberRef.js.map +1 -1
  59. package/dist/esm/Layer.js +0 -22
  60. package/dist/esm/Layer.js.map +1 -1
  61. package/dist/esm/RuntimeFlags.js +0 -28
  62. package/dist/esm/RuntimeFlags.js.map +1 -1
  63. package/dist/esm/SourceLocation.js +51 -0
  64. package/dist/esm/SourceLocation.js.map +1 -0
  65. package/dist/esm/Tracer.js +0 -14
  66. package/dist/esm/Tracer.js.map +1 -1
  67. package/dist/esm/Utils.js +1 -1
  68. package/dist/esm/Utils.js.map +1 -1
  69. package/dist/esm/index.js +6 -0
  70. package/dist/esm/index.js.map +1 -1
  71. package/dist/esm/internal/clock.js +1 -1
  72. package/dist/esm/internal/clock.js.map +1 -1
  73. package/dist/esm/internal/core.js +12 -45
  74. package/dist/esm/internal/core.js.map +1 -1
  75. package/dist/esm/internal/effect/circular.js +18 -30
  76. package/dist/esm/internal/effect/circular.js.map +1 -1
  77. package/dist/esm/internal/fiberRuntime.js +13 -60
  78. package/dist/esm/internal/fiberRuntime.js.map +1 -1
  79. package/dist/esm/internal/layer/circular.js +0 -4
  80. package/dist/esm/internal/layer/circular.js.map +1 -1
  81. package/dist/esm/internal/layer.js +0 -2
  82. package/dist/esm/internal/layer.js.map +1 -1
  83. package/dist/esm/internal/logger.js +25 -2
  84. package/dist/esm/internal/logger.js.map +1 -1
  85. package/dist/esm/internal/runtimeFlags.js +1 -9
  86. package/dist/esm/internal/runtimeFlags.js.map +1 -1
  87. package/dist/esm/internal/tracer.js +0 -111
  88. package/dist/esm/internal/tracer.js.map +1 -1
  89. package/package.json +12 -1
  90. package/src/Arbitrary.ts +1101 -0
  91. package/src/Array.ts +3589 -0
  92. package/src/BigDecimal.ts +1349 -0
  93. package/src/BigInt.ts +643 -0
  94. package/src/Boolean.ts +287 -0
  95. package/src/Brand.ts +360 -0
  96. package/src/Cache.ts +281 -0
  97. package/src/Cause.ts +1555 -0
  98. package/src/Channel.ts +2355 -0
  99. package/src/ChildExecutorDecision.ts +146 -0
  100. package/src/Chunk.ts +1495 -0
  101. package/src/Clock.ts +111 -0
  102. package/src/Config.ts +542 -0
  103. package/src/ConfigError.ts +270 -0
  104. package/src/ConfigProvider.ts +333 -0
  105. package/src/ConfigProviderPathPatch.ts +100 -0
  106. package/src/Console.ts +226 -0
  107. package/src/Context.ts +585 -0
  108. package/src/Cron.ts +706 -0
  109. package/src/Data.ts +596 -0
  110. package/src/DateTime.ts +1686 -0
  111. package/src/DefaultServices.ts +34 -0
  112. package/src/Deferred.ts +301 -0
  113. package/src/Differ.ts +450 -0
  114. package/src/Duration.ts +1000 -0
  115. package/src/Effect.ts +14817 -0
  116. package/src/Effectable.ts +107 -0
  117. package/src/Either.ts +1040 -0
  118. package/src/Encoding.ts +195 -0
  119. package/src/Equal.ts +98 -0
  120. package/src/Equivalence.ts +235 -0
  121. package/src/ExecutionPlan.ts +308 -0
  122. package/src/ExecutionStrategy.ts +119 -0
  123. package/src/Exit.ts +467 -0
  124. package/src/FastCheck.ts +9 -0
  125. package/src/Fiber.ts +744 -0
  126. package/src/FiberHandle.ts +540 -0
  127. package/src/FiberId.ts +195 -0
  128. package/src/FiberMap.ts +656 -0
  129. package/src/FiberRef.ts +444 -0
  130. package/src/FiberRefs.ts +204 -0
  131. package/src/FiberRefsPatch.ts +105 -0
  132. package/src/FiberSet.ts +491 -0
  133. package/src/FiberStatus.ts +108 -0
  134. package/src/Function.ts +1222 -0
  135. package/src/GlobalValue.ts +53 -0
  136. package/src/Graph.ts +3732 -0
  137. package/src/GroupBy.ts +103 -0
  138. package/src/HKT.ts +45 -0
  139. package/src/Hash.ts +195 -0
  140. package/src/HashMap.ts +519 -0
  141. package/src/HashRing.ts +317 -0
  142. package/src/HashSet.ts +2346 -0
  143. package/src/Inspectable.ts +287 -0
  144. package/src/Iterable.ts +1119 -0
  145. package/src/JSONSchema.ts +1044 -0
  146. package/src/KeyedPool.ts +167 -0
  147. package/src/Layer.ts +1228 -0
  148. package/src/LayerMap.ts +436 -0
  149. package/src/List.ts +977 -0
  150. package/src/LogLevel.ts +285 -0
  151. package/src/LogSpan.ts +25 -0
  152. package/src/Logger.ts +702 -0
  153. package/src/Mailbox.ts +268 -0
  154. package/src/ManagedRuntime.ts +180 -0
  155. package/src/Match.ts +1477 -0
  156. package/src/MergeDecision.ts +95 -0
  157. package/src/MergeState.ts +172 -0
  158. package/src/MergeStrategy.ts +107 -0
  159. package/src/Metric.ts +780 -0
  160. package/src/MetricBoundaries.ts +69 -0
  161. package/src/MetricHook.ts +151 -0
  162. package/src/MetricKey.ts +224 -0
  163. package/src/MetricKeyType.ts +262 -0
  164. package/src/MetricLabel.ts +47 -0
  165. package/src/MetricPair.ts +71 -0
  166. package/src/MetricPolling.ts +148 -0
  167. package/src/MetricRegistry.ts +48 -0
  168. package/src/MetricState.ts +257 -0
  169. package/src/Micro.ts +4405 -0
  170. package/src/ModuleVersion.ts +18 -0
  171. package/src/MutableHashMap.ts +411 -0
  172. package/src/MutableHashSet.ts +706 -0
  173. package/src/MutableList.ts +297 -0
  174. package/src/MutableQueue.ts +227 -0
  175. package/src/MutableRef.ts +202 -0
  176. package/src/NonEmptyIterable.ts +32 -0
  177. package/src/Number.ts +1071 -0
  178. package/src/Option.ts +2170 -0
  179. package/src/Order.ts +373 -0
  180. package/src/Ordering.ts +111 -0
  181. package/src/ParseResult.ts +2031 -0
  182. package/src/PartitionedSemaphore.ts +200 -0
  183. package/src/Pipeable.ts +566 -0
  184. package/src/Pool.ts +204 -0
  185. package/src/Predicate.ts +1405 -0
  186. package/src/Pretty.ts +205 -0
  187. package/src/PrimaryKey.ts +23 -0
  188. package/src/PubSub.ts +182 -0
  189. package/src/Queue.ts +644 -0
  190. package/src/Random.ts +204 -0
  191. package/src/RateLimiter.ts +138 -0
  192. package/src/RcMap.ts +141 -0
  193. package/src/RcRef.ts +122 -0
  194. package/src/Readable.ts +93 -0
  195. package/src/Record.ts +1274 -0
  196. package/src/RedBlackTree.ts +421 -0
  197. package/src/Redacted.ts +144 -0
  198. package/src/Ref.ts +180 -0
  199. package/src/RegExp.ts +38 -0
  200. package/src/Reloadable.ts +127 -0
  201. package/src/Request.ts +347 -0
  202. package/src/RequestBlock.ts +118 -0
  203. package/src/RequestResolver.ts +366 -0
  204. package/src/Resource.ts +119 -0
  205. package/src/Runtime.ts +383 -0
  206. package/src/RuntimeFlags.ts +336 -0
  207. package/src/RuntimeFlagsPatch.ts +183 -0
  208. package/src/STM.ts +2045 -0
  209. package/src/Schedule.ts +2219 -0
  210. package/src/ScheduleDecision.ts +62 -0
  211. package/src/ScheduleInterval.ts +151 -0
  212. package/src/ScheduleIntervals.ts +122 -0
  213. package/src/Scheduler.ts +353 -0
  214. package/src/Schema.ts +10914 -0
  215. package/src/SchemaAST.ts +3043 -0
  216. package/src/Scope.ts +204 -0
  217. package/src/ScopedCache.ts +151 -0
  218. package/src/ScopedRef.ts +117 -0
  219. package/src/Secret.ts +88 -0
  220. package/src/SingleProducerAsyncInput.ts +67 -0
  221. package/src/Sink.ts +1461 -0
  222. package/src/SortedMap.ts +287 -0
  223. package/src/SortedSet.ts +390 -0
  224. package/src/SourceLocation.ts +108 -0
  225. package/src/Stream.ts +6468 -0
  226. package/src/StreamEmit.ts +136 -0
  227. package/src/StreamHaltStrategy.ts +123 -0
  228. package/src/Streamable.ts +45 -0
  229. package/src/String.ts +778 -0
  230. package/src/Struct.ts +243 -0
  231. package/src/Subscribable.ts +100 -0
  232. package/src/SubscriptionRef.ts +298 -0
  233. package/src/Supervisor.ts +240 -0
  234. package/src/Symbol.ts +29 -0
  235. package/src/SynchronizedRef.ts +270 -0
  236. package/src/TArray.ts +495 -0
  237. package/src/TDeferred.ts +100 -0
  238. package/src/TMap.ts +515 -0
  239. package/src/TPriorityQueue.ts +223 -0
  240. package/src/TPubSub.ts +200 -0
  241. package/src/TQueue.ts +432 -0
  242. package/src/TRandom.ts +129 -0
  243. package/src/TReentrantLock.ts +224 -0
  244. package/src/TRef.ts +178 -0
  245. package/src/TSemaphore.ts +129 -0
  246. package/src/TSet.ts +365 -0
  247. package/src/TSubscriptionRef.ts +192 -0
  248. package/src/Take.ts +258 -0
  249. package/src/TestAnnotation.ts +158 -0
  250. package/src/TestAnnotationMap.ts +119 -0
  251. package/src/TestAnnotations.ts +117 -0
  252. package/src/TestClock.ts +556 -0
  253. package/src/TestConfig.ts +47 -0
  254. package/src/TestContext.ts +36 -0
  255. package/src/TestLive.ts +53 -0
  256. package/src/TestServices.ts +390 -0
  257. package/src/TestSized.ts +55 -0
  258. package/src/Tracer.ts +182 -0
  259. package/src/Trie.ts +840 -0
  260. package/src/Tuple.ts +305 -0
  261. package/src/Types.ts +353 -0
  262. package/src/Unify.ts +113 -0
  263. package/src/UpstreamPullRequest.ts +117 -0
  264. package/src/UpstreamPullStrategy.ts +121 -0
  265. package/src/Utils.ts +809 -0
  266. package/src/index.ts +1568 -0
  267. package/src/internal/array.ts +8 -0
  268. package/src/internal/blockedRequests.ts +520 -0
  269. package/src/internal/cache.ts +733 -0
  270. package/src/internal/cause.ts +1050 -0
  271. package/src/internal/channel/channelExecutor.ts +1200 -0
  272. package/src/internal/channel/channelState.ts +134 -0
  273. package/src/internal/channel/childExecutorDecision.ts +96 -0
  274. package/src/internal/channel/continuation.ts +200 -0
  275. package/src/internal/channel/mergeDecision.ts +113 -0
  276. package/src/internal/channel/mergeState.ts +120 -0
  277. package/src/internal/channel/mergeStrategy.ts +72 -0
  278. package/src/internal/channel/singleProducerAsyncInput.ts +259 -0
  279. package/src/internal/channel/subexecutor.ts +229 -0
  280. package/src/internal/channel/upstreamPullRequest.ts +84 -0
  281. package/src/internal/channel/upstreamPullStrategy.ts +87 -0
  282. package/src/internal/channel.ts +2603 -0
  283. package/src/internal/clock.ts +95 -0
  284. package/src/internal/completedRequestMap.ts +9 -0
  285. package/src/internal/concurrency.ts +54 -0
  286. package/src/internal/config.ts +716 -0
  287. package/src/internal/configError.ts +304 -0
  288. package/src/internal/configProvider/pathPatch.ts +97 -0
  289. package/src/internal/configProvider.ts +799 -0
  290. package/src/internal/console.ts +153 -0
  291. package/src/internal/context.ts +337 -0
  292. package/src/internal/core-effect.ts +2293 -0
  293. package/src/internal/core-stream.ts +998 -0
  294. package/src/internal/core.ts +3189 -0
  295. package/src/internal/data.ts +36 -0
  296. package/src/internal/dataSource.ts +327 -0
  297. package/src/internal/dateTime.ts +1277 -0
  298. package/src/internal/defaultServices/console.ts +100 -0
  299. package/src/internal/defaultServices.ts +163 -0
  300. package/src/internal/deferred.ts +46 -0
  301. package/src/internal/differ/chunkPatch.ts +211 -0
  302. package/src/internal/differ/contextPatch.ts +232 -0
  303. package/src/internal/differ/hashMapPatch.ts +220 -0
  304. package/src/internal/differ/hashSetPatch.ts +176 -0
  305. package/src/internal/differ/orPatch.ts +311 -0
  306. package/src/internal/differ/readonlyArrayPatch.ts +210 -0
  307. package/src/internal/differ.ts +200 -0
  308. package/src/internal/doNotation.ts +80 -0
  309. package/src/internal/effect/circular.ts +895 -0
  310. package/src/internal/effectable.ts +131 -0
  311. package/src/internal/either.ts +110 -0
  312. package/src/internal/encoding/base64.ts +286 -0
  313. package/src/internal/encoding/base64Url.ts +29 -0
  314. package/src/internal/encoding/common.ts +51 -0
  315. package/src/internal/encoding/hex.ts +315 -0
  316. package/src/internal/errors.ts +7 -0
  317. package/src/internal/executionPlan.ts +114 -0
  318. package/src/internal/executionStrategy.ts +74 -0
  319. package/src/internal/fiber.ts +388 -0
  320. package/src/internal/fiberId.ts +267 -0
  321. package/src/internal/fiberMessage.ts +82 -0
  322. package/src/internal/fiberRefs/patch.ts +144 -0
  323. package/src/internal/fiberRefs.ts +297 -0
  324. package/src/internal/fiberRuntime.ts +3842 -0
  325. package/src/internal/fiberScope.ts +71 -0
  326. package/src/internal/fiberStatus.ts +119 -0
  327. package/src/internal/groupBy.ts +530 -0
  328. package/src/internal/hashMap/array.ts +49 -0
  329. package/src/internal/hashMap/bitwise.ts +32 -0
  330. package/src/internal/hashMap/config.ts +14 -0
  331. package/src/internal/hashMap/keySet.ts +8 -0
  332. package/src/internal/hashMap/node.ts +391 -0
  333. package/src/internal/hashMap.ts +586 -0
  334. package/src/internal/hashSet.ts +323 -0
  335. package/src/internal/keyedPool.ts +244 -0
  336. package/src/internal/layer/circular.ts +214 -0
  337. package/src/internal/layer.ts +1483 -0
  338. package/src/internal/logSpan.ts +20 -0
  339. package/src/internal/logger-circular.ts +24 -0
  340. package/src/internal/logger.ts +522 -0
  341. package/src/internal/mailbox.ts +561 -0
  342. package/src/internal/managedRuntime/circular.ts +6 -0
  343. package/src/internal/managedRuntime.ts +134 -0
  344. package/src/internal/matcher.ts +652 -0
  345. package/src/internal/metric/boundaries.ts +75 -0
  346. package/src/internal/metric/hook.ts +483 -0
  347. package/src/internal/metric/key.ts +167 -0
  348. package/src/internal/metric/keyType.ts +238 -0
  349. package/src/internal/metric/label.ts +41 -0
  350. package/src/internal/metric/pair.ts +48 -0
  351. package/src/internal/metric/polling.ts +149 -0
  352. package/src/internal/metric/registry.ts +187 -0
  353. package/src/internal/metric/state.ts +290 -0
  354. package/src/internal/metric.ts +577 -0
  355. package/src/internal/opCodes/cause.ts +35 -0
  356. package/src/internal/opCodes/channel.ts +83 -0
  357. package/src/internal/opCodes/channelChildExecutorDecision.ts +17 -0
  358. package/src/internal/opCodes/channelMergeDecision.ts +11 -0
  359. package/src/internal/opCodes/channelMergeState.ts +17 -0
  360. package/src/internal/opCodes/channelMergeStrategy.ts +11 -0
  361. package/src/internal/opCodes/channelState.ts +23 -0
  362. package/src/internal/opCodes/channelUpstreamPullRequest.ts +11 -0
  363. package/src/internal/opCodes/channelUpstreamPullStrategy.ts +11 -0
  364. package/src/internal/opCodes/config.ts +65 -0
  365. package/src/internal/opCodes/configError.ts +35 -0
  366. package/src/internal/opCodes/continuation.ts +11 -0
  367. package/src/internal/opCodes/deferred.ts +11 -0
  368. package/src/internal/opCodes/effect.ts +89 -0
  369. package/src/internal/opCodes/layer.ts +59 -0
  370. package/src/internal/opCodes/streamHaltStrategy.ts +23 -0
  371. package/src/internal/option.ts +80 -0
  372. package/src/internal/pool.ts +432 -0
  373. package/src/internal/pubsub.ts +1762 -0
  374. package/src/internal/query.ts +204 -0
  375. package/src/internal/queue.ts +766 -0
  376. package/src/internal/random.ts +161 -0
  377. package/src/internal/rateLimiter.ts +93 -0
  378. package/src/internal/rcMap.ts +285 -0
  379. package/src/internal/rcRef.ts +192 -0
  380. package/src/internal/redBlackTree/iterator.ts +200 -0
  381. package/src/internal/redBlackTree/node.ts +68 -0
  382. package/src/internal/redBlackTree.ts +1245 -0
  383. package/src/internal/redacted.ts +73 -0
  384. package/src/internal/ref.ts +171 -0
  385. package/src/internal/reloadable.ts +140 -0
  386. package/src/internal/request.ts +177 -0
  387. package/src/internal/resource.ts +76 -0
  388. package/src/internal/ringBuffer.ts +68 -0
  389. package/src/internal/runtime.ts +558 -0
  390. package/src/internal/runtimeFlags.ts +178 -0
  391. package/src/internal/runtimeFlagsPatch.ts +103 -0
  392. package/src/internal/schedule/decision.ts +47 -0
  393. package/src/internal/schedule/interval.ts +101 -0
  394. package/src/internal/schedule/intervals.ts +180 -0
  395. package/src/internal/schedule.ts +2199 -0
  396. package/src/internal/schema/errors.ts +191 -0
  397. package/src/internal/schema/schemaId.ts +106 -0
  398. package/src/internal/schema/util.ts +50 -0
  399. package/src/internal/scopedCache.ts +644 -0
  400. package/src/internal/scopedRef.ts +118 -0
  401. package/src/internal/secret.ts +89 -0
  402. package/src/internal/singleShotGen.ts +35 -0
  403. package/src/internal/sink.ts +2120 -0
  404. package/src/internal/stack.ts +10 -0
  405. package/src/internal/stm/core.ts +817 -0
  406. package/src/internal/stm/entry.ts +59 -0
  407. package/src/internal/stm/journal.ts +123 -0
  408. package/src/internal/stm/opCodes/stm.ts +71 -0
  409. package/src/internal/stm/opCodes/stmState.ts +17 -0
  410. package/src/internal/stm/opCodes/strategy.ts +17 -0
  411. package/src/internal/stm/opCodes/tExit.ts +29 -0
  412. package/src/internal/stm/opCodes/tryCommit.ts +11 -0
  413. package/src/internal/stm/stm.ts +1453 -0
  414. package/src/internal/stm/stmState.ts +136 -0
  415. package/src/internal/stm/tArray.ts +550 -0
  416. package/src/internal/stm/tDeferred.ts +81 -0
  417. package/src/internal/stm/tExit.ts +190 -0
  418. package/src/internal/stm/tMap.ts +824 -0
  419. package/src/internal/stm/tPriorityQueue.ts +267 -0
  420. package/src/internal/stm/tPubSub.ts +551 -0
  421. package/src/internal/stm/tQueue.ts +393 -0
  422. package/src/internal/stm/tRandom.ts +140 -0
  423. package/src/internal/stm/tReentrantLock.ts +352 -0
  424. package/src/internal/stm/tRef.ts +195 -0
  425. package/src/internal/stm/tSemaphore.ts +113 -0
  426. package/src/internal/stm/tSet.ts +259 -0
  427. package/src/internal/stm/tSubscriptionRef.ts +286 -0
  428. package/src/internal/stm/tryCommit.ts +34 -0
  429. package/src/internal/stm/txnId.ts +14 -0
  430. package/src/internal/stm/versioned.ts +4 -0
  431. package/src/internal/stream/debounceState.ts +57 -0
  432. package/src/internal/stream/emit.ts +123 -0
  433. package/src/internal/stream/haltStrategy.ts +94 -0
  434. package/src/internal/stream/handoff.ts +187 -0
  435. package/src/internal/stream/handoffSignal.ts +59 -0
  436. package/src/internal/stream/pull.ts +34 -0
  437. package/src/internal/stream/sinkEndReason.ts +30 -0
  438. package/src/internal/stream/zipAllState.ts +88 -0
  439. package/src/internal/stream/zipChunksState.ts +56 -0
  440. package/src/internal/stream.ts +8801 -0
  441. package/src/internal/string-utils.ts +107 -0
  442. package/src/internal/subscriptionRef.ts +138 -0
  443. package/src/internal/supervisor/patch.ts +190 -0
  444. package/src/internal/supervisor.ts +303 -0
  445. package/src/internal/synchronizedRef.ts +114 -0
  446. package/src/internal/take.ts +199 -0
  447. package/src/internal/testing/sleep.ts +27 -0
  448. package/src/internal/testing/suspendedWarningData.ts +85 -0
  449. package/src/internal/testing/warningData.ts +94 -0
  450. package/src/internal/tracer.ts +150 -0
  451. package/src/internal/trie.ts +722 -0
  452. package/src/internal/version.ts +7 -0
package/src/String.ts ADDED
@@ -0,0 +1,778 @@
1
+ /**
2
+ * This module provides utility functions and type class instances for working with the `string` type in TypeScript.
3
+ * It includes functions for basic string manipulation, as well as type class instances for
4
+ * `Equivalence` and `Order`.
5
+ *
6
+ * @since 2.0.0
7
+ */
8
+
9
+ import type { NonEmptyArray } from "./Array.js"
10
+ import * as equivalence from "./Equivalence.js"
11
+ import { dual } from "./Function.js"
12
+ import * as readonlyArray from "./internal/array.js"
13
+ import * as number from "./Number.js"
14
+ import * as Option from "./Option.js"
15
+ import * as order from "./Order.js"
16
+ import type * as Ordering from "./Ordering.js"
17
+ import type { Refinement } from "./Predicate.js"
18
+ import * as predicate from "./Predicate.js"
19
+
20
+ /**
21
+ * Tests if a value is a `string`.
22
+ *
23
+ * @example
24
+ * ```ts
25
+ * import * as assert from "node:assert"
26
+ * import { String } from "effect"
27
+ *
28
+ * assert.deepStrictEqual(String.isString("a"), true)
29
+ * assert.deepStrictEqual(String.isString(1), false)
30
+ * ```
31
+ *
32
+ * @category guards
33
+ * @since 2.0.0
34
+ */
35
+ export const isString: Refinement<unknown, string> = predicate.isString
36
+
37
+ /**
38
+ * @category instances
39
+ * @since 2.0.0
40
+ */
41
+ export const Equivalence: equivalence.Equivalence<string> = equivalence.string
42
+
43
+ /**
44
+ * @category instances
45
+ * @since 2.0.0
46
+ */
47
+ export const Order: order.Order<string> = order.string
48
+
49
+ /**
50
+ * The empty string `""`.
51
+ *
52
+ * @since 2.0.0
53
+ */
54
+ export const empty: "" = "" as const
55
+
56
+ /**
57
+ * Concatenates two strings at the type level.
58
+ *
59
+ * @since 2.0.0
60
+ */
61
+ export type Concat<A extends string, B extends string> = `${A}${B}`
62
+
63
+ /**
64
+ * Concatenates two strings at runtime.
65
+ *
66
+ * @since 2.0.0
67
+ */
68
+ export const concat: {
69
+ <B extends string>(that: B): <A extends string>(self: A) => Concat<A, B>
70
+ <A extends string, B extends string>(self: A, that: B): Concat<A, B>
71
+ } = dual(2, (self: string, that: string): string => self + that)
72
+
73
+ /**
74
+ * @example
75
+ * ```ts
76
+ * import * as assert from "node:assert"
77
+ * import { pipe, String } from "effect"
78
+ *
79
+ * assert.deepStrictEqual(pipe('a', String.toUpperCase), 'A')
80
+ * ```
81
+ *
82
+ * @since 2.0.0
83
+ */
84
+ export const toUpperCase = <S extends string>(self: S): Uppercase<S> => self.toUpperCase() as Uppercase<S>
85
+
86
+ /**
87
+ * @example
88
+ * ```ts
89
+ * import * as assert from "node:assert"
90
+ * import { pipe, String } from "effect"
91
+ *
92
+ * assert.deepStrictEqual(pipe('A', String.toLowerCase), 'a')
93
+ * ```
94
+ *
95
+ * @since 2.0.0
96
+ */
97
+ export const toLowerCase = <T extends string>(self: T): Lowercase<T> => self.toLowerCase() as Lowercase<T>
98
+
99
+ /**
100
+ * @example
101
+ * ```ts
102
+ * import * as assert from "node:assert"
103
+ * import { pipe, String } from "effect"
104
+ *
105
+ * assert.deepStrictEqual(pipe('abc', String.capitalize), 'Abc')
106
+ * ```
107
+ *
108
+ * @since 2.0.0
109
+ */
110
+ export const capitalize = <T extends string>(self: T): Capitalize<T> => {
111
+ if (self.length === 0) return self as Capitalize<T>
112
+
113
+ return (toUpperCase(self[0]) + self.slice(1)) as Capitalize<T>
114
+ }
115
+
116
+ /**
117
+ * @example
118
+ * ```ts
119
+ * import * as assert from "node:assert"
120
+ * import { pipe, String } from "effect"
121
+ *
122
+ * assert.deepStrictEqual(pipe('ABC', String.uncapitalize), 'aBC')
123
+ * ```
124
+ *
125
+ * @since 2.0.0
126
+ */
127
+ export const uncapitalize = <T extends string>(self: T): Uncapitalize<T> => {
128
+ if (self.length === 0) return self as Uncapitalize<T>
129
+
130
+ return (toLowerCase(self[0]) + self.slice(1)) as Uncapitalize<T>
131
+ }
132
+
133
+ /**
134
+ * @example
135
+ * ```ts
136
+ * import * as assert from "node:assert"
137
+ * import { pipe, String } from "effect"
138
+ *
139
+ * assert.deepStrictEqual(pipe('abc', String.replace('b', 'd')), 'adc')
140
+ * ```
141
+ *
142
+ * @since 2.0.0
143
+ */
144
+ export const replace = (searchValue: string | RegExp, replaceValue: string) => (self: string): string =>
145
+ self.replace(searchValue, replaceValue)
146
+
147
+ /**
148
+ * @since 2.0.0
149
+ */
150
+ export type Trim<A extends string> = TrimEnd<TrimStart<A>>
151
+
152
+ /**
153
+ * @example
154
+ * ```ts
155
+ * import * as assert from "node:assert"
156
+ * import { String } from "effect"
157
+ *
158
+ * assert.deepStrictEqual(String.trim(' a '), 'a')
159
+ * ```
160
+ *
161
+ * @since 2.0.0
162
+ */
163
+ export const trim = <A extends string>(self: A): Trim<A> => self.trim() as Trim<A>
164
+
165
+ /**
166
+ * @since 2.0.0
167
+ */
168
+ export type TrimStart<A extends string> = A extends `${" " | "\n" | "\t" | "\r"}${infer B}` ? TrimStart<B> : A
169
+
170
+ /**
171
+ * @example
172
+ * ```ts
173
+ * import * as assert from "node:assert"
174
+ * import { String } from "effect"
175
+ *
176
+ * assert.deepStrictEqual(String.trimStart(' a '), 'a ')
177
+ * ```
178
+ *
179
+ * @since 2.0.0
180
+ */
181
+ export const trimStart = <A extends string>(self: A): TrimStart<A> => self.trimStart() as TrimStart<A>
182
+
183
+ /**
184
+ * @since 2.0.0
185
+ */
186
+ export type TrimEnd<A extends string> = A extends `${infer B}${" " | "\n" | "\t" | "\r"}` ? TrimEnd<B> : A
187
+
188
+ /**
189
+ * @example
190
+ * ```ts
191
+ * import * as assert from "node:assert"
192
+ * import { String } from "effect"
193
+ *
194
+ * assert.deepStrictEqual(String.trimEnd(' a '), ' a')
195
+ * ```
196
+ *
197
+ * @since 2.0.0
198
+ */
199
+ export const trimEnd = <A extends string>(self: A): TrimEnd<A> => self.trimEnd() as TrimEnd<A>
200
+
201
+ /**
202
+ * @example
203
+ * ```ts
204
+ * import * as assert from "node:assert"
205
+ * import { pipe, String } from "effect"
206
+ *
207
+ * assert.deepStrictEqual(pipe('abcd', String.slice(1, 3)), 'bc')
208
+ * ```
209
+ *
210
+ * @since 2.0.0
211
+ */
212
+ export const slice = (start?: number, end?: number) => (self: string): string => self.slice(start, end)
213
+
214
+ /**
215
+ * Test whether a `string` is empty.
216
+ *
217
+ * @example
218
+ * ```ts
219
+ * import * as assert from "node:assert"
220
+ * import { String } from "effect"
221
+ *
222
+ * assert.deepStrictEqual(String.isEmpty(''), true)
223
+ * assert.deepStrictEqual(String.isEmpty('a'), false)
224
+ * ```
225
+ *
226
+ * @since 2.0.0
227
+ */
228
+ export const isEmpty = (self: string): self is "" => self.length === 0
229
+
230
+ /**
231
+ * Test whether a `string` is non empty.
232
+ *
233
+ * @since 2.0.0
234
+ */
235
+ export const isNonEmpty = (self: string): boolean => self.length > 0
236
+
237
+ /**
238
+ * Calculate the number of characters in a `string`.
239
+ *
240
+ * @example
241
+ * ```ts
242
+ * import * as assert from "node:assert"
243
+ * import { String } from "effect"
244
+ *
245
+ * assert.deepStrictEqual(String.length('abc'), 3)
246
+ * ```
247
+ *
248
+ * @since 2.0.0
249
+ */
250
+ export const length = (self: string): number => self.length
251
+
252
+ /**
253
+ * @example
254
+ * ```ts
255
+ * import * as assert from "node:assert"
256
+ * import { pipe, String } from "effect"
257
+ *
258
+ * assert.deepStrictEqual(pipe('abc', String.split('')), ['a', 'b', 'c'])
259
+ * assert.deepStrictEqual(pipe('', String.split('')), [''])
260
+ * ```
261
+ *
262
+ * @since 2.0.0
263
+ */
264
+ export const split: {
265
+ (separator: string | RegExp): (self: string) => NonEmptyArray<string>
266
+ (self: string, separator: string | RegExp): NonEmptyArray<string>
267
+ } = dual(2, (self: string, separator: string | RegExp): NonEmptyArray<string> => {
268
+ const out = self.split(separator)
269
+ return readonlyArray.isNonEmptyArray(out) ? out : [self]
270
+ })
271
+
272
+ /**
273
+ * Returns `true` if `searchString` appears as a substring of `self`, at one or more positions that are
274
+ * greater than or equal to `position`; otherwise, returns `false`.
275
+ *
276
+ * @since 2.0.0
277
+ */
278
+ export const includes = (searchString: string, position?: number) => (self: string): boolean =>
279
+ self.includes(searchString, position)
280
+
281
+ /**
282
+ * @since 2.0.0
283
+ */
284
+ export const startsWith = (searchString: string, position?: number) => (self: string): boolean =>
285
+ self.startsWith(searchString, position)
286
+
287
+ /**
288
+ * @since 2.0.0
289
+ */
290
+ export const endsWith = (searchString: string, position?: number) => (self: string): boolean =>
291
+ self.endsWith(searchString, position)
292
+
293
+ /**
294
+ * @example
295
+ * ```ts
296
+ * import * as assert from "node:assert"
297
+ * import { pipe, String, Option } from "effect"
298
+ *
299
+ * assert.deepStrictEqual(pipe("abc", String.charCodeAt(1)), Option.some(98))
300
+ * assert.deepStrictEqual(pipe("abc", String.charCodeAt(4)), Option.none())
301
+ * ```
302
+ *
303
+ * @since 2.0.0
304
+ */
305
+ export const charCodeAt: {
306
+ (index: number): (self: string) => Option.Option<number>
307
+ (self: string, index: number): Option.Option<number>
308
+ } = dual(
309
+ 2,
310
+ (self: string, index: number): Option.Option<number> =>
311
+ Option.filter(Option.some(self.charCodeAt(index)), (charCode) => !isNaN(charCode))
312
+ )
313
+
314
+ /**
315
+ * @example
316
+ * ```ts
317
+ * import * as assert from "node:assert"
318
+ * import { pipe, String, Option } from "effect"
319
+ *
320
+ * assert.deepStrictEqual(pipe("abcd", String.substring(1)), "bcd")
321
+ * assert.deepStrictEqual(pipe("abcd", String.substring(1, 3)), "bc")
322
+ * ```
323
+ *
324
+ * @since 2.0.0
325
+ */
326
+ export const substring = (start: number, end?: number) => (self: string): string => self.substring(start, end)
327
+
328
+ /**
329
+ * @example
330
+ * ```ts
331
+ * import * as assert from "node:assert"
332
+ * import { pipe, String, Option } from "effect"
333
+ *
334
+ * assert.deepStrictEqual(pipe("abc", String.at(1)), Option.some("b"))
335
+ * assert.deepStrictEqual(pipe("abc", String.at(4)), Option.none())
336
+ * ```
337
+ *
338
+ * @since 2.0.0
339
+ */
340
+ export const at: {
341
+ (index: number): (self: string) => Option.Option<string>
342
+ (self: string, index: number): Option.Option<string>
343
+ } = dual(2, (self: string, index: number): Option.Option<string> => Option.fromNullable(self.at(index)))
344
+
345
+ /**
346
+ * @example
347
+ * ```ts
348
+ * import * as assert from "node:assert"
349
+ * import { pipe, String, Option } from "effect"
350
+ *
351
+ * assert.deepStrictEqual(pipe("abc", String.charAt(1)), Option.some("b"))
352
+ * assert.deepStrictEqual(pipe("abc", String.charAt(4)), Option.none())
353
+ * ```
354
+ *
355
+ * @since 2.0.0
356
+ */
357
+ export const charAt: {
358
+ (index: number): (self: string) => Option.Option<string>
359
+ (self: string, index: number): Option.Option<string>
360
+ } = dual(
361
+ 2,
362
+ (self: string, index: number): Option.Option<string> => Option.filter(Option.some(self.charAt(index)), isNonEmpty)
363
+ )
364
+
365
+ /**
366
+ * @example
367
+ * ```ts
368
+ * import * as assert from "node:assert"
369
+ * import { pipe, String, Option } from "effect"
370
+ *
371
+ * assert.deepStrictEqual(pipe("abc", String.codePointAt(1)), Option.some(98))
372
+ * ```
373
+ *
374
+ * @since 2.0.0
375
+ */
376
+ export const codePointAt: {
377
+ (index: number): (self: string) => Option.Option<number>
378
+ (self: string, index: number): Option.Option<number>
379
+ } = dual(2, (self: string, index: number): Option.Option<number> => Option.fromNullable(self.codePointAt(index)))
380
+
381
+ /**
382
+ * @example
383
+ * ```ts
384
+ * import * as assert from "node:assert"
385
+ * import { pipe, String, Option } from "effect"
386
+ *
387
+ * assert.deepStrictEqual(pipe("abbbc", String.indexOf("b")), Option.some(1))
388
+ * ```
389
+ *
390
+ * @since 2.0.0
391
+ */
392
+ export const indexOf = (searchString: string) => (self: string): Option.Option<number> =>
393
+ Option.filter(Option.some(self.indexOf(searchString)), number.greaterThanOrEqualTo(0))
394
+
395
+ /**
396
+ * @example
397
+ * ```ts
398
+ * import * as assert from "node:assert"
399
+ * import { pipe, String, Option } from "effect"
400
+ *
401
+ * assert.deepStrictEqual(pipe("abbbc", String.lastIndexOf("b")), Option.some(3))
402
+ * assert.deepStrictEqual(pipe("abbbc", String.lastIndexOf("d")), Option.none())
403
+ * ```
404
+ *
405
+ * @since 2.0.0
406
+ */
407
+ export const lastIndexOf = (searchString: string) => (self: string): Option.Option<number> =>
408
+ Option.filter(Option.some(self.lastIndexOf(searchString)), number.greaterThanOrEqualTo(0))
409
+
410
+ /**
411
+ * @example
412
+ * ```ts
413
+ * import * as assert from "node:assert"
414
+ * import { pipe, String } from "effect"
415
+ *
416
+ * assert.deepStrictEqual(pipe("a", String.localeCompare("b")), -1)
417
+ * assert.deepStrictEqual(pipe("b", String.localeCompare("a")), 1)
418
+ * assert.deepStrictEqual(pipe("a", String.localeCompare("a")), 0)
419
+ * ```
420
+ *
421
+ * @since 2.0.0
422
+ */
423
+ export const localeCompare =
424
+ (that: string, locales?: Intl.LocalesArgument, options?: Intl.CollatorOptions) => (self: string): Ordering.Ordering =>
425
+ number.sign(self.localeCompare(that, locales, options))
426
+
427
+ /**
428
+ * It is the `pipe`-able version of the native `match` method.
429
+ *
430
+ * @since 2.0.0
431
+ */
432
+ export const match = (regexp: RegExp | string) => (self: string): Option.Option<RegExpMatchArray> =>
433
+ Option.fromNullable(self.match(regexp))
434
+
435
+ /**
436
+ * It is the `pipe`-able version of the native `matchAll` method.
437
+ *
438
+ * @since 2.0.0
439
+ */
440
+ export const matchAll = (regexp: RegExp) => (self: string): IterableIterator<RegExpMatchArray> => self.matchAll(regexp)
441
+
442
+ /**
443
+ * @example
444
+ * ```ts
445
+ * import * as assert from "node:assert"
446
+ * import { pipe, String } from "effect"
447
+ *
448
+ * const str = "\u1E9B\u0323";
449
+ * assert.deepStrictEqual(pipe(str, String.normalize()), "\u1E9B\u0323")
450
+ * assert.deepStrictEqual(pipe(str, String.normalize("NFC")), "\u1E9B\u0323")
451
+ * assert.deepStrictEqual(pipe(str, String.normalize("NFD")), "\u017F\u0323\u0307")
452
+ * assert.deepStrictEqual(pipe(str, String.normalize("NFKC")), "\u1E69")
453
+ * assert.deepStrictEqual(pipe(str, String.normalize("NFKD")), "\u0073\u0323\u0307")
454
+ * ```
455
+ *
456
+ * @since 2.0.0
457
+ */
458
+ export const normalize = (form?: "NFC" | "NFD" | "NFKC" | "NFKD") => (self: string): string => self.normalize(form)
459
+
460
+ /**
461
+ * @example
462
+ * ```ts
463
+ * import * as assert from "node:assert"
464
+ * import { pipe, String } from "effect"
465
+ *
466
+ * assert.deepStrictEqual(pipe("a", String.padEnd(5)), "a ")
467
+ * assert.deepStrictEqual(pipe("a", String.padEnd(5, "_")), "a____")
468
+ * ```
469
+ *
470
+ * @since 2.0.0
471
+ */
472
+ export const padEnd = (maxLength: number, fillString?: string) => (self: string): string =>
473
+ self.padEnd(maxLength, fillString)
474
+
475
+ /**
476
+ * @example
477
+ * ```ts
478
+ * import * as assert from "node:assert"
479
+ * import { pipe, String } from "effect"
480
+ *
481
+ * assert.deepStrictEqual(pipe("a", String.padStart(5)), " a")
482
+ * assert.deepStrictEqual(pipe("a", String.padStart(5, "_")), "____a")
483
+ * ```
484
+ *
485
+ * @since 2.0.0
486
+ */
487
+ export const padStart = (maxLength: number, fillString?: string) => (self: string): string =>
488
+ self.padStart(maxLength, fillString)
489
+
490
+ /**
491
+ * @example
492
+ * ```ts
493
+ * import * as assert from "node:assert"
494
+ * import { pipe, String } from "effect"
495
+ *
496
+ * assert.deepStrictEqual(pipe("a", String.repeat(5)), "aaaaa")
497
+ * ```
498
+ *
499
+ * @since 2.0.0
500
+ */
501
+ export const repeat = (count: number) => (self: string): string => self.repeat(count)
502
+
503
+ /**
504
+ * @example
505
+ * ```ts
506
+ * import * as assert from "node:assert"
507
+ * import { pipe, String } from "effect"
508
+ *
509
+ * assert.deepStrictEqual(pipe("ababb", String.replaceAll("b", "c")), "acacc")
510
+ * assert.deepStrictEqual(pipe("ababb", String.replaceAll(/ba/g, "cc")), "accbb")
511
+ * ```
512
+ *
513
+ * @since 2.0.0
514
+ */
515
+ export const replaceAll = (searchValue: string | RegExp, replaceValue: string) => (self: string): string =>
516
+ self.replaceAll(searchValue, replaceValue)
517
+
518
+ /**
519
+ * @example
520
+ * ```ts
521
+ * import * as assert from "node:assert"
522
+ * import { pipe, String, Option } from "effect"
523
+ *
524
+ * assert.deepStrictEqual(pipe("ababb", String.search("b")), Option.some(1))
525
+ * assert.deepStrictEqual(pipe("ababb", String.search(/abb/)), Option.some(2))
526
+ * assert.deepStrictEqual(pipe("ababb", String.search("d")), Option.none())
527
+ * ```
528
+ *
529
+ * @since 2.0.0
530
+ */
531
+ export const search: {
532
+ (regexp: RegExp | string): (self: string) => Option.Option<number>
533
+ (self: string, regexp: RegExp | string): Option.Option<number>
534
+ } = dual(
535
+ 2,
536
+ (self: string, regexp: RegExp | string): Option.Option<number> =>
537
+ Option.filter(Option.some(self.search(regexp)), number.greaterThanOrEqualTo(0))
538
+ )
539
+
540
+ /**
541
+ * @example
542
+ * ```ts
543
+ * import * as assert from "node:assert"
544
+ * import { pipe, String } from "effect"
545
+ *
546
+ * const str = "\u0130"
547
+ * assert.deepStrictEqual(pipe(str, String.toLocaleLowerCase("tr")), "i")
548
+ * ```
549
+ *
550
+ * @since 2.0.0
551
+ */
552
+ export const toLocaleLowerCase = (locale?: Intl.LocalesArgument) => (self: string): string =>
553
+ self.toLocaleLowerCase(locale)
554
+
555
+ /**
556
+ * @example
557
+ * ```ts
558
+ * import * as assert from "node:assert"
559
+ * import { pipe, String } from "effect"
560
+ *
561
+ * const str = "i\u0307"
562
+ * assert.deepStrictEqual(pipe(str, String.toLocaleUpperCase("lt-LT")), "I")
563
+ * ```
564
+ *
565
+ * @since 2.0.0
566
+ */
567
+ export const toLocaleUpperCase = (locale?: Intl.LocalesArgument) => (self: string): string =>
568
+ self.toLocaleUpperCase(locale)
569
+
570
+ /**
571
+ * Keep the specified number of characters from the start of a string.
572
+ *
573
+ * If `n` is larger than the available number of characters, the string will
574
+ * be returned whole.
575
+ *
576
+ * If `n` is not a positive number, an empty string will be returned.
577
+ *
578
+ * If `n` is a float, it will be rounded down to the nearest integer.
579
+ *
580
+ * @example
581
+ * ```ts
582
+ * import * as assert from "node:assert"
583
+ * import { String } from "effect"
584
+ *
585
+ * assert.deepStrictEqual(String.takeLeft("Hello World", 5), "Hello")
586
+ * ```
587
+ *
588
+ * @since 2.0.0
589
+ */
590
+ export const takeLeft: {
591
+ (n: number): (self: string) => string
592
+ (self: string, n: number): string
593
+ } = dual(2, (self: string, n: number): string => self.slice(0, Math.max(n, 0)))
594
+
595
+ /**
596
+ * Keep the specified number of characters from the end of a string.
597
+ *
598
+ * If `n` is larger than the available number of characters, the string will
599
+ * be returned whole.
600
+ *
601
+ * If `n` is not a positive number, an empty string will be returned.
602
+ *
603
+ * If `n` is a float, it will be rounded down to the nearest integer.
604
+ *
605
+ * @example
606
+ * ```ts
607
+ * import * as assert from "node:assert"
608
+ * import { String } from "effect"
609
+ *
610
+ * assert.deepStrictEqual(String.takeRight("Hello World", 5), "World")
611
+ * ```
612
+ *
613
+ * @since 2.0.0
614
+ */
615
+ export const takeRight: {
616
+ (n: number): (self: string) => string
617
+ (self: string, n: number): string
618
+ } = dual(
619
+ 2,
620
+ (self: string, n: number): string => self.slice(Math.max(0, self.length - Math.floor(n)), Infinity)
621
+ )
622
+
623
+ const CR = 0x0d
624
+ const LF = 0x0a
625
+
626
+ /**
627
+ * Returns an `IterableIterator` which yields each line contained within the
628
+ * string, trimming off the trailing newline character.
629
+ *
630
+ * @since 2.0.0
631
+ */
632
+ export const linesIterator = (self: string): LinesIterator => linesSeparated(self, true)
633
+
634
+ /**
635
+ * Returns an `IterableIterator` which yields each line contained within the
636
+ * string as well as the trailing newline character.
637
+ *
638
+ * @since 2.0.0
639
+ */
640
+ export const linesWithSeparators = (s: string): LinesIterator => linesSeparated(s, false)
641
+
642
+ /**
643
+ * For every line in this string, strip a leading prefix consisting of blanks
644
+ * or control characters followed by the character specified by `marginChar`
645
+ * from the line.
646
+ *
647
+ * @since 2.0.0
648
+ */
649
+ export const stripMarginWith: {
650
+ (marginChar: string): (self: string) => string
651
+ (self: string, marginChar: string): string
652
+ } = dual(2, (self: string, marginChar: string): string => {
653
+ let out = ""
654
+
655
+ for (const line of linesWithSeparators(self)) {
656
+ let index = 0
657
+
658
+ while (index < line.length && line.charAt(index) <= " ") {
659
+ index = index + 1
660
+ }
661
+
662
+ const stripped = index < line.length && line.charAt(index) === marginChar
663
+ ? line.substring(index + 1)
664
+ : line
665
+
666
+ out = out + stripped
667
+ }
668
+
669
+ return out
670
+ })
671
+
672
+ /**
673
+ * For every line in this string, strip a leading prefix consisting of blanks
674
+ * or control characters followed by the `"|"` character from the line.
675
+ *
676
+ * @since 2.0.0
677
+ */
678
+ export const stripMargin = (self: string): string => stripMarginWith(self, "|")
679
+
680
+ /**
681
+ * @since 2.0.0
682
+ */
683
+ export const snakeToCamel = (self: string): string => {
684
+ let str = self[0]
685
+ for (let i = 1; i < self.length; i++) {
686
+ str += self[i] === "_" ? self[++i].toUpperCase() : self[i]
687
+ }
688
+ return str
689
+ }
690
+
691
+ /**
692
+ * @since 2.0.0
693
+ */
694
+ export const snakeToPascal = (self: string): string => {
695
+ let str = self[0].toUpperCase()
696
+ for (let i = 1; i < self.length; i++) {
697
+ str += self[i] === "_" ? self[++i].toUpperCase() : self[i]
698
+ }
699
+ return str
700
+ }
701
+
702
+ /**
703
+ * @since 2.0.0
704
+ */
705
+ export const snakeToKebab = (self: string): string => self.replace(/_/g, "-")
706
+
707
+ /**
708
+ * @since 2.0.0
709
+ */
710
+ export const camelToSnake = (self: string): string => self.replace(/([A-Z])/g, "_$1").toLowerCase()
711
+
712
+ /**
713
+ * @since 2.0.0
714
+ */
715
+ export const pascalToSnake = (self: string): string =>
716
+ (self.slice(0, 1) + self.slice(1).replace(/([A-Z])/g, "_$1")).toLowerCase()
717
+
718
+ /**
719
+ * @since 2.0.0
720
+ */
721
+ export const kebabToSnake = (self: string): string => self.replace(/-/g, "_")
722
+
723
+ class LinesIterator implements IterableIterator<string> {
724
+ private index: number
725
+ private readonly length: number
726
+
727
+ constructor(readonly s: string, readonly stripped: boolean = false) {
728
+ this.index = 0
729
+ this.length = s.length
730
+ }
731
+
732
+ next(): IteratorResult<string> {
733
+ if (this.done) {
734
+ return { done: true, value: undefined }
735
+ }
736
+ const start = this.index
737
+ while (!this.done && !isLineBreak(this.s[this.index]!)) {
738
+ this.index = this.index + 1
739
+ }
740
+ let end = this.index
741
+ if (!this.done) {
742
+ const char = this.s[this.index]!
743
+ this.index = this.index + 1
744
+ if (!this.done && isLineBreak2(char, this.s[this.index]!)) {
745
+ this.index = this.index + 1
746
+ }
747
+ if (!this.stripped) {
748
+ end = this.index
749
+ }
750
+ }
751
+ return { done: false, value: this.s.substring(start, end) }
752
+ }
753
+
754
+ [Symbol.iterator](): IterableIterator<string> {
755
+ return new LinesIterator(this.s, this.stripped)
756
+ }
757
+
758
+ private get done(): boolean {
759
+ return this.index >= this.length
760
+ }
761
+ }
762
+
763
+ /**
764
+ * Test if the provided character is a line break character (i.e. either `"\r"`
765
+ * or `"\n"`).
766
+ */
767
+ const isLineBreak = (char: string): boolean => {
768
+ const code = char.charCodeAt(0)
769
+ return code === CR || code === LF
770
+ }
771
+
772
+ /**
773
+ * Test if the provided characters combine to form a carriage return/line-feed
774
+ * (i.e. `"\r\n"`).
775
+ */
776
+ const isLineBreak2 = (char0: string, char1: string): boolean => char0.charCodeAt(0) === CR && char1.charCodeAt(0) === LF
777
+
778
+ const linesSeparated = (self: string, stripped: boolean): LinesIterator => new LinesIterator(self, stripped)