Skip to main content
Module

x/evt/lib/types/interfaces/Ctx.ts

💧EventEmitter's typesafe replacement
Go to Latest
File
import type { CtxLike } from "./CtxLike.ts";import type { Handler } from "../Handler.ts";import type { NonPostableEvtLike } from "./NonPostableEvtLike.ts";import type { Evt } from "./Evt.ts";
export type DoneOrAborted<Result> = DoneOrAborted.Done<Result> | DoneOrAborted.Aborted<Result>;export namespace DoneOrAborted {
type Common<Result> = { handlers: Handler.WithEvt<any, Result>[]; }
export type Done<Result> = Common<Result> & { type: "DONE"; result: Result; error?: undefined; };
export type Aborted<Result> = Common<Result> & { type: "ABORTED"; error: Error; result?: undefined; };
}

/** https://docs.evt.land/api/ctx */export interface Ctx<Result = void> {
/** https://docs.evt.land/api/ctx#ctx-evtdoneoraborted */ readonly evtDoneOrAborted: Evt<DoneOrAborted<Result>>;
/** * https://docs.evt.land/api/ctx#ctx-evtattach * * Posted every time a handler is bound to this context * */ readonly evtAttach: Evt<Handler.WithEvt<any, Result>>;
/** * https://docs.evt.land/api/ctx#ctx-evtdetach * * Posted every time a handler bound to this context is detached from it's Evt * */ readonly evtDetach: Evt<Handler.WithEvt<any, Result>>;
/** * If .done() of .abort() has been called, returns the result or error of the call. **/ readonly completionStatus: DoneOrAborted<Result> | undefined;
/** * https://docs.evt.land/api/ctx#ctx-waitfor-timeout * * Return a promise that resolve next time ctx.done(result) is invoked * Reject if ctx.abort(error) is invoked. * Optionally a timeout can be passed, if so the returned promise will reject * with EvtError.Timeout if done(result) is not called within [timeout]ms. * If the timeout is reached ctx.abort(timeoutError) will be invoked. */ waitFor(timeout?: number): Promise<Result>;

/** * https://docs.evt.land/api/ctx#ctx-abort-error * * All the handler will be detached. * evtDone will post [ error, undefined, handlers (detached) ] * if getPrDone() was invoked the promise will reject with the error */ abort(error: Error): Handler.WithEvt<any, Result>[];
/** * https://docs.evt.land/api/ctx#ctx-done-result * * Detach all handlers. * evtDone will post [ null, result, handlers (detached) ] * If getPrDone() was invoked the promise will result with result */ done(result: Result): Handler.WithEvt<any, Result>[];

/** https://docs.evt.land/api/ctx#ctx-gethandlers */ getHandlers(): Handler.WithEvt<any, Result>[];
/** * Exposed to enable safe interoperability between mismatching EVT versions. * Should be considered private * */ zz__addHandler<T>( handler: Handler<T, any, CtxLike<Result>>, evt: NonPostableEvtLike<T> ): void;
/** * Exposed to enable safe interoperability between EVT versions. * Should be considered private * */ zz__removeHandler<T>( handler: Handler<T, any, CtxLike<Result>>, ): void;
}