@clayroach/effect 3.19.14-source-capture.7 → 3.19.14-source-capture.8

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 (371) hide show
  1. package/dist/cjs/Utils.js +1 -1
  2. package/dist/cjs/Utils.js.map +1 -1
  3. package/dist/cjs/internal/clock.js +1 -1
  4. package/dist/cjs/internal/clock.js.map +1 -1
  5. package/dist/esm/Utils.js +1 -1
  6. package/dist/esm/Utils.js.map +1 -1
  7. package/dist/esm/internal/clock.js +1 -1
  8. package/dist/esm/internal/clock.js.map +1 -1
  9. package/package.json +1 -1
  10. package/src/Arbitrary.ts +0 -1101
  11. package/src/Array.ts +0 -3589
  12. package/src/BigDecimal.ts +0 -1349
  13. package/src/BigInt.ts +0 -643
  14. package/src/Boolean.ts +0 -287
  15. package/src/Brand.ts +0 -360
  16. package/src/Cache.ts +0 -281
  17. package/src/Cause.ts +0 -1555
  18. package/src/Channel.ts +0 -2355
  19. package/src/ChildExecutorDecision.ts +0 -146
  20. package/src/Chunk.ts +0 -1495
  21. package/src/Clock.ts +0 -111
  22. package/src/Config.ts +0 -542
  23. package/src/ConfigError.ts +0 -270
  24. package/src/ConfigProvider.ts +0 -333
  25. package/src/ConfigProviderPathPatch.ts +0 -100
  26. package/src/Console.ts +0 -226
  27. package/src/Context.ts +0 -585
  28. package/src/Cron.ts +0 -706
  29. package/src/Data.ts +0 -596
  30. package/src/DateTime.ts +0 -1686
  31. package/src/DefaultServices.ts +0 -34
  32. package/src/Deferred.ts +0 -301
  33. package/src/Differ.ts +0 -450
  34. package/src/Duration.ts +0 -1000
  35. package/src/Effect.ts +0 -14839
  36. package/src/Effectable.ts +0 -107
  37. package/src/Either.ts +0 -1040
  38. package/src/Encoding.ts +0 -195
  39. package/src/Equal.ts +0 -98
  40. package/src/Equivalence.ts +0 -235
  41. package/src/ExecutionPlan.ts +0 -308
  42. package/src/ExecutionStrategy.ts +0 -119
  43. package/src/Exit.ts +0 -467
  44. package/src/FastCheck.ts +0 -9
  45. package/src/Fiber.ts +0 -744
  46. package/src/FiberHandle.ts +0 -540
  47. package/src/FiberId.ts +0 -195
  48. package/src/FiberMap.ts +0 -656
  49. package/src/FiberRef.ts +0 -431
  50. package/src/FiberRefs.ts +0 -204
  51. package/src/FiberRefsPatch.ts +0 -105
  52. package/src/FiberSet.ts +0 -491
  53. package/src/FiberStatus.ts +0 -108
  54. package/src/Function.ts +0 -1222
  55. package/src/GlobalValue.ts +0 -53
  56. package/src/Graph.ts +0 -3732
  57. package/src/GroupBy.ts +0 -103
  58. package/src/HKT.ts +0 -45
  59. package/src/Hash.ts +0 -195
  60. package/src/HashMap.ts +0 -519
  61. package/src/HashRing.ts +0 -317
  62. package/src/HashSet.ts +0 -2346
  63. package/src/Inspectable.ts +0 -287
  64. package/src/Iterable.ts +0 -1119
  65. package/src/JSONSchema.ts +0 -1044
  66. package/src/KeyedPool.ts +0 -167
  67. package/src/Layer.ts +0 -1251
  68. package/src/LayerMap.ts +0 -436
  69. package/src/List.ts +0 -977
  70. package/src/LogLevel.ts +0 -285
  71. package/src/LogSpan.ts +0 -25
  72. package/src/Logger.ts +0 -702
  73. package/src/Mailbox.ts +0 -268
  74. package/src/ManagedRuntime.ts +0 -180
  75. package/src/Match.ts +0 -1477
  76. package/src/MergeDecision.ts +0 -95
  77. package/src/MergeState.ts +0 -172
  78. package/src/MergeStrategy.ts +0 -107
  79. package/src/Metric.ts +0 -780
  80. package/src/MetricBoundaries.ts +0 -69
  81. package/src/MetricHook.ts +0 -151
  82. package/src/MetricKey.ts +0 -224
  83. package/src/MetricKeyType.ts +0 -262
  84. package/src/MetricLabel.ts +0 -47
  85. package/src/MetricPair.ts +0 -71
  86. package/src/MetricPolling.ts +0 -148
  87. package/src/MetricRegistry.ts +0 -48
  88. package/src/MetricState.ts +0 -257
  89. package/src/Micro.ts +0 -4405
  90. package/src/ModuleVersion.ts +0 -18
  91. package/src/MutableHashMap.ts +0 -411
  92. package/src/MutableHashSet.ts +0 -706
  93. package/src/MutableList.ts +0 -297
  94. package/src/MutableQueue.ts +0 -227
  95. package/src/MutableRef.ts +0 -202
  96. package/src/NonEmptyIterable.ts +0 -32
  97. package/src/Number.ts +0 -1071
  98. package/src/Option.ts +0 -2170
  99. package/src/Order.ts +0 -373
  100. package/src/Ordering.ts +0 -111
  101. package/src/ParseResult.ts +0 -2031
  102. package/src/PartitionedSemaphore.ts +0 -200
  103. package/src/Pipeable.ts +0 -566
  104. package/src/Pool.ts +0 -204
  105. package/src/Predicate.ts +0 -1405
  106. package/src/Pretty.ts +0 -205
  107. package/src/PrimaryKey.ts +0 -23
  108. package/src/PubSub.ts +0 -182
  109. package/src/Queue.ts +0 -644
  110. package/src/Random.ts +0 -204
  111. package/src/RateLimiter.ts +0 -138
  112. package/src/RcMap.ts +0 -141
  113. package/src/RcRef.ts +0 -122
  114. package/src/Readable.ts +0 -93
  115. package/src/Record.ts +0 -1274
  116. package/src/RedBlackTree.ts +0 -421
  117. package/src/Redacted.ts +0 -144
  118. package/src/Ref.ts +0 -180
  119. package/src/RegExp.ts +0 -38
  120. package/src/Reloadable.ts +0 -127
  121. package/src/Request.ts +0 -347
  122. package/src/RequestBlock.ts +0 -118
  123. package/src/RequestResolver.ts +0 -366
  124. package/src/Resource.ts +0 -119
  125. package/src/Runtime.ts +0 -383
  126. package/src/RuntimeFlags.ts +0 -368
  127. package/src/RuntimeFlagsPatch.ts +0 -183
  128. package/src/STM.ts +0 -2045
  129. package/src/Schedule.ts +0 -2219
  130. package/src/ScheduleDecision.ts +0 -62
  131. package/src/ScheduleInterval.ts +0 -151
  132. package/src/ScheduleIntervals.ts +0 -122
  133. package/src/Scheduler.ts +0 -353
  134. package/src/Schema.ts +0 -10914
  135. package/src/SchemaAST.ts +0 -3043
  136. package/src/Scope.ts +0 -204
  137. package/src/ScopedCache.ts +0 -151
  138. package/src/ScopedRef.ts +0 -117
  139. package/src/Secret.ts +0 -88
  140. package/src/SingleProducerAsyncInput.ts +0 -67
  141. package/src/Sink.ts +0 -1461
  142. package/src/SortedMap.ts +0 -287
  143. package/src/SortedSet.ts +0 -390
  144. package/src/Stream.ts +0 -6468
  145. package/src/StreamEmit.ts +0 -136
  146. package/src/StreamHaltStrategy.ts +0 -123
  147. package/src/Streamable.ts +0 -45
  148. package/src/String.ts +0 -778
  149. package/src/Struct.ts +0 -243
  150. package/src/Subscribable.ts +0 -100
  151. package/src/SubscriptionRef.ts +0 -298
  152. package/src/Supervisor.ts +0 -240
  153. package/src/Symbol.ts +0 -29
  154. package/src/SynchronizedRef.ts +0 -270
  155. package/src/TArray.ts +0 -495
  156. package/src/TDeferred.ts +0 -100
  157. package/src/TMap.ts +0 -515
  158. package/src/TPriorityQueue.ts +0 -223
  159. package/src/TPubSub.ts +0 -200
  160. package/src/TQueue.ts +0 -432
  161. package/src/TRandom.ts +0 -129
  162. package/src/TReentrantLock.ts +0 -224
  163. package/src/TRef.ts +0 -178
  164. package/src/TSemaphore.ts +0 -129
  165. package/src/TSet.ts +0 -365
  166. package/src/TSubscriptionRef.ts +0 -192
  167. package/src/Take.ts +0 -258
  168. package/src/TestAnnotation.ts +0 -158
  169. package/src/TestAnnotationMap.ts +0 -119
  170. package/src/TestAnnotations.ts +0 -117
  171. package/src/TestClock.ts +0 -556
  172. package/src/TestConfig.ts +0 -47
  173. package/src/TestContext.ts +0 -36
  174. package/src/TestLive.ts +0 -53
  175. package/src/TestServices.ts +0 -390
  176. package/src/TestSized.ts +0 -55
  177. package/src/Tracer.ts +0 -198
  178. package/src/Trie.ts +0 -840
  179. package/src/Tuple.ts +0 -305
  180. package/src/Types.ts +0 -353
  181. package/src/Unify.ts +0 -113
  182. package/src/UpstreamPullRequest.ts +0 -117
  183. package/src/UpstreamPullStrategy.ts +0 -121
  184. package/src/Utils.ts +0 -809
  185. package/src/index.ts +0 -1561
  186. package/src/internal/array.ts +0 -8
  187. package/src/internal/blockedRequests.ts +0 -520
  188. package/src/internal/cache.ts +0 -733
  189. package/src/internal/cause.ts +0 -1050
  190. package/src/internal/channel/channelExecutor.ts +0 -1200
  191. package/src/internal/channel/channelState.ts +0 -134
  192. package/src/internal/channel/childExecutorDecision.ts +0 -96
  193. package/src/internal/channel/continuation.ts +0 -200
  194. package/src/internal/channel/mergeDecision.ts +0 -113
  195. package/src/internal/channel/mergeState.ts +0 -120
  196. package/src/internal/channel/mergeStrategy.ts +0 -72
  197. package/src/internal/channel/singleProducerAsyncInput.ts +0 -259
  198. package/src/internal/channel/subexecutor.ts +0 -229
  199. package/src/internal/channel/upstreamPullRequest.ts +0 -84
  200. package/src/internal/channel/upstreamPullStrategy.ts +0 -87
  201. package/src/internal/channel.ts +0 -2603
  202. package/src/internal/clock.ts +0 -95
  203. package/src/internal/completedRequestMap.ts +0 -9
  204. package/src/internal/concurrency.ts +0 -54
  205. package/src/internal/config.ts +0 -716
  206. package/src/internal/configError.ts +0 -304
  207. package/src/internal/configProvider/pathPatch.ts +0 -97
  208. package/src/internal/configProvider.ts +0 -799
  209. package/src/internal/console.ts +0 -153
  210. package/src/internal/context.ts +0 -337
  211. package/src/internal/core-effect.ts +0 -2293
  212. package/src/internal/core-stream.ts +0 -998
  213. package/src/internal/core.ts +0 -3273
  214. package/src/internal/data.ts +0 -36
  215. package/src/internal/dataSource.ts +0 -327
  216. package/src/internal/dateTime.ts +0 -1277
  217. package/src/internal/defaultServices/console.ts +0 -100
  218. package/src/internal/defaultServices.ts +0 -163
  219. package/src/internal/deferred.ts +0 -46
  220. package/src/internal/differ/chunkPatch.ts +0 -211
  221. package/src/internal/differ/contextPatch.ts +0 -232
  222. package/src/internal/differ/hashMapPatch.ts +0 -220
  223. package/src/internal/differ/hashSetPatch.ts +0 -176
  224. package/src/internal/differ/orPatch.ts +0 -311
  225. package/src/internal/differ/readonlyArrayPatch.ts +0 -210
  226. package/src/internal/differ.ts +0 -200
  227. package/src/internal/doNotation.ts +0 -80
  228. package/src/internal/effect/circular.ts +0 -905
  229. package/src/internal/effectable.ts +0 -131
  230. package/src/internal/either.ts +0 -110
  231. package/src/internal/encoding/base64.ts +0 -286
  232. package/src/internal/encoding/base64Url.ts +0 -29
  233. package/src/internal/encoding/common.ts +0 -51
  234. package/src/internal/encoding/hex.ts +0 -315
  235. package/src/internal/errors.ts +0 -7
  236. package/src/internal/executionPlan.ts +0 -114
  237. package/src/internal/executionStrategy.ts +0 -74
  238. package/src/internal/fiber.ts +0 -388
  239. package/src/internal/fiberId.ts +0 -267
  240. package/src/internal/fiberMessage.ts +0 -82
  241. package/src/internal/fiberRefs/patch.ts +0 -144
  242. package/src/internal/fiberRefs.ts +0 -297
  243. package/src/internal/fiberRuntime.ts +0 -3915
  244. package/src/internal/fiberScope.ts +0 -71
  245. package/src/internal/fiberStatus.ts +0 -119
  246. package/src/internal/groupBy.ts +0 -530
  247. package/src/internal/hashMap/array.ts +0 -49
  248. package/src/internal/hashMap/bitwise.ts +0 -32
  249. package/src/internal/hashMap/config.ts +0 -14
  250. package/src/internal/hashMap/keySet.ts +0 -8
  251. package/src/internal/hashMap/node.ts +0 -391
  252. package/src/internal/hashMap.ts +0 -586
  253. package/src/internal/hashSet.ts +0 -323
  254. package/src/internal/keyedPool.ts +0 -244
  255. package/src/internal/layer/circular.ts +0 -228
  256. package/src/internal/layer.ts +0 -1487
  257. package/src/internal/logSpan.ts +0 -20
  258. package/src/internal/logger-circular.ts +0 -24
  259. package/src/internal/logger.ts +0 -485
  260. package/src/internal/mailbox.ts +0 -561
  261. package/src/internal/managedRuntime/circular.ts +0 -6
  262. package/src/internal/managedRuntime.ts +0 -134
  263. package/src/internal/matcher.ts +0 -652
  264. package/src/internal/metric/boundaries.ts +0 -75
  265. package/src/internal/metric/hook.ts +0 -483
  266. package/src/internal/metric/key.ts +0 -167
  267. package/src/internal/metric/keyType.ts +0 -238
  268. package/src/internal/metric/label.ts +0 -41
  269. package/src/internal/metric/pair.ts +0 -48
  270. package/src/internal/metric/polling.ts +0 -149
  271. package/src/internal/metric/registry.ts +0 -187
  272. package/src/internal/metric/state.ts +0 -290
  273. package/src/internal/metric.ts +0 -577
  274. package/src/internal/opCodes/cause.ts +0 -35
  275. package/src/internal/opCodes/channel.ts +0 -83
  276. package/src/internal/opCodes/channelChildExecutorDecision.ts +0 -17
  277. package/src/internal/opCodes/channelMergeDecision.ts +0 -11
  278. package/src/internal/opCodes/channelMergeState.ts +0 -17
  279. package/src/internal/opCodes/channelMergeStrategy.ts +0 -11
  280. package/src/internal/opCodes/channelState.ts +0 -23
  281. package/src/internal/opCodes/channelUpstreamPullRequest.ts +0 -11
  282. package/src/internal/opCodes/channelUpstreamPullStrategy.ts +0 -11
  283. package/src/internal/opCodes/config.ts +0 -65
  284. package/src/internal/opCodes/configError.ts +0 -35
  285. package/src/internal/opCodes/continuation.ts +0 -11
  286. package/src/internal/opCodes/deferred.ts +0 -11
  287. package/src/internal/opCodes/effect.ts +0 -89
  288. package/src/internal/opCodes/layer.ts +0 -59
  289. package/src/internal/opCodes/streamHaltStrategy.ts +0 -23
  290. package/src/internal/option.ts +0 -80
  291. package/src/internal/pool.ts +0 -432
  292. package/src/internal/pubsub.ts +0 -1762
  293. package/src/internal/query.ts +0 -204
  294. package/src/internal/queue.ts +0 -766
  295. package/src/internal/random.ts +0 -161
  296. package/src/internal/rateLimiter.ts +0 -93
  297. package/src/internal/rcMap.ts +0 -285
  298. package/src/internal/rcRef.ts +0 -192
  299. package/src/internal/redBlackTree/iterator.ts +0 -200
  300. package/src/internal/redBlackTree/node.ts +0 -68
  301. package/src/internal/redBlackTree.ts +0 -1245
  302. package/src/internal/redacted.ts +0 -73
  303. package/src/internal/ref.ts +0 -171
  304. package/src/internal/reloadable.ts +0 -140
  305. package/src/internal/request.ts +0 -177
  306. package/src/internal/resource.ts +0 -76
  307. package/src/internal/ringBuffer.ts +0 -68
  308. package/src/internal/runtime.ts +0 -558
  309. package/src/internal/runtimeFlags.ts +0 -188
  310. package/src/internal/runtimeFlagsPatch.ts +0 -103
  311. package/src/internal/schedule/decision.ts +0 -47
  312. package/src/internal/schedule/interval.ts +0 -101
  313. package/src/internal/schedule/intervals.ts +0 -180
  314. package/src/internal/schedule.ts +0 -2199
  315. package/src/internal/schema/errors.ts +0 -191
  316. package/src/internal/schema/schemaId.ts +0 -106
  317. package/src/internal/schema/util.ts +0 -50
  318. package/src/internal/scopedCache.ts +0 -644
  319. package/src/internal/scopedRef.ts +0 -118
  320. package/src/internal/secret.ts +0 -89
  321. package/src/internal/singleShotGen.ts +0 -35
  322. package/src/internal/sink.ts +0 -2120
  323. package/src/internal/stack.ts +0 -10
  324. package/src/internal/stm/core.ts +0 -817
  325. package/src/internal/stm/entry.ts +0 -59
  326. package/src/internal/stm/journal.ts +0 -123
  327. package/src/internal/stm/opCodes/stm.ts +0 -71
  328. package/src/internal/stm/opCodes/stmState.ts +0 -17
  329. package/src/internal/stm/opCodes/strategy.ts +0 -17
  330. package/src/internal/stm/opCodes/tExit.ts +0 -29
  331. package/src/internal/stm/opCodes/tryCommit.ts +0 -11
  332. package/src/internal/stm/stm.ts +0 -1453
  333. package/src/internal/stm/stmState.ts +0 -136
  334. package/src/internal/stm/tArray.ts +0 -550
  335. package/src/internal/stm/tDeferred.ts +0 -81
  336. package/src/internal/stm/tExit.ts +0 -190
  337. package/src/internal/stm/tMap.ts +0 -824
  338. package/src/internal/stm/tPriorityQueue.ts +0 -267
  339. package/src/internal/stm/tPubSub.ts +0 -551
  340. package/src/internal/stm/tQueue.ts +0 -393
  341. package/src/internal/stm/tRandom.ts +0 -140
  342. package/src/internal/stm/tReentrantLock.ts +0 -352
  343. package/src/internal/stm/tRef.ts +0 -195
  344. package/src/internal/stm/tSemaphore.ts +0 -113
  345. package/src/internal/stm/tSet.ts +0 -259
  346. package/src/internal/stm/tSubscriptionRef.ts +0 -286
  347. package/src/internal/stm/tryCommit.ts +0 -34
  348. package/src/internal/stm/txnId.ts +0 -14
  349. package/src/internal/stm/versioned.ts +0 -4
  350. package/src/internal/stream/debounceState.ts +0 -57
  351. package/src/internal/stream/emit.ts +0 -123
  352. package/src/internal/stream/haltStrategy.ts +0 -94
  353. package/src/internal/stream/handoff.ts +0 -187
  354. package/src/internal/stream/handoffSignal.ts +0 -59
  355. package/src/internal/stream/pull.ts +0 -34
  356. package/src/internal/stream/sinkEndReason.ts +0 -30
  357. package/src/internal/stream/zipAllState.ts +0 -88
  358. package/src/internal/stream/zipChunksState.ts +0 -56
  359. package/src/internal/stream.ts +0 -8801
  360. package/src/internal/string-utils.ts +0 -107
  361. package/src/internal/subscriptionRef.ts +0 -138
  362. package/src/internal/supervisor/patch.ts +0 -190
  363. package/src/internal/supervisor.ts +0 -303
  364. package/src/internal/synchronizedRef.ts +0 -114
  365. package/src/internal/take.ts +0 -199
  366. package/src/internal/testing/sleep.ts +0 -27
  367. package/src/internal/testing/suspendedWarningData.ts +0 -85
  368. package/src/internal/testing/warningData.ts +0 -94
  369. package/src/internal/tracer.ts +0 -293
  370. package/src/internal/trie.ts +0 -722
  371. package/src/internal/version.ts +0 -7
@@ -1,118 +0,0 @@
1
- /**
2
- * @since 2.0.0
3
- */
4
- import * as RequestBlock_ from "./internal/blockedRequests.js"
5
- import type * as Request from "./Request.js"
6
- import type * as RequestResolver from "./RequestResolver.js"
7
-
8
- /**
9
- * `RequestBlock` captures a collection of blocked requests as a data
10
- * structure. By doing this the library is able to preserve information about
11
- * which requests must be performed sequentially and which can be performed in
12
- * parallel, allowing for maximum possible batching and pipelining while
13
- * preserving ordering guarantees.
14
- *
15
- * @since 2.0.0
16
- * @category models
17
- */
18
- export type RequestBlock = Empty | Par | Seq | Single
19
-
20
- /**
21
- * @since 2.0.0
22
- * @category models
23
- */
24
- export declare namespace RequestBlock {
25
- /**
26
- * @since 2.0.0
27
- * @category models
28
- */
29
- export interface Reducer<in out Z> {
30
- emptyCase(): Z
31
- parCase(left: Z, right: Z): Z
32
- singleCase(
33
- dataSource: RequestResolver.RequestResolver<unknown>,
34
- blockedRequest: Request.Entry<unknown>
35
- ): Z
36
- seqCase(left: Z, right: Z): Z
37
- }
38
- }
39
-
40
- /**
41
- * @since 2.0.0
42
- * @category models
43
- */
44
- export interface Empty {
45
- readonly _tag: "Empty"
46
- }
47
-
48
- /**
49
- * @since 2.0.0
50
- * @category models
51
- */
52
- export interface Par {
53
- readonly _tag: "Par"
54
- readonly left: RequestBlock
55
- readonly right: RequestBlock
56
- }
57
-
58
- /**
59
- * @since 2.0.0
60
- * @category models
61
- */
62
- export interface Seq {
63
- readonly _tag: "Seq"
64
- readonly left: RequestBlock
65
- readonly right: RequestBlock
66
- }
67
-
68
- /**
69
- * @since 2.0.0
70
- * @category models
71
- */
72
- export interface Single {
73
- readonly _tag: "Single"
74
- readonly dataSource: RequestResolver.RequestResolver<unknown>
75
- readonly blockedRequest: Request.Entry<unknown>
76
- }
77
-
78
- /**
79
- * @since 2.0.0
80
- * @category constructors
81
- */
82
- export const single: <A>(
83
- dataSource: RequestResolver.RequestResolver<A>,
84
- blockedRequest: Request.Entry<A>
85
- ) => RequestBlock = RequestBlock_.single
86
-
87
- /**
88
- * @since 2.0.0
89
- * @category constructors
90
- */
91
- export const empty: RequestBlock = RequestBlock_.empty
92
-
93
- /**
94
- * @since 2.0.0
95
- * @category constructors
96
- */
97
- export const mapRequestResolvers: <A>(
98
- self: RequestBlock,
99
- f: (dataSource: RequestResolver.RequestResolver<A>) => RequestResolver.RequestResolver<A>
100
- ) => RequestBlock = RequestBlock_.mapRequestResolvers
101
-
102
- /**
103
- * @since 2.0.0
104
- * @category constructors
105
- */
106
- export const parallel: (self: RequestBlock, that: RequestBlock) => RequestBlock = RequestBlock_.par
107
-
108
- /**
109
- * @since 2.0.0
110
- * @category constructors
111
- */
112
- export const reduce: <Z>(self: RequestBlock, reducer: RequestBlock.Reducer<Z>) => Z = RequestBlock_.reduce
113
-
114
- /**
115
- * @since 2.0.0
116
- * @category constructors
117
- */
118
- export const sequential: (self: RequestBlock, that: RequestBlock) => RequestBlock = RequestBlock_.seq
@@ -1,366 +0,0 @@
1
- /**
2
- * @since 2.0.0
3
- */
4
-
5
- import type { NonEmptyArray } from "./Array.js"
6
- import * as Context from "./Context.js"
7
- import * as Effect from "./Effect.js"
8
- import type * as Either from "./Either.js"
9
- import type * as Equal from "./Equal.js"
10
- import type { FiberRef } from "./FiberRef.js"
11
- import * as core from "./internal/core.js"
12
- import * as internal from "./internal/dataSource.js"
13
- import type { Pipeable } from "./Pipeable.js"
14
- import type * as Request from "./Request.js"
15
- import type * as Types from "./Types.js"
16
-
17
- /**
18
- * @since 2.0.0
19
- * @category symbols
20
- */
21
- export const RequestResolverTypeId: unique symbol = core.RequestResolverTypeId
22
-
23
- /**
24
- * @since 2.0.0
25
- * @category symbols
26
- */
27
- export type RequestResolverTypeId = typeof RequestResolverTypeId
28
-
29
- /**
30
- * The `RequestResolver<A, R>` interface requires an environment `R` and handles
31
- * the execution of requests of type `A`.
32
- *
33
- * Implementations must provide a `runAll` method, which processes a collection
34
- * of requests and produces an effect that fulfills these requests. Requests are
35
- * organized into a `Array<Array<A>>`, where the outer `Array` groups requests
36
- * into batches that are executed sequentially, and each inner `Array` contains
37
- * requests that can be executed in parallel. This structure allows
38
- * implementations to analyze all incoming requests collectively and optimize
39
- * query execution accordingly.
40
- *
41
- * Implementations are typically specialized for a subtype of `Request<A, E>`.
42
- * However, they are not strictly limited to these subtypes as long as they can
43
- * map any given request type to `Request<A, E>`. Implementations should inspect
44
- * the collection of requests to identify the needed information and execute the
45
- * corresponding queries. It is imperative that implementations resolve all the
46
- * requests they receive. Failing to do so will lead to a `QueryFailure` error
47
- * during query execution.
48
- *
49
- * @since 2.0.0
50
- * @category models
51
- */
52
- export interface RequestResolver<in A, out R = never> extends RequestResolver.Variance<A, R>, Equal.Equal, Pipeable {
53
- /**
54
- * Execute a collection of requests. The outer `Array` represents batches
55
- * of requests that must be performed sequentially. The inner `Array`
56
- * represents a batch of requests that can be performed in parallel.
57
- */
58
- runAll(requests: Array<Array<Request.Entry<A>>>): Effect.Effect<void, never, R>
59
-
60
- /**
61
- * Identify the data source using the specific identifier
62
- */
63
- identified(...identifiers: Array<unknown>): RequestResolver<A, R>
64
- }
65
-
66
- /**
67
- * @since 2.0.0
68
- */
69
- export declare namespace RequestResolver {
70
- /**
71
- * @since 2.0.0
72
- * @category models
73
- */
74
- export interface Variance<in A, out R> {
75
- readonly [RequestResolverTypeId]: {
76
- readonly _A: Types.Contravariant<A>
77
- readonly _R: Types.Covariant<R>
78
- }
79
- }
80
- }
81
-
82
- /**
83
- * @since 2.0.0
84
- * @category utils
85
- */
86
- export const contextFromEffect = <R, A extends Request.Request<any, any>>(self: RequestResolver<A, R>) =>
87
- Effect.contextWith((_: Context.Context<R>) => provideContext(self, _))
88
-
89
- /**
90
- * @since 2.0.0
91
- * @category utils
92
- */
93
- export const contextFromServices =
94
- <Services extends Array<Context.Tag<any, any>>>(...services: Services) =>
95
- <R, A extends Request.Request<any, any>>(
96
- self: RequestResolver<A, R>
97
- ): Effect.Effect<
98
- RequestResolver<A, Exclude<R, { [k in keyof Services]: Effect.Effect.Context<Services[k]> }[number]>>,
99
- never,
100
- { [k in keyof Services]: Effect.Effect.Context<Services[k]> }[number]
101
- > => Effect.contextWith((_) => provideContext(self as any, Context.pick(...services)(_ as any)))
102
-
103
- /**
104
- * Returns `true` if the specified value is a `RequestResolver`, `false` otherwise.
105
- *
106
- * @since 2.0.0
107
- * @category refinements
108
- */
109
- export const isRequestResolver: (u: unknown) => u is RequestResolver<unknown, unknown> = core.isRequestResolver
110
-
111
- /**
112
- * Constructs a data source with the specified identifier and method to run
113
- * requests.
114
- *
115
- * @since 2.0.0
116
- * @category constructors
117
- */
118
- export const make: <A, R>(
119
- runAll: (requests: Array<Array<A>>) => Effect.Effect<void, never, R>
120
- ) => RequestResolver<A, R> = internal.make
121
-
122
- /**
123
- * Constructs a data source with the specified identifier and method to run
124
- * requests.
125
- *
126
- * @since 2.0.0
127
- * @category constructors
128
- */
129
- export const makeWithEntry: <A, R>(
130
- runAll: (requests: Array<Array<Request.Entry<A>>>) => Effect.Effect<void, never, R>
131
- ) => RequestResolver<A, R> = internal.makeWithEntry
132
-
133
- /**
134
- * Constructs a data source from a function taking a collection of requests.
135
- *
136
- * @since 2.0.0
137
- * @category constructors
138
- */
139
- export const makeBatched: <A extends Request.Request<any, any>, R>(
140
- run: (requests: NonEmptyArray<A>) => Effect.Effect<void, never, R>
141
- ) => RequestResolver<A, R> = internal.makeBatched
142
-
143
- /**
144
- * A data source aspect that executes requests between two effects, `before`
145
- * and `after`, where the result of `before` can be used by `after`.
146
- *
147
- * @since 2.0.0
148
- * @category combinators
149
- */
150
- export const around: {
151
- <A2, R2, X, R3>(
152
- before: Effect.Effect<A2, never, R2>,
153
- after: (a: A2) => Effect.Effect<X, never, R3>
154
- ): <A, R>(self: RequestResolver<A, R>) => RequestResolver<A, R2 | R3 | R>
155
- <A, R, A2, R2, X, R3>(
156
- self: RequestResolver<A, R>,
157
- before: Effect.Effect<A2, never, R2>,
158
- after: (a: A2) => Effect.Effect<X, never, R3>
159
- ): RequestResolver<A, R | R2 | R3>
160
- } = internal.around
161
-
162
- /**
163
- * A data source aspect that executes requests between two effects, `before`
164
- * and `after`, where the result of `before` can be used by `after`.
165
- *
166
- * The `before` and `after` effects are provided with the requests being executed.
167
- *
168
- * @since 2.0.0
169
- * @category combinators
170
- * @example
171
- * ```ts
172
- * import { Effect, Request, RequestResolver } from "effect"
173
- *
174
- * interface GetUserById extends Request.Request<unknown> {
175
- * readonly id: number
176
- * }
177
- *
178
- * const resolver = RequestResolver.fromFunction(
179
- * (request: GetUserById) => ({ id: request.id, name: "John" })
180
- * )
181
- *
182
- * RequestResolver.aroundRequests(
183
- * resolver,
184
- * (requests) => Effect.log(`got ${requests.length} requests`),
185
- * (requests, _) => Effect.log(`finised running ${requests.length} requests`)
186
- * )
187
- * ```
188
- */
189
- export const aroundRequests: {
190
- <A, A2, R2, X, R3>(
191
- before: (requests: ReadonlyArray<Types.NoInfer<A>>) => Effect.Effect<A2, never, R2>,
192
- after: (requests: ReadonlyArray<Types.NoInfer<A>>, _: A2) => Effect.Effect<X, never, R3>
193
- ): <R>(self: RequestResolver<A, R>) => RequestResolver<A, R2 | R3 | R>
194
- <A, R, A2, R2, X, R3>(
195
- self: RequestResolver<A, R>,
196
- before: (requests: ReadonlyArray<Types.NoInfer<A>>) => Effect.Effect<A2, never, R2>,
197
- after: (requests: ReadonlyArray<Types.NoInfer<A>>, _: A2) => Effect.Effect<X, never, R3>
198
- ): RequestResolver<A, R | R2 | R3>
199
- } = internal.aroundRequests
200
-
201
- /**
202
- * Returns a data source that executes at most `n` requests in parallel.
203
- *
204
- * @since 2.0.0
205
- * @category combinators
206
- */
207
- export const batchN: {
208
- (n: number): <A, R>(self: RequestResolver<A, R>) => RequestResolver<A, R>
209
- <A, R>(self: RequestResolver<A, R>, n: number): RequestResolver<A, R>
210
- } = internal.batchN
211
-
212
- /**
213
- * Provides this data source with part of its required context.
214
- *
215
- * @since 2.0.0
216
- * @category context
217
- */
218
- export const mapInputContext: {
219
- <R0, R>(
220
- f: (context: Context.Context<R0>) => Context.Context<R>
221
- ): <A extends Request.Request<any, any>>(self: RequestResolver<A, R>) => RequestResolver<A, R0>
222
- <R, A extends Request.Request<any, any>, R0>(
223
- self: RequestResolver<A, R>,
224
- f: (context: Context.Context<R0>) => Context.Context<R>
225
- ): RequestResolver<A, R0>
226
- } = internal.mapInputContext
227
-
228
- /**
229
- * Returns a new data source that executes requests of type `C` using the
230
- * specified function to transform `C` requests into requests that either this
231
- * data source or that data source can execute.
232
- *
233
- * @since 2.0.0
234
- * @category combinators
235
- */
236
- export const eitherWith: {
237
- <A extends Request.Request<any, any>, R2, B extends Request.Request<any, any>, C extends Request.Request<any, any>>(
238
- that: RequestResolver<B, R2>,
239
- f: (_: Request.Entry<C>) => Either.Either<Request.Entry<B>, Request.Entry<A>>
240
- ): <R>(self: RequestResolver<A, R>) => RequestResolver<C, R2 | R>
241
- <
242
- R,
243
- A extends Request.Request<any, any>,
244
- R2,
245
- B extends Request.Request<any, any>,
246
- C extends Request.Request<any, any>
247
- >(
248
- self: RequestResolver<A, R>,
249
- that: RequestResolver<B, R2>,
250
- f: (_: Request.Entry<C>) => Either.Either<Request.Entry<B>, Request.Entry<A>>
251
- ): RequestResolver<C, R | R2>
252
- } = internal.eitherWith
253
-
254
- /**
255
- * Constructs a data source from a pure function.
256
- *
257
- * @since 2.0.0
258
- * @category constructors
259
- */
260
- export const fromFunction: <A extends Request.Request<any>>(
261
- f: (request: A) => Request.Request.Success<A>
262
- ) => RequestResolver<A> = internal.fromFunction
263
-
264
- /**
265
- * Constructs a data source from a pure function that takes a list of requests
266
- * and returns a list of results of the same size. Each item in the result
267
- * list must correspond to the item at the same index in the request list.
268
- *
269
- * @since 2.0.0
270
- * @category constructors
271
- */
272
- export const fromFunctionBatched: <A extends Request.Request<any>>(
273
- f: (chunk: NonEmptyArray<A>) => Iterable<Request.Request.Success<A>>
274
- ) => RequestResolver<A> = internal.fromFunctionBatched
275
-
276
- /**
277
- * Constructs a data source from an effectual function.
278
- *
279
- * @since 2.0.0
280
- * @category constructors
281
- */
282
- export const fromEffect: <R, A extends Request.Request<any, any>>(
283
- f: (a: A) => Effect.Effect<Request.Request.Success<A>, Request.Request.Error<A>, R>
284
- ) => RequestResolver<A, R> = internal.fromEffect
285
-
286
- /**
287
- * Constructs a data source from a list of tags paired to functions, that takes
288
- * a list of requests and returns a list of results of the same size. Each item
289
- * in the result list must correspond to the item at the same index in the
290
- * request list.
291
- *
292
- * @since 2.0.0
293
- * @category constructors
294
- */
295
- export const fromEffectTagged: <A extends Request.Request<any, any> & { readonly _tag: string }>() => <
296
- Fns extends {
297
- readonly [Tag in A["_tag"]]: [Extract<A, { readonly _tag: Tag }>] extends [infer Req]
298
- ? Req extends Request.Request<infer ReqA, infer ReqE>
299
- ? (requests: Array<Req>) => Effect.Effect<Iterable<ReqA>, ReqE, any>
300
- : never
301
- : never
302
- }
303
- >(
304
- fns: Fns
305
- ) => RequestResolver<A, ReturnType<Fns[keyof Fns]> extends Effect.Effect<infer _A, infer _E, infer R> ? R : never> =
306
- internal.fromEffectTagged
307
-
308
- /**
309
- * A data source that never executes requests.
310
- *
311
- * @since 2.0.0
312
- * @category constructors
313
- */
314
- export const never: RequestResolver<never> = internal.never
315
-
316
- /**
317
- * Provides this data source with its required context.
318
- *
319
- * @since 2.0.0
320
- * @category context
321
- */
322
- export const provideContext: {
323
- <R>(
324
- context: Context.Context<R>
325
- ): <A extends Request.Request<any, any>>(self: RequestResolver<A, R>) => RequestResolver<A>
326
- <R, A extends Request.Request<any, any>>(
327
- self: RequestResolver<A, R>,
328
- context: Context.Context<R>
329
- ): RequestResolver<A>
330
- } = internal.provideContext
331
-
332
- /**
333
- * Returns a new data source that executes requests by sending them to this
334
- * data source and that data source, returning the results from the first data
335
- * source to complete and safely interrupting the loser.
336
- *
337
- * @since 2.0.0
338
- * @category combinators
339
- */
340
- export const race: {
341
- <A2 extends Request.Request<any, any>, R2>(
342
- that: RequestResolver<A2, R2>
343
- ): <A extends Request.Request<any, any>, R>(self: RequestResolver<A, R>) => RequestResolver<A2 | A, R2 | R>
344
- <A extends Request.Request<any, any>, R, A2 extends Request.Request<any, any>, R2>(
345
- self: RequestResolver<A, R>,
346
- that: RequestResolver<A2, R2>
347
- ): RequestResolver<A | A2, R | R2>
348
- } = internal.race
349
-
350
- /**
351
- * Returns a new data source with a localized FiberRef
352
- *
353
- * @since 2.0.0
354
- * @category combinators
355
- */
356
- export const locally: {
357
- <A>(
358
- self: FiberRef<A>,
359
- value: A
360
- ): <R, B extends Request.Request<any, any>>(use: RequestResolver<B, R>) => RequestResolver<B, R>
361
- <R, B extends Request.Request<any, any>, A>(
362
- use: RequestResolver<B, R>,
363
- self: FiberRef<A>,
364
- value: A
365
- ): RequestResolver<B, R>
366
- } = core.resolverLocally
package/src/Resource.ts DELETED
@@ -1,119 +0,0 @@
1
- /**
2
- * @since 2.0.0
3
- */
4
- import type * as Effect from "./Effect.js"
5
- import type * as Exit from "./Exit.js"
6
- import * as internal from "./internal/resource.js"
7
- import type * as Schedule from "./Schedule.js"
8
- import type * as Scope from "./Scope.js"
9
- import type * as ScopedRef from "./ScopedRef.js"
10
- import type * as Types from "./Types.js"
11
- import type * as Unify from "./Unify.js"
12
-
13
- /**
14
- * @since 2.0.0
15
- * @category symbols
16
- */
17
- export const ResourceTypeId: unique symbol = internal.ResourceTypeId
18
-
19
- /**
20
- * @since 2.0.0
21
- * @category symbols
22
- */
23
- export type ResourceTypeId = typeof ResourceTypeId
24
-
25
- /**
26
- * A `Resource` is a possibly resourceful value that is loaded into memory, and
27
- * which can be refreshed either manually or automatically.
28
- *
29
- * @since 2.0.0
30
- * @category models
31
- */
32
- export interface Resource<in out A, in out E = never> extends Effect.Effect<A, E>, Resource.Variance<A, E> {
33
- /** @internal */
34
- readonly scopedRef: ScopedRef.ScopedRef<Exit.Exit<A, E>>
35
- /** @internal */
36
- readonly acquire: Effect.Effect<A, E, Scope.Scope>
37
-
38
- readonly [Unify.typeSymbol]?: unknown
39
- readonly [Unify.unifySymbol]?: ResourceUnify<this>
40
- readonly [Unify.ignoreSymbol]?: ResourceUnifyIgnore
41
- }
42
-
43
- /**
44
- * @category models
45
- * @since 3.9.0
46
- */
47
- export interface ResourceUnify<A extends { [Unify.typeSymbol]?: any }> extends Effect.EffectUnify<A> {
48
- Resource?: () => Extract<A[Unify.typeSymbol], Resource<any, any>>
49
- }
50
-
51
- /**
52
- * @category models
53
- * @since 3.9.0
54
- */
55
- export interface ResourceUnifyIgnore extends Effect.EffectUnifyIgnore {
56
- Effect?: true
57
- }
58
-
59
- /**
60
- * @since 2.0.0
61
- */
62
- export declare namespace Resource {
63
- /**
64
- * @since 2.0.0
65
- * @category models
66
- */
67
- export interface Variance<in out A, in out E> {
68
- readonly [ResourceTypeId]: {
69
- _A: Types.Invariant<A>
70
- _E: Types.Invariant<E>
71
- }
72
- }
73
- }
74
-
75
- /**
76
- * Creates a new `Resource` value that is automatically refreshed according to
77
- * the specified policy. Note that error retrying is not performed
78
- * automatically, so if you want to retry on errors, you should first apply
79
- * retry policies to the acquisition effect before passing it to this
80
- * constructor.
81
- *
82
- * @since 2.0.0
83
- * @category constructors
84
- */
85
- export const auto: <A, E, R, Out, R2>(
86
- acquire: Effect.Effect<A, E, R>,
87
- policy: Schedule.Schedule<Out, unknown, R2>
88
- ) => Effect.Effect<Resource<A, E>, never, R | R2 | Scope.Scope> = internal.auto
89
-
90
- /**
91
- * Retrieves the current value stored in the cache.
92
- *
93
- * @since 2.0.0
94
- * @category getters
95
- */
96
- export const get: <A, E>(self: Resource<A, E>) => Effect.Effect<A, E> = internal.get
97
-
98
- /**
99
- * Creates a new `Resource` value that must be manually refreshed by calling
100
- * the refresh method. Note that error retrying is not performed
101
- * automatically, so if you want to retry on errors, you should first apply
102
- * retry policies to the acquisition effect before passing it to this
103
- * constructor.
104
- *
105
- * @since 2.0.0
106
- * @category constructors
107
- */
108
- export const manual: <A, E, R>(
109
- acquire: Effect.Effect<A, E, R>
110
- ) => Effect.Effect<Resource<A, E>, never, Scope.Scope | R> = internal.manual
111
-
112
- /**
113
- * Refreshes the cache. This method will not return until either the refresh
114
- * is successful, or the refresh operation fails.
115
- *
116
- * @since 2.0.0
117
- * @category utils
118
- */
119
- export const refresh: <A, E>(self: Resource<A, E>) => Effect.Effect<void, E> = internal.refresh