From 9b40c7bd789a3abdeedfd306f3453ba37bed0bf2 Mon Sep 17 00:00:00 2001 From: Jonas Bushart Date: Tue, 13 Feb 2024 22:27:46 +0100 Subject: [PATCH] Replace uses of write! with write_str and write_fmt write! with a single string argument is not properly optimized and using write_str generates better code: https://github.com/serde-rs/serde/pull/2697 https://github.com/rust-lang/rust/pull/121001 --- serde_with/src/de/impls.rs | 4 ++-- serde_with/src/enum_map.rs | 2 +- serde_with/src/key_value_map.rs | 2 +- serde_with/src/utils/duration.rs | 2 +- serde_with/tests/derives/serialize_display.rs | 4 ++-- serde_with/tests/serde_as/enum_map.rs | 2 +- 6 files changed, 8 insertions(+), 8 deletions(-) diff --git a/serde_with/src/de/impls.rs b/serde_with/src/de/impls.rs index 5998b28d..4622c6ae 100644 --- a/serde_with/src/de/impls.rs +++ b/serde_with/src/de/impls.rs @@ -847,7 +847,7 @@ where type Value = S; fn expecting(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result { - write!(formatter, "a string") + formatter.write_str("a string") } fn visit_str(self, value: &str) -> Result @@ -1091,7 +1091,7 @@ where type Value = I; fn expecting(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result { - write!(formatter, "a string") + formatter.write_str("a string") } fn visit_str(self, value: &str) -> Result diff --git a/serde_with/src/enum_map.rs b/serde_with/src/enum_map.rs index bc6f1378..58471d07 100644 --- a/serde_with/src/enum_map.rs +++ b/serde_with/src/enum_map.rs @@ -186,7 +186,7 @@ where type Value = Vec; fn expecting(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result { - write!(formatter, "a map of enum values") + formatter.write_str("a map of enum values") } fn visit_map>(self, map: A) -> Result { diff --git a/serde_with/src/key_value_map.rs b/serde_with/src/key_value_map.rs index 7faaf068..ce0b883d 100644 --- a/serde_with/src/key_value_map.rs +++ b/serde_with/src/key_value_map.rs @@ -188,7 +188,7 @@ where type Value = Vec; fn expecting(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result { - write!(formatter, "a map") + formatter.write_str("a map") } fn visit_map>(self, map: A) -> Result { diff --git a/serde_with/src/utils/duration.rs b/serde_with/src/utils/duration.rs index a0607b18..7d8702fc 100644 --- a/serde_with/src/utils/duration.rs +++ b/serde_with/src/utils/duration.rs @@ -390,7 +390,7 @@ impl<'de> DeserializeAs<'de, DurationSigned> for DurationSeconds type Value = DurationSigned; fn expecting(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result { - write!(formatter, "a string containing a number") + formatter.write_str("a string containing a number") } fn visit_str(self, value: &str) -> Result diff --git a/serde_with/tests/derives/serialize_display.rs b/serde_with/tests/derives/serialize_display.rs index e660fa75..610666e7 100644 --- a/serde_with/tests/derives/serialize_display.rs +++ b/serde_with/tests/derives/serialize_display.rs @@ -1,5 +1,5 @@ use super::*; -use core::fmt; +use core::fmt::{self, Write}; use serde_with::SerializeDisplay; #[derive(Debug, SerializeDisplay)] @@ -10,7 +10,7 @@ struct A { impl fmt::Display for A { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { - write!(f, "->{} <> {}<-", self.a, self.b) + f.write_fmt(format_args!("->{} <> {}<-", self.a, self.b)) } } diff --git a/serde_with/tests/serde_as/enum_map.rs b/serde_with/tests/serde_as/enum_map.rs index c6aa814c..ada33e93 100644 --- a/serde_with/tests/serde_as/enum_map.rs +++ b/serde_with/tests/serde_as/enum_map.rs @@ -9,7 +9,7 @@ fn bytes_debug_readable(bytes: &[u8]) -> String { for &byte in bytes { match byte { non_printable if !(0x20..0x7f).contains(&non_printable) => { - write!(result, "\\x{byte:02x}").unwrap(); + result.write_fmt(format_args!("\\x{byte:02x}")).unwrap(); } b'\\' => result.push_str("\\\\"), _ => {