@effect-ts/system
Version:
Effect-TS is a zero dependency set of libraries to write highly productive, purely functional TypeScript at scale.
40 lines • 2.08 kB
TypeScript
import type * as CL from "../Clock/index.js";
import * as O from "../Option/index.js";
import type { Effect } from "./effect.js";
/**
* Returns an effect that will timeout this effect, returning `None` if the
* timeout elapses before the effect has produced a value; and returning
* `Some` of the produced value otherwise.
*
* If the timeout elapses without producing a value, the running effect
* will be safely interrupted.
*
* WARNING: The effect returned by this method will not itself return until
* the underlying effect is actually interrupted. This leads to more
* predictable resource utilization. If early return is desired, then
* instead of using `timeout(d)(effect)`, use `disconnect(timeout(d)(effect))`,
* which first disconnects the effect's interruption signal before performing
* the timeout, resulting in earliest possible return, before an underlying
* effect has been successfully interrupted.
*
* @ets_data_first timeout_
*/
export declare function timeout(d: number, __trace?: string): <R, E, A>(self: Effect<R, E, A>) => Effect<R & CL.HasClock, E, O.Option<A>>;
/**
* Returns an effect that will timeout this effect, returning `None` if the
* timeout elapses before the effect has produced a value; and returning
* `Some` of the produced value otherwise.
*
* If the timeout elapses without producing a value, the running effect
* will be safely interrupted.
*
* WARNING: The effect returned by this method will not itself return until
* the underlying effect is actually interrupted. This leads to more
* predictable resource utilization. If early return is desired, then
* instead of using `timeout(d)(effect)`, use `disconnect(timeout(d)(effect))`,
* which first disconnects the effect's interruption signal before performing
* the timeout, resulting in earliest possible return, before an underlying
* effect has been successfully interrupted.
*/
export declare function timeout_<R, E, A>(self: Effect<R, E, A>, d: number, __trace?: string): Effect<R & CL.HasClock, E, O.Option<A>>;
//# sourceMappingURL=timeout.d.ts.map