// ets_tracing: off import { chain_, succeed } from "./core.js" import type { Effect } from "./effect.js" import { map_ } from "./map.js" /** * Binds an effectful value in a `do` scope * * @ets_data_first bind_ */ function bind( tag: Exclude, f: (_: K) => Effect, __trace?: string ) { return ( mk: Effect ): Effect< R & R2, E | E2, K & { [k in N]: A } > => bind_(mk, tag, f, __trace) } /** * Binds an effectful value in a `do` scope */ export function bind_( mk: Effect, tag: Exclude, f: (_: K) => Effect, __trace?: string ): Effect< R & R2, E | E2, K & { [k in N]: A } > { return chain_( mk, (k) => map_( f(k), ( a ): K & { [k in N]: A } => ({ ...k, [tag]: a } as any) ), __trace ) } /** * Like bind for values * * @ets_data_first let_ */ function let__( tag: Exclude, f: (_: K) => A, __trace?: string ) { return ( mk: Effect ): Effect< R2, E2, K & { [k in N]: A } > => let_(mk, tag, f) } /** * Like bind for values */ export function let_( mk: Effect, tag: Exclude, f: (_: K) => A, __trace?: string ): Effect< R2, E2, K & { [k in N]: A } > { return map_( mk, ( k ): K & { [k in N]: A } => ({ ...k, [tag]: f(k) } as any), __trace ) } const do_ = succeed({}) export { let__ as let, bind, do_ as do }