@typed/fx 1.22.2 → 1.24.0

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 (157) hide show
  1. package/dist/cjs/AsyncData.js.map +1 -1
  2. package/dist/cjs/Form.js.map +1 -1
  3. package/dist/cjs/FormEntry.js.map +1 -1
  4. package/dist/cjs/Fx.js +1 -1
  5. package/dist/cjs/Fx.js.map +1 -1
  6. package/dist/cjs/Idle.js.map +1 -1
  7. package/dist/cjs/Match.js.map +1 -1
  8. package/dist/cjs/Pull.js +5 -3
  9. package/dist/cjs/Pull.js.map +1 -1
  10. package/dist/cjs/RefArray.js.map +1 -1
  11. package/dist/cjs/RefChunk.js.map +1 -1
  12. package/dist/cjs/RefHashSet.js.map +1 -1
  13. package/dist/cjs/RefSubject.js +3 -2
  14. package/dist/cjs/RefSubject.js.map +1 -1
  15. package/dist/cjs/Sink.js.map +1 -1
  16. package/dist/cjs/Subject.js.map +1 -1
  17. package/dist/cjs/Versioned.js.map +1 -1
  18. package/dist/cjs/internal/core.js.map +1 -1
  19. package/dist/cjs/internal/helpers.js.map +1 -1
  20. package/dist/cjs/internal/keyed.js +1 -1
  21. package/dist/cjs/internal/keyed.js.map +1 -1
  22. package/dist/cjs/internal/provide.js.map +1 -1
  23. package/dist/cjs/internal/share.js.map +1 -1
  24. package/dist/cjs/internal/sync-producer.js.map +1 -1
  25. package/dist/dts/AsyncData.d.ts +53 -53
  26. package/dist/dts/AsyncData.d.ts.map +1 -1
  27. package/dist/dts/Emitter.d.ts +7 -7
  28. package/dist/dts/Emitter.d.ts.map +1 -1
  29. package/dist/dts/Form.d.ts +14 -14
  30. package/dist/dts/Form.d.ts.map +1 -1
  31. package/dist/dts/FormEntry.d.ts +11 -11
  32. package/dist/dts/FormEntry.d.ts.map +1 -1
  33. package/dist/dts/Fx.d.ts +417 -417
  34. package/dist/dts/Fx.d.ts.map +1 -1
  35. package/dist/dts/Guard.d.ts +21 -21
  36. package/dist/dts/Guard.d.ts.map +1 -1
  37. package/dist/dts/Idle.d.ts +12 -12
  38. package/dist/dts/Idle.d.ts.map +1 -1
  39. package/dist/dts/Match.d.ts +16 -16
  40. package/dist/dts/Match.d.ts.map +1 -1
  41. package/dist/dts/Pull.d.ts +5 -5
  42. package/dist/dts/Pull.d.ts.map +1 -1
  43. package/dist/dts/Push.d.ts +40 -40
  44. package/dist/dts/Push.d.ts.map +1 -1
  45. package/dist/dts/RefArray.d.ts +59 -59
  46. package/dist/dts/RefArray.d.ts.map +1 -1
  47. package/dist/dts/RefChunk.d.ts +45 -45
  48. package/dist/dts/RefChunk.d.ts.map +1 -1
  49. package/dist/dts/RefHashMap.d.ts +35 -35
  50. package/dist/dts/RefHashMap.d.ts.map +1 -1
  51. package/dist/dts/RefHashSet.d.ts +17 -17
  52. package/dist/dts/RefHashSet.d.ts.map +1 -1
  53. package/dist/dts/RefSubject.d.ts +136 -136
  54. package/dist/dts/RefSubject.d.ts.map +1 -1
  55. package/dist/dts/Sink.d.ts +63 -63
  56. package/dist/dts/Sink.d.ts.map +1 -1
  57. package/dist/dts/Stream.d.ts +11 -11
  58. package/dist/dts/Stream.d.ts.map +1 -1
  59. package/dist/dts/Subject.d.ts +13 -13
  60. package/dist/dts/Subject.d.ts.map +1 -1
  61. package/dist/dts/Typeclass.d.ts +1 -1
  62. package/dist/dts/Typeclass.d.ts.map +1 -1
  63. package/dist/dts/Versioned.d.ts +33 -33
  64. package/dist/dts/Versioned.d.ts.map +1 -1
  65. package/dist/dts/index.d.ts +1 -1
  66. package/dist/dts/internal/DeferredRef.d.ts +8 -8
  67. package/dist/dts/internal/DeferredRef.d.ts.map +1 -1
  68. package/dist/dts/internal/core.d.ts +191 -191
  69. package/dist/dts/internal/core.d.ts.map +1 -1
  70. package/dist/dts/internal/effect-loop-operator.d.ts +6 -6
  71. package/dist/dts/internal/effect-loop-operator.d.ts.map +1 -1
  72. package/dist/dts/internal/effect-operator.d.ts +16 -16
  73. package/dist/dts/internal/effect-operator.d.ts.map +1 -1
  74. package/dist/dts/internal/effect-producer.d.ts +13 -13
  75. package/dist/dts/internal/effect-producer.d.ts.map +1 -1
  76. package/dist/dts/internal/helpers.d.ts +26 -26
  77. package/dist/dts/internal/helpers.d.ts.map +1 -1
  78. package/dist/dts/internal/keyed.d.ts +1 -1
  79. package/dist/dts/internal/keyed.d.ts.map +1 -1
  80. package/dist/dts/internal/loop-operator.d.ts +2 -2
  81. package/dist/dts/internal/loop-operator.d.ts.map +1 -1
  82. package/dist/dts/internal/operator.d.ts +2 -2
  83. package/dist/dts/internal/operator.d.ts.map +1 -1
  84. package/dist/dts/internal/protos.d.ts +12 -12
  85. package/dist/dts/internal/protos.d.ts.map +1 -1
  86. package/dist/dts/internal/provide.d.ts +15 -15
  87. package/dist/dts/internal/provide.d.ts.map +1 -1
  88. package/dist/dts/internal/share.d.ts +11 -11
  89. package/dist/dts/internal/share.d.ts.map +1 -1
  90. package/dist/dts/internal/sync-operator.d.ts +2 -2
  91. package/dist/dts/internal/sync-operator.d.ts.map +1 -1
  92. package/dist/dts/internal/sync-producer.d.ts +6 -6
  93. package/dist/dts/internal/sync-producer.d.ts.map +1 -1
  94. package/dist/dts/internal/withKey.d.ts +1 -1
  95. package/dist/dts/internal/withKey.d.ts.map +1 -1
  96. package/dist/esm/AsyncData.js.map +1 -1
  97. package/dist/esm/Form.js.map +1 -1
  98. package/dist/esm/FormEntry.js.map +1 -1
  99. package/dist/esm/Fx.js +1 -1
  100. package/dist/esm/Fx.js.map +1 -1
  101. package/dist/esm/Idle.js.map +1 -1
  102. package/dist/esm/Match.js.map +1 -1
  103. package/dist/esm/Pull.js +3 -3
  104. package/dist/esm/Pull.js.map +1 -1
  105. package/dist/esm/RefArray.js.map +1 -1
  106. package/dist/esm/RefChunk.js.map +1 -1
  107. package/dist/esm/RefHashSet.js.map +1 -1
  108. package/dist/esm/RefSubject.js +3 -1
  109. package/dist/esm/RefSubject.js.map +1 -1
  110. package/dist/esm/Sink.js.map +1 -1
  111. package/dist/esm/Subject.js.map +1 -1
  112. package/dist/esm/Versioned.js.map +1 -1
  113. package/dist/esm/index.js +1 -1
  114. package/dist/esm/internal/core.js.map +1 -1
  115. package/dist/esm/internal/helpers.js.map +1 -1
  116. package/dist/esm/internal/keyed.js +1 -1
  117. package/dist/esm/internal/keyed.js.map +1 -1
  118. package/dist/esm/internal/provide.js.map +1 -1
  119. package/dist/esm/internal/share.js.map +1 -1
  120. package/dist/esm/internal/sync-producer.js.map +1 -1
  121. package/package.json +6 -6
  122. package/src/AsyncData.ts +142 -144
  123. package/src/Emitter.ts +13 -13
  124. package/src/Form.ts +55 -55
  125. package/src/FormEntry.ts +39 -39
  126. package/src/Fx.ts +788 -789
  127. package/src/Guard.ts +43 -43
  128. package/src/Idle.ts +26 -26
  129. package/src/Match.ts +60 -61
  130. package/src/Pull.ts +42 -43
  131. package/src/Push.ts +195 -195
  132. package/src/RefArray.ts +121 -119
  133. package/src/RefChunk.ts +98 -97
  134. package/src/RefHashMap.ts +79 -79
  135. package/src/RefHashSet.ts +40 -39
  136. package/src/RefSubject.ts +574 -565
  137. package/src/Sink.ts +303 -303
  138. package/src/Stream.ts +27 -27
  139. package/src/Subject.ts +48 -46
  140. package/src/Typeclass.ts +2 -2
  141. package/src/Versioned.ts +97 -97
  142. package/src/index.ts +1 -1
  143. package/src/internal/DeferredRef.ts +7 -7
  144. package/src/internal/core.ts +768 -781
  145. package/src/internal/effect-loop-operator.ts +7 -7
  146. package/src/internal/effect-operator.ts +23 -23
  147. package/src/internal/effect-producer.ts +38 -38
  148. package/src/internal/helpers.ts +51 -51
  149. package/src/internal/keyed.ts +21 -21
  150. package/src/internal/loop-operator.ts +2 -2
  151. package/src/internal/operator.ts +2 -2
  152. package/src/internal/protos.ts +15 -15
  153. package/src/internal/provide.ts +27 -27
  154. package/src/internal/share.ts +25 -25
  155. package/src/internal/sync-operator.ts +4 -4
  156. package/src/internal/sync-producer.ts +15 -15
  157. package/src/internal/withKey.ts +13 -13
package/src/Fx.ts CHANGED
@@ -49,13 +49,13 @@ import { TypeId } from "./TypeId.js"
49
49
  * Fx is a push-based reactive primitive built atop of Effect.
50
50
  * @since 1.20.0
51
51
  */
52
- export interface Fx<out R, out E, out A> extends Pipeable.Pipeable {
53
- readonly [TypeId]: Fx.Variance<R, E, A>
52
+ export interface Fx<out A, out E = never, out R = never> extends Pipeable.Pipeable {
53
+ readonly [TypeId]: Fx.Variance<A, E, R>
54
54
 
55
55
  /**
56
56
  * @since 1.20.0
57
57
  */
58
- run<R2 = never>(sink: Sink.Sink<R2, E, A>): Effect.Effect<R | R2, never, unknown>
58
+ run<R2 = never>(sink: Sink.Sink<A, E, R2>): Effect.Effect<unknown, never, R | R2>
59
59
  }
60
60
 
61
61
  /**
@@ -65,7 +65,7 @@ export namespace Fx {
65
65
  /**
66
66
  * @since 1.20.0
67
67
  */
68
- export interface Variance<R, E, A> {
68
+ export interface Variance<A, E, R> {
69
69
  readonly _R: Types.Covariant<R>
70
70
  readonly _E: Types.Covariant<E>
71
71
  readonly _A: Types.Covariant<A>
@@ -74,22 +74,22 @@ export namespace Fx {
74
74
  /**
75
75
  * @since 1.20.0
76
76
  */
77
- export type Context<T> = T extends Fx<infer R, infer _E, infer _A> ? R : never
77
+ export type Context<T> = T extends Fx<infer _A, infer _E, infer R> ? R : never
78
78
 
79
79
  /**
80
80
  * @since 1.20.0
81
81
  */
82
- export type Error<T> = T extends Fx<infer _R, infer E, infer _A> ? E : never
82
+ export type Error<T> = T extends Fx<infer _A, infer E, infer _R> ? E : never
83
83
 
84
84
  /**
85
85
  * @since 1.20.0
86
86
  */
87
- export type Success<T> = T extends Fx<infer _R, infer _E, infer A> ? A : never
87
+ export type Success<T> = T extends Fx<infer A, infer _E, infer _R> ? A : never
88
88
 
89
89
  /**
90
90
  * @since 1.20.0
91
91
  */
92
- export type Unify<T> = T extends Fx<infer R, infer E, infer A> | infer _ ? Fx<R, E, A> : never
92
+ export type Unify<T> = T extends Fx<infer A, infer E, infer R> | infer _ ? Fx<A, E, R> : never
93
93
  }
94
94
 
95
95
  /**
@@ -115,7 +115,7 @@ export type Unify<T> = Fx.Unify<T>
115
115
  /**
116
116
  * @since 1.20.0
117
117
  */
118
- export function isFx<R, E, A>(u: unknown): u is Fx<R, E, A> {
118
+ export function isFx<A, E, R>(u: unknown): u is Fx<A, E, R> {
119
119
  return u === null ? false : hasProperty(u, TypeId)
120
120
  }
121
121
 
@@ -264,7 +264,7 @@ export const Ordered: (concurrency: number) => Ordered = strategies.Ordered
264
264
  * @since 1.20.0
265
265
  * @category models
266
266
  */
267
- export type ScopedFork = <R, E, A>(effect: Effect.Effect<R, E, A>) => Effect.Effect<R, never, Fiber.Fiber<E, A>>
267
+ export type ScopedFork = <A, E, R>(effect: Effect.Effect<A, E, R>) => Effect.Effect<Fiber.Fiber<A, E>, never, R>
268
268
 
269
269
  /**
270
270
  * Type-alias for Effect.forkIn(scope) which runs the Effect runtime
@@ -274,42 +274,42 @@ export type ScopedFork = <R, E, A>(effect: Effect.Effect<R, E, A>) => Effect.Eff
274
274
  * @category models
275
275
  */
276
276
  export type FxFork = <R>(
277
- effect: Effect.Effect<R, never, void>
278
- ) => Effect.Effect<R, never, void>
277
+ effect: Effect.Effect<void, never, R>
278
+ ) => Effect.Effect<void, never, R>
279
279
 
280
280
  /**
281
281
  * @since 1.20.0
282
282
  */
283
283
  export const make: {
284
- <R, E, A>(run: (sink: Sink.Sink<never, E, A>) => Effect.Effect<R, never, unknown>): Fx<R, E, A>
285
- <E, A>(run: (sink: Sink.Sink<never, E, A>) => Effect.Effect<never, never, unknown>): Fx<never, E, A>
286
- <A>(run: (sink: Sink.Sink<never, never, A>) => Effect.Effect<never, never, unknown>): Fx<never, never, A>
284
+ <A, E, R>(run: (sink: Sink.Sink<A, E>) => Effect.Effect<unknown, never, R>): Fx<A, E, R>
285
+ <A, E>(run: (sink: Sink.Sink<A, E>) => Effect.Effect<unknown>): Fx<A, E>
286
+ <A>(run: (sink: Sink.Sink<A>) => Effect.Effect<unknown>): Fx<A>
287
287
  } = core.make
288
288
 
289
289
  /**
290
290
  * @since 1.20.0
291
291
  */
292
- export const succeed: <A>(value: A) => Fx<never, never, A> = core.succeed
292
+ export const succeed: <A>(value: A) => Fx<A> = core.succeed
293
293
 
294
294
  /**
295
295
  * @since 1.20.0
296
296
  */
297
- export const sync: <A>(f: () => A) => Fx<never, never, A> = core.fromSync
297
+ export const sync: <A>(f: () => A) => Fx<A> = core.fromSync
298
298
 
299
299
  /**
300
300
  * @since 1.20.0
301
301
  */
302
- export const fromArray: <const A extends ReadonlyArray<any>>(array: A) => Fx<never, never, A[number]> = core.fromArray
302
+ export const fromArray: <const A extends ReadonlyArray<any>>(array: A) => Fx<A[number]> = core.fromArray
303
303
 
304
304
  /**
305
305
  * @since 1.20.0
306
306
  */
307
- export const fromIterable: <A>(iterable: Iterable<A>) => Fx<never, never, A> = core.fromIterable
307
+ export const fromIterable: <A>(iterable: Iterable<A>) => Fx<A> = core.fromIterable
308
308
 
309
309
  /**
310
310
  * @since 1.20.0
311
311
  */
312
- export const fromEffect: <R, E, A>(effect: Effect.Effect<R, E, A>) => Fx<R, E, A> = core.fromEffect
312
+ export const fromEffect: <A, E, R>(effect: Effect.Effect<A, E, R>) => Fx<A, E, R> = core.fromEffect
313
313
 
314
314
  /**
315
315
  * @since 1.20.0
@@ -317,12 +317,12 @@ export const fromEffect: <R, E, A>(effect: Effect.Effect<R, E, A>) => Fx<R, E, A
317
317
  export const fromScheduled: {
318
318
  <R2, I, O>(
319
319
  schedule: Schedule.Schedule<R2, I, O>
320
- ): <R, E>(input: Effect.Effect<R, E, I>) => Fx<R | R2, E, O>
320
+ ): <E, R>(input: Effect.Effect<I, E, R>) => Fx<O, E, R | R2>
321
321
 
322
- <R, E, I, R2, O>(
323
- input: Effect.Effect<R, E, I>,
322
+ <I, E, R, R2, O>(
323
+ input: Effect.Effect<I, E, R>,
324
324
  schedule: Schedule.Schedule<R2, I, O>
325
- ): Fx<R | R2, E, O>
325
+ ): Fx<O, E, R | R2>
326
326
  } = dual(2, core.fromScheduled)
327
327
 
328
328
  /**
@@ -331,294 +331,294 @@ export const fromScheduled: {
331
331
  export const schedule: {
332
332
  <R2, O>(
333
333
  schedule: Schedule.Schedule<R2, unknown, O>
334
- ): <R, E, A>(input: Effect.Effect<R, E, A>) => Fx<R | R2, E, A>
334
+ ): <A, E, R>(input: Effect.Effect<A, E, R>) => Fx<A, E, R | R2>
335
335
 
336
- <R, E, A, R2, O>(
337
- input: Effect.Effect<R, E, A>,
336
+ <A, E, R, R2, O>(
337
+ input: Effect.Effect<A, E, R>,
338
338
  schedule: Schedule.Schedule<R2, unknown, O>
339
- ): Fx<R | R2, E, A>
339
+ ): Fx<A, E, R | R2>
340
340
  } = dual(2, core.schedule)
341
341
 
342
342
  /**
343
343
  * @since 1.20.0
344
344
  */
345
345
  export const periodic: {
346
- (period: Duration.DurationInput): <R, E, A>(iterator: Effect.Effect<R, E, A>) => Fx<R, E, A>
347
- <R, E, A>(iterator: Effect.Effect<R, E, A>, period: Duration.DurationInput): Fx<R, E, A>
348
- } = dual(2, <R, E, A>(
349
- iterator: Effect.Effect<R, E, A>,
346
+ (period: Duration.DurationInput): <A, E, R>(iterator: Effect.Effect<A, E, R>) => Fx<A, E, R>
347
+ <A, E, R>(iterator: Effect.Effect<A, E, R>, period: Duration.DurationInput): Fx<A, E, R>
348
+ } = dual(2, <A, E, R>(
349
+ iterator: Effect.Effect<A, E, R>,
350
350
  period: Duration.DurationInput
351
- ): Fx<R, E, A> => continueWith(fromEffect(iterator), () => schedule(iterator, Schedule.spaced(period))))
351
+ ): Fx<A, E, R> => continueWith(fromEffect(iterator), () => schedule(iterator, Schedule.spaced(period))))
352
352
 
353
353
  /**
354
354
  * @since 1.20.0
355
355
  */
356
- export const failCause: <E>(cause: Cause.Cause<E>) => Fx<never, E, never> = core.failCause
356
+ export const failCause: <E>(cause: Cause.Cause<E>) => Fx<never, E> = core.failCause
357
357
 
358
358
  /**
359
359
  * @since 1.20.0
360
360
  */
361
- export const fail: <E>(error: E) => Fx<never, E, never> = core.fail
361
+ export const fail: <E>(error: E) => Fx<never, E> = core.fail
362
362
 
363
363
  /**
364
364
  * @since 1.20.0
365
365
  */
366
- export const die: (error: unknown) => Fx<never, never, never> = core.die
366
+ export const die: (error: unknown) => Fx<never> = core.die
367
367
 
368
368
  /**
369
369
  * @since 1.20.0
370
370
  */
371
371
  export const map: {
372
- <A, B>(f: (a: A) => B): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, B>
373
- <R, E, A, B>(fx: Fx<R, E, A>, f: (a: A) => B): Fx<R, E, B>
372
+ <A, B>(f: (a: A) => B): <E, R>(fx: Fx<A, E, R>) => Fx<B, E, R>
373
+ <A, E, R, B>(fx: Fx<A, E, R>, f: (a: A) => B): Fx<B, E, R>
374
374
  } = dual(2, core.map)
375
375
 
376
376
  /**
377
377
  * @since 1.20.0
378
378
  */
379
379
  export const filter: {
380
- <A, B extends A>(f: Predicate.Refinement<A, B>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, B>
381
- <A>(f: Predicate.Predicate<A>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, A>
382
- <R, E, A, B extends A>(fx: Fx<R, E, A>, f: Predicate.Refinement<A, B>): Fx<R, E, B>
383
- <R, E, A>(fx: Fx<R, E, A>, f: Predicate.Predicate<A>): Fx<R, E, A>
380
+ <A, B extends A>(f: Predicate.Refinement<A, B>): <E, R>(fx: Fx<A, E, R>) => Fx<B, E, R>
381
+ <A>(f: Predicate.Predicate<A>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
382
+ <A, E, R, B extends A>(fx: Fx<A, E, R>, f: Predicate.Refinement<A, B>): Fx<B, E, R>
383
+ <A, E, R>(fx: Fx<A, E, R>, f: Predicate.Predicate<A>): Fx<A, E, R>
384
384
  } = dual(2, core.filter)
385
385
 
386
386
  /**
387
387
  * @since 1.20.0
388
388
  */
389
389
  export const filterMap: {
390
- <A, B>(f: (a: A) => Option.Option<B>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, B>
391
- <R, E, A, B>(fx: Fx<R, E, A>, f: (a: A) => Option.Option<B>): Fx<R, E, B>
390
+ <A, B>(f: (a: A) => Option.Option<B>): <E, R>(fx: Fx<A, E, R>) => Fx<B, E, R>
391
+ <A, E, R, B>(fx: Fx<A, E, R>, f: (a: A) => Option.Option<B>): Fx<B, E, R>
392
392
  } = dual(2, core.filterMap)
393
393
 
394
394
  /**
395
395
  * @since 1.20.0
396
396
  */
397
- export const compact = <R, E, A>(fx: Fx<R, E, Option.Option<A>>): Fx<R, E, A> => filterMap(fx, identity)
397
+ export const compact = <A, E, R>(fx: Fx<Option.Option<A>, E, R>): Fx<A, E, R> => filterMap(fx, identity)
398
398
 
399
399
  /**
400
400
  * @since 1.20.0
401
401
  */
402
402
  export const mapEffect: {
403
- <A, R2, E2, B>(f: (a: A) => Effect.Effect<R2, E2, B>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, B>
404
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, B>): Fx<R | R2, E | E2, B>
403
+ <A, B, E2, R2>(f: (a: A) => Effect.Effect<B, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2>
404
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<B, E2, R2>): Fx<B, E | E2, R | R2>
405
405
  } = dual(2, core.mapEffect)
406
406
 
407
407
  /**
408
408
  * @since 1.20.0
409
409
  */
410
410
  export const filterMapEffect: {
411
- <A, R2, E2, B>(f: (a: A) => Effect.Effect<R2, E2, Option.Option<B>>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, B>
412
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, Option.Option<B>>): Fx<R | R2, E | E2, B>
411
+ <A, B, E2, R2>(f: (a: A) => Effect.Effect<Option.Option<B>, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2>
412
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<Option.Option<B>, E2, R2>): Fx<B, E | E2, R | R2>
413
413
  } = dual(2, core.filterMapEffect)
414
414
 
415
415
  /**
416
416
  * @since 1.20.0
417
417
  */
418
418
  export const filterEffect: {
419
- <A, R2, E2>(f: (a: A) => Effect.Effect<R2, E2, boolean>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A>
420
- <R, E, A, R2, E2>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, boolean>): Fx<R | R2, E | E2, A>
419
+ <A, E2, R2>(f: (a: A) => Effect.Effect<boolean, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R | R2>
420
+ <A, E, R, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<boolean, E2, R2>): Fx<A, E | E2, R | R2>
421
421
  } = dual(2, core.filterEffect)
422
422
 
423
423
  /**
424
424
  * @since 1.20.0
425
425
  */
426
426
  export const tapEffect: {
427
- <A, R2, E2>(f: (a: A) => Effect.Effect<R2, E2, unknown>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A>
428
- <R, E, A, R2, E2>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, unknown>): Fx<R | R2, E | E2, A>
427
+ <A, E2, R2>(f: (a: A) => Effect.Effect<unknown, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R | R2>
428
+ <A, E, R, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<unknown, E2, R2>): Fx<A, E | E2, R | R2>
429
429
  } = dual(2, core.tapEffect)
430
430
 
431
431
  /**
432
432
  * @since 1.20.0
433
433
  */
434
434
  export const tap: {
435
- <A>(f: (a: A) => unknown): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, A>
436
- <R, E, A>(fx: Fx<R, E, A>, f: (a: A) => unknown): Fx<R, E, A>
435
+ <A>(f: (a: A) => unknown): <E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
436
+ <A, E, R>(fx: Fx<A, E, R>, f: (a: A) => unknown): Fx<A, E, R>
437
437
  } = dual(2, (fx, f) => tapEffect(fx, (a) => Effect.sync(() => f(a))))
438
438
 
439
439
  /**
440
440
  * @since 1.20.0
441
441
  */
442
442
  export const loop: {
443
- <B, A, C>(seed: B, f: (acc: B, a: A) => readonly [C, B]): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, C>
444
- <R, E, A, B, C>(fx: Fx<R, E, A>, seed: B, f: (acc: B, a: A) => readonly [C, B]): Fx<R, E, C>
443
+ <B, A, C>(seed: B, f: (acc: B, a: A) => readonly [C, B]): <E, R>(fx: Fx<A, E, R>) => Fx<C, E, R>
444
+ <A, E, R, B, C>(fx: Fx<A, E, R>, seed: B, f: (acc: B, a: A) => readonly [C, B]): Fx<C, E, R>
445
445
  } = dual(3, core.loop)
446
446
 
447
447
  /**
448
448
  * @since 1.20.0
449
449
  */
450
450
  export const filterMapLoop: {
451
- <B, A, C>(seed: B, f: (acc: B, a: A) => readonly [Option.Option<C>, B]): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, C>
452
- <R, E, A, B, C>(fx: Fx<R, E, A>, seed: B, f: (acc: B, a: A) => readonly [Option.Option<C>, B]): Fx<R, E, C>
451
+ <B, A, C>(seed: B, f: (acc: B, a: A) => readonly [Option.Option<C>, B]): <E, R>(fx: Fx<A, E, R>) => Fx<C, E, R>
452
+ <A, E, R, B, C>(fx: Fx<A, E, R>, seed: B, f: (acc: B, a: A) => readonly [Option.Option<C>, B]): Fx<C, E, R>
453
453
  } = dual(3, core.filterMapLoop)
454
454
 
455
455
  /**
456
456
  * @since 1.20.0
457
457
  */
458
458
  export const loopEffect: {
459
- <R2, E2, B, A, C>(
459
+ <B, E2, R2, A, C>(
460
460
  seed: B,
461
- f: (acc: B, a: A) => Effect.Effect<R2, E2, readonly [C, B]>
462
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, C>
463
- <R, E, A, R2, E2, B, C>(
464
- fx: Fx<R, E, A>,
461
+ f: (acc: B, a: A) => Effect.Effect<readonly [C, B], E2, R2>
462
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<C, E | E2, R | R2>
463
+ <A, E, R, B, E2, R2, C>(
464
+ fx: Fx<A, E, R>,
465
465
  seed: B,
466
- f: (acc: B, a: A) => Effect.Effect<R2, E2, readonly [C, B]>
467
- ): Fx<R | R2, E | E2, C>
466
+ f: (acc: B, a: A) => Effect.Effect<readonly [C, B], E2, R2>
467
+ ): Fx<C, E | E2, R | R2>
468
468
  } = dual(3, core.loopEffect)
469
469
 
470
470
  /**
471
471
  * @since 1.20.0
472
472
  */
473
473
  export const filterMapLoopEffect: {
474
- <R2, E2, B, A, C>(
474
+ <B, E2, R2, A, C>(
475
475
  seed: B,
476
- f: (acc: B, a: A) => Effect.Effect<R2, E2, readonly [Option.Option<C>, B]>
477
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, C>
478
- <R, E, A, R2, E2, B, C>(
479
- fx: Fx<R, E, A>,
476
+ f: (acc: B, a: A) => Effect.Effect<readonly [Option.Option<C>, B], E2, R2>
477
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<C, E | E2, R | R2>
478
+ <A, E, R, B, E2, R2, C>(
479
+ fx: Fx<A, E, R>,
480
480
  seed: B,
481
- f: (acc: B, a: A) => Effect.Effect<R2, E2, readonly [Option.Option<C>, B]>
482
- ): Fx<R | R2, E | E2, C>
481
+ f: (acc: B, a: A) => Effect.Effect<readonly [Option.Option<C>, B], E2, R2>
482
+ ): Fx<C, E | E2, R | R2>
483
483
  } = dual(3, core.filterMapLoopEffect)
484
484
 
485
485
  /**
486
486
  * @since 1.20.0
487
487
  */
488
488
  export const observe: {
489
- <A, R2, E2, B>(f: (a: A) => Effect.Effect<R2, E2, B>): <R, E>(fx: Fx<R, E, A>) => Effect.Effect<R | R2, E | E2, void>
490
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, B>): Effect.Effect<R | R2, E | E2, void>
489
+ <A, B, E2, R2>(f: (a: A) => Effect.Effect<B, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Effect.Effect<void, E | E2, R | R2>
490
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<B, E2, R2>): Effect.Effect<void, E | E2, R | R2>
491
491
  } = dual(2, core.observe)
492
492
 
493
493
  /**
494
494
  * @since 1.20.0
495
495
  */
496
- export const drain: <R, E, A>(fx: Fx<R, E, A>) => Effect.Effect<R, E, void> = core.drain
496
+ export const drain: <A, E, R>(fx: Fx<A, E, R>) => Effect.Effect<void, E, R> = core.drain
497
497
 
498
498
  /**
499
499
  * @since 1.20.0
500
500
  */
501
501
  export const reduce: {
502
- <A, B>(seed: B, f: (acc: B, a: A) => B): <R, E>(fx: Fx<R, E, A>) => Effect.Effect<R, E, B>
503
- <R, E, A, B>(fx: Fx<R, E, A>, seed: B, f: (acc: B, a: A) => B): Effect.Effect<R, E, B>
502
+ <A, B>(seed: B, f: (acc: B, a: A) => B): <E, R>(fx: Fx<A, E, R>) => Effect.Effect<B, E, R>
503
+ <A, E, R, B>(fx: Fx<A, E, R>, seed: B, f: (acc: B, a: A) => B): Effect.Effect<B, E, R>
504
504
  } = dual(3, core.reduce)
505
505
 
506
506
  /**
507
507
  * @since 1.20.0
508
508
  */
509
- export const toReadonlyArray: <R, E, A>(fx: Fx<R, E, A>) => Effect.Effect<R, E, ReadonlyArray<A>> = core.toReadonlyArray
509
+ export const toReadonlyArray: <A, E, R>(fx: Fx<A, E, R>) => Effect.Effect<ReadonlyArray<A>, E, R> = core.toReadonlyArray
510
510
 
511
511
  /**
512
512
  * @since 1.20.0
513
513
  */
514
514
  export const slice: {
515
- (drop: number, take: number): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
516
- <R, E, A>(fx: Fx<R, E, A>, drop: number, take: number): Fx<R, E, A>
515
+ (drop: number, take: number): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
516
+ <A, E, R>(fx: Fx<A, E, R>, drop: number, take: number): Fx<A, E, R>
517
517
  } = dual(3, core.slice)
518
518
 
519
519
  /**
520
520
  * @since 1.20.0
521
521
  */
522
522
  export const take: {
523
- (n: number): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
524
- <R, E, A>(fx: Fx<R, E, A>, n: number): Fx<R, E, A>
523
+ (n: number): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
524
+ <A, E, R>(fx: Fx<A, E, R>, n: number): Fx<A, E, R>
525
525
  } = dual(2, core.take)
526
526
 
527
527
  /**
528
528
  * @since 1.20.0
529
529
  */
530
530
  export const drop: {
531
- (n: number): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
532
- <R, E, A>(fx: Fx<R, E, A>, n: number): Fx<R, E, A>
531
+ (n: number): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
532
+ <A, E, R>(fx: Fx<A, E, R>, n: number): Fx<A, E, R>
533
533
  } = dual(2, core.drop)
534
534
 
535
535
  /**
536
536
  * @since 1.20.0
537
537
  */
538
- export const skipRepeats: <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A> = core.skipRepeats
538
+ export const skipRepeats: <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R> = core.skipRepeats
539
539
 
540
540
  /**
541
541
  * @since 1.20.0
542
542
  */
543
543
  export const skipRepeatsWith: {
544
- <A>(eq: Equivalence.Equivalence<A>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, A>
545
- <R, E, A>(fx: Fx<R, E, A>, eq: Equivalence.Equivalence<A>): Fx<R, E, A>
544
+ <A>(eq: Equivalence.Equivalence<A>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
545
+ <A, E, R>(fx: Fx<A, E, R>, eq: Equivalence.Equivalence<A>): Fx<A, E, R>
546
546
  } = dual(2, core.skipRepeatsWith)
547
547
 
548
548
  /**
549
549
  * @since 1.20.0
550
550
  */
551
- export const empty: Fx<never, never, never> = core.empty
551
+ export const empty: Fx<never> = core.empty
552
552
 
553
553
  /**
554
554
  * @since 1.20.0
555
555
  */
556
- export const never: Fx<never, never, never> = core.never
556
+ export const never: Fx<never> = core.never
557
557
 
558
558
  /**
559
559
  * @since 1.20.0
560
560
  */
561
561
  export const padWith: {
562
- <B, C>(start: Iterable<B>, end: Iterable<C>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A | B | C>
563
- <R, E, A, B, C>(fx: Fx<R, E, A>, start: Iterable<B>, end: Iterable<C>): Fx<R, E, A | B | C>
562
+ <B, C>(start: Iterable<B>, end: Iterable<C>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | B | C, E, R>
563
+ <A, E, R, B, C>(fx: Fx<A, E, R>, start: Iterable<B>, end: Iterable<C>): Fx<A | B | C, E, R>
564
564
  } = dual(3, core.padWith)
565
565
 
566
566
  /**
567
567
  * @since 1.20.0
568
568
  */
569
569
  export const prependAll: {
570
- <B>(start: Iterable<B>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A | B>
571
- <R, E, A, B>(fx: Fx<R, E, A>, start: Iterable<B>): Fx<R, E, A | B>
570
+ <B>(start: Iterable<B>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | B, E, R>
571
+ <A, E, R, B>(fx: Fx<A, E, R>, start: Iterable<B>): Fx<A | B, E, R>
572
572
  } = dual(2, core.prependAll)
573
573
 
574
574
  /**
575
575
  * @since 1.20.0
576
576
  */
577
577
  export const appendAll: {
578
- <C>(end: Iterable<C>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A | C>
579
- <R, E, A, C>(fx: Fx<R, E, A>, end: Iterable<C>): Fx<R, E, A | C>
578
+ <C>(end: Iterable<C>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | C, E, R>
579
+ <A, E, R, C>(fx: Fx<A, E, R>, end: Iterable<C>): Fx<A | C, E, R>
580
580
  } = dual(2, core.appendAll)
581
581
 
582
582
  /**
583
583
  * @since 1.20.0
584
584
  */
585
585
  export const prepend: {
586
- <B>(start: B): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A | B>
587
- <R, E, A, B>(fx: Fx<R, E, A>, start: B): Fx<R, E, A | B>
586
+ <B>(start: B): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | B, E, R>
587
+ <A, E, R, B>(fx: Fx<A, E, R>, start: B): Fx<A | B, E, R>
588
588
  } = dual(2, core.prepend)
589
589
 
590
590
  /**
591
591
  * @since 1.20.0
592
592
  */
593
593
  export const append: {
594
- <C>(end: C): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A | C>
595
- <R, E, A, C>(fx: Fx<R, E, A>, end: C): Fx<R, E, A | C>
594
+ <C>(end: C): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | C, E, R>
595
+ <A, E, R, C>(fx: Fx<A, E, R>, end: C): Fx<A | C, E, R>
596
596
  } = dual(2, core.append)
597
597
 
598
598
  /**
599
599
  * @since 1.20.0
600
600
  */
601
601
  export const scan: {
602
- <B, A>(seed: B, f: (b: B, a: A) => B): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, B>
603
- <R, E, A, B>(fx: Fx<R, E, A>, seed: B, f: (b: B, a: A) => B): Fx<R, E, B>
602
+ <B, A>(seed: B, f: (b: B, a: A) => B): <E, R>(fx: Fx<A, E, R>) => Fx<B, E, R>
603
+ <A, E, R, B>(fx: Fx<A, E, R>, seed: B, f: (b: B, a: A) => B): Fx<B, E, R>
604
604
  } = dual(3, core.scan)
605
605
 
606
606
  /**
607
607
  * @since 1.20.0
608
608
  */
609
609
  export const flatMapWithStrategy: {
610
- <A, R2, E2, B>(
611
- f: (a: A) => Fx<R2, E2, B>,
610
+ <A, B, E2, R2>(
611
+ f: (a: A) => Fx<B, E2, R2>,
612
612
  strategy: FlattenStrategy,
613
613
  executionStrategy?: ExecutionStrategy.ExecutionStrategy
614
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
614
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
615
615
 
616
- <R, E, A, R2, E2, B>(
617
- fx: Fx<R, E, A>,
618
- f: (a: A) => Fx<R2, E2, B>,
616
+ <A, E, R, B, E2, R2>(
617
+ fx: Fx<A, E, R>,
618
+ f: (a: A) => Fx<B, E2, R2>,
619
619
  strategy: FlattenStrategy,
620
620
  executionStrategy?: ExecutionStrategy.ExecutionStrategy
621
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
621
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
622
622
  } = dual(4, core.flatMapWithStrategy)
623
623
 
624
624
  const isDataFirstFx = (args: IArguments) => isFx(args[0])
@@ -627,215 +627,215 @@ const isDataFirstFx = (args: IArguments) => isFx(args[0])
627
627
  * @since 1.20.0
628
628
  */
629
629
  export const flatMap: {
630
- <A, R2, E2, B>(
631
- f: (a: A) => Fx<R2, E2, B>,
630
+ <A, B, E2, R2>(
631
+ f: (a: A) => Fx<B, E2, R2>,
632
632
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
633
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
633
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
634
634
 
635
- <R, E, A, R2, E2, B>(
636
- fx: Fx<R, E, A>,
637
- f: (a: A) => Fx<R2, E2, B>,
635
+ <A, E, R, B, E2, R2>(
636
+ fx: Fx<A, E, R>,
637
+ f: (a: A) => Fx<B, E2, R2>,
638
638
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
639
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
639
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
640
640
  } = dual(isDataFirstFx, core.flatMap)
641
641
 
642
642
  /**
643
643
  * @since 1.20.0
644
644
  */
645
645
  export const flatMapEffect: {
646
- <A, R2, E2, B>(
647
- f: (a: A) => Effect.Effect<R2, E2, B>,
646
+ <A, B, E2, R2>(
647
+ f: (a: A) => Effect.Effect<B, E2, R2>,
648
648
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
649
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
649
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
650
650
 
651
- <R, E, A, R2, E2, B>(
652
- fx: Fx<R, E, A>,
653
- f: (a: A) => Effect.Effect<R2, E2, B>,
651
+ <A, E, R, B, E2, R2>(
652
+ fx: Fx<A, E, R>,
653
+ f: (a: A) => Effect.Effect<B, E2, R2>,
654
654
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
655
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
655
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
656
656
  } = dual(isDataFirstFx, core.flatMapEffect)
657
657
 
658
658
  /**
659
659
  * @since 1.20.0
660
660
  */
661
661
  export const switchMap: {
662
- <A, R2, E2, B>(
663
- f: (a: A) => Fx<R2, E2, B>,
662
+ <A, B, E2, R2>(
663
+ f: (a: A) => Fx<B, E2, R2>,
664
664
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
665
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
665
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
666
666
 
667
- <R, E, A, R2, E2, B>(
668
- fx: Fx<R, E, A>,
669
- f: (a: A) => Fx<R2, E2, B>,
667
+ <A, E, R, B, E2, R2>(
668
+ fx: Fx<A, E, R>,
669
+ f: (a: A) => Fx<B, E2, R2>,
670
670
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
671
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
671
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
672
672
  } = dual(isDataFirstFx, core.switchMap)
673
673
 
674
674
  /**
675
675
  * @since 1.20.0
676
676
  */
677
677
  export const switchMapEffect: {
678
- <A, R2, E2, B>(
679
- f: (a: A) => Effect.Effect<R2, E2, B>,
678
+ <A, B, E2, R2>(
679
+ f: (a: A) => Effect.Effect<B, E2, R2>,
680
680
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
681
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
681
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
682
682
 
683
- <R, E, A, R2, E2, B>(
684
- fx: Fx<R, E, A>,
685
- f: (a: A) => Effect.Effect<R2, E2, B>,
683
+ <A, E, R, B, E2, R2>(
684
+ fx: Fx<A, E, R>,
685
+ f: (a: A) => Effect.Effect<B, E2, R2>,
686
686
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
687
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
687
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
688
688
  } = dual(isDataFirstFx, core.switchMapEffect)
689
689
 
690
690
  /**
691
691
  * @since 1.20.0
692
692
  */
693
693
  export const exhaustMap: {
694
- <A, R2, E2, B>(
695
- f: (a: A) => Fx<R2, E2, B>,
694
+ <A, B, E2, R2>(
695
+ f: (a: A) => Fx<B, E2, R2>,
696
696
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
697
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
697
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
698
698
 
699
- <R, E, A, R2, E2, B>(
700
- fx: Fx<R, E, A>,
701
- f: (a: A) => Fx<R2, E2, B>,
699
+ <A, E, R, B, E2, R2>(
700
+ fx: Fx<A, E, R>,
701
+ f: (a: A) => Fx<B, E2, R2>,
702
702
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
703
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
703
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
704
704
  } = dual(isDataFirstFx, core.exhaustMap)
705
705
 
706
706
  /**
707
707
  * @since 1.20.0
708
708
  */
709
709
  export const exhaustMapEffect: {
710
- <A, R2, E2, B>(
711
- f: (a: A) => Effect.Effect<R2, E2, B>,
710
+ <A, B, E2, R2>(
711
+ f: (a: A) => Effect.Effect<B, E2, R2>,
712
712
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
713
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
713
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
714
714
 
715
- <R, E, A, R2, E2, B>(
716
- fx: Fx<R, E, A>,
717
- f: (a: A) => Effect.Effect<R2, E2, B>,
715
+ <A, E, R, B, E2, R2>(
716
+ fx: Fx<A, E, R>,
717
+ f: (a: A) => Effect.Effect<B, E2, R2>,
718
718
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
719
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
719
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
720
720
  } = dual(isDataFirstFx, core.exhaustMapEffect)
721
721
 
722
722
  /**
723
723
  * @since 1.20.0
724
724
  */
725
725
  export const exhaustMapLatest: {
726
- <A, R2, E2, B>(
727
- f: (a: A) => Fx<R2, E2, B>,
726
+ <A, B, E2, R2>(
727
+ f: (a: A) => Fx<B, E2, R2>,
728
728
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
729
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
729
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
730
730
 
731
- <R, E, A, R2, E2, B>(
732
- fx: Fx<R, E, A>,
733
- f: (a: A) => Fx<R2, E2, B>,
731
+ <A, E, R, B, E2, R2>(
732
+ fx: Fx<A, E, R>,
733
+ f: (a: A) => Fx<B, E2, R2>,
734
734
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
735
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
735
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
736
736
  } = dual(isDataFirstFx, core.exhaustMapLatest)
737
737
 
738
738
  /**
739
739
  * @since 1.20.0
740
740
  */
741
741
  export const exhaustMapLatestEffect: {
742
- <A, R2, E2, B>(
743
- f: (a: A) => Effect.Effect<R2, E2, B>,
742
+ <A, B, E2, R2>(
743
+ f: (a: A) => Effect.Effect<B, E2, R2>,
744
744
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
745
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
745
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
746
746
 
747
- <R, E, A, R2, E2, B>(
748
- fx: Fx<R, E, A>,
749
- f: (a: A) => Effect.Effect<R2, E2, B>,
747
+ <A, E, R, B, E2, R2>(
748
+ fx: Fx<A, E, R>,
749
+ f: (a: A) => Effect.Effect<B, E2, R2>,
750
750
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
751
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
751
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
752
752
  } = dual(isDataFirstFx, core.exhaustMapLatestEffect)
753
753
 
754
754
  /**
755
755
  * @since 1.20.0
756
756
  */
757
757
  export const flatMapConcurrently: {
758
- <A, R2, E2, B>(
759
- f: (a: A) => Fx<R2, E2, B>,
758
+ <A, B, E2, R2>(
759
+ f: (a: A) => Fx<B, E2, R2>,
760
760
  capacity: number,
761
761
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
762
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
762
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
763
763
 
764
- <R, E, A, R2, E2, B>(
765
- fx: Fx<R, E, A>,
766
- f: (a: A) => Fx<R2, E2, B>,
764
+ <A, E, R, B, E2, R2>(
765
+ fx: Fx<A, E, R>,
766
+ f: (a: A) => Fx<B, E2, R2>,
767
767
  capacity: number,
768
768
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
769
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
769
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
770
770
  } = dual(isDataFirstFx, core.flatMapConcurrently)
771
771
 
772
772
  /**
773
773
  * @since 1.20.0
774
774
  */
775
775
  export const flatMapConcurrentlyEffect: {
776
- <A, R2, E2, B>(
777
- f: (a: A) => Effect.Effect<R2, E2, B>,
776
+ <A, B, E2, R2>(
777
+ f: (a: A) => Effect.Effect<B, E2, R2>,
778
778
  capacity: number,
779
779
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
780
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, B>
780
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, R | R2 | Scope.Scope>
781
781
 
782
- <R, E, A, R2, E2, B>(
783
- fx: Fx<R, E, A>,
784
- f: (a: A) => Effect.Effect<R2, E2, B>,
782
+ <A, E, R, B, E2, R2>(
783
+ fx: Fx<A, E, R>,
784
+ f: (a: A) => Effect.Effect<B, E2, R2>,
785
785
  capacity: number,
786
786
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
787
- ): Fx<R | R2 | Scope.Scope, E | E2, B>
787
+ ): Fx<B, E | E2, R | R2 | Scope.Scope>
788
788
  } = dual(isDataFirstFx, core.flatMapConcurrentlyEffect)
789
789
 
790
790
  /**
791
791
  * @since 1.20.0
792
792
  */
793
793
  export const concatMap: {
794
- <A, R2, E2, B>(
795
- f: (a: A) => Fx<R2, E2, B>,
794
+ <A, B, E2, R2>(
795
+ f: (a: A) => Fx<B, E2, R2>,
796
796
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
797
- ): <R, E>(fx: Fx<R, E, A>) => Fx<Scope.Scope | R | R2, E | E2, B>
798
- <R, E, A, R2, E2, B>(
799
- fx: Fx<R, E, A>,
800
- f: (a: A) => Fx<R2, E2, B>,
797
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<B, E | E2, Scope.Scope | R | R2>
798
+ <A, E, R, B, E2, R2>(
799
+ fx: Fx<A, E, R>,
800
+ f: (a: A) => Fx<B, E2, R2>,
801
801
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
802
- ): Fx<Scope.Scope | R | R2, E | E2, B>
802
+ ): Fx<B, E | E2, Scope.Scope | R | R2>
803
803
  } = dual(isDataFirstFx, core.concatMap)
804
804
 
805
805
  /**
806
806
  * @since 1.20.0
807
807
  */
808
- export const fromFxEffect: <R, E, R2, E2, B>(effect: Effect.Effect<R, E, Fx<R2, E2, B>>) => Fx<R | R2, E | E2, B> =
808
+ export const fromFxEffect: <B, E, R, E2, R2>(effect: Effect.Effect<Fx<B, E2, R2>, E, R>) => Fx<B, E | E2, R | R2> =
809
809
  core.fromFxEffect
810
810
 
811
811
  /**
812
812
  * @since 1.20.0
813
813
  */
814
814
  export const continueWith: {
815
- <R2, E2, B>(f: () => Fx<R2, E2, B>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A | B>
816
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, f: () => Fx<R2, E2, B>): Fx<R | R2, E | E2, A | B>
815
+ <B, E2, R2>(f: () => Fx<B, E2, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | B, E | E2, R | R2>
816
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, f: () => Fx<B, E2, R2>): Fx<A | B, E | E2, R | R2>
817
817
  } = dual(2, core.continueWith)
818
818
 
819
819
  /**
820
820
  * @since 1.20.0
821
821
  */
822
822
  export const orElseCause: {
823
- <E, R2, E2, B>(f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2, E2, A | B>
824
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>): Fx<R | R2, E2, A | B>
823
+ <E, B, E2, R2>(f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2>
824
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>): Fx<A | B, E2, R | R2>
825
825
  } = dual(2, core.orElseCause)
826
826
 
827
827
  /**
828
828
  * @since 1.20.0
829
829
  */
830
830
  export const orElse: {
831
- <E, R2, E2, B>(f: (error: E) => Fx<R2, E2, B>): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2, E2, A | B>
832
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, f: (error: E) => Fx<R2, E2, B>): Fx<R | R2, E2, A | B>
831
+ <E, B, E2, R2>(f: (error: E) => Fx<B, E2, R2>): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2>
832
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, f: (error: E) => Fx<B, E2, R2>): Fx<A | B, E2, R | R2>
833
833
  } = dual(2, core.orElse)
834
834
 
835
835
  /**
836
836
  * @since 1.20.0
837
837
  */
838
- export const suspend: <R, E, A>(f: () => Fx<R, E, A>) => Fx<R, E, A> = core.suspend
838
+ export const suspend: <A, E, R>(f: () => Fx<A, E, R>) => Fx<A, E, R> = core.suspend
839
839
 
840
840
  /**
841
841
  * @since 1.20.0
@@ -843,20 +843,20 @@ export const suspend: <R, E, A>(f: () => Fx<R, E, A>) => Fx<R, E, A> = core.susp
843
843
  export const mergeWithStrategy: {
844
844
  (strategy: MergeStrategy): <FX extends ReadonlyArray<Fx<any, any, any>>>(
845
845
  fx: FX
846
- ) => Fx<Fx.Context<FX[number]>, Fx.Error<FX[number]>, Fx.Success<FX[number]>>
846
+ ) => Fx<Fx.Success<FX[number]>, Fx.Error<FX[number]>, Fx.Context<FX[number]>>
847
847
 
848
848
  <const FX extends ReadonlyArray<Fx<any, any, any>>>(
849
849
  fx: FX,
850
850
  stategy: MergeStrategy
851
- ): Fx<Fx.Context<FX[number]>, Fx.Error<FX[number]>, Fx.Success<FX[number]>>
851
+ ): Fx<Fx.Success<FX[number]>, Fx.Error<FX[number]>, Fx.Context<FX[number]>>
852
852
  } = dual(2, core.mergeWithStrategy)
853
853
 
854
854
  /**
855
855
  * @since 1.20.0
856
856
  */
857
857
  export const merge: {
858
- <R2, E2, B>(other: Fx<R2, E2, B>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A | B>
859
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, other: Fx<R2, E2, B>): Fx<R | R2, E | E2, A | B>
858
+ <B, E2, R2>(other: Fx<B, E2, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | B, E | E2, R | R2>
859
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, other: Fx<B, E2, R2>): Fx<A | B, E | E2, R | R2>
860
860
  } = dual(
861
861
  2,
862
862
  core.merge
@@ -867,14 +867,14 @@ export const merge: {
867
867
  */
868
868
  export const mergeAll: <FX extends ReadonlyArray<Fx<any, any, any>>>(
869
869
  fx: FX
870
- ) => Fx<Fx.Context<FX[number]>, Fx.Error<FX[number]>, Fx.Success<FX[number]>> = core.mergeAll
870
+ ) => Fx<Fx.Success<FX[number]>, Fx.Error<FX[number]>, Fx.Context<FX[number]>> = core.mergeAll
871
871
 
872
872
  /**
873
873
  * @since 1.20.0
874
874
  */
875
875
  export const mergeOrdered: <FX extends ReadonlyArray<Fx<any, any, any>>>(
876
876
  fx: FX
877
- ) => Fx<Fx.Context<FX[number]>, Fx.Error<FX[number]>, Fx.Success<FX[number]>> = core.mergeOrdered
877
+ ) => Fx<Fx.Success<FX[number]>, Fx.Error<FX[number]>, Fx.Context<FX[number]>> = core.mergeOrdered
878
878
 
879
879
  /**
880
880
  * @since 1.20.0
@@ -882,148 +882,148 @@ export const mergeOrdered: <FX extends ReadonlyArray<Fx<any, any, any>>>(
882
882
  export const mergeOrderedConcurrently: <FX extends ReadonlyArray<Fx<any, any, any>>>(
883
883
  fx: FX,
884
884
  concurrency: number
885
- ) => Fx<Fx.Context<FX[number]>, Fx.Error<FX[number]>, Fx.Success<FX[number]>> = core.mergeOrderedConcurrently
885
+ ) => Fx<Fx.Success<FX[number]>, Fx.Error<FX[number]>, Fx.Context<FX[number]>> = core.mergeOrderedConcurrently
886
886
 
887
887
  /**
888
888
  * @since 1.20.0
889
889
  */
890
890
  export const mergeSwitch: <FX extends ReadonlyArray<Fx<any, any, any>>>(
891
891
  fx: FX
892
- ) => Fx<Fx.Context<FX[number]>, Fx.Error<FX[number]>, Fx.Success<FX[number]>> = core.mergeSwitch
892
+ ) => Fx<Fx.Success<FX[number]>, Fx.Error<FX[number]>, Fx.Context<FX[number]>> = core.mergeSwitch
893
893
 
894
894
  /**
895
895
  * @since 1.20.0
896
896
  */
897
897
  export const takeWhile: {
898
- <A, B extends A>(f: Predicate.Refinement<A, B>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, B>
899
- <A>(f: Predicate.Predicate<A>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, A>
900
- <R, E, A, B extends A>(fx: Fx<R, E, A>, f: Predicate.Refinement<A, B>): Fx<R, E, B>
901
- <R, E, A>(fx: Fx<R, E, A>, f: Predicate.Predicate<A>): Fx<R, E, A>
898
+ <A, B extends A>(f: Predicate.Refinement<A, B>): <E, R>(fx: Fx<A, E, R>) => Fx<B, E, R>
899
+ <A>(f: Predicate.Predicate<A>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
900
+ <A, E, R, B extends A>(fx: Fx<A, E, R>, f: Predicate.Refinement<A, B>): Fx<B, E, R>
901
+ <A, E, R>(fx: Fx<A, E, R>, f: Predicate.Predicate<A>): Fx<A, E, R>
902
902
  } = dual(2, core.takeWhile)
903
903
 
904
904
  /**
905
905
  * @since 1.20.0
906
906
  */
907
907
  export const takeUntil: {
908
- <A, B extends A>(f: Predicate.Refinement<A, B>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, Exclude<A, B>>
909
- <A>(f: Predicate.Predicate<A>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, A>
910
- <R, E, A, B extends A>(fx: Fx<R, E, A>, f: Predicate.Refinement<A, B>): Fx<R, E, Exclude<A, B>>
911
- <R, E, A>(fx: Fx<R, E, A>, f: Predicate.Predicate<A>): Fx<R, E, A>
908
+ <A, B extends A>(f: Predicate.Refinement<A, B>): <E, R>(fx: Fx<A, E, R>) => Fx<Exclude<A, B>, E, R>
909
+ <A>(f: Predicate.Predicate<A>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
910
+ <A, E, R, B extends A>(fx: Fx<A, E, R>, f: Predicate.Refinement<A, B>): Fx<Exclude<A, B>, E, R>
911
+ <A, E, R>(fx: Fx<A, E, R>, f: Predicate.Predicate<A>): Fx<A, E, R>
912
912
  } = dual(2, core.takeUntil)
913
913
 
914
914
  /**
915
915
  * @since 1.20.0
916
916
  */
917
917
  export const dropWhile: {
918
- <A, B extends A>(f: Predicate.Refinement<A, B>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, Exclude<A, B>>
919
- <A>(f: Predicate.Predicate<A>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, A>
920
- <R, E, A, B extends A>(fx: Fx<R, E, A>, f: Predicate.Refinement<A, B>): Fx<R, E, Exclude<A, B>>
921
- <R, E, A>(fx: Fx<R, E, A>, f: Predicate.Predicate<A>): Fx<R, E, A>
918
+ <A, B extends A>(f: Predicate.Refinement<A, B>): <E, R>(fx: Fx<A, E, R>) => Fx<Exclude<A, B>, E, R>
919
+ <A>(f: Predicate.Predicate<A>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
920
+ <A, E, R, B extends A>(fx: Fx<A, E, R>, f: Predicate.Refinement<A, B>): Fx<Exclude<A, B>, E, R>
921
+ <A, E, R>(fx: Fx<A, E, R>, f: Predicate.Predicate<A>): Fx<A, E, R>
922
922
  } = dual(2, core.dropWhile)
923
923
 
924
924
  /**
925
925
  * @since 1.20.0
926
926
  */
927
927
  export const dropUntil: {
928
- <A, B extends A>(f: Predicate.Refinement<A, B>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, A | B>
929
- <A>(f: Predicate.Predicate<A>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, A>
930
- <R, E, A, B extends A>(fx: Fx<R, E, A>, f: Predicate.Refinement<A, B>): Fx<R, E, A | B>
931
- <R, E, A>(fx: Fx<R, E, A>, f: Predicate.Predicate<A>): Fx<R, E, A>
928
+ <A, B extends A>(f: Predicate.Refinement<A, B>): <E, R>(fx: Fx<A, E, R>) => Fx<A | B, E, R>
929
+ <A>(f: Predicate.Predicate<A>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
930
+ <A, E, R, B extends A>(fx: Fx<A, E, R>, f: Predicate.Refinement<A, B>): Fx<A | B, E, R>
931
+ <A, E, R>(fx: Fx<A, E, R>, f: Predicate.Predicate<A>): Fx<A, E, R>
932
932
  } = dual(2, core.dropUntil)
933
933
 
934
934
  /**
935
935
  * @since 1.20.0
936
936
  */
937
937
  export const dropAfter: {
938
- <A, B extends A>(f: Predicate.Refinement<A, B>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, Exclude<A, B>>
939
- <A>(f: Predicate.Predicate<A>): <R, E>(fx: Fx<R, E, A>) => Fx<R, E, A>
940
- <R, E, A, B extends A>(fx: Fx<R, E, A>, f: Predicate.Refinement<A, B>): Fx<R, E, Exclude<A, B>>
941
- <R, E, A>(fx: Fx<R, E, A>, f: Predicate.Predicate<A>): Fx<R, E, A>
938
+ <A, B extends A>(f: Predicate.Refinement<A, B>): <E, R>(fx: Fx<A, E, R>) => Fx<Exclude<A, B>, E, R>
939
+ <A>(f: Predicate.Predicate<A>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
940
+ <A, E, R, B extends A>(fx: Fx<A, E, R>, f: Predicate.Refinement<A, B>): Fx<Exclude<A, B>, E, R>
941
+ <A, E, R>(fx: Fx<A, E, R>, f: Predicate.Predicate<A>): Fx<A, E, R>
942
942
  } = dual(2, core.dropAfter)
943
943
 
944
944
  /**
945
945
  * @since 1.20.0
946
946
  */
947
947
  export const takeWhileEffect: {
948
- <A, R2, E2>(f: (a: A) => Effect.Effect<R2, E2, boolean>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A>
949
- <R, E, A, R2, E2>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, boolean>): Fx<R | R2, E | E2, A>
948
+ <A, E2, R2>(f: (a: A) => Effect.Effect<boolean, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R | R2>
949
+ <A, E, R, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<boolean, E2, R2>): Fx<A, E | E2, R | R2>
950
950
  } = dual(2, core.takeWhileEffect)
951
951
 
952
952
  /**
953
953
  * @since 1.20.0
954
954
  */
955
955
  export const takeUntiEffect: {
956
- <A, R2, E2>(f: (a: A) => Effect.Effect<R2, E2, boolean>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A>
957
- <R, E, A, R2, E2>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, boolean>): Fx<R | R2, E | E2, A>
956
+ <A, E2, R2>(f: (a: A) => Effect.Effect<boolean, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R | R2>
957
+ <A, E, R, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<boolean, E2, R2>): Fx<A, E | E2, R | R2>
958
958
  } = dual(2, core.takeUntilEffect)
959
959
 
960
960
  /**
961
961
  * @since 1.20.0
962
962
  */
963
963
  export const dropWhileEffect: {
964
- <A, R2, E2>(f: (a: A) => Effect.Effect<R2, E2, boolean>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A>
965
- <R, E, A, R2, E2>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, boolean>): Fx<R | R2, E | E2, A>
964
+ <A, E2, R2>(f: (a: A) => Effect.Effect<boolean, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R | R2>
965
+ <A, E, R, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<boolean, E2, R2>): Fx<A, E | E2, R | R2>
966
966
  } = dual(2, core.dropWhileEffect)
967
967
 
968
968
  /**
969
969
  * @since 1.20.0
970
970
  */
971
971
  export const dropUntilEffect: {
972
- <A, R2, E2>(f: (a: A) => Effect.Effect<R2, E2, boolean>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A>
973
- <R, E, A, R2, E2>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, boolean>): Fx<R | R2, E | E2, A>
972
+ <A, E2, R2>(f: (a: A) => Effect.Effect<boolean, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R | R2>
973
+ <A, E, R, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<boolean, E2, R2>): Fx<A, E | E2, R | R2>
974
974
  } = dual(2, core.dropUntilEffect)
975
975
 
976
976
  /**
977
977
  * @since 1.20.0
978
978
  */
979
979
  export const dropAfterEffect: {
980
- <A, R2, E2>(f: (a: A) => Effect.Effect<R2, E2, boolean>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A>
981
- <R, E, A, R2, E2>(fx: Fx<R, E, A>, f: (a: A) => Effect.Effect<R2, E2, boolean>): Fx<R | R2, E | E2, A>
980
+ <A, E2, R2>(f: (a: A) => Effect.Effect<boolean, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R | R2>
981
+ <A, E, R, E2, R2>(fx: Fx<A, E, R>, f: (a: A) => Effect.Effect<boolean, E2, R2>): Fx<A, E | E2, R | R2>
982
982
  } = dual(2, core.dropAfterEffect)
983
983
 
984
984
  /**
985
985
  * @since 1.20.0
986
986
  */
987
987
  export const during: {
988
- <R2, E2, A, R3, E3, B>(
989
- window: Fx<R2, E2, Fx<R3, E3, B>>
990
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, A>
991
- <R, E, A, R2, E2, R3, E3, B>(
992
- fx: Fx<R, E, A>,
993
- window: Fx<R2, E2, Fx<R3, E3, B>>
994
- ): Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, A>
988
+ <E2, R2, A, R3, E3, B>(
989
+ window: Fx<Fx<B, E3, R3>, E2, R2>
990
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2 | E3, R | R2 | R3 | Scope.Scope>
991
+ <A, E, R, E2, R2, R3, E3, B>(
992
+ fx: Fx<A, E, R>,
993
+ window: Fx<Fx<B, E3, R3>, E2, R2>
994
+ ): Fx<A, E | E2 | E3, R | R2 | R3 | Scope.Scope>
995
995
  } = dual(2, core.during)
996
996
 
997
997
  /**
998
998
  * @since 1.20.0
999
999
  */
1000
1000
  export const since: {
1001
- <R2, E2, B>(window: Fx<R2, E2, B>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, A>
1002
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, window: Fx<R2, E2, B>): Fx<R | R2 | Scope.Scope, E | E2, A>
1001
+ <B, E2, R2>(window: Fx<B, E2, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R | R2 | Scope.Scope>
1002
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, window: Fx<B, E2, R2>): Fx<A, E | E2, R | R2 | Scope.Scope>
1003
1003
  } = dual(2, core.since)
1004
1004
 
1005
1005
  /**
1006
1006
  * @since 1.20.0
1007
1007
  */
1008
1008
  export const until: {
1009
- <R2, E2, B>(window: Fx<R2, E2, B>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E | E2, A>
1010
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, window: Fx<R2, E2, B>): Fx<R | R2 | Scope.Scope, E | E2, A>
1009
+ <B, E2, R2>(window: Fx<B, E2, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R | R2 | Scope.Scope>
1010
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, window: Fx<B, E2, R2>): Fx<A, E | E2, R | R2 | Scope.Scope>
1011
1011
  } = dual(2, core.until)
1012
1012
 
1013
1013
  /**
1014
1014
  * @since 1.20.0
1015
1015
  */
1016
1016
  export const middleware: {
1017
- <R, R3, E, A>(
1018
- effect: (effect: Effect.Effect<R, never, unknown>) => Effect.Effect<R3, never, unknown>,
1019
- sink?: ((sink: Sink.Sink<never, E, A>) => Sink.Sink<R, E, A>) | undefined
1020
- ): <E, A>(fx: Fx<R, E, A>) => Fx<R3, E, A>
1021
-
1022
- <R, E, A, R3>(
1023
- fx: Fx<R, E, A>,
1024
- effect: (effect: Effect.Effect<R, never, unknown>) => Effect.Effect<R3, never, unknown>,
1025
- sink?: ((sink: Sink.Sink<never, E, A>) => Sink.Sink<R, E, A>) | undefined
1026
- ): Fx<R3, E, A>
1017
+ <R, A, E, R3>(
1018
+ effect: (effect: Effect.Effect<unknown, never, R>) => Effect.Effect<unknown, never, R3>,
1019
+ sink?: ((sink: Sink.Sink<A, E>) => Sink.Sink<A, E, R>) | undefined
1020
+ ): <A, E>(fx: Fx<A, E, R>) => Fx<A, E, R3>
1021
+
1022
+ <A, E, R, R3>(
1023
+ fx: Fx<A, E, R>,
1024
+ effect: (effect: Effect.Effect<unknown, never, R>) => Effect.Effect<unknown, never, R3>,
1025
+ sink?: ((sink: Sink.Sink<A, E>) => Sink.Sink<A, E, R>) | undefined
1026
+ ): Fx<A, E, R3>
1027
1027
  } = dual(isDataFirstFx, core.middleware)
1028
1028
 
1029
1029
  /**
@@ -1031,13 +1031,13 @@ export const middleware: {
1031
1031
  */
1032
1032
  export const onExit: {
1033
1033
  <R2>(
1034
- f: (exit: Exit.Exit<never, unknown>) => Effect.Effect<R2, never, unknown>
1035
- ): <R, E, A>(fx: Fx<R, E, A>) => Fx<R2, E, A>
1034
+ f: (exit: Exit.Exit<unknown>) => Effect.Effect<unknown, never, R2>
1035
+ ): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R2>
1036
1036
 
1037
- <R, E, A, R2>(
1038
- fx: Fx<R, E, A>,
1039
- f: (exit: Exit.Exit<never, unknown>) => Effect.Effect<R2, never, unknown>
1040
- ): Fx<R | R2, E, A>
1037
+ <A, E, R, R2>(
1038
+ fx: Fx<A, E, R>,
1039
+ f: (exit: Exit.Exit<unknown>) => Effect.Effect<unknown, never, R2>
1040
+ ): Fx<A, E, R | R2>
1041
1041
  } = dual(2, core.onExit)
1042
1042
 
1043
1043
  /**
@@ -1045,162 +1045,162 @@ export const onExit: {
1045
1045
  */
1046
1046
  export const onInterrupt: {
1047
1047
  <R2>(
1048
- f: (interruptors: HashSet.HashSet<FiberId.FiberId>) => Effect.Effect<R2, never, unknown>
1049
- ): <R, E, A>(fx: Fx<R, E, A>) => Fx<R2, E, A>
1050
- <R, E, A, R2>(
1051
- fx: Fx<R, E, A>,
1052
- f: (interruptors: HashSet.HashSet<FiberId.FiberId>) => Effect.Effect<R2, never, unknown>
1053
- ): Fx<R | R2, E, A>
1048
+ f: (interruptors: HashSet.HashSet<FiberId.FiberId>) => Effect.Effect<unknown, never, R2>
1049
+ ): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R2>
1050
+ <A, E, R, R2>(
1051
+ fx: Fx<A, E, R>,
1052
+ f: (interruptors: HashSet.HashSet<FiberId.FiberId>) => Effect.Effect<unknown, never, R2>
1053
+ ): Fx<A, E, R | R2>
1054
1054
  } = dual(2, core.onInterrupt)
1055
1055
 
1056
1056
  /**
1057
1057
  * @since 1.20.0
1058
1058
  */
1059
1059
  export const onError: {
1060
- <R2>(f: (cause: Cause.Cause<never>) => Effect.Effect<R2, never, unknown>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R2, E, A>
1061
- <R, E, A, R2>(fx: Fx<R, E, A>, f: (cause: Cause.Cause<never>) => Effect.Effect<R2, never, unknown>): Fx<R | R2, E, A>
1060
+ <R2>(f: (cause: Cause.Cause<never>) => Effect.Effect<unknown, never, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R2>
1061
+ <A, E, R, R2>(fx: Fx<A, E, R>, f: (cause: Cause.Cause<never>) => Effect.Effect<unknown, never, R2>): Fx<A, E, R | R2>
1062
1062
  } = dual(2, core.onError)
1063
1063
 
1064
1064
  /**
1065
1065
  * @since 1.20.0
1066
1066
  */
1067
- export const scoped: <R, E, A>(fx: Fx<R, E, A>) => Fx<Exclude<R, Scope.Scope>, E, A> = core.scoped
1067
+ export const scoped: <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, Exclude<R, Scope.Scope>> = core.scoped
1068
1068
 
1069
1069
  /**
1070
1070
  * @since 1.20.0
1071
1071
  */
1072
1072
  export const annotateLogs: {
1073
- (key: string | Record<string, unknown>, value?: unknown): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1074
- <R, E, A>(fx: Fx<R, E, A>, key: string | Record<string, unknown>, value?: unknown): Fx<R, E, A>
1073
+ (key: string | Record<string, unknown>, value?: unknown): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1074
+ <A, E, R>(fx: Fx<A, E, R>, key: string | Record<string, unknown>, value?: unknown): Fx<A, E, R>
1075
1075
  } = dual(isDataFirstFx, core.annotateLogs)
1076
1076
 
1077
1077
  /**
1078
1078
  * @since 1.20.0
1079
1079
  */
1080
1080
  export const annotateSpans: {
1081
- (key: string | Record<string, unknown>, value?: unknown): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1082
- <R, E, A>(fx: Fx<R, E, A>, key: string | Record<string, unknown>, value?: unknown): Fx<R, E, A>
1081
+ (key: string | Record<string, unknown>, value?: unknown): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1082
+ <A, E, R>(fx: Fx<A, E, R>, key: string | Record<string, unknown>, value?: unknown): Fx<A, E, R>
1083
1083
  } = dual(isDataFirstFx, core.annotateSpans)
1084
1084
 
1085
1085
  /**
1086
1086
  * @since 1.20.0
1087
1087
  */
1088
- export const interruptible: <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A> = core.interruptible
1088
+ export const interruptible: <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R> = core.interruptible
1089
1089
 
1090
1090
  /**
1091
1091
  * @since 1.20.0
1092
1092
  */
1093
- export const uninterruptible: <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A> = core.uninterruptible
1093
+ export const uninterruptible: <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R> = core.uninterruptible
1094
1094
 
1095
1095
  /**
1096
1096
  * @since 1.20.0
1097
1097
  */
1098
1098
  export const locally: {
1099
- <A>(self: FiberRef.FiberRef<A>, value: A): <R, E, B>(fx: Fx<R, E, B>) => Fx<R, E, B>
1100
- <R, E, B, A>(use: Fx<R, E, B>, self: FiberRef.FiberRef<A>, value: A): Fx<R, E, B>
1099
+ <A>(self: FiberRef.FiberRef<A>, value: A): <B, E, R>(fx: Fx<B, E, R>) => Fx<B, E, R>
1100
+ <B, E, R, A>(use: Fx<B, E, R>, self: FiberRef.FiberRef<A>, value: A): Fx<B, E, R>
1101
1101
  } = dual(3, core.locally)
1102
1102
 
1103
1103
  /**
1104
1104
  * @since 1.20.0
1105
1105
  */
1106
1106
  export const locallyWith: {
1107
- <A>(self: FiberRef.FiberRef<A>, f: (a: A) => A): <R, E, B>(fx: Fx<R, E, B>) => Fx<R, E, B>
1108
- <R, E, B, A>(use: Fx<R, E, B>, self: FiberRef.FiberRef<A>, f: (a: A) => A): Fx<R, E, B>
1107
+ <A>(self: FiberRef.FiberRef<A>, f: (a: A) => A): <B, E, R>(fx: Fx<B, E, R>) => Fx<B, E, R>
1108
+ <B, E, R, A>(use: Fx<B, E, R>, self: FiberRef.FiberRef<A>, f: (a: A) => A): Fx<B, E, R>
1109
1109
  } = dual(3, core.locallyWith)
1110
1110
 
1111
1111
  /**
1112
1112
  * @since 1.20.0
1113
1113
  */
1114
1114
  export const withTracerTiming: {
1115
- (enabled: boolean): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1116
- <R, E, A>(fx: Fx<R, E, A>, enabled: boolean): Fx<R, E, A>
1115
+ (enabled: boolean): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1116
+ <A, E, R>(fx: Fx<A, E, R>, enabled: boolean): Fx<A, E, R>
1117
1117
  } = dual(2, core.withTracerTiming)
1118
1118
 
1119
1119
  /**
1120
1120
  * @since 1.20.0
1121
1121
  */
1122
1122
  export const withConcurrency: {
1123
- (concurrency: number | "unbounded"): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1124
- <R, E, A>(fx: Fx<R, E, A>, concurrency: number | "unbounded"): Fx<R, E, A>
1123
+ (concurrency: number | "unbounded"): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1124
+ <A, E, R>(fx: Fx<A, E, R>, concurrency: number | "unbounded"): Fx<A, E, R>
1125
1125
  } = dual(2, core.withConcurrency)
1126
1126
 
1127
1127
  /**
1128
1128
  * @since 1.20.0
1129
1129
  */
1130
1130
  export const withConfigProvider: {
1131
- (configProvider: ConfigProvider.ConfigProvider): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1132
- <R, E, A>(fx: Fx<R, E, A>, configProvider: ConfigProvider.ConfigProvider): Fx<R, E, A>
1131
+ (configProvider: ConfigProvider.ConfigProvider): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1132
+ <A, E, R>(fx: Fx<A, E, R>, configProvider: ConfigProvider.ConfigProvider): Fx<A, E, R>
1133
1133
  } = dual(2, core.withConfigProvider)
1134
1134
 
1135
1135
  /**
1136
1136
  * @since 1.20.0
1137
1137
  */
1138
1138
  export const withLogSpan: {
1139
- (span: string): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1140
- <R, E, A>(fx: Fx<R, E, A>, span: string): Fx<R, E, A>
1139
+ (span: string): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1140
+ <A, E, R>(fx: Fx<A, E, R>, span: string): Fx<A, E, R>
1141
1141
  } = dual(2, core.withLogSpan)
1142
1142
 
1143
1143
  /**
1144
1144
  * @since 1.20.0
1145
1145
  */
1146
1146
  export const withMaxOpsBeforeYield: {
1147
- (maxOps: number): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1148
- <R, E, A>(fx: Fx<R, E, A>, maxOps: number): Fx<R, E, A>
1147
+ (maxOps: number): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1148
+ <A, E, R>(fx: Fx<A, E, R>, maxOps: number): Fx<A, E, R>
1149
1149
  } = dual(2, core.withMaxOpsBeforeYield)
1150
1150
 
1151
1151
  /**
1152
1152
  * @since 1.20.0
1153
1153
  */
1154
1154
  export const withParentSpan: {
1155
- (parentSpan: Tracer.ParentSpan): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1156
- <R, E, A>(fx: Fx<R, E, A>, parentSpan: Tracer.ParentSpan): Fx<R, E, A>
1155
+ (parentSpan: Tracer.ParentSpan): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1156
+ <A, E, R>(fx: Fx<A, E, R>, parentSpan: Tracer.ParentSpan): Fx<A, E, R>
1157
1157
  } = dual(2, core.withParentSpan)
1158
1158
 
1159
1159
  /**
1160
1160
  * @since 1.20.0
1161
1161
  */
1162
1162
  export const withRequestBatching: {
1163
- (requestBatching: boolean): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1164
- <R, E, A>(fx: Fx<R, E, A>, requestBatching: boolean): Fx<R, E, A>
1163
+ (requestBatching: boolean): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1164
+ <A, E, R>(fx: Fx<A, E, R>, requestBatching: boolean): Fx<A, E, R>
1165
1165
  } = dual(2, core.withRequestBatching)
1166
1166
 
1167
1167
  /**
1168
1168
  * @since 1.20.0
1169
1169
  */
1170
1170
  export const withRequestCache: {
1171
- (cache: Request.Cache): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1172
- <R, E, A>(fx: Fx<R, E, A>, cache: Request.Cache): Fx<R, E, A>
1171
+ (cache: Request.Cache): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1172
+ <A, E, R>(fx: Fx<A, E, R>, cache: Request.Cache): Fx<A, E, R>
1173
1173
  } = dual(2, core.withRequestCache)
1174
1174
 
1175
1175
  /**
1176
1176
  * @since 1.20.0
1177
1177
  */
1178
1178
  export const withRequestCaching: {
1179
- (requestCaching: boolean): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1180
- <R, E, A>(fx: Fx<R, E, A>, requestCaching: boolean): Fx<R, E, A>
1179
+ (requestCaching: boolean): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1180
+ <A, E, R>(fx: Fx<A, E, R>, requestCaching: boolean): Fx<A, E, R>
1181
1181
  } = dual(2, core.withRequestCaching)
1182
1182
 
1183
1183
  /**
1184
1184
  * @since 1.20.0
1185
1185
  */
1186
1186
  export const withTracer: {
1187
- (tracer: Tracer.Tracer): <R, E, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1188
- <R, E, A>(fx: Fx<R, E, A>, tracer: Tracer.Tracer): Fx<R, E, A>
1187
+ (tracer: Tracer.Tracer): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R>
1188
+ <A, E, R>(fx: Fx<A, E, R>, tracer: Tracer.Tracer): Fx<A, E, R>
1189
1189
  } = dual(2, core.withTracer)
1190
1190
 
1191
1191
  /**
1192
1192
  * @since 1.20.0
1193
1193
  */
1194
1194
  export const acquireUseRelease: {
1195
- <A, R2, E2, B, R3, E3, C>(
1196
- use: (a: A) => Fx<R2, E2, B>,
1197
- release: (a: A, exit: Exit.Exit<unknown, unknown>) => Effect.Effect<R3, E3, C>
1198
- ): <R, E>(acquire: Effect.Effect<R, E, A>) => Fx<R | R2 | R3, E | E2 | E3, B>
1199
- <R, E, A, R2, E2, B, R3, E3, C>(
1200
- acquire: Effect.Effect<R, E, A>,
1201
- use: (a: A) => Fx<R2, E2, B>,
1202
- release: (a: A, exit: Exit.Exit<unknown, unknown>) => Effect.Effect<R3, E3, C>
1203
- ): Fx<R | R2 | R3, E | E2 | E3, B>
1195
+ <A, B, E2, R2, C, E3, R3>(
1196
+ use: (a: A) => Fx<B, E2, R2>,
1197
+ release: (a: A, exit: Exit.Exit<unknown, unknown>) => Effect.Effect<C, E3, R3>
1198
+ ): <E, R>(acquire: Effect.Effect<A, E, R>) => Fx<B, E | E2 | E3, R | R2 | R3>
1199
+ <A, E, R, B, E2, R2, C, E3, R3>(
1200
+ acquire: Effect.Effect<A, E, R>,
1201
+ use: (a: A) => Fx<B, E2, R2>,
1202
+ release: (a: A, exit: Exit.Exit<unknown, unknown>) => Effect.Effect<C, E3, R3>
1203
+ ): Fx<B, E | E2 | E3, R | R2 | R3>
1204
1204
  } = dual(3, core.acquireUseRelease)
1205
1205
 
1206
1206
  /**
@@ -1213,226 +1213,226 @@ export const withSpan: {
1213
1213
  readonly parent?: Tracer.ParentSpan
1214
1214
  readonly root?: boolean
1215
1215
  readonly context?: Ctx.Context<never>
1216
- }): <R, E, A>(self: Fx<R, E, A>) => Fx<R, E, A>
1216
+ }): <A, E, R>(self: Fx<A, E, R>) => Fx<A, E, R>
1217
1217
 
1218
- <R, E, A>(self: Fx<R, E, A>, name: string, options?: {
1218
+ <A, E, R>(self: Fx<A, E, R>, name: string, options?: {
1219
1219
  readonly attributes?: Record<string, unknown>
1220
1220
  readonly links?: ReadonlyArray<Tracer.SpanLink>
1221
1221
  readonly parent?: Tracer.ParentSpan
1222
1222
  readonly root?: boolean
1223
1223
  readonly context?: Ctx.Context<never>
1224
- }): Fx<R, E, A>
1224
+ }): Fx<A, E, R>
1225
1225
  } = dual(3, core.withSpan)
1226
1226
 
1227
1227
  /**
1228
1228
  * @since 1.20.0
1229
1229
  */
1230
1230
  export const provideContext: {
1231
- <R2>(context: Ctx.Context<R2>): <R, E, A>(fx: Fx<R, E, A>) => Fx<Exclude<R, R2>, E, A>
1232
- <R, E, A, R2>(fx: Fx<R, E, A>, context: Ctx.Context<R2>): Fx<Exclude<R, R2>, E, A>
1231
+ <R2>(context: Ctx.Context<R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, Exclude<R, R2>>
1232
+ <A, E, R, R2>(fx: Fx<A, E, R>, context: Ctx.Context<R2>): Fx<A, E, Exclude<R, R2>>
1233
1233
  } = dual(2, core.provideContext)
1234
1234
 
1235
1235
  /**
1236
1236
  * @since 1.20.0
1237
1237
  */
1238
1238
  export const provideLayer: {
1239
- <R2, E2, S>(layer: Layer.Layer<R2, E2, S>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R2 | Exclude<R, S>, E | E2, A>
1240
- <R, E, A, R2, E2, S>(fx: Fx<R, E, A>, layer: Layer.Layer<R2, E2, S>): Fx<R2 | Exclude<R, S>, E | E2, A>
1239
+ <E2, R2, S>(layer: Layer.Layer<S, E2, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R2 | Exclude<R, S>>
1240
+ <A, E, R, E2, R2, S>(fx: Fx<A, E, R>, layer: Layer.Layer<S, E2, R2>): Fx<A, E | E2, R2 | Exclude<R, S>>
1241
1241
  } = dual(2, core.provideLayer)
1242
1242
 
1243
1243
  /**
1244
1244
  * @since 1.20.0
1245
1245
  */
1246
1246
  export const provideRuntime: {
1247
- <R2>(runtime: Runtime.Runtime<R2>): <R, E, A>(fx: Fx<R, E, A>) => Fx<Exclude<R, R2>, E, A>
1248
- <R, E, A, R2>(fx: Fx<R, E, A>, runtime: Runtime.Runtime<R2>): Fx<Exclude<R, R2>, E, A>
1247
+ <R2>(runtime: Runtime.Runtime<R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, Exclude<R, R2>>
1248
+ <A, E, R, R2>(fx: Fx<A, E, R>, runtime: Runtime.Runtime<R2>): Fx<A, E, Exclude<R, R2>>
1249
1249
  } = dual(2, core.provideRuntime)
1250
1250
 
1251
1251
  /**
1252
1252
  * @since 1.20.0
1253
1253
  */
1254
1254
  export const provideService: {
1255
- <I, S>(service: Ctx.Tag<I, S>, instance: S): <R, E, A>(fx: Fx<R, E, A>) => Fx<Exclude<R, I>, E, A>
1256
- <R, E, A, I, S>(fx: Fx<R, E, A>, service: Ctx.Tag<I, S>, instance: S): Fx<Exclude<R, I>, E, A>
1255
+ <I, S>(service: Ctx.Tag<I, S>, instance: S): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, Exclude<R, I>>
1256
+ <A, E, R, I, S>(fx: Fx<A, E, R>, service: Ctx.Tag<I, S>, instance: S): Fx<A, E, Exclude<R, I>>
1257
1257
  } = dual(3, core.provideService)
1258
1258
 
1259
1259
  /**
1260
1260
  * @since 1.20.0
1261
1261
  */
1262
1262
  export const provideServiceEffect: {
1263
- <I, S, R2, E2>(
1263
+ <I, S, E2, R2>(
1264
1264
  service: Ctx.Tag<I, S>,
1265
- instance: Effect.Effect<R2, E2, S>
1266
- ): <R, E, A>(fx: Fx<R, E, A>) => Fx<R2 | Exclude<R, I>, E | E2, A>
1267
- <R, E, A, I, S, R2, E2>(
1268
- fx: Fx<R, E, A>,
1265
+ instance: Effect.Effect<S, E2, R2>
1266
+ ): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R2 | Exclude<R, I>>
1267
+ <A, E, R, I, S, E2, R2>(
1268
+ fx: Fx<A, E, R>,
1269
1269
  service: Ctx.Tag<I, S>,
1270
- instance: Effect.Effect<R2, E2, S>
1271
- ): Fx<R2 | Exclude<R, I>, E | E2, A>
1270
+ instance: Effect.Effect<S, E2, R2>
1271
+ ): Fx<A, E | E2, R2 | Exclude<R, I>>
1272
1272
  } = dual(3, core.provideServiceEffect)
1273
1273
 
1274
1274
  /**
1275
1275
  * @since 1.20.0
1276
1276
  */
1277
1277
  export const provide: {
1278
- <R2>(context: Ctx.Context<R2>): <R, E, A>(fx: Fx<R, E, A>) => Fx<Exclude<R, R2>, E, A>
1279
- <R2>(runtime: Runtime.Runtime<R2>): <R, E, A>(fx: Fx<R, E, A>) => Fx<Exclude<R, R2>, E, A>
1280
- <R2, E2, S>(layer: Layer.Layer<R2, E2, S>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R2 | Exclude<R, S>, E | E2, A>
1281
- <R2 = never, E2 = never, S = never>(
1282
- provide: Layer.Layer<R2, E2, S> | Ctx.Context<S> | Runtime.Runtime<S>
1283
- ): <R, E, A>(fx: Fx<R, E, A>) => Fx<R2 | Exclude<R, S>, E | E2, A>
1284
-
1285
- <R, E, A, R2>(fx: Fx<R, E, A>, context: Ctx.Context<R2>): Fx<Exclude<R, R2>, E, A>
1286
- <R, E, A, R2>(fx: Fx<R, E, A>, runtime: Runtime.Runtime<R2>): Fx<Exclude<R, R2>, E, A>
1287
- <R, E, A, R2, E2, S>(fx: Fx<R, E, A>, layer: Layer.Layer<R2, E2, S>): Fx<R2 | Exclude<R, S>, E | E2, A>
1288
- <R, E, A, R2 = never, E2 = never, S = never>(
1289
- fx: Fx<R, E, A>,
1290
- provide: Layer.Layer<R2, E2, S> | Ctx.Context<S> | Runtime.Runtime<S>
1291
- ): Fx<R2 | Exclude<R, S>, E | E2, A>
1278
+ <R2>(context: Ctx.Context<R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, Exclude<R, R2>>
1279
+ <R2>(runtime: Runtime.Runtime<R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, Exclude<R, R2>>
1280
+ <S, E2, R2>(layer: Layer.Layer<S, E2, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R2 | Exclude<R, S>>
1281
+ <S, E2 = never, R2 = never>(
1282
+ provide: Layer.Layer<S, E2, R2> | Ctx.Context<S> | Runtime.Runtime<S>
1283
+ ): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E | E2, R2 | Exclude<R, S>>
1284
+
1285
+ <A, E, R, R2>(fx: Fx<A, E, R>, context: Ctx.Context<R2>): Fx<A, E, Exclude<R, R2>>
1286
+ <A, E, R, R2>(fx: Fx<A, E, R>, runtime: Runtime.Runtime<R2>): Fx<A, E, Exclude<R, R2>>
1287
+ <A, E, R, S, E2, R2>(fx: Fx<A, E, R>, layer: Layer.Layer<S, E2, R2>): Fx<A, E | E2, R2 | Exclude<R, S>>
1288
+ <A, E, R, S, E2 = never, R2 = never>(
1289
+ fx: Fx<A, E, R>,
1290
+ provide: Layer.Layer<S, E2, R2> | Ctx.Context<S> | Runtime.Runtime<S>
1291
+ ): Fx<A, E | E2, R2 | Exclude<R, S>>
1292
1292
  } = dual(2, core.provide)
1293
1293
 
1294
1294
  /**
1295
1295
  * @since 1.20.0
1296
1296
  */
1297
1297
  export const share: {
1298
- <R2, E2, A>(subject: Subject.Subject<R2, E2, A>): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E, A>
1299
- <R, E, A, R2>(fx: Fx<R, E, A>, subject: Subject.Subject<R2, E, A>): Fx<R | R2 | Scope.Scope, E, A>
1298
+ <E2, R2, A>(subject: Subject.Subject<A, E2, R2>): <E, R>(fx: Fx<A, E, R>) => Fx<A, E, R | R2 | Scope.Scope>
1299
+ <A, E, R, R2>(fx: Fx<A, E, R>, subject: Subject.Subject<A, E, R2>): Fx<A, E, R | R2 | Scope.Scope>
1300
1300
  } = dual(2, coreShare.share)
1301
1301
 
1302
1302
  /**
1303
1303
  * @since 1.20.0
1304
1304
  */
1305
- export const multicast: <R, E, A>(fx: Fx<R, E, A>) => Fx<Scope.Scope | R, E, A> = coreShare.multicast
1305
+ export const multicast: <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, Scope.Scope | R> = coreShare.multicast
1306
1306
 
1307
1307
  /**
1308
1308
  * @since 1.20.0
1309
1309
  */
1310
- export const hold: <R, E, A>(fx: Fx<R, E, A>) => Fx<Scope.Scope | R, E, A> = coreShare.hold
1310
+ export const hold: <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, Scope.Scope | R> = coreShare.hold
1311
1311
 
1312
1312
  /**
1313
1313
  * @since 1.20.0
1314
1314
  */
1315
1315
  export const replay: {
1316
- (capacity: number): <R, E, A>(fx: Fx<R, E, A>) => Fx<Scope.Scope | R, E, A>
1317
- <R, E, A>(fx: Fx<R, E, A>, capacity: number): Fx<Scope.Scope | R, E, A>
1316
+ (capacity: number): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, Scope.Scope | R>
1317
+ <A, E, R>(fx: Fx<A, E, R>, capacity: number): Fx<A, E, Scope.Scope | R>
1318
1318
  } = dual(2, coreShare.replay)
1319
1319
 
1320
1320
  /**
1321
1321
  * @since 1.20.0
1322
1322
  */
1323
1323
  export const mapCause: {
1324
- <E, E2>(f: (cause: Cause.Cause<E>) => Cause.Cause<E2>): <R, A>(fx: Fx<R, E, A>) => Fx<R, E2, A>
1325
- <R, E, A, E2>(fx: Fx<R, E, A>, f: (cause: Cause.Cause<E>) => Cause.Cause<E2>): Fx<R, E2, A>
1324
+ <E, E2>(f: (cause: Cause.Cause<E>) => Cause.Cause<E2>): <R, A>(fx: Fx<A, E, R>) => Fx<A, E2, R>
1325
+ <A, E, R, E2>(fx: Fx<A, E, R>, f: (cause: Cause.Cause<E>) => Cause.Cause<E2>): Fx<A, E2, R>
1326
1326
  } = dual(2, core.mapCause)
1327
1327
 
1328
1328
  /**
1329
1329
  * @since 1.20.0
1330
1330
  */
1331
1331
  export const mapError: {
1332
- <E, E2>(f: (e: E) => E2): <R, A>(fx: Fx<R, E, A>) => Fx<R, E2, A>
1333
- <R, E, A, E2>(fx: Fx<R, E, A>, f: (e: E) => E2): Fx<R, E2, A>
1332
+ <E, E2>(f: (e: E) => E2): <R, A>(fx: Fx<A, E, R>) => Fx<A, E2, R>
1333
+ <A, E, R, E2>(fx: Fx<A, E, R>, f: (e: E) => E2): Fx<A, E2, R>
1334
1334
  } = dual(2, core.mapError)
1335
1335
 
1336
1336
  /**
1337
1337
  * @since 1.20.0
1338
1338
  */
1339
1339
  export const mapBoth: {
1340
- <E, E2, A, B>(f: (e: E) => E2, g: (a: A) => B): <R>(fx: Fx<R, E, A>) => Fx<R, E2, B>
1341
- <R, E, A, B, C>(fx: Fx<R, E, A>, f: (e: E) => B, g: (a: A) => C): Fx<R, B, C>
1340
+ <E, E2, A, B>(f: (e: E) => E2, g: (a: A) => B): <R>(fx: Fx<A, E, R>) => Fx<B, E2, R>
1341
+ <A, E, R, B, C>(fx: Fx<A, E, R>, f: (e: E) => B, g: (a: A) => C): Fx<C, B, R>
1342
1342
  } = dual(3, core.mapBoth)
1343
1343
 
1344
1344
  /**
1345
1345
  * @since 1.20.0
1346
1346
  */
1347
1347
  export const filterCause: {
1348
- <E>(f: (cause: Cause.Cause<E>) => boolean): <R, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1349
- <R, E, A>(fx: Fx<R, E, A>, f: (cause: Cause.Cause<E>) => boolean): Fx<R, E, A>
1348
+ <E>(f: (cause: Cause.Cause<E>) => boolean): <R, A>(fx: Fx<A, E, R>) => Fx<A, E, R>
1349
+ <A, E, R>(fx: Fx<A, E, R>, f: (cause: Cause.Cause<E>) => boolean): Fx<A, E, R>
1350
1350
  } = dual(2, core.filterCause)
1351
1351
 
1352
1352
  /**
1353
1353
  * @since 1.20.0
1354
1354
  */
1355
1355
  export const filterError: {
1356
- <E>(f: (e: E) => boolean): <R, A>(fx: Fx<R, E, A>) => Fx<R, E, A>
1357
- <R, E, A>(fx: Fx<R, E, A>, f: (e: E) => boolean): Fx<R, E, A>
1356
+ <E>(f: (e: E) => boolean): <R, A>(fx: Fx<A, E, R>) => Fx<A, E, R>
1357
+ <A, E, R>(fx: Fx<A, E, R>, f: (e: E) => boolean): Fx<A, E, R>
1358
1358
  } = dual(2, core.filterError)
1359
1359
 
1360
1360
  /**
1361
1361
  * @since 1.20.0
1362
1362
  */
1363
1363
  export const filterMapCause: {
1364
- <E, E2>(f: (cause: Cause.Cause<E>) => Option.Option<Cause.Cause<E2>>): <R, A>(fx: Fx<R, E, A>) => Fx<R, E2, A>
1365
- <R, E, A, E2>(fx: Fx<R, E, A>, f: (cause: Cause.Cause<E>) => Option.Option<Cause.Cause<E2>>): Fx<R, E2, A>
1364
+ <E, E2>(f: (cause: Cause.Cause<E>) => Option.Option<Cause.Cause<E2>>): <R, A>(fx: Fx<A, E, R>) => Fx<A, E2, R>
1365
+ <A, E, R, E2>(fx: Fx<A, E, R>, f: (cause: Cause.Cause<E>) => Option.Option<Cause.Cause<E2>>): Fx<A, E2, R>
1366
1366
  } = dual(2, core.filterMapCause)
1367
1367
 
1368
1368
  /**
1369
1369
  * @since 1.20.0
1370
1370
  */
1371
1371
  export const filterMapError: {
1372
- <E, E2>(f: (e: E) => Option.Option<E2>): <R, A>(fx: Fx<R, E, A>) => Fx<R, E2, A>
1373
- <R, E, A, E2>(fx: Fx<R, E, A>, f: (e: E) => Option.Option<E2>): Fx<R, E2, A>
1372
+ <E, E2>(f: (e: E) => Option.Option<E2>): <R, A>(fx: Fx<A, E, R>) => Fx<A, E2, R>
1373
+ <A, E, R, E2>(fx: Fx<A, E, R>, f: (e: E) => Option.Option<E2>): Fx<A, E2, R>
1374
1374
  } = dual(2, core.filterMapError)
1375
1375
 
1376
1376
  /**
1377
1377
  * @since 1.20.0
1378
1378
  */
1379
1379
  export const mapCauseEffect: {
1380
- <R2, E2, E3>(f: (cause: Cause.Cause<E2>) => Effect.Effect<R2, E3, Cause.Cause<E3>>): <R, E, A>(
1381
- fx: Fx<R, E, A>
1382
- ) => Fx<R | R2, E2 | E3, A>
1383
- <R, E, A, R2, E2, E3>(
1384
- fx: Fx<R, E, A>,
1385
- f: (cause: Cause.Cause<E>) => Effect.Effect<R2, E2, Cause.Cause<E3>>
1386
- ): Fx<R | R2, E2 | E3, A>
1380
+ <E3, E2, R2>(f: (cause: Cause.Cause<E2>) => Effect.Effect<Cause.Cause<E3>, E3, R2>): <A, E, R>(
1381
+ fx: Fx<A, E, R>
1382
+ ) => Fx<A, E2 | E3, R | R2>
1383
+ <A, E, R, E3, E2, R2>(
1384
+ fx: Fx<A, E, R>,
1385
+ f: (cause: Cause.Cause<E>) => Effect.Effect<Cause.Cause<E3>, E2, R2>
1386
+ ): Fx<A, E2 | E3, R | R2>
1387
1387
  } = dual(2, core.mapCauseEffect)
1388
1388
 
1389
1389
  /**
1390
1390
  * @since 1.20.0
1391
1391
  */
1392
1392
  export const mapErrorEffect: {
1393
- <R2, E2, E3>(f: (e: E2) => Effect.Effect<R2, E3, E3>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | R2, E2 | E3, A>
1394
- <R, E, A, R2, E2, E3>(fx: Fx<R, E, A>, f: (e: E) => Effect.Effect<R2, E2, E3>): Fx<R | R2, E2 | E3, A>
1393
+ <E3, E2, R2>(f: (e: E2) => Effect.Effect<E3, E3, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E2 | E3, R | R2>
1394
+ <A, E, R, E3, E2, R2>(fx: Fx<A, E, R>, f: (e: E) => Effect.Effect<E3, E2, R2>): Fx<A, E2 | E3, R | R2>
1395
1395
  } = dual(2, core.mapErrorEffect)
1396
1396
 
1397
1397
  /**
1398
1398
  * @since 1.20.0
1399
1399
  */
1400
1400
  export const filterCauseEffect: {
1401
- <E, R2, E2>(f: (cause: Cause.Cause<E>) => Effect.Effect<R2, E2, boolean>): <R, A>(
1402
- fx: Fx<R, E, A>
1403
- ) => Fx<R | R2, E2, A>
1404
- <R, E, A, R2, E2>(fx: Fx<R, E, A>, f: (cause: Cause.Cause<E>) => Effect.Effect<R2, E2, boolean>): Fx<R | R2, E2, A>
1401
+ <E, E2, R2>(f: (cause: Cause.Cause<E>) => Effect.Effect<boolean, E2, R2>): <R, A>(
1402
+ fx: Fx<A, E, R>
1403
+ ) => Fx<A, E2, R | R2>
1404
+ <A, E, R, E2, R2>(fx: Fx<A, E, R>, f: (cause: Cause.Cause<E>) => Effect.Effect<boolean, E2, R2>): Fx<A, E2, R | R2>
1405
1405
  } = dual(2, core.filterCauseEffect)
1406
1406
 
1407
1407
  /**
1408
1408
  * @since 1.20.0
1409
1409
  */
1410
1410
  export const filterErrorEffect: {
1411
- <E, R2, E2>(f: (e: E) => Effect.Effect<R2, E2, boolean>): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2, E2, A>
1412
- <R, E, A, R2, E2>(fx: Fx<R, E, A>, f: (e: E) => Effect.Effect<R2, E2, boolean>): Fx<R | R2, E2, A>
1411
+ <E, E2, R2>(f: (e: E) => Effect.Effect<boolean, E2, R2>): <R, A>(fx: Fx<A, E, R>) => Fx<A, E2, R | R2>
1412
+ <A, E, R, E2, R2>(fx: Fx<A, E, R>, f: (e: E) => Effect.Effect<boolean, E2, R2>): Fx<A, E2, R | R2>
1413
1413
  } = dual(2, core.filterErrorEffect)
1414
1414
 
1415
1415
  /**
1416
1416
  * @since 1.20.0
1417
1417
  */
1418
1418
  export const filterMapCauseEffect: {
1419
- <R2, E2, E3>(f: (cause: Cause.Cause<E2>) => Effect.Effect<R2, E2, Option.Option<Cause.Cause<E3>>>): <R, E, A>(
1420
- fx: Fx<R, E, A>
1421
- ) => Fx<R | R2, E2 | E3, A>
1422
- <R, E, A, R2, E2, E3>(
1423
- fx: Fx<R, E, A>,
1424
- f: (cause: Cause.Cause<E>) => Effect.Effect<R2, E2, Option.Option<Cause.Cause<E3>>>
1425
- ): Fx<R | R2, E2 | E3, A>
1419
+ <E3, E2, R2>(f: (cause: Cause.Cause<E2>) => Effect.Effect<Option.Option<Cause.Cause<E3>>, E2, R2>): <A, E, R>(
1420
+ fx: Fx<A, E, R>
1421
+ ) => Fx<A, E2 | E3, R | R2>
1422
+ <A, E, R, E3, E2, R2>(
1423
+ fx: Fx<A, E, R>,
1424
+ f: (cause: Cause.Cause<E>) => Effect.Effect<Option.Option<Cause.Cause<E3>>, E2, R2>
1425
+ ): Fx<A, E2 | E3, R | R2>
1426
1426
  } = dual(2, core.filterMapCauseEffect)
1427
1427
 
1428
1428
  /**
1429
1429
  * @since 1.20.0
1430
1430
  */
1431
1431
  export const filterMapErrorEffect: {
1432
- <E, R2, E2, E3>(
1433
- f: (e: E) => Effect.Effect<R2, E2, Option.Option<E3>>
1434
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2, E2 | E3, A>
1435
- <R, E, A, R2, E2, E3>(fx: Fx<R, E, A>, f: (e: E) => Effect.Effect<R2, E2, Option.Option<E3>>): Fx<R | R2, E2 | E3, A>
1432
+ <E, E3, E2, R2>(
1433
+ f: (e: E) => Effect.Effect<Option.Option<E3>, E2, R2>
1434
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A, E2 | E3, R | R2>
1435
+ <A, E, R, E3, E2, R2>(fx: Fx<A, E, R>, f: (e: E) => Effect.Effect<Option.Option<E3>, E2, R2>): Fx<A, E2 | E3, R | R2>
1436
1436
  } = dual(2, core.filterMapErrorEffect)
1437
1437
 
1438
1438
  /**
@@ -1442,318 +1442,318 @@ export const loopCause: {
1442
1442
  <B, E, C>(
1443
1443
  seed: B,
1444
1444
  f: (b: B, cause: Cause.Cause<E>) => readonly [Cause.Cause<C>, B]
1445
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R, C, A>
1445
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A, C, R>
1446
1446
 
1447
- <R, E, A, B, C>(
1448
- fx: Fx<R, E, A>,
1447
+ <A, E, R, B, C>(
1448
+ fx: Fx<A, E, R>,
1449
1449
  seed: B,
1450
1450
  f: (b: B, cause: Cause.Cause<E>) => readonly [Cause.Cause<C>, B]
1451
- ): Fx<R, C, A>
1451
+ ): Fx<A, C, R>
1452
1452
  } = dual(3, core.loopCause)
1453
1453
 
1454
1454
  /**
1455
1455
  * @since 1.20.0
1456
1456
  */
1457
1457
  export const loopError: {
1458
- <B, E, C>(seed: B, f: (b: B, e: E) => readonly [C, B]): <R, A>(fx: Fx<R, E, A>) => Fx<R, C, A>
1459
- <R, E, A, B, C>(fx: Fx<R, E, A>, seed: B, f: (b: B, e: E) => readonly [C, B]): Fx<R, C, A>
1458
+ <B, E, C>(seed: B, f: (b: B, e: E) => readonly [C, B]): <R, A>(fx: Fx<A, E, R>) => Fx<A, C, R>
1459
+ <A, E, R, B, C>(fx: Fx<A, E, R>, seed: B, f: (b: B, e: E) => readonly [C, B]): Fx<A, C, R>
1460
1460
  } = dual(3, core.loopError)
1461
1461
 
1462
1462
  /**
1463
1463
  * @since 1.20.0
1464
1464
  */
1465
1465
  export const loopCauseEffect: {
1466
- <B, E, R2, E2, C>(
1466
+ <B, E, E2, R2, C>(
1467
1467
  seed: B,
1468
- f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<R2, E2, readonly [Cause.Cause<C>, B]>
1469
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2, E2 | C, A>
1470
- <R, E, A, R2, E2, B, C>(
1471
- fx: Fx<R, E, A>,
1468
+ f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<readonly [Cause.Cause<C>, B], E2, R2>
1469
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A, E2 | C, R | R2>
1470
+ <A, E, R, B, E2, R2, C>(
1471
+ fx: Fx<A, E, R>,
1472
1472
  seed: B,
1473
- f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<R2, E2, readonly [Cause.Cause<C>, B]>
1474
- ): Fx<R | R2, E2 | C, A>
1473
+ f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<readonly [Cause.Cause<C>, B], E2, R2>
1474
+ ): Fx<A, E2 | C, R | R2>
1475
1475
  } = dual(3, core.loopCauseEffect)
1476
1476
 
1477
1477
  /**
1478
1478
  * @since 1.20.0
1479
1479
  */
1480
1480
  export const loopErrorEffect: {
1481
- <B, E, R2, E2, C>(seed: B, f: (b: B, e: E) => Effect.Effect<R2, E2, readonly [C, B]>): <R, A>(
1482
- fx: Fx<R, E, A>
1483
- ) => Fx<R | R2, E2 | C, A>
1484
- <R, E, A, R2, E2, B, C>(
1485
- fx: Fx<R, E, A>,
1481
+ <B, E, E2, R2, C>(seed: B, f: (b: B, e: E) => Effect.Effect<readonly [C, B], E2, R2>): <R, A>(
1482
+ fx: Fx<A, E, R>
1483
+ ) => Fx<A, E2 | C, R | R2>
1484
+ <A, E, R, B, E2, R2, C>(
1485
+ fx: Fx<A, E, R>,
1486
1486
  seed: B,
1487
- f: (b: B, e: E) => Effect.Effect<R2, E2, readonly [C, B]>
1488
- ): Fx<R | R2, E2 | C, A>
1487
+ f: (b: B, e: E) => Effect.Effect<readonly [C, B], E2, R2>
1488
+ ): Fx<A, E2 | C, R | R2>
1489
1489
  } = dual(3, core.loopErrorEffect)
1490
1490
 
1491
1491
  /**
1492
1492
  * @since 1.20.0
1493
1493
  */
1494
1494
  export const filterMapLoopCause: {
1495
- <B, E, R2, E2, C>(
1495
+ <B, E, E2, R2, C>(
1496
1496
  seed: B,
1497
- f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<R2, E2, readonly [Option.Option<Cause.Cause<C>>, B]>
1498
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2, E2 | C, A>
1499
- <R, E, A, B, C>(
1500
- fx: Fx<R, E, A>,
1497
+ f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<readonly [Option.Option<Cause.Cause<C>>, B], E2, R2>
1498
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A, E2 | C, R | R2>
1499
+ <A, E, R, B, C>(
1500
+ fx: Fx<A, E, R>,
1501
1501
  seed: B,
1502
1502
  f: (b: B, cause: Cause.Cause<E>) => readonly [Option.Option<Cause.Cause<C>>, B]
1503
- ): Fx<R, C, A>
1503
+ ): Fx<A, C, R>
1504
1504
  } = dual(3, core.filterMapLoopCause)
1505
1505
 
1506
1506
  /**
1507
1507
  * @since 1.20.0
1508
1508
  */
1509
1509
  export const filterMapLoopError: {
1510
- <B, E, R2, E2, C>(seed: B, f: (b: B, e: E) => Effect.Effect<R2, E2, readonly [Option.Option<C>, B]>): <R, A>(
1511
- fx: Fx<R, E, A>
1512
- ) => Fx<R | R2, E2 | C, A>
1513
- <R, E, A, B, C>(fx: Fx<R, E, A>, seed: B, f: (b: B, e: E) => readonly [Option.Option<C>, B]): Fx<R, C, A>
1510
+ <B, E, E2, R2, C>(seed: B, f: (b: B, e: E) => Effect.Effect<readonly [Option.Option<C>, B], E2, R2>): <R, A>(
1511
+ fx: Fx<A, E, R>
1512
+ ) => Fx<A, E2 | C, R | R2>
1513
+ <A, E, R, B, C>(fx: Fx<A, E, R>, seed: B, f: (b: B, e: E) => readonly [Option.Option<C>, B]): Fx<A, C, R>
1514
1514
  } = dual(3, core.filterMapLoopError)
1515
1515
 
1516
1516
  /**
1517
1517
  * @since 1.20.0
1518
1518
  */
1519
1519
  export const filterMapLoopCauseEffect: {
1520
- <B, E, R2, E2, C>(
1520
+ <B, E, E2, R2, C>(
1521
1521
  seed: B,
1522
- f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<R2, E2, readonly [Option.Option<Cause.Cause<C>>, B]>
1523
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2, E2 | C, A>
1524
- <R, E, A, R2, E2, B, C>(
1525
- fx: Fx<R, E, A>,
1522
+ f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<readonly [Option.Option<Cause.Cause<C>>, B], E2, R2>
1523
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A, E2 | C, R | R2>
1524
+ <A, E, R, B, E2, R2, C>(
1525
+ fx: Fx<A, E, R>,
1526
1526
  seed: B,
1527
- f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<R2, E2, readonly [Option.Option<Cause.Cause<C>>, B]>
1528
- ): Fx<R | R2, E2 | C, A>
1527
+ f: (b: B, cause: Cause.Cause<E>) => Effect.Effect<readonly [Option.Option<Cause.Cause<C>>, B], E2, R2>
1528
+ ): Fx<A, E2 | C, R | R2>
1529
1529
  } = dual(3, core.filterMapLoopCauseEffect)
1530
1530
 
1531
1531
  /**
1532
1532
  * @since 1.20.0
1533
1533
  */
1534
1534
  export const filterMapLoopErrorEffect: {
1535
- <B, E, R2, E2, C>(seed: B, f: (b: B, e: E) => Effect.Effect<R2, E2, readonly [Option.Option<C>, B]>): <R, A>(
1536
- fx: Fx<R, E, A>
1537
- ) => Fx<R | R2, E2 | C, A>
1538
- <R, E, A, R2, E2, B, C>(
1539
- fx: Fx<R, E, A>,
1535
+ <B, E, E2, R2, C>(seed: B, f: (b: B, e: E) => Effect.Effect<readonly [Option.Option<C>, B], E2, R2>): <R, A>(
1536
+ fx: Fx<A, E, R>
1537
+ ) => Fx<A, E2 | C, R | R2>
1538
+ <A, E, R, B, E2, R2, C>(
1539
+ fx: Fx<A, E, R>,
1540
1540
  seed: B,
1541
- f: (b: B, e: E) => Effect.Effect<R2, E2, readonly [Option.Option<C>, B]>
1542
- ): Fx<R | R2, E2 | C, A>
1541
+ f: (b: B, e: E) => Effect.Effect<readonly [Option.Option<C>, B], E2, R2>
1542
+ ): Fx<A, E2 | C, R | R2>
1543
1543
  } = dual(3, core.filterMapLoopErrorEffect)
1544
1544
 
1545
1545
  /**
1546
1546
  * @since 1.20.0
1547
1547
  */
1548
1548
  export const flatMapCauseWithStrategy: {
1549
- <E, R2, E2, B>(
1550
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1549
+ <E, B, E2, R2>(
1550
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1551
1551
  flattenStrategy: FlattenStrategy,
1552
1552
  executionStrategy?: ExecutionStrategy.ExecutionStrategy
1553
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1554
- <R, E, A, R2, E2, B>(
1555
- fx: Fx<R, E, A>,
1556
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1553
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1554
+ <A, E, R, B, E2, R2>(
1555
+ fx: Fx<A, E, R>,
1556
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1557
1557
  flattenStrategy: FlattenStrategy,
1558
1558
  executionStrategy?: ExecutionStrategy.ExecutionStrategy
1559
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1559
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1560
1560
  } = dual(isDataFirstFx, core.flatMapCauseWithStrategy)
1561
1561
 
1562
1562
  /**
1563
1563
  * @since 1.20.0
1564
1564
  */
1565
1565
  export const flatMapErrorWithStrategy: {
1566
- <E, R2, E2, B>(
1567
- f: (e: E) => Fx<R2, E2, B>,
1566
+ <E, B, E2, R2>(
1567
+ f: (e: E) => Fx<B, E2, R2>,
1568
1568
  flattenStrategy: FlattenStrategy,
1569
1569
  executionStrategy?: ExecutionStrategy.ExecutionStrategy
1570
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1571
- <R, E, A, R2, E2, B>(
1572
- fx: Fx<R, E, A>,
1573
- f: (e: E) => Fx<R2, E2, B>,
1570
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1571
+ <A, E, R, B, E2, R2>(
1572
+ fx: Fx<A, E, R>,
1573
+ f: (e: E) => Fx<B, E2, R2>,
1574
1574
  flattenStrategy: FlattenStrategy,
1575
1575
  executionStrategy?: ExecutionStrategy.ExecutionStrategy
1576
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1576
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1577
1577
  } = dual(isDataFirstFx, core.flatMapErrorWithStrategy)
1578
1578
 
1579
1579
  /**
1580
1580
  * @since 1.20.0
1581
1581
  */
1582
1582
  export const switchMapCause: {
1583
- <R, E, A, R2, E2, B>(
1584
- fx: Fx<R, E, A>,
1585
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1583
+ <A, E, R, B, E2, R2>(
1584
+ fx: Fx<A, E, R>,
1585
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1586
1586
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1587
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1587
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1588
1588
 
1589
- <E, R2, E2, B>(
1590
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1589
+ <E, B, E2, R2>(
1590
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1591
1591
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1592
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1592
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1593
1593
  } = dual(isDataFirstFx, core.switchMapCause)
1594
1594
 
1595
1595
  /**
1596
1596
  * @since 1.20.0
1597
1597
  */
1598
1598
  export const switchMapError: {
1599
- <E, R2, E2, B>(
1600
- f: (e: E) => Fx<R2, E2, B>,
1599
+ <E, B, E2, R2>(
1600
+ f: (e: E) => Fx<B, E2, R2>,
1601
1601
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1602
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1602
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1603
1603
 
1604
- <R, E, A, R2, E2, B>(
1605
- fx: Fx<R, E, A>,
1606
- f: (e: E) => Fx<R2, E2, B>,
1604
+ <A, E, R, B, E2, R2>(
1605
+ fx: Fx<A, E, R>,
1606
+ f: (e: E) => Fx<B, E2, R2>,
1607
1607
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1608
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1608
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1609
1609
  } = dual(isDataFirstFx, core.switchMapError)
1610
1610
 
1611
1611
  /**
1612
1612
  * @since 1.20.0
1613
1613
  */
1614
1614
  export const flatMapCause: {
1615
- <E, R2, E2, B>(
1616
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1615
+ <E, B, E2, R2>(
1616
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1617
1617
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1618
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1618
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1619
1619
 
1620
- <R, E, A, R2, E2, B>(
1621
- fx: Fx<R, E, A>,
1622
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1620
+ <A, E, R, B, E2, R2>(
1621
+ fx: Fx<A, E, R>,
1622
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1623
1623
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1624
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1624
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1625
1625
  } = dual(isDataFirstFx, core.flatMapCause)
1626
1626
 
1627
1627
  /**
1628
1628
  * @since 1.20.0
1629
1629
  */
1630
1630
  export const flatMapError: {
1631
- <E, R2, E2, B>(
1632
- f: (e: E) => Fx<R2, E2, B>,
1631
+ <E, B, E2, R2>(
1632
+ f: (e: E) => Fx<B, E2, R2>,
1633
1633
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1634
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1634
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1635
1635
 
1636
- <R, E, A, R2, E2, B>(
1637
- fx: Fx<R, E, A>,
1638
- f: (e: E) => Fx<R2, E2, B>,
1636
+ <A, E, R, B, E2, R2>(
1637
+ fx: Fx<A, E, R>,
1638
+ f: (e: E) => Fx<B, E2, R2>,
1639
1639
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1640
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1640
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1641
1641
  } = dual(isDataFirstFx, core.flatMapError)
1642
1642
 
1643
1643
  /**
1644
1644
  * @since 1.20.0
1645
1645
  */
1646
1646
  export const flatMapCauseConcurrently: {
1647
- <E, R2, E2, B>(
1648
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1647
+ <E, B, E2, R2>(
1648
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1649
1649
  concurrency: number,
1650
1650
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1651
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1652
- <R, E, A, R2, E2, B>(
1653
- fx: Fx<R, E, A>,
1654
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1651
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1652
+ <A, E, R, B, E2, R2>(
1653
+ fx: Fx<A, E, R>,
1654
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1655
1655
  concurrency: number,
1656
1656
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1657
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1657
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1658
1658
  } = dual(isDataFirstFx, core.flatMapCauseConcurrently)
1659
1659
 
1660
1660
  /**
1661
1661
  * @since 1.20.0
1662
1662
  */
1663
1663
  export const flatMapErrorConcurrently: {
1664
- <E, R2, E2, B>(
1665
- f: (e: E) => Fx<R2, E2, B>,
1664
+ <E, B, E2, R2>(
1665
+ f: (e: E) => Fx<B, E2, R2>,
1666
1666
  concurrency: number,
1667
1667
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1668
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1668
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1669
1669
 
1670
- <R, E, A, R2, E2, B>(
1671
- fx: Fx<R, E, A>,
1672
- f: (e: E) => Fx<R2, E2, B>,
1670
+ <A, E, R, B, E2, R2>(
1671
+ fx: Fx<A, E, R>,
1672
+ f: (e: E) => Fx<B, E2, R2>,
1673
1673
  concurrency: number,
1674
1674
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1675
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1675
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1676
1676
  } = dual(isDataFirstFx, core.flatMapErrorConcurrently)
1677
1677
 
1678
1678
  /**
1679
1679
  * @since 1.20.0
1680
1680
  */
1681
1681
  export const exhaustMapCause: {
1682
- <E, R2, E2, B>(
1683
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1682
+ <E, B, E2, R2>(
1683
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1684
1684
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1685
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1685
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1686
1686
 
1687
- <R, E, A, R2, E2, B>(
1688
- fx: Fx<R, E, A>,
1689
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1687
+ <A, E, R, B, E2, R2>(
1688
+ fx: Fx<A, E, R>,
1689
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1690
1690
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1691
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1691
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1692
1692
  } = dual(isDataFirstFx, core.exhaustMapCause)
1693
1693
 
1694
1694
  /**
1695
1695
  * @since 1.20.0
1696
1696
  */
1697
1697
  export const exhaustMapError: {
1698
- <E, R2, E2, B>(
1699
- f: (e: E) => Fx<R2, E2, B>,
1698
+ <E, B, E2, R2>(
1699
+ f: (e: E) => Fx<B, E2, R2>,
1700
1700
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1701
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1701
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1702
1702
 
1703
- <R, E, A, R2, E2, B>(
1704
- fx: Fx<R, E, A>,
1705
- f: (e: E) => Fx<R2, E2, B>,
1703
+ <A, E, R, B, E2, R2>(
1704
+ fx: Fx<A, E, R>,
1705
+ f: (e: E) => Fx<B, E2, R2>,
1706
1706
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1707
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1707
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1708
1708
  } = dual(isDataFirstFx, core.exhaustMapError)
1709
1709
 
1710
1710
  /**
1711
1711
  * @since 1.20.0
1712
1712
  */
1713
1713
  export const exhaustMapLatestCause: {
1714
- <E, R2, E2, B>(
1715
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1714
+ <E, B, E2, R2>(
1715
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1716
1716
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1717
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1717
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1718
1718
 
1719
- <R, E, A, R2, E2, B>(
1720
- fx: Fx<R, E, A>,
1721
- f: (cause: Cause.Cause<E>) => Fx<R2, E2, B>,
1719
+ <A, E, R, B, E2, R2>(
1720
+ fx: Fx<A, E, R>,
1721
+ f: (cause: Cause.Cause<E>) => Fx<B, E2, R2>,
1722
1722
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1723
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1723
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1724
1724
  } = dual(isDataFirstFx, core.exhaustMapLatestCause)
1725
1725
 
1726
1726
  /**
1727
1727
  * @since 1.20.0
1728
1728
  */
1729
1729
  export const exhaustMapLatestError: {
1730
- <E, R2, E2, B>(
1731
- f: (e: E) => Fx<R2, E2, B>,
1730
+ <E, B, E2, R2>(
1731
+ f: (e: E) => Fx<B, E2, R2>,
1732
1732
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1733
- ): <R, A>(fx: Fx<R, E, A>) => Fx<R | R2 | Scope.Scope, E2, A | B>
1733
+ ): <R, A>(fx: Fx<A, E, R>) => Fx<A | B, E2, R | R2 | Scope.Scope>
1734
1734
 
1735
- <R, E, A, R2, E2, B>(
1736
- fx: Fx<R, E, A>,
1737
- f: (e: E) => Fx<R2, E2, B>,
1735
+ <A, E, R, B, E2, R2>(
1736
+ fx: Fx<A, E, R>,
1737
+ f: (e: E) => Fx<B, E2, R2>,
1738
1738
  executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1739
- ): Fx<R | R2 | Scope.Scope, E2, A | B>
1739
+ ): Fx<A | B, E2, R | R2 | Scope.Scope>
1740
1740
  } = dual(isDataFirstFx, core.exhaustMapLatestError)
1741
1741
 
1742
1742
  /**
1743
1743
  * @since 1.20.0
1744
1744
  */
1745
- export type MatchCauseOptions<E, A, R2, E2, B, R3, E3, C> = {
1746
- readonly onFailure: (cause: Cause.Cause<E>) => Fx<R2, E2, B>
1747
- readonly onSuccess: (a: A) => Fx<R3, E3, C>
1745
+ export type MatchCauseOptions<E, A, B, E2, R2, C, E3, R3> = {
1746
+ readonly onFailure: (cause: Cause.Cause<E>) => Fx<B, E2, R2>
1747
+ readonly onSuccess: (a: A) => Fx<C, E3, R3>
1748
1748
  readonly executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1749
1749
  }
1750
1750
 
1751
1751
  /**
1752
1752
  * @since 1.20.0
1753
1753
  */
1754
- export type MatchErrorOptions<E, A, R2, E2, B, R3, E3, C> = {
1755
- readonly onFailure: (e: E) => Fx<R2, E2, B>
1756
- readonly onSuccess: (a: A) => Fx<R3, E3, C>
1754
+ export type MatchErrorOptions<E, A, B, E2, R2, C, E3, R3> = {
1755
+ readonly onFailure: (e: E) => Fx<B, E2, R2>
1756
+ readonly onSuccess: (a: A) => Fx<C, E3, R3>
1757
1757
  readonly executionStrategy?: ExecutionStrategy.ExecutionStrategy | undefined
1758
1758
  }
1759
1759
 
@@ -1761,192 +1761,192 @@ export type MatchErrorOptions<E, A, R2, E2, B, R3, E3, C> = {
1761
1761
  * @since 1.20.0
1762
1762
  */
1763
1763
  export const matchCauseWithStrategy: {
1764
- <E, A, R2, E2, B, R3, E3, C>(
1765
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1766
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1764
+ <E, A, B, E2, R2, C, E3, R3>(
1765
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1766
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1767
1767
 
1768
- <R, E, A, R2, E2, B, R3, E3, C>(
1769
- fx: Fx<R, E, A>,
1768
+ <A, E, R, B, E2, R2, C, E3, R3>(
1769
+ fx: Fx<A, E, R>,
1770
1770
  flattenStrategy: FlattenStrategy,
1771
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1772
- ): Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1771
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1772
+ ): Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1773
1773
  } = dual(3, core.matchCauseWithStrategy)
1774
1774
 
1775
1775
  /**
1776
1776
  * @since 1.20.0
1777
1777
  */
1778
1778
  export const matchErrorWithStrategy: {
1779
- <E, A, R2, E2, B, R3, E3, C>(
1780
- { executionStrategy, onFailure, onSuccess }: MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1781
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1782
- <R, E, A, R2, E2, B, R3, E3, C>(
1783
- fx: Fx<R, E, A>,
1779
+ <E, A, B, E2, R2, C, E3, R3>(
1780
+ { executionStrategy, onFailure, onSuccess }: MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1781
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1782
+ <A, E, R, B, E2, R2, C, E3, R3>(
1783
+ fx: Fx<A, E, R>,
1784
1784
  flattenStrategy: FlattenStrategy,
1785
- { executionStrategy, onFailure, onSuccess }: MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1786
- ): Fx<Scope.Scope | R | R2 | R3, E2 | E3, B | C>
1785
+ { executionStrategy, onFailure, onSuccess }: MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1786
+ ): Fx<B | C, E2 | E3, Scope.Scope | R | R2 | R3>
1787
1787
  } = dual(3, core.matchErrorWithStrategy)
1788
1788
 
1789
1789
  /**
1790
1790
  * @since 1.20.0
1791
1791
  */
1792
1792
  export const matchCause: {
1793
- <E, A, R2, E2, B, R3, E3, C>(
1794
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1795
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1796
-
1797
- <R, E, A, R2, E2, B, R3, E3, C>(
1798
- fx: Fx<R, E, A>,
1799
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1800
- ): Fx<Scope.Scope | R | R2 | R3, E2 | E3, B | C>
1793
+ <E, A, B, E2, R2, C, E3, R3>(
1794
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1795
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1796
+
1797
+ <A, E, R, B, E2, R2, C, E3, R3>(
1798
+ fx: Fx<A, E, R>,
1799
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1800
+ ): Fx<B | C, E2 | E3, Scope.Scope | R | R2 | R3>
1801
1801
  } = dual(2, core.matchCause)
1802
1802
 
1803
1803
  /**
1804
1804
  * @since 1.20.0
1805
1805
  */
1806
1806
  export const matchError: {
1807
- <E, A, R2, E2, B, R3, E3, C>(
1808
- opts: MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1809
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1810
- <R, E, A, R2, E2, B, R3, E3, C>(
1811
- fx: Fx<R, E, A>,
1812
- opts: core.MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1813
- ): Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1807
+ <E, A, B, E2, R2, C, E3, R3>(
1808
+ opts: MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1809
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1810
+ <A, E, R, B, E2, R2, C, E3, R3>(
1811
+ fx: Fx<A, E, R>,
1812
+ opts: core.MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1813
+ ): Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1814
1814
  } = dual(2, core.matchError)
1815
1815
 
1816
1816
  /**
1817
1817
  * @since 1.20.0
1818
1818
  */
1819
1819
  export const matchCauseConcurrently: {
1820
- <E, A, R2, E2, B, R3, E3, C>(
1820
+ <E, A, B, E2, R2, C, E3, R3>(
1821
1821
  concurrency: number,
1822
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1823
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1824
- <R, E, A, R2, E2, B, R3, E3, C>(
1825
- fx: Fx<R, E, A>,
1822
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1823
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1824
+ <A, E, R, B, E2, R2, C, E3, R3>(
1825
+ fx: Fx<A, E, R>,
1826
1826
  concurrency: number,
1827
- opts: core.MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1828
- ): Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1827
+ opts: core.MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1828
+ ): Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1829
1829
  } = dual(3, core.matchCauseConcurrently)
1830
1830
 
1831
1831
  /**
1832
1832
  * @since 1.20.0
1833
1833
  */
1834
1834
  export const matchErrorConcurrently: {
1835
- <E, A, R2, E2, B, R3, E3, C>(
1835
+ <E, A, B, E2, R2, C, E3, R3>(
1836
1836
  concurrency: number,
1837
- opts: MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1838
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1839
- <R, E, A, R2, E2, B, R3, E3, C>(
1840
- fx: Fx<R, E, A>,
1837
+ opts: MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1838
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1839
+ <A, E, R, B, E2, R2, C, E3, R3>(
1840
+ fx: Fx<A, E, R>,
1841
1841
  concurrency: number,
1842
- opts: core.MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1843
- ): Fx<Scope.Scope | R | R2 | R3, E2 | E3, B | C>
1842
+ opts: core.MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1843
+ ): Fx<B | C, E2 | E3, Scope.Scope | R | R2 | R3>
1844
1844
  } = dual(3, core.matchErrorConcurrently)
1845
1845
 
1846
1846
  /**
1847
1847
  * @since 1.20.0
1848
1848
  */
1849
1849
  export const switchMatchCause: {
1850
- <E, A, R2, E2, B, R3, E3, C>(
1851
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1852
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1853
-
1854
- <R, E, A, R2, E2, B, R3, E3, C>(
1855
- fx: Fx<R, E, A>,
1856
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1857
- ): Fx<Scope.Scope | R | R2 | R3, E2 | E3, B | C>
1850
+ <E, A, B, E2, R2, C, E3, R3>(
1851
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1852
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1853
+
1854
+ <A, E, R, B, E2, R2, C, E3, R3>(
1855
+ fx: Fx<A, E, R>,
1856
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1857
+ ): Fx<B | C, E2 | E3, Scope.Scope | R | R2 | R3>
1858
1858
  } = dual(2, core.switchMatchCause)
1859
1859
 
1860
1860
  /**
1861
1861
  * @since 1.20.0
1862
1862
  */
1863
1863
  export const switchMatchError: {
1864
- <E, A, R2, E2, B, R3, E3, C>(
1865
- opts: MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1866
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1867
- <R, E, A, R2, E2, B, R3, E3, C>(
1868
- fx: Fx<R, E, A>,
1869
- opts: core.MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1870
- ): Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1864
+ <E, A, B, E2, R2, C, E3, R3>(
1865
+ opts: MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1866
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1867
+ <A, E, R, B, E2, R2, C, E3, R3>(
1868
+ fx: Fx<A, E, R>,
1869
+ opts: core.MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1870
+ ): Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1871
1871
  } = dual(2, core.switchMatchError)
1872
1872
 
1873
1873
  /**
1874
1874
  * @since 1.20.0
1875
1875
  */
1876
1876
  export const exhaustMatchCause: {
1877
- <E, A, R2, E2, B, R3, E3, C>(
1878
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1879
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1880
-
1881
- <R, E, A, R2, E2, B, R3, E3, C>(
1882
- fx: Fx<R, E, A>,
1883
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1884
- ): Fx<Scope.Scope | R | R2 | R3, E2 | E3, B | C>
1877
+ <E, A, B, E2, R2, C, E3, R3>(
1878
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1879
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1880
+
1881
+ <A, E, R, B, E2, R2, C, E3, R3>(
1882
+ fx: Fx<A, E, R>,
1883
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1884
+ ): Fx<B | C, E2 | E3, Scope.Scope | R | R2 | R3>
1885
1885
  } = dual(2, core.exhaustMatchCause)
1886
1886
 
1887
1887
  /**
1888
1888
  * @since 1.20.0
1889
1889
  */
1890
1890
  export const exhaustMatchError: {
1891
- <E, A, R2, E2, B, R3, E3, C>(
1892
- opts: MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1893
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1894
- <R, E, A, R2, E2, B, R3, E3, C>(
1895
- fx: Fx<R, E, A>,
1896
- opts: core.MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1897
- ): Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1891
+ <E, A, B, E2, R2, C, E3, R3>(
1892
+ opts: MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1893
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1894
+ <A, E, R, B, E2, R2, C, E3, R3>(
1895
+ fx: Fx<A, E, R>,
1896
+ opts: core.MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1897
+ ): Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1898
1898
  } = dual(2, core.exhaustMatchError)
1899
1899
 
1900
1900
  /**
1901
1901
  * @since 1.20.0
1902
1902
  */
1903
1903
  export const exhaustMatchLatestCause: {
1904
- <E, A, R2, E2, B, R3, E3, C>(
1905
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1906
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1907
-
1908
- <R, E, A, R2, E2, B, R3, E3, C>(
1909
- fx: Fx<R, E, A>,
1910
- opts: MatchCauseOptions<E, A, R2, E2, B, R3, E3, C>
1911
- ): Fx<Scope.Scope | R | R2 | R3, E2 | E3, B | C>
1904
+ <E, A, B, E2, R2, C, E3, R3>(
1905
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1906
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1907
+
1908
+ <A, E, R, B, E2, R2, C, E3, R3>(
1909
+ fx: Fx<A, E, R>,
1910
+ opts: MatchCauseOptions<E, A, B, E2, R2, C, E3, R3>
1911
+ ): Fx<B | C, E2 | E3, Scope.Scope | R | R2 | R3>
1912
1912
  } = dual(2, core.exhaustMatchLatestCause)
1913
1913
 
1914
1914
  /**
1915
1915
  * @since 1.20.0
1916
1916
  */
1917
1917
  export const exhaustMatchLatestError: {
1918
- <E, A, R2, E2, B, R3, E3, C>(
1919
- opts: MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1920
- ): <R>(fx: Fx<R, E, A>) => Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1921
- <R, E, A, R2, E2, B, R3, E3, C>(
1922
- fx: Fx<R, E, A>,
1923
- opts: core.MatchErrorOptions<E, A, R2, E2, B, R3, E3, C>
1924
- ): Fx<R | R2 | R3 | Scope.Scope, E2 | E3, B | C>
1918
+ <E, A, B, E2, R2, C, E3, R3>(
1919
+ opts: MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1920
+ ): <R>(fx: Fx<A, E, R>) => Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1921
+ <A, E, R, B, E2, R2, C, E3, R3>(
1922
+ fx: Fx<A, E, R>,
1923
+ opts: core.MatchErrorOptions<E, A, B, E2, R2, C, E3, R3>
1924
+ ): Fx<B | C, E2 | E3, R | R2 | R3 | Scope.Scope>
1925
1925
  } = dual(2, core.exhaustMatchLatestError)
1926
1926
 
1927
1927
  /**
1928
1928
  * @since 1.20.0
1929
1929
  */
1930
- export const exit: <R, E, A>(fx: Fx<R, E, A>) => Fx<R, never, Exit.Exit<E, A>> = core.exit
1930
+ export const exit: <A, E, R>(fx: Fx<A, E, R>) => Fx<Exit.Exit<A, E>, never, R> = core.exit
1931
1931
 
1932
1932
  /**
1933
1933
  * @since 1.20.0
1934
1934
  */
1935
- export const either: <R, E, A>(fx: Fx<R, E, A>) => Fx<R, never, Either.Either<E, A>> = core.either
1935
+ export const either: <A, E, R>(fx: Fx<A, E, R>) => Fx<Either.Either<E, A>, never, R> = core.either
1936
1936
 
1937
1937
  /**
1938
1938
  * @since 1.20.0
1939
1939
  */
1940
1940
  export const tuple: <const FX extends ReadonlyArray<Fx<any, any, any>>>(
1941
1941
  fx: FX
1942
- ) => Fx<Fx.Context<FX[number]>, Fx.Error<FX[number]>, { readonly [K in keyof FX]: Fx.Success<FX[K]> }> = core.tuple
1942
+ ) => Fx<{ readonly [K in keyof FX]: Fx.Success<FX[K]> }, Fx.Error<FX[number]>, Fx.Context<FX[number]>> = core.tuple
1943
1943
 
1944
1944
  /**
1945
1945
  * @since 1.20.0
1946
1946
  */
1947
1947
  export const struct: <const FX extends Readonly<Record<string, Fx<any, any, any>>>>(
1948
1948
  fx: FX
1949
- ) => Fx<Fx.Context<FX[string]>, Fx.Error<FX[string]>, { readonly [K in keyof FX]: Fx.Success<FX[K]> }> = core.struct
1949
+ ) => Fx<{ readonly [K in keyof FX]: Fx.Success<FX[K]> }, Fx.Error<FX[string]>, Fx.Context<FX[string]>> = core.struct
1950
1950
 
1951
1951
  /**
1952
1952
  * @since 1.20.0
@@ -1954,10 +1954,10 @@ export const struct: <const FX extends Readonly<Record<string, Fx<any, any, any>
1954
1954
  export const all: {
1955
1955
  <const FX extends ReadonlyArray<Fx<any, any, any>>>(
1956
1956
  fx: FX
1957
- ): Fx<Fx.Context<FX[number]>, Fx.Error<FX[number]>, { readonly [K in keyof FX]: Fx.Success<FX[K]> }>
1957
+ ): Fx<{ readonly [K in keyof FX]: Fx.Success<FX[K]> }, Fx.Error<FX[number]>, Fx.Context<FX[number]>>
1958
1958
  <const FX extends Readonly<Record<string, Fx<any, any, any>>>>(
1959
1959
  fx: FX
1960
- ): Fx<Fx.Context<FX[string]>, Fx.Error<FX[string]>, { readonly [K in keyof FX]: Fx.Success<FX[K]> }>
1960
+ ): Fx<{ readonly [K in keyof FX]: Fx.Success<FX[K]> }, Fx.Error<FX[string]>, Fx.Context<FX[string]>>
1961
1961
  } = core.all
1962
1962
 
1963
1963
  /**
@@ -1966,40 +1966,40 @@ export const all: {
1966
1966
  export const toEnqueue: {
1967
1967
  <R2 = never, A = never>(
1968
1968
  queue: Ctx.Enqueue<R2, A> | Queue.Enqueue<A>
1969
- ): <R, E>(fx: Fx<R, E, A>) => Effect.Effect<R | R2, E, void>
1970
- <R, E, A, R2 = never>(fx: Fx<R, E, A>, queue: Ctx.Enqueue<R2, A> | Queue.Enqueue<A>): Effect.Effect<R | R2, E, void>
1969
+ ): <E, R>(fx: Fx<A, E, R>) => Effect.Effect<void, E, R | R2>
1970
+ <A, E, R, R2 = never>(fx: Fx<A, E, R>, queue: Ctx.Enqueue<R2, A> | Queue.Enqueue<A>): Effect.Effect<void, E, R | R2>
1971
1971
  } = dual(2, core.toEnqueue)
1972
1972
 
1973
1973
  /**
1974
1974
  * @since 1.20.0
1975
1975
  */
1976
1976
  export const debounce: {
1977
- (delay: Duration.DurationInput): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | Scope.Scope, E, A>
1978
- <R, E, A>(fx: Fx<R, E, A>, delay: Duration.DurationInput): Fx<R | Scope.Scope, E, A>
1977
+ (delay: Duration.DurationInput): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R | Scope.Scope>
1978
+ <A, E, R>(fx: Fx<A, E, R>, delay: Duration.DurationInput): Fx<A, E, R | Scope.Scope>
1979
1979
  } = dual(2, core.debounce)
1980
1980
 
1981
1981
  /**
1982
1982
  * @since 1.20.0
1983
1983
  */
1984
1984
  export const throttle: {
1985
- (delay: Duration.DurationInput): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | Scope.Scope, E, A>
1986
- <R, E, A>(fx: Fx<R, E, A>, delay: Duration.DurationInput): Fx<R | Scope.Scope, E, A>
1985
+ (delay: Duration.DurationInput): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R | Scope.Scope>
1986
+ <A, E, R>(fx: Fx<A, E, R>, delay: Duration.DurationInput): Fx<A, E, R | Scope.Scope>
1987
1987
  } = dual(2, core.throttle)
1988
1988
 
1989
1989
  /**
1990
1990
  * @since 1.20.0
1991
1991
  */
1992
1992
  export const throttleLatest: {
1993
- (delay: Duration.DurationInput): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | Scope.Scope, E, A>
1994
- <R, E, A>(fx: Fx<R, E, A>, delay: Duration.DurationInput): Fx<R | Scope.Scope, E, A>
1993
+ (delay: Duration.DurationInput): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R | Scope.Scope>
1994
+ <A, E, R>(fx: Fx<A, E, R>, delay: Duration.DurationInput): Fx<A, E, R | Scope.Scope>
1995
1995
  } = dual(2, core.throttleLatest)
1996
1996
 
1997
1997
  /**
1998
1998
  * @since 1.20.0
1999
1999
  */
2000
- export interface KeyedOptions<A, B, R2, E2, C> {
2000
+ export interface KeyedOptions<A, B, C, E2, R2> {
2001
2001
  readonly getKey: (a: A) => B
2002
- readonly onValue: (ref: RefSubject<never, never, A>, key: B) => Fx<R2, E2, C>
2002
+ readonly onValue: (ref: RefSubject<A>, key: B) => Fx<C, E2, R2>
2003
2003
  readonly debounce?: Duration.DurationInput
2004
2004
  }
2005
2005
 
@@ -2007,36 +2007,36 @@ export interface KeyedOptions<A, B, R2, E2, C> {
2007
2007
  * @since 1.20.0
2008
2008
  */
2009
2009
  export const keyed: {
2010
- <A, B extends PropertyKey, R2, E2, C>(
2011
- options: KeyedOptions<A, B, R2, E2, C>
2012
- ): <R, E>(fx: Fx<R, E, ReadonlyArray<A>>) => Fx<R | R2, E | E2, ReadonlyArray<C>>
2013
-
2014
- <R, E, A, B extends PropertyKey, R2, E2, C>(
2015
- fx: Fx<R, E, ReadonlyArray<A>>,
2016
- options: KeyedOptions<A, B, R2, E2, C>
2017
- ): Fx<R | R2, E | E2, ReadonlyArray<C>>
2010
+ <A, B extends PropertyKey, E2, R2, C>(
2011
+ options: KeyedOptions<A, B, C, E2, R2>
2012
+ ): <E, R>(fx: Fx<ReadonlyArray<A>, E, R>) => Fx<ReadonlyArray<C>, E | E2, R | R2>
2013
+
2014
+ <A, E, R, B extends PropertyKey, E2, R2, C>(
2015
+ fx: Fx<ReadonlyArray<A>, E, R>,
2016
+ options: KeyedOptions<A, B, C, E2, R2>
2017
+ ): Fx<ReadonlyArray<C>, E | E2, R | R2>
2018
2018
  } = dual(2, coreKeyed.keyed)
2019
2019
 
2020
2020
  /**
2021
2021
  * @since 1.20.0
2022
2022
  */
2023
- export interface WithKeyOptions<A, B, R2, E2, C> {
2023
+ export interface WithKeyOptions<A, B, C, E2, R2> {
2024
2024
  readonly getKey: (a: A) => B
2025
- readonly onValue: (ref: RefSubject<never, never, A>, key: B) => Fx<R2, E2, C>
2025
+ readonly onValue: (ref: RefSubject<A>, key: B) => Fx<C, E2, R2>
2026
2026
  }
2027
2027
 
2028
2028
  /**
2029
2029
  * @since 1.20.0
2030
2030
  */
2031
2031
  export const withKey: {
2032
- <A, B extends PropertyKey, R2, E2, C>(
2033
- options: WithKeyOptions<A, B, R2, E2, C>
2034
- ): <R, E>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, C>
2035
-
2036
- <R, E, A, B extends PropertyKey, R2, E2, C>(
2037
- fx: Fx<R, E, A>,
2038
- options: WithKeyOptions<A, B, R2, E2, C>
2039
- ): Fx<R | R2, E | E2, C>
2032
+ <A, B extends PropertyKey, E2, R2, C>(
2033
+ options: WithKeyOptions<A, B, C, E2, R2>
2034
+ ): <E, R>(fx: Fx<A, E, R>) => Fx<C, E | E2, R | R2>
2035
+
2036
+ <A, E, R, B extends PropertyKey, E2, R2, C>(
2037
+ fx: Fx<A, E, R>,
2038
+ options: WithKeyOptions<A, B, C, E2, R2>
2039
+ ): Fx<C, E | E2, R | R2>
2040
2040
  } = dual(2, coreWithKey.withKey)
2041
2041
 
2042
2042
  const getTag = (a: { readonly _tag: string }): string => a._tag
@@ -2052,29 +2052,31 @@ const getTag = (a: { readonly _tag: string }): string => a._tag
2052
2052
  export const matchTags: {
2053
2053
  <A extends { readonly _tag: string }, Matchers extends DefaultMatchersFrom<A>>(
2054
2054
  matchers: Matchers
2055
- ): <R, E>(fx: Fx<R, E, A>) => Fx<
2056
- R | Fx.Context<ReturnType<Matchers[keyof Matchers]>>,
2055
+ ): <E, R>(
2056
+ fx: Fx<A, E, R>
2057
+ ) => Fx<
2058
+ Fx.Success<ReturnType<Matchers[keyof Matchers]>>,
2057
2059
  E | Fx.Error<ReturnType<Matchers[keyof Matchers]>>,
2058
- Fx.Success<ReturnType<Matchers[keyof Matchers]>>
2060
+ R | Fx.Context<ReturnType<Matchers[keyof Matchers]>>
2059
2061
  >
2060
2062
 
2061
- <R, E, A extends { readonly _tag: string }, Matchers extends DefaultMatchersFrom<A>>(
2062
- fx: Fx<R, E, A>,
2063
+ <A extends { readonly _tag: string }, E, R, Matchers extends DefaultMatchersFrom<A>>(
2064
+ fx: Fx<A, E, R>,
2063
2065
  matchers: Matchers
2064
2066
  ): Fx<
2065
- R | Fx.Context<ReturnType<Matchers[keyof Matchers]>>,
2067
+ Fx.Success<ReturnType<Matchers[keyof Matchers]>>,
2066
2068
  E | Fx.Error<ReturnType<Matchers[keyof Matchers]>>,
2067
- Fx.Success<ReturnType<Matchers[keyof Matchers]>>
2069
+ R | Fx.Context<ReturnType<Matchers[keyof Matchers]>>
2068
2070
  >
2069
2071
  } = dual(
2070
2072
  2,
2071
- function matchTags<R, E, A extends { readonly _tag: string }, Matchers extends DefaultMatchersFrom<A>>(
2072
- fx: Fx<R, E, A>,
2073
+ function matchTags<A extends { readonly _tag: string }, E, R, Matchers extends DefaultMatchersFrom<A>>(
2074
+ fx: Fx<A, E, R>,
2073
2075
  matchers: Matchers
2074
2076
  ): Fx<
2075
- R | Fx.Context<ReturnType<Matchers[keyof Matchers]>>,
2077
+ Fx.Success<ReturnType<Matchers[keyof Matchers]>>,
2076
2078
  E | Fx.Error<ReturnType<Matchers[keyof Matchers]>>,
2077
- Fx.Success<ReturnType<Matchers[keyof Matchers]>>
2079
+ R | Fx.Context<ReturnType<Matchers[keyof Matchers]>>
2078
2080
  > {
2079
2081
  return withKey(fx, {
2080
2082
  getKey: getTag,
@@ -2088,7 +2090,7 @@ export const matchTags: {
2088
2090
  */
2089
2091
  export type DefaultMatchersFrom<A extends { readonly _tag: string }> = {
2090
2092
  readonly [Tag in A["_tag"]]: (
2091
- value: RefSubject<never, never, Extract<A, { readonly _tag: Tag }>>
2093
+ value: RefSubject<Extract<A, { readonly _tag: Tag }>>
2092
2094
  ) => Fx<any, any, any>
2093
2095
  }
2094
2096
 
@@ -2096,23 +2098,23 @@ export type DefaultMatchersFrom<A extends { readonly _tag: string }> = {
2096
2098
  * @since 1.20.0
2097
2099
  */
2098
2100
  export const matchOption: {
2099
- <A, R2 = never, E2 = never, B = never, R3 = never, E3 = never, C = never>(
2100
- onNone: () => Fx<R2, E2, B>,
2101
- onSome: (a: RefSubject<never, never, A>) => Fx<R3, E3, C>
2102
- ): <R, E>(fx: Fx<R, E, Option.Option<A>>) => Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, B | C>
2103
-
2104
- <R, E, A, R2 = never, E2 = never, B = never, R3 = never, E3 = never, C = never>(
2105
- fx: Fx<R, E, Option.Option<A>>,
2106
- onNone: () => Fx<R2, E2, B>,
2107
- onSome: (a: RefSubject<never, never, A>) => Fx<R3, E3, C>
2108
- ): Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, B | C>
2101
+ <A, B = never, E2 = never, R2 = never, C = never, E3 = never, R3 = never>(
2102
+ onNone: () => Fx<B, E2, R2>,
2103
+ onSome: (a: RefSubject<A>) => Fx<C, E3, R3>
2104
+ ): <E, R>(fx: Fx<Option.Option<A>, E, R>) => Fx<B | C, E | E2 | E3, R | R2 | R3 | Scope.Scope>
2105
+
2106
+ <A, E, R, B = never, E2 = never, R2 = never, C = never, E3 = never, R3 = never>(
2107
+ fx: Fx<Option.Option<A>, E, R>,
2108
+ onNone: () => Fx<B, E2, R2>,
2109
+ onSome: (a: RefSubject<A>) => Fx<C, E3, R3>
2110
+ ): Fx<B | C, E | E2 | E3, R | R2 | R3 | Scope.Scope>
2109
2111
  } = dual(
2110
2112
  3,
2111
- function matchOption<R, E, A, R2 = never, E2 = never, B = never, R3 = never, E3 = never, C = never>(
2112
- fx: Fx<R, E, Option.Option<A>>,
2113
- onNone: () => Fx<R2, E2, B>,
2114
- onSome: (a: RefSubject<never, never, A>) => Fx<R3, E3, C>
2115
- ): Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, B | C> {
2113
+ function matchOption<A, E, R, B = never, E2 = never, R2 = never, C = never, E3 = never, R3 = never>(
2114
+ fx: Fx<Option.Option<A>, E, R>,
2115
+ onNone: () => Fx<B, E2, R2>,
2116
+ onSome: (a: RefSubject<A>) => Fx<C, E3, R3>
2117
+ ): Fx<B | C, E | E2 | E3, R | R2 | R3 | Scope.Scope> {
2116
2118
  return matchTags(fx, {
2117
2119
  None: onNone,
2118
2120
  Some: (some) => onSome(transform(some, (s) => s.value, (value) => Option.some(value) as Option.Some<A>))
@@ -2124,21 +2126,21 @@ export const matchOption: {
2124
2126
  * @since 1.20.0
2125
2127
  */
2126
2128
  export const getOrElse: {
2127
- <A, R2 = never, E2 = never, B = never>(
2128
- orElse: () => Fx<R2, E2, B>
2129
- ): <R, E>(fx: Fx<R, E, Option.Option<A>>) => Fx<R | R2 | Scope.Scope, E | E2, A | B>
2130
-
2131
- <R, E, A, R2 = never, E2 = never, B = never>(
2132
- fx: Fx<R, E, Option.Option<A>>,
2133
- orElse: () => Fx<R2, E2, B>
2134
- ): Fx<R | R2 | Scope.Scope, E | E2, A | B>
2129
+ <A, B = never, E2 = never, R2 = never>(
2130
+ orElse: () => Fx<B, E2, R2>
2131
+ ): <E, R>(fx: Fx<Option.Option<A>, E, R>) => Fx<A | B, E | E2, R | R2 | Scope.Scope>
2132
+
2133
+ <A, E, R, B = never, E2 = never, R2 = never>(
2134
+ fx: Fx<Option.Option<A>, E, R>,
2135
+ orElse: () => Fx<B, E2, R2>
2136
+ ): Fx<A | B, E | E2, R | R2 | Scope.Scope>
2135
2137
  } = dual(
2136
2138
  2,
2137
- function getOrElse<R, E, A, R2 = never, E2 = never, B = never>(
2138
- fx: Fx<R, E, Option.Option<A>>,
2139
- orElse: () => Fx<R2, E2, B>
2140
- ): Fx<R | R2 | Scope.Scope, E | E2, A | B> {
2141
- return matchOption(fx, orElse, identity)
2139
+ function getOrElse<A, E, R, B = never, E2 = never, R2 = never>(
2140
+ fx: Fx<Option.Option<A>, E, R>,
2141
+ orElse: () => Fx<B, E2, R2>
2142
+ ): Fx<A | B, E | E2, R | R2 | Scope.Scope> {
2143
+ return matchOption(fx, () => orElse(), (ref) => ref)
2142
2144
  }
2143
2145
  )
2144
2146
 
@@ -2146,23 +2148,23 @@ export const getOrElse: {
2146
2148
  * @since 1.20.0
2147
2149
  */
2148
2150
  export const matchEither: {
2149
- <E1, A, R2 = never, E2 = never, B = never, R3 = never, E3 = never, C = never>(
2150
- onLeft: (e: RefSubject<never, never, E1>) => Fx<R2, E2, B>,
2151
- onRight: (a: RefSubject<never, never, A>) => Fx<R3, E3, C>
2152
- ): <R, E>(fx: Fx<R, E, Either.Either<E1, A>>) => Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, B | C>
2153
-
2154
- <R, E, E1, A, R2 = never, E2 = never, B = never, R3 = never, E3 = never, C = never>(
2155
- fx: Fx<R, E, Either.Either<E1, A>>,
2156
- onLeft: (e: RefSubject<never, never, E1>) => Fx<R2, E2, B>,
2157
- onRight: (a: RefSubject<never, never, A>) => Fx<R3, E3, C>
2158
- ): Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, B | C>
2151
+ <E1, A, B = never, E2 = never, R2 = never, C = never, E3 = never, R3 = never>(
2152
+ onLeft: (e: RefSubject<E1>) => Fx<B, E2, R2>,
2153
+ onRight: (a: RefSubject<A>) => Fx<C, E3, R3>
2154
+ ): <E, R>(fx: Fx<Either.Either<E1, A>, E, R>) => Fx<B | C, E | E2 | E3, R | R2 | R3 | Scope.Scope>
2155
+
2156
+ <R, E, E1, A, B = never, E2 = never, R2 = never, C = never, E3 = never, R3 = never>(
2157
+ fx: Fx<Either.Either<E1, A>, E, R>,
2158
+ onLeft: (e: RefSubject<E1>) => Fx<B, E2, R2>,
2159
+ onRight: (a: RefSubject<A>) => Fx<C, E3, R3>
2160
+ ): Fx<B | C, E | E2 | E3, R | R2 | R3 | Scope.Scope>
2159
2161
  } = dual(
2160
2162
  3,
2161
- function matchEither<R, E, E1, A, R2 = never, E2 = never, B = never, R3 = never, E3 = never, C = never>(
2162
- fx: Fx<R, E, Either.Either<E1, A>>,
2163
- onLeft: (e: RefSubject<never, never, E1>) => Fx<R2, E2, B>,
2164
- onRight: (a: RefSubject<never, never, A>) => Fx<R3, E3, C>
2165
- ): Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, B | C> {
2163
+ function matchEither<R, E, E1, A, B = never, E2 = never, R2 = never, C = never, E3 = never, R3 = never>(
2164
+ fx: Fx<Either.Either<E1, A>, E, R>,
2165
+ onLeft: (e: RefSubject<E1>) => Fx<B, E2, R2>,
2166
+ onRight: (a: RefSubject<A>) => Fx<C, E3, R3>
2167
+ ): Fx<B | C, E | E2 | E3, R | R2 | R3 | Scope.Scope> {
2166
2168
  return matchTags(fx, {
2167
2169
  Left: (left) => onLeft(transform(left, (a) => a.left, (a) => Either.left(a) as Either.Left<E1, A>)),
2168
2170
  Right: (right) => onRight(transform(right, (s) => s.right, (value) => Either.right(value) as Either.Right<E1, A>))
@@ -2174,59 +2176,56 @@ export const matchEither: {
2174
2176
  * @since 1.20.0
2175
2177
  */
2176
2178
  export const at: {
2177
- (duration: Duration.DurationInput): <A>(value: A) => Fx<never, never, A>
2178
- <A>(value: A, duration: Duration.DurationInput): Fx<never, never, A>
2179
+ (duration: Duration.DurationInput): <A>(value: A) => Fx<A>
2180
+ <A>(value: A, duration: Duration.DurationInput): Fx<A>
2179
2181
  } = dual(
2180
2182
  2,
2181
- <A>(value: A, duration: Duration.DurationInput): Fx<never, never, A> =>
2182
- fromEffect(Effect.delay(Effect.succeed(value), duration))
2183
+ <A>(value: A, duration: Duration.DurationInput): Fx<A> => fromEffect(Effect.delay(Effect.succeed(value), duration))
2183
2184
  )
2184
2185
 
2185
2186
  /**
2186
2187
  * @since 1.20.0
2187
2188
  */
2188
- export function drainLayer<FXS extends ReadonlyArray<Fx<any, never, any>>>(...fxs: FXS): Layer.Layer<
2189
- Exclude<Fx.Context<FXS[number]>, Scope.Scope>,
2190
- never,
2191
- never
2192
- > {
2189
+ export function drainLayer<FXS extends ReadonlyArray<Fx<any, never, any>>>(
2190
+ ...fxs: FXS
2191
+ ): Layer.Layer<never, never, Exclude<Fx.Context<FXS[number]>, Scope.Scope>> {
2193
2192
  return Layer.scopedDiscard(Effect.forkWithErrorHandler(core.drain(core.mergeAll(fxs)), Effect.logError))
2194
2193
  }
2195
2194
 
2196
2195
  /**
2197
2196
  * @since 1.20.0
2198
2197
  */
2199
- export const fork = <R, E, A>(fx: Fx<R, E, A>): Effect.Effect<R, never, Fiber.RuntimeFiber<E, void>> =>
2198
+ export const fork = <A, E, R>(fx: Fx<A, E, R>): Effect.Effect<Fiber.RuntimeFiber<void, E>, never, R> =>
2200
2199
  Effect.fork(drain(fx))
2201
2200
 
2202
2201
  /**
2203
2202
  * @since 1.20.0
2204
2203
  */
2205
- export const forkScoped = <R, E, A>(
2206
- fx: Fx<R, E, A>
2207
- ): Effect.Effect<R | Scope.Scope, never, Fiber.RuntimeFiber<E, void>> => Effect.forkScoped(drain(fx))
2204
+ export const forkScoped = <A, E, R>(
2205
+ fx: Fx<A, E, R>
2206
+ ): Effect.Effect<Fiber.RuntimeFiber<void, E>, never, R | Scope.Scope> => Effect.forkScoped(drain(fx))
2208
2207
 
2209
2208
  /**
2210
2209
  * @since 1.20.0
2211
2210
  */
2212
- export const forkDaemon = <R, E, A>(fx: Fx<R, E, A>): Effect.Effect<R, never, Fiber.RuntimeFiber<E, void>> =>
2211
+ export const forkDaemon = <A, E, R>(fx: Fx<A, E, R>): Effect.Effect<Fiber.RuntimeFiber<void, E>, never, R> =>
2213
2212
  Effect.forkDaemon(drain(fx))
2214
2213
 
2215
2214
  /**
2216
2215
  * @since 1.20.0
2217
2216
  */
2218
2217
  export const forkIn: {
2219
- (scope: Scope.Scope): <R, E, A>(fx: Fx<R, E, A>) => Effect.Effect<R, never, Fiber.RuntimeFiber<E, void>>
2220
- <R, E, A>(fx: Fx<R, E, A>, scope: Scope.Scope): Effect.Effect<R, never, Fiber.RuntimeFiber<E, void>>
2221
- } = dual(2, <R, E, A>(
2222
- fx: Fx<R, E, A>,
2218
+ (scope: Scope.Scope): <A, E, R>(fx: Fx<A, E, R>) => Effect.Effect<Fiber.RuntimeFiber<void, E>, never, R>
2219
+ <A, E, R>(fx: Fx<A, E, R>, scope: Scope.Scope): Effect.Effect<Fiber.RuntimeFiber<void, E>, never, R>
2220
+ } = dual(2, <A, E, R>(
2221
+ fx: Fx<A, E, R>,
2223
2222
  scope: Scope.Scope
2224
- ): Effect.Effect<R, never, Fiber.RuntimeFiber<E, void>> => Effect.forkIn(drain(fx), scope))
2223
+ ): Effect.Effect<Fiber.RuntimeFiber<void, E>, never, R> => Effect.forkIn(drain(fx), scope))
2225
2224
 
2226
2225
  /**
2227
2226
  * @since 1.20.0
2228
2227
  */
2229
- export const fromAsyncIterable: <A>(iterable: AsyncIterable<A>) => Fx<never, never, A> = core.fromAsyncIterable
2228
+ export const fromAsyncIterable: <A>(iterable: AsyncIterable<A>) => Fx<A> = core.fromAsyncIterable
2230
2229
 
2231
2230
  /**
2232
2231
  * @since 1.20.0
@@ -2234,15 +2233,15 @@ export const fromAsyncIterable: <A>(iterable: AsyncIterable<A>) => Fx<never, nev
2234
2233
  export const partitionMap: {
2235
2234
  <A, B, C>(
2236
2235
  f: (a: A) => Either.Either<B, C>
2237
- ): <R, E>(fx: Fx<R, E, A>) => readonly [Fx<Scope.Scope | R, E, B>, Fx<Scope.Scope | R, E, C>]
2238
- <R, E, A, B, C>(
2239
- fx: Fx<R, E, A>,
2236
+ ): <E, R>(fx: Fx<A, E, R>) => readonly [Fx<B, E, Scope.Scope | R>, Fx<C, E, Scope.Scope | R>]
2237
+ <A, E, R, B, C>(
2238
+ fx: Fx<A, E, R>,
2240
2239
  f: (a: A) => Either.Either<B, C>
2241
- ): readonly [Fx<Scope.Scope | R, E, B>, Fx<Scope.Scope | R, E, C>]
2242
- } = dual(2, function partitionMap<R, E, A, B, C>(
2243
- fx: Fx<R, E, A>,
2240
+ ): readonly [Fx<B, E, Scope.Scope | R>, Fx<C, E, Scope.Scope | R>]
2241
+ } = dual(2, function partitionMap<A, E, R, B, C>(
2242
+ fx: Fx<A, E, R>,
2244
2243
  f: (a: A) => Either.Either<B, C>
2245
- ): readonly [Fx<R | Scope.Scope, E, B>, Fx<R | Scope.Scope, E, C>] {
2244
+ ): readonly [Fx<B, E, R | Scope.Scope>, Fx<C, E, R | Scope.Scope>] {
2246
2245
  const source = coreShare.multicast(core.map(fx, f))
2247
2246
 
2248
2247
  return [
@@ -2257,9 +2256,9 @@ export const partitionMap: {
2257
2256
  export const gen: <Y extends Effect.EffectGen<any, any, any>, FX extends Fx<any, any, any>>(
2258
2257
  f: (_: Effect.Adapter) => Generator<Y, FX, any>
2259
2258
  ) => Fx<
2260
- Effect.Effect.Context<Y["value"]> | Fx.Context<FX>,
2259
+ Fx.Success<FX>,
2261
2260
  Effect.Effect.Error<Y["value"]> | Fx.Error<FX>,
2262
- Fx.Success<FX>
2261
+ Effect.Effect.Context<Y["value"]> | Fx.Context<FX>
2263
2262
  > = core.gen
2264
2263
 
2265
2264
  /**
@@ -2268,40 +2267,40 @@ export const gen: <Y extends Effect.EffectGen<any, any, any>, FX extends Fx<any,
2268
2267
  export const genScoped: <Y extends Effect.EffectGen<any, any, any>, FX extends Fx<any, any, any>>(
2269
2268
  f: (_: Effect.Adapter) => Generator<Y, FX, any>
2270
2269
  ) => Fx<
2271
- Exclude<Effect.Effect.Context<Y["value"]> | Fx.Context<FX>, Scope.Scope>,
2270
+ Fx.Success<FX>,
2272
2271
  Effect.Effect.Error<Y["value"]> | Fx.Error<FX>,
2273
- Fx.Success<FX>
2272
+ Exclude<Effect.Effect.Context<Y["value"]> | Fx.Context<FX>, Scope.Scope>
2274
2273
  > = core.genScoped
2275
2274
 
2276
2275
  /**
2277
2276
  * @since 1.20.0
2278
2277
  */
2279
2278
  export const findFirst: {
2280
- <A, B extends A>(refinement: Predicate.Refinement<A, B>): <R, E>(fx: Fx<R, E, A>) => Effect.Effect<R, E, B>
2281
- <A>(predicate: Predicate.Predicate<A>): <R, E>(fx: Fx<R, E, A>) => Effect.Effect<R, E, A>
2282
- <R, E, A, B extends A>(fx: Fx<R, E, A>, refinement: Predicate.Refinement<A, B>): Effect.Effect<R, E, B>
2283
- <R, E, A>(fx: Fx<R, E, A>, predicate: Predicate.Predicate<A>): Effect.Effect<R, E, A>
2279
+ <A, B extends A>(refinement: Predicate.Refinement<A, B>): <E, R>(fx: Fx<A, E, R>) => Effect.Effect<B, E, R>
2280
+ <A>(predicate: Predicate.Predicate<A>): <E, R>(fx: Fx<A, E, R>) => Effect.Effect<A, E, R>
2281
+ <A, E, R, B extends A>(fx: Fx<A, E, R>, refinement: Predicate.Refinement<A, B>): Effect.Effect<B, E, R>
2282
+ <A, E, R>(fx: Fx<A, E, R>, predicate: Predicate.Predicate<A>): Effect.Effect<A, E, R>
2284
2283
  } = dual(2, core.findFirst)
2285
2284
 
2286
2285
  /**
2287
2286
  * @since 1.20.0
2288
2287
  */
2289
- export const first: <R, E, A>(fx: Fx<R, E, A>) => Effect.Effect<R, E, A> = core.first
2288
+ export const first: <A, E, R>(fx: Fx<A, E, R>) => Effect.Effect<A, E, R> = core.first
2290
2289
 
2291
2290
  /**
2292
2291
  * @since 1.20.0
2293
2292
  */
2294
2293
  export const mergeFirst: {
2295
- <R2, E2, B>(that: Fx<R2, E2, B>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A | B>
2296
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, that: Fx<R2, E2, B>): Fx<R | R2, E | E2, A>
2294
+ <B, E2, R2>(that: Fx<B, E2, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | B, E | E2, R | R2>
2295
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, that: Fx<B, E2, R2>): Fx<A, E | E2, R | R2>
2297
2296
  } = dual(2, core.mergeFirst)
2298
2297
 
2299
2298
  /**
2300
2299
  * @since 1.20.0
2301
2300
  */
2302
2301
  export const mergeRace: {
2303
- <R2, E2, B>(that: Fx<R2, E2, B>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A | B>
2304
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, that: Fx<R2, E2, B>): Fx<R | R2, E | E2, A | B>
2302
+ <B, E2, R2>(that: Fx<B, E2, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | B, E | E2, R | R2>
2303
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, that: Fx<B, E2, R2>): Fx<A | B, E | E2, R | R2>
2305
2304
  } = dual(2, core.mergeRace)
2306
2305
 
2307
2306
  /**
@@ -2309,54 +2308,54 @@ export const mergeRace: {
2309
2308
  */
2310
2309
  export const raceAll: <const FX extends ReadonlyArray<Fx<any, any, any>>>(
2311
2310
  fx: FX
2312
- ) => Fx<Fx.Context<FX[number]>, Fx.Error<FX[number]>, Fx.Success<FX[number]>> = core.raceAll
2311
+ ) => Fx<Fx.Success<FX[number]>, Fx.Error<FX[number]>, Fx.Context<FX[number]>> = core.raceAll
2313
2312
 
2314
2313
  /**
2315
2314
  * @since 1.20.0
2316
2315
  */
2317
2316
  export const race: {
2318
- <R2, E2, B>(that: Fx<R2, E2, B>): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | R2, E | E2, A | B>
2319
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, that: Fx<R2, E2, B>): Fx<R | R2, E | E2, A | B>
2317
+ <B, E2, R2>(that: Fx<B, E2, R2>): <A, E, R>(fx: Fx<A, E, R>) => Fx<A | B, E | E2, R | R2>
2318
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, that: Fx<B, E2, R2>): Fx<A | B, E | E2, R | R2>
2320
2319
  } = dual(2, core.race)
2321
2320
 
2322
2321
  /**
2323
2322
  * @since 1.20.0
2324
2323
  */
2325
2324
  export const snapshot: {
2326
- <R, E, B, A, C>(sampled: Fx<R, E, B>, g: (a: A, b: B) => C): <R2, E2>(fx: Fx<R2, E2, A>) => Fx<R | R2, E | E2, C>
2327
- <R, E, A, R2, E2, B, C>(fx: Fx<R, E, A>, sampled: Fx<R2, E2, B>, f: (a: A, b: B) => C): Fx<R | R2, E | E2, C>
2325
+ <B, E, R, A, C>(sampled: Fx<B, E, R>, g: (a: A, b: B) => C): <E2, R2>(fx: Fx<A, E2, R2>) => Fx<C, E | E2, R | R2>
2326
+ <A, E, R, B, E2, R2, C>(fx: Fx<A, E, R>, sampled: Fx<B, E2, R2>, f: (a: A, b: B) => C): Fx<C, E | E2, R | R2>
2328
2327
  } = dual(3, core.snapshot)
2329
2328
 
2330
2329
  /**
2331
2330
  * @since 1.20.0
2332
2331
  */
2333
2332
  export const sample: {
2334
- <R, E, B>(sampled: Fx<R, E, B>): <R2, E2, A>(fx: Fx<R2, E2, A>) => Fx<R | R2, E | E2, B>
2335
- <R, E, A, R2, E2, B>(fx: Fx<R, E, A>, sampled: Fx<R2, E2, B>): Fx<R | R2, E | E2, B>
2333
+ <B, E, R>(sampled: Fx<B, E, R>): <E2, R2, A>(fx: Fx<A, E2, R2>) => Fx<B, E | E2, R | R2>
2334
+ <A, E, R, B, E2, R2>(fx: Fx<A, E, R>, sampled: Fx<B, E2, R2>): Fx<B, E | E2, R | R2>
2336
2335
  } = dual(2, core.sample)
2337
2336
 
2338
2337
  /**
2339
2338
  * @since 1.20.0
2340
2339
  */
2341
2340
  export const snapshotEffect: {
2342
- <R2, E2, B, A, R3, E3, C>(sampled: Fx<R2, E2, B>, g: (a: A, b: B) => Effect.Effect<R3, E3, C>): <R, E>(
2343
- fx: Fx<R, E, A>
2344
- ) => Fx<R | R2 | R3, E | E2 | E3, C>
2345
- <R, E, A, R2, E2, B, R3, E3, C>(
2346
- fx: Fx<R, E, A>,
2347
- sampled: Fx<R2, E2, B>,
2348
- f: (a: A, b: B) => Effect.Effect<R3, E3, C>
2349
- ): Fx<R | R2 | R3, E | E2 | E3, C>
2341
+ <B, E2, R2, A, C, E3, R3>(sampled: Fx<B, E2, R2>, g: (a: A, b: B) => Effect.Effect<C, E3, R3>): <E, R>(
2342
+ fx: Fx<A, E, R>
2343
+ ) => Fx<C, E | E2 | E3, R | R2 | R3>
2344
+ <A, E, R, B, E2, R2, C, E3, R3>(
2345
+ fx: Fx<A, E, R>,
2346
+ sampled: Fx<B, E2, R2>,
2347
+ f: (a: A, b: B) => Effect.Effect<C, E3, R3>
2348
+ ): Fx<C, E | E2 | E3, R | R2 | R3>
2350
2349
  } = dual(3, core.snapshotEffect)
2351
2350
 
2352
2351
  const if_: {
2353
- <R2, E2, B, R3, E3, C>(options: { readonly onTrue: Fx<R2, E2, B>; readonly onFalse: Fx<R3, E3, C> }): <R, E>(
2354
- bool: Fx<R, E, boolean>
2355
- ) => Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, B | C>
2356
- <R, E, R2, E2, B, R3, E3, C>(
2357
- bool: Fx<R, E, boolean>,
2358
- options: { readonly onTrue: Fx<R2, E2, B>; readonly onFalse: Fx<R3, E3, C> }
2359
- ): Fx<R | R2 | R3 | Scope.Scope, E | E2 | E3, B | C>
2352
+ <B, E2, R2, C, E3, R3>(options: { readonly onTrue: Fx<B, E2, R2>; readonly onFalse: Fx<C, E3, R3> }): <E, R>(
2353
+ bool: Fx<boolean, E, R>
2354
+ ) => Fx<B | C, E | E2 | E3, R | R2 | R3 | Scope.Scope>
2355
+ <B, E, R, E2, R2, C, E3, R3>(
2356
+ bool: Fx<boolean, E, R>,
2357
+ options: { readonly onTrue: Fx<B, E2, R2>; readonly onFalse: Fx<C, E3, R3> }
2358
+ ): Fx<B | C, E | E2 | E3, R | R2 | R3 | Scope.Scope>
2360
2359
  } = dual(2, core.if)
2361
2360
 
2362
2361
  export {
@@ -2372,19 +2371,19 @@ export {
2372
2371
  export const when: {
2373
2372
  <B, C>(
2374
2373
  options: { readonly onTrue: B; readonly onFalse: C }
2375
- ): <R, E>(bool: Fx<R, E, boolean>) => Fx<R | Scope.Scope, E, B | C>
2376
- <R, E, B, C>(
2377
- bool: Fx<R, E, boolean>,
2374
+ ): <E, R>(bool: Fx<boolean, E, R>) => Fx<B | C, E, R | Scope.Scope>
2375
+ <B, E, R, C>(
2376
+ bool: Fx<boolean, E, R>,
2378
2377
  options: { readonly onTrue: B; readonly onFalse: C }
2379
- ): Fx<R | Scope.Scope, E, B | C>
2378
+ ): Fx<B | C, E, R | Scope.Scope>
2380
2379
  } = dual(2, core.when)
2381
2380
 
2382
2381
  /**
2383
2382
  * @since 1.20.0
2384
2383
  */
2385
- export const withEmitter = <E, A, R = never, E2 = never>(
2386
- f: (emitter: Emitter.Emitter<E, A>) => Effect.Effect<R, E2, unknown>
2387
- ): Fx<R | Scope.Scope, E | E2, A> => core.make<R | Scope.Scope, E | E2, A>((sink) => Emitter.withEmitter(sink, f))
2384
+ export const withEmitter = <A, E = never, E2 = never, R = never>(
2385
+ f: (emitter: Emitter.Emitter<A, E>) => Effect.Effect<unknown, E2, R>
2386
+ ): Fx<A, E | E2, R | Scope.Scope> => core.make<A, E | E2, R | Scope.Scope>((sink) => Emitter.withEmitter(sink, f))
2388
2387
 
2389
2388
  /**
2390
2389
  * Create an Fx which will wait a specified duration of time where no
@@ -2392,9 +2391,9 @@ export const withEmitter = <E, A, R = never, E2 = never>(
2392
2391
  * @since 1.18.0
2393
2392
  */
2394
2393
  export const delay: {
2395
- (delay: DurationInput): <R, E, A>(fx: Fx<R, E, A>) => Fx<R | Scope.Scope, E, A>
2396
- <R, E, A>(fx: Fx<R, E, A>, delay: DurationInput): Fx<R | Scope.Scope, E, A>
2397
- } = dual(2, function<R, E, A>(fx: Fx<R, E, A>, delay: DurationInput): Fx<R | Scope.Scope, E, A> {
2394
+ (delay: DurationInput): <A, E, R>(fx: Fx<A, E, R>) => Fx<A, E, R | Scope.Scope>
2395
+ <A, E, R>(fx: Fx<A, E, R>, delay: DurationInput): Fx<A, E, R | Scope.Scope>
2396
+ } = dual(2, function<A, E, R>(fx: Fx<A, E, R>, delay: DurationInput): Fx<A, E, R | Scope.Scope> {
2398
2397
  return core.flatMap(fx, (a) => core.fromEffect(Effect.delay(Effect.succeed(a), delay)))
2399
2398
  })
2400
2399
 
@@ -2402,20 +2401,20 @@ export const delay: {
2402
2401
  * @since 1.20.0
2403
2402
  */
2404
2403
  export const ensuring: {
2405
- <R2>(finalizer: Effect.Effect<R2, never, unknown>): <R, E, A>(self: Fx<R, E, A>) => Fx<R | R2, E, A>
2406
- <R, E, A, R2>(self: Fx<R, E, A>, finalizer: Effect.Effect<R2, never, unknown>): Fx<R | R2, E, A>
2407
- } = dual(2, function<R, E, A, R2>(
2408
- self: Fx<R, E, A>,
2409
- finalizer: Effect.Effect<R2, never, unknown>
2410
- ): Fx<R | R2, E, A> {
2404
+ <R2>(finalizer: Effect.Effect<unknown, never, R2>): <A, E, R>(self: Fx<A, E, R>) => Fx<A, E, R | R2>
2405
+ <A, E, R, R2>(self: Fx<A, E, R>, finalizer: Effect.Effect<unknown, never, R2>): Fx<A, E, R | R2>
2406
+ } = dual(2, function<A, E, R, R2>(
2407
+ self: Fx<A, E, R>,
2408
+ finalizer: Effect.Effect<unknown, never, R2>
2409
+ ): Fx<A, E, R | R2> {
2411
2410
  return core.middleware(self, (effect) => Effect.ensuring(effect, finalizer))
2412
2411
  })
2413
2412
 
2414
2413
  /**
2415
2414
  * @since 1.20.0
2416
2415
  */
2417
- export const flip = <R, E, A>(fx: Fx<R, E, A>): Fx<R, A, E> =>
2418
- core.make<R, A, E>((sink) =>
2416
+ export const flip = <A, E, R>(fx: Fx<A, E, R>): Fx<E, A, R> =>
2417
+ core.make<E, A, R>((sink) =>
2419
2418
  fx.run(Sink.make(
2420
2419
  (cause) =>
2421
2420
  Either.match(Cause.failureOrCause(cause), {
@@ -2429,7 +2428,7 @@ export const flip = <R, E, A>(fx: Fx<R, E, A>): Fx<R, A, E> =>
2429
2428
  /**
2430
2429
  * @since 1.20.0
2431
2430
  */
2432
- export const fromNullable = <A>(value: A | null | undefined | void): Fx<never, never, NonNullable<A>> => {
2431
+ export const fromNullable = <A>(value: A | null | undefined | void): Fx<NonNullable<A>> => {
2433
2432
  if (value === null || value === undefined) {
2434
2433
  return core.empty
2435
2434
  } else {
@@ -2440,9 +2439,9 @@ export const fromNullable = <A>(value: A | null | undefined | void): Fx<never, n
2440
2439
  /**
2441
2440
  * @since 1.20.0
2442
2441
  */
2443
- export function fromDequeue<A>(dequeue: Queue.Dequeue<A>): Fx<never, never, A>
2444
- export function fromDequeue<I, A>(dequeue: Ctx.Dequeue<I, A>): Fx<I, never, A>
2445
- export function fromDequeue<I, A>(dequeue: Ctx.Dequeue<I, A> | Queue.Dequeue<A>): Fx<I, never, A> {
2442
+ export function fromDequeue<A>(dequeue: Queue.Dequeue<A>): Fx<A>
2443
+ export function fromDequeue<I, A>(dequeue: Ctx.Dequeue<I, A>): Fx<A, never, I>
2444
+ export function fromDequeue<I, A>(dequeue: Ctx.Dequeue<I, A> | Queue.Dequeue<A>): Fx<A, never, I> {
2446
2445
  return core.make((sink) =>
2447
2446
  Effect.gen(function*(_) {
2448
2447
  while (yield* _(dequeueIsActive(dequeue))) {
@@ -2457,7 +2456,7 @@ export function fromDequeue<I, A>(dequeue: Ctx.Dequeue<I, A> | Queue.Dequeue<A>)
2457
2456
  */
2458
2457
  export function dequeueIsActive<I, A>(
2459
2458
  dequeue: Ctx.Dequeue<I, A> | Queue.Dequeue<A>
2460
- ): Effect.Effect<I, never, boolean> {
2459
+ ): Effect.Effect<boolean, never, I> {
2461
2460
  if (Queue.DequeueTypeId in dequeue) {
2462
2461
  return Effect.sync(() => dequeue.isActive())
2463
2462
  } else {
@@ -2468,9 +2467,9 @@ export function dequeueIsActive<I, A>(
2468
2467
  /**
2469
2468
  * @since 1.20.0
2470
2469
  */
2471
- export function fromPubSub<A>(pubSub: PubSub.PubSub<A>): Fx<Scope.Scope, never, A>
2472
- export function fromPubSub<I, A>(pubSub: Ctx.PubSub<I, A>): Fx<I | Scope.Scope, never, A>
2473
- export function fromPubSub<I, A>(pubSub: Ctx.PubSub<I, A> | PubSub.PubSub<A>): Fx<I | Scope.Scope, never, A> {
2470
+ export function fromPubSub<A>(pubSub: PubSub.PubSub<A>): Fx<A, never, Scope.Scope>
2471
+ export function fromPubSub<I, A>(pubSub: Ctx.PubSub<I, A>): Fx<A, never, I | Scope.Scope>
2472
+ export function fromPubSub<I, A>(pubSub: Ctx.PubSub<I, A> | PubSub.PubSub<A>): Fx<A, never, I | Scope.Scope> {
2474
2473
  return core.acquireUseRelease(
2475
2474
  pubSub.subscribe,
2476
2475
  (q) => fromDequeue(q),
@@ -2481,23 +2480,23 @@ export function fromPubSub<I, A>(pubSub: Ctx.PubSub<I, A> | PubSub.PubSub<A>): F
2481
2480
  /**
2482
2481
  * @since 1.20.0
2483
2482
  */
2484
- export abstract class FxEffectBase<R, E, A, R2, E2, B> extends protos.FxEffectBase<R, E, A, R2, E2, B> {
2485
- private _fx: Fx<R, E, A> | undefined
2483
+ export abstract class FxEffectBase<A, E, R, B, E2, R2> extends protos.FxEffectBase<A, E, R, B, E2, R2> {
2484
+ private _fx: Fx<A, E, R> | undefined
2486
2485
 
2487
2486
  /**
2488
2487
  * @since 1.20.0
2489
2488
  */
2490
- run<R3>(sink: Sink.Sink<R3, E, A>): Effect.Effect<R | R3, never, void> {
2489
+ run<R3>(sink: Sink.Sink<A, E, R3>): Effect.Effect<void, never, R | R3> {
2491
2490
  return (this._fx ||= this.toFx()).run(sink)
2492
2491
  }
2493
2492
 
2494
2493
  /**
2495
2494
  * @since 1.20.0
2496
2495
  */
2497
- abstract toFx(): Fx<R, E, A>
2496
+ abstract toFx(): Fx<A, E, R>
2498
2497
 
2499
2498
  /**
2500
2499
  * @since 1.20.0
2501
2500
  */
2502
- abstract toEffect(): Effect.Effect<R2, E2, B>
2501
+ abstract toEffect(): Effect.Effect<B, E2, R2>
2503
2502
  }