Skip to content

Commit

Permalink
feat: change reduce behavior, when empty iterable
Browse files Browse the repository at this point in the history
  • Loading branch information
ppeeou committed Oct 9, 2023
1 parent ed9cad2 commit 95060d6
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 13 deletions.
15 changes: 6 additions & 9 deletions src/reduce.ts
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,6 @@ async function async<A, B>(
* {@link https://fxts.dev/docs/map | map}, {@link https://fxts.dev/docs/filter | filter}
*/

function reduce<A extends readonly []>(f: Arrow, iterable: A): undefined;

function reduce<A extends readonly [], B>(f: Arrow, seed: B, iterable: A): B;

function reduce<A>(f: (a: A, b: A) => A, iterable: Iterable<A>): A;
Expand Down Expand Up @@ -113,11 +111,7 @@ function reduce<A extends Iterable<unknown> | AsyncIterable<unknown>, B>(
f: (a: B, b: IterableInfer<A>) => B,
seed?: B | Iterable<IterableInfer<A>> | AsyncIterable<IterableInfer<A>>,
iterable?: Iterable<IterableInfer<A>> | AsyncIterable<IterableInfer<A>>,
):
| B
| undefined
| Promise<B | undefined>
| ((iterable: A) => ReturnValueType<A, B>) {
): B | Promise<B> | ((iterable: A) => ReturnValueType<A, B>) {
if (iterable === undefined) {
if (seed === undefined) {
return (iterable: A) =>
Expand All @@ -128,7 +122,7 @@ function reduce<A extends Iterable<unknown> | AsyncIterable<unknown>, B>(
const iterator = seed[Symbol.iterator]();
const { done, value } = iterator.next();
if (done) {
return undefined;
throw new TypeError("'reduce' of empty iterable with no initial value");
}
return sync(f, value as B, {
[Symbol.iterator]() {
Expand All @@ -141,8 +135,11 @@ function reduce<A extends Iterable<unknown> | AsyncIterable<unknown>, B>(
const iterator = seed[Symbol.asyncIterator]();
return iterator.next().then(({ done, value }) => {
if (done) {
return undefined;
throw new TypeError(
"'reduce' of empty iterable with no initial value",
);
}

return async(f, value as Promise<B>, {
[Symbol.asyncIterator]() {
return iterator;
Expand Down
4 changes: 2 additions & 2 deletions test/reduce.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@ describe("reduce", function () {
expect(reduce((a, b) => a + b, "seed", [])).toEqual("seed");
});

it("should return 'undefined' when the given `iterable` is an empty array and initial value is absent", function () {
expect(reduce((a, b) => a + b, [])).toBeUndefined();
it("should be occured error when the given `iterable` is an empty array and initial value is absent", function () {
expect(() => reduce((a) => a, [])).toThrow();
});

it("should work given it is initial value", function () {
Expand Down
4 changes: 2 additions & 2 deletions type-check/reduce.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import * as Test from "../src/types/Test";

const { checks, check } = Test;

const res1 = reduce((a, b) => a + b, []);
const res1 = reduce((a) => a, []);
const res2 = reduce((a, b) => a + b, "seed", []);
const res3 = reduce((a, b) => a + b, 0, [1, 2, 3]);
const res4 = reduce((a, b) => a + b, [1, 2, 3]);
Expand Down Expand Up @@ -52,7 +52,7 @@ const res16 = pipe(
);

checks([
check<typeof res1, undefined, Test.Pass>(),
check<typeof res1, never, Test.Pass>(),
check<typeof res2, "seed", Test.Pass>(),
check<typeof res3, number, Test.Pass>(),
check<typeof res4, number, Test.Pass>(),
Expand Down

0 comments on commit 95060d6

Please sign in to comment.