-
-
Notifications
You must be signed in to change notification settings - Fork 238
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Rewriter with Promises #273
Comments
I actually had a very similar issue recently and worked around it in custom subclass of RewritingStream. If @inikulin doesn't mind, I can upstream my changes. |
For what it's worth, what I did to work around this is subscribed to all the events, but added rewriters to a Promise-based task queue so that ordering of the output would be still preserved. Pseudo-code (without error handling etc.): let queue = Promise.resolve();
function defer(fn) {
// adds function to the queue making sure that it runs only after all the previous have completed
queue = queue.then(fn);
}
rewriter.on('text', (_, raw) => defer(async () => {
let res = await myfunctionPromise(raw);
rewriter.emitRaw(res);
}));
for (let eventName of ['startTag', 'endTag', 'doctype', 'comment']) {
// each event has to be subscribed to and deferred individually or it
// will fall back to emitting as-is synchronously
rewriter.on(eventName, (_, raw) => defer(() => {
rewriter.emitRaw(raw);
}));
}
rewriter.write(html, async () => {
// don't close the stream until all the tasks have finished
await queue;
rewriter.end();
}); |
@RReverser I wonder how idiomatic it is to have async handlers for stream events? If that's a common a practice then I'm all for including support for such a functionality into package. |
It's not common at all (unfortunately), although there have been some discussions. |
@RReverser Maybe it's worth adding your code as receipt in the docs then? |
It's kinda ugly due to need to iterate all events not subscribed yet manually. I wonder if it would be better to add |
As it's not idiomatic I would rather avoid adding support for that to the API. However, I'll be happy to add @RReverser's recipe to the docs. |
Hello
I can't use the HTML rewriting with a Promise
I do have an error:
Error [ERR_STREAM_PUSH_AFTER_EOF]: stream.push() after EOF
This is my code :
with the following code, it's working :
Could you please help me
Vincent
The text was updated successfully, but these errors were encountered: