/** * Do notation for Reader * it allows you to chain multiple Reader computations together * * @example * ```ts * pipe( * Do, * bind('a', () => of(1)), * bind('b', ({ a }) => of(a + 1)), * map(({ a, b }) => a + b), * ) * ``` */ export declare const Do: import("./reader.types").Reader<{}, unknown>; /** * bind an Reader to a name * @param name name of the Reader * @param f function that returns a Reader * @returns Reader with the name binded * * @example * ```ts * pipe( * Do, * bind('a', () => of(1)), * bind('b', ({ a }) => of(a + 1)), * map(({ a, b }) => a + b), * ) * ``` */ export declare const bind: (args_0: A1 extends string ? Exclude : never, args_1: (args_0: A2) => import("./reader.types").Reader) => (args_0: import("./reader.types").Reader) => import("./reader.types").Reader; declare const $let: (args_0: A1 extends string ? Exclude : never, args_1: (args_0: A2) => A3) => (args_0: import("./reader.types").Reader) => import("./reader.types").Reader; export { $let as let };