diff --git a/.changeset/dry-badgers-boil.md b/.changeset/dry-badgers-boil.md new file mode 100644 index 00000000000..f8faab1f3f9 --- /dev/null +++ b/.changeset/dry-badgers-boil.md @@ -0,0 +1,5 @@ +--- +"effect": minor +--- + +improve: type Fiber.awaitAll as Exit[]. diff --git a/packages/effect/dtslint/Fiber.ts b/packages/effect/dtslint/Fiber.ts new file mode 100644 index 00000000000..36195d251ed --- /dev/null +++ b/packages/effect/dtslint/Fiber.ts @@ -0,0 +1,16 @@ +import { Fiber } from "effect" + +declare const string: Fiber.Fiber +declare const number: Fiber.Fiber +declare const array: Array | Fiber.Fiber> + +// awaitAll + +// $ExpectType Effect<[Exit, Exit], never, never> +Fiber.awaitAll([string, number]) + +// $ExpectType Effect<(Exit | Exit)[], never, never> +Fiber.awaitAll(new Set([string, number])) + +// $ExpectType Effect<(Exit | Exit)[], never, never> +Fiber.awaitAll(array) diff --git a/packages/effect/src/Fiber.ts b/packages/effect/src/Fiber.ts index d7df138b35f..15f8623a3f9 100644 --- a/packages/effect/src/Fiber.ts +++ b/packages/effect/src/Fiber.ts @@ -275,7 +275,14 @@ export { * @since 2.0.0 * @category destructors */ -export const awaitAll: (fibers: Iterable>) => Effect.Effect = fiberRuntime.fiberAwaitAll +export const awaitAll: >>( + fibers: T +) => Effect.Effect< + [T] extends [ReadonlyArray] + ? number extends T["length"] ? Array ? Exit.Exit : never> + : { -readonly [K in keyof T]: T[K] extends Fiber ? Exit.Exit : never } + : Array ? U extends Fiber ? Exit.Exit : never : never> +> = fiberRuntime.fiberAwaitAll /** * Retrieves the immediate children of the fiber. diff --git a/packages/effect/src/internal/fiberRuntime.ts b/packages/effect/src/internal/fiberRuntime.ts index 6a96fb57b69..c48bfcccf9f 100644 --- a/packages/effect/src/internal/fiberRuntime.ts +++ b/packages/effect/src/internal/fiberRuntime.ts @@ -3288,8 +3288,14 @@ export const currentSupervisor: FiberRef.FiberRef> = // circular with Fiber /* @internal */ -export const fiberAwaitAll = (fibers: Iterable>): Effect.Effect => - core.asVoid(internalFiber._await(fiberAll(fibers))) +export const fiberAwaitAll = >>( + fibers: T +): Effect.Effect< + [T] extends [ReadonlyArray] + ? number extends T["length"] ? Array ? Exit.Exit : never> + : { -readonly [K in keyof T]: T[K] extends Fiber.Fiber ? Exit.Exit : never } + : Array ? U extends Fiber.Fiber ? Exit.Exit : never : never> +> => forEach(fibers, internalFiber._await) as any /** @internal */ export const fiberAll = (fibers: Iterable>): Fiber.Fiber, E> => ({ diff --git a/packages/effect/test/Fiber.test.ts b/packages/effect/test/Fiber.test.ts index e76e8c0c8bd..1bd813ccae8 100644 --- a/packages/effect/test/Fiber.test.ts +++ b/packages/effect/test/Fiber.test.ts @@ -210,7 +210,9 @@ describe("Fiber", () => { it.effect("awaitAll - stack safety", () => Effect.gen(function*($) { const result = yield* $(Fiber.awaitAll(fibers)) - assert.isUndefined(result) + assert.isArray(result) + assert(result.length === fibers.length) + result.forEach((_) => assert.isTrue(Exit.isSuccess(_) && _.value === undefined)) }), 10000) it.effect("joinAll - stack safety", () => Effect.gen(function*($) {