Fix bug that interrupts error handling early

master
Sven Slootweg 3 years ago
parent 53891f2347
commit 4f89083282

@ -66,20 +66,22 @@ module.exports = function simpleSinkStream(_options) {
return attemptRead(); return attemptRead();
}).catch(isEndOfStream, (error) => { }).catch(isEndOfStream, (error) => {
/* Don't attempt to do another read, we're done. */ /* Don't attempt to do another read, we're done. */
if (!onEndCalled && onEnd != null) { return Promise.try(() => {
onEndCalled = true; if (!onEndCalled && onEnd != null) {
onEndCalled = true;
return Promise.try(() => {
return onEnd(); return Promise.try(() => {
}).then((result) => { return onEnd();
if (result !== undefined) { }).then((result) => {
resultBuffer.push(result); if (result !== undefined) {
} resultBuffer.push(result);
}
});
}
}).then(() => {
return resultBuffer.maybeRead(() => {
throw error;
}); });
}
return resultBuffer.maybeRead(() => {
throw error;
}); });
}).catch((error) => !isAborted(error), (error) => { }).catch((error) => !isAborted(error), (error) => {
return Promise.try(() => { return Promise.try(() => {

Loading…
Cancel
Save