@hazae41/plume
Version:
Typed async events with sequenced and parallel dispatching
44 lines (40 loc) • 1.78 kB
JavaScript
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
;