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