Skip to content

Commit

Permalink
optimize by avoiding second fmt.value() call
Browse files Browse the repository at this point in the history
  • Loading branch information
nyurik committed Feb 9, 2024
1 parent d7e738e commit cd79876
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 39 deletions.
16 changes: 8 additions & 8 deletions impl/src/attr.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ pub struct Attrs<'a> {
#[derive(Clone)]
pub struct Display<'a> {
pub original: &'a Attribute,
pub use_write_str: bool,
pub fmt: LitStr,
pub args: TokenStream,
pub has_bonus_display: bool,
Expand Down Expand Up @@ -103,10 +104,14 @@ fn parse_error_attribute<'a>(attrs: &mut Attrs<'a>, attr: &'a Attribute) -> Resu
return Ok(());
}

let fmt = input.parse()?;
let args = parse_token_expr(input, false)?;
let display = Display {
original: attr,
fmt: input.parse()?,
args: parse_token_expr(input, false)?,
// This will be updated later if format_args are still required (i.e. has braces)
use_write_str: args.is_empty(),
fmt,
args,
has_bonus_display: false,
implied_bounds: Set::new(),
};
Expand Down Expand Up @@ -200,12 +205,7 @@ impl ToTokens for Display<'_> {
// Currently compiler is unable to generate as efficient code for
// write!(f, "text") as it does for f.write_str("text"),
// so handle it here when the literal string has no braces/no args.
let use_write_str = self.args.is_empty() && {
let value = fmt.value();
!value.contains('{') && !value.contains('}')
};

tokens.extend(if use_write_str {
tokens.extend(if self.use_write_str {
quote! {
__formatter.write_str(#fmt)
}
Expand Down
5 changes: 5 additions & 0 deletions impl/src/fmt.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,12 @@ impl Display<'_> {
}
}

if self.use_write_str && fmt.contains('}') {
self.use_write_str = false;
}

while let Some(brace) = read.find('{') {
self.use_write_str = false;
out += &read[..brace + 1];
read = &read[brace + 1..];
if read.starts_with('{') {
Expand Down
61 changes: 30 additions & 31 deletions tests/test_display.rs
Original file line number Diff line number Diff line change
Expand Up @@ -306,14 +306,18 @@ fn test_keyword() {
fn test_str_special_chars() {
#[derive(Error, Debug)]
pub enum Error {
#[error("text")]
Text,
#[error("braces {{}}")]
Braces,
#[error("braces2 \x7B\x7B\x7D\x7D")]
Braces2,
#[error("braces3 \u{7B}\u{7B}\u{7D}\u{7D}")]
Braces3,
#[error("brace left {{")]
BraceLeft,
#[error("brace left 2 \x7B\x7B")]
BraceLeft2,
#[error("brace left 3 \u{7B}\u{7B}")]
BraceLeft3,
#[error("brace right }}")]
BraceRight,
#[error("brace right 2 \x7D\x7D")]
BraceRight2,
#[error("brace right 3 \u{7D}\u{7D}")]
BraceRight3,
#[error(
"new_\
line"
Expand All @@ -323,10 +327,12 @@ line"
Escape24,
}

assert("text", Error::Text);
assert("braces {}", Error::Braces);
assert("braces2 {}", Error::Braces2);
assert("braces3 {}", Error::Braces3);
assert("brace left {", Error::BraceLeft);
assert("brace left 2 {", Error::BraceLeft2);
assert("brace left 3 {", Error::BraceLeft3);
assert("brace right }", Error::BraceRight);
assert("brace right 2 }", Error::BraceRight2);
assert("brace right 3 }", Error::BraceRight3);
assert("new_line", Error::NewLine);
assert("escape24 x", Error::Escape24);
}
Expand All @@ -335,25 +341,18 @@ line"
fn test_raw_str() {
#[derive(Error, Debug)]
pub enum Error {
#[error(r#"raw_text"#)]
Text,
#[error(r#"raw_braces {{}}"#)]
Braces,
#[error(r#"raw_braces2 \x7B\x7D"#)]
Braces2,
#[error(
r#"raw_new_\
line"#
)]
NewLine,
#[error(r#"raw brace left {{"#)]
BraceLeft,
#[error(r#"raw brace left 2 \x7B"#)]
BraceLeft2,
#[error(r#"raw brace right }}"#)]
BraceRight,
#[error(r#"raw brace right 2 \x7D"#)]
BraceRight2,
}

assert(r#"raw_text"#, Error::Text);
assert(r#"raw_braces {}"#, Error::Braces);
assert(r#"raw_braces2 \x7B\x7D"#, Error::Braces2);
assert(
r#"raw_new_\
line"#,
Error::NewLine,
);
assert(r#"raw brace left {"#, Error::BraceLeft);
assert(r#"raw brace left 2 \x7B"#, Error::BraceLeft2);
assert(r#"raw brace right }"#, Error::BraceRight);
assert(r#"raw brace right 2 \x7D"#, Error::BraceRight2);
}

0 comments on commit cd79876

Please # to comment.