From 69d86c9b28253687bf076f7e31da8246e35d588f Mon Sep 17 00:00:00 2001 From: Michael Howell Date: Thu, 4 Jan 2024 12:28:18 -0700 Subject: [PATCH] Clean up serialization code nits --- src/librustdoc/html/render/mod.rs | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/src/librustdoc/html/render/mod.rs b/src/librustdoc/html/render/mod.rs index 345a47a21b8f7..13be751fe7467 100644 --- a/src/librustdoc/html/render/mod.rs +++ b/src/librustdoc/html/render/mod.rs @@ -132,13 +132,16 @@ pub(crate) struct RenderType { impl RenderType { pub fn write_to_string(&self, string: &mut String) { - if self.generics.is_some() || self.bindings.is_some() { - string.push('{'); + fn write_optional_id(id: Option, string: &mut String) { // 0 is a sentinel, everything else is one-indexed - match self.id { + match id { Some(id) => id.write_to_string(string), None => string.push('`'), } + } + if self.generics.is_some() || self.bindings.is_some() { + string.push('{'); + write_optional_id(self.id, &mut string); string.push('{'); for generic in &self.generics.as_ref().map(Vec::as_slice).unwrap_or_default()[..] { generic.write_to_string(string); @@ -153,18 +156,13 @@ impl RenderType { for constraint in &binding.1[..] { constraint.write_to_string(string); } - string.push('}'); - string.push('}'); + string.push_str("}}"); } string.push('}'); } string.push('}'); } else { - // 0 is a sentinel, everything else is one-indexed - match self.id { - Some(id) => id.write_to_string(string), - None => string.push('`'), - } + write_optional_id(self.id, &mut string); } } }