UNPKG

race-cancellation

Version:

Utilities for using Promise.race([task, cancellation]) for async/await code.

32 lines 1.27 kB
import withDisposableCancel from "./withCancel.js"; /** * Wrap a cancellable async function with a timeout. * * @remarks * * @example * ```js * async function fetchWithTimeout(url, timeoutMs, raceCancel) { * return await withTimeout((raceTimeout) => cancellableFetch(url, raceTimeout), timeoutMs, raceCancel); * } * ``` * * @param cancellableAsync - a {@link CancellableAsyncFn} function * @param milliseconds - a timeout in miliseconds * @param raceCancel - an optional outer scope {@link RaceCancelFn} function that will be combined with the timeout race before being passed to the {@link CancellableAsyncFn} function * @public */ export default function withTimeout(cancellableAsync, milliseconds, raceCancel) { return withDisposableCancel(cancellableAsync, (resolve) => { const id = setTimeout(() => resolve(newTimeoutError(milliseconds)), milliseconds); return () => clearTimeout(id); }, raceCancel); } function newTimeoutError(milliseconds) { const timeoutError = new Error(`The operation timed out after taking longer than ${milliseconds}ms`); timeoutError.name = "TimeoutError"; timeoutError.isCancelled = true; timeoutError.isTimeout = true; return timeoutError; } //# sourceMappingURL=withTimeout.js.map