UNPKG

@hazae41/plume

Version:

Typed async events with sequenced and parallel dispatching

44 lines (40 loc) 1.78 kB
'use strict'; var tslib_es6 = require('../../node_modules/tslib/tslib.es6.cjs'); var signals = require('@hazae41/signals'); var closed = require('./closed.cjs'); var errored = require('./errored.cjs'); async function waitOrThrow(target, type, callback, signal = new AbortController().signal) { const env_1 = { stack: [], error: void 0, hasError: false }; try { const abort = tslib_es6.__addDisposableResource(env_1, signals.Signals.rejectOnAbort(signal), false); const event = tslib_es6.__addDisposableResource(env_1, target.wait(type, callback), false); return await Promise.race([abort.get(), event.get()]); } catch (e_1) { env_1.error = e_1; env_1.hasError = true; } finally { tslib_es6.__disposeResources(env_1); } } async function waitWithCloseAndErrorOrThrow(target, type, callback, signal = new AbortController().signal) { const env_2 = { stack: [], error: void 0, hasError: false }; try { const abort = tslib_es6.__addDisposableResource(env_2, signals.Signals.rejectOnAbort(signal), false); const error = tslib_es6.__addDisposableResource(env_2, errored.rejectOnError(target), false); const close = tslib_es6.__addDisposableResource(env_2, closed.rejectOnClose(target), false); const event = tslib_es6.__addDisposableResource(env_2, target.wait(type, callback), false); return await Promise.race([abort.get(), error.get(), close.get(), event.get()]); } catch (e_2) { env_2.error = e_2; env_2.hasError = true; } finally { tslib_es6.__disposeResources(env_2); } } exports.waitOrThrow = waitOrThrow; exports.waitWithCloseAndErrorOrThrow = waitWithCloseAndErrorOrThrow; //# sourceMappingURL=waiters.cjs.map