Preserve logger reports through translation by encapculating translated output in report_cb #14380
+83
−54
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
The thing that is bothering me and that I'm looking for a way to address is the fact that translators are destructive to the report log messages. Most reports don't survive default translator and are replaced with a chardata, but some logger handlers clearly have a demand for the original report data, since they go as far as parsing chardata to build their own report.
One idea I have is that instead of converting report to chardata, translator could wrap the
report_cb
callback function, since the existing one would be useless after the translation anyway.Some caveats with this approach:
report_cb
can have any performance implications or run into problems with multi-node setup?report_cb
use is a little different from what translator does right now, so there's probably more changes to make here to make it return format string (?).In general I would love to get some feedback on if this is the right way to approach this or if there is even a good way 🙏