fmt: Skip calling write_str for empty strings #31966
Closed
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.
fmt: Skip calling write_str for empty strings
format_args!
uses one string literal per used{}
, in many cases, theseparating string pieces are empty.
For example,
write!(w, "{}", x);
will attempt to write one emptystring before the
{}
format, andwrite!(w, "{}{}{}", x, y, z);"
willwrite one empty string piece between each format.
Simply skip writing if the string is empty. It is a cheap branch
compared to the virtual Write::write_str call that it makes possible to
skip.
It does not solve issue #10761 in any way, yet that's where I noticed
this. The testcase in the issue shows a performance difference between
write!(w, "abc")
andwrite!(w, "{}", "abc")
, and this change halvesthe size of the difference.