// ets_tracing: off
import * as I from "../Iterable/index.js"
import { chain_, succeed, suspend } from "./core.js"
import type { Effect } from "./effect.js"
/**
* Folds an Iterable[A] using an effectual function f, working sequentially from left to right.
*/
export function reduce_(
i: Iterable,
zero: Z,
f: (z: Z, a: A) => Effect,
__trace?: string
): Effect {
return suspend(
() =>
I.reduce_(i, succeed(zero) as Effect, (acc, el) =>
chain_(acc, (a) => f(a, el))
),
__trace
)
}
/**
* Folds an Iterable[A] using an effectual function f, working sequentially from left to right.
*
* @ets_data_first reduce_
*/
export function reduce(
zero: Z,
f: (z: Z, a: A) => Effect,
__trace?: string
) {
return (i: Iterable) => reduce_(i, zero, f, __trace)
}
/**
* Folds an Iterable[A] using an effectual function f, working sequentially from left to right.
*/
export function reduceRight_(
i: Iterable,
zero: Z,
f: (a: A, z: Z) => Effect,
__trace?: string
): Effect {
return suspend(
() =>
I.reduceRight_(i, succeed(zero) as Effect, (el, acc) =>
chain_(acc, (a) => f(el, a))
),
__trace
)
}
/**
* Folds an Iterable[A] using an effectual function f, working sequentially from left to right.
*
* @ets_data_first reduceRight_
*/
export function reduceRight(
zero: Z,
f: (a: A, z: Z) => Effect,
__trace?: string
) {
return (i: Iterable) => reduceRight_(i, zero, f, __trace)
}