UNPKG

@effect-ts/system

Version:

Effect-TS is a zero dependency set of libraries to write highly productive, purely functional TypeScript at scale.

37 lines (33 loc) 1.03 kB
// ets_tracing: off import type * as T from "../../../../Effect/index.js" import type * as M from "../../../../Managed/index.js" import type * as C from "../core.js" import * as RunReduceWhileManagedEffect from "./runReduceWhileManagedEffect.js" /** * Executes an effectful fold over the stream of values. * Returns a Managed value that represents the scope of the stream. */ export function runReduceManagedEffect_<R, R1, E, E1, A, S>( self: C.Stream<R, E, A>, s: S, f: (s: S, a: A) => T.Effect<R1, E1, S> ): M.Managed<R & R1, E | E1, S> { return RunReduceWhileManagedEffect.runReduceWhileManagedEffect_( self, s, (_) => true, f ) } /** * Executes an effectful fold over the stream of values. * Returns a Managed value that represents the scope of the stream. * * @ets_data_first runReduceManagedEffect_ */ export function runReduceManagedEffect<R1, E1, A, S>( s: S, f: (s: S, a: A) => T.Effect<R1, E1, S> ) { return <R, E>(self: C.Stream<R, E, A>) => runReduceManagedEffect_(self, s, f) }