From caea7f93f88449d2e30ce3c1f6a0390abd044e60 Mon Sep 17 00:00:00 2001 From: Kornel Date: Tue, 24 Dec 2024 14:50:37 +0000 Subject: [PATCH] Remove invalid /> when content is added to an element #215 --- src/rewritable_units/element.rs | 3 +++ src/rewritable_units/tokens/start_tag.rs | 4 ++++ src/rewriter/mod.rs | 24 ++++++++++++++++++++++++ 3 files changed, 31 insertions(+) diff --git a/src/rewritable_units/element.rs b/src/rewritable_units/element.rs index 784e5103..b3e13cf8 100644 --- a/src/rewritable_units/element.rs +++ b/src/rewritable_units/element.rs @@ -370,6 +370,7 @@ impl<'r, 't, H: HandlerTypes> Element<'r, 't, H> { fn prepend_chunk(&mut self, chunk: StringChunk) { if self.can_have_content { + self.start_tag.set_self_closing_syntax(false); self.start_tag .mutations .mutate() @@ -434,6 +435,7 @@ impl<'r, 't, H: HandlerTypes> Element<'r, 't, H> { fn append_chunk(&mut self, chunk: StringChunk) { if self.can_have_content { + self.start_tag.set_self_closing_syntax(false); self.end_tag_mutations_mut().content_before.push_back(chunk); } } @@ -492,6 +494,7 @@ impl<'r, 't, H: HandlerTypes> Element<'r, 't, H> { fn set_inner_content_chunk(&mut self, chunk: StringChunk) { if self.can_have_content { + self.start_tag.set_self_closing_syntax(false); self.remove_content(); self.start_tag .mutations diff --git a/src/rewritable_units/tokens/start_tag.rs b/src/rewritable_units/tokens/start_tag.rs index 4542f303..a026f6eb 100644 --- a/src/rewritable_units/tokens/start_tag.rs +++ b/src/rewritable_units/tokens/start_tag.rs @@ -117,6 +117,10 @@ impl<'i> StartTag<'i> { self.self_closing } + pub(crate) fn set_self_closing_syntax(&mut self, has_slash: bool) { + self.self_closing = has_slash; + } + /// Inserts `content` before the start tag. /// /// Consequent calls to the method append `content` to the previously inserted content. diff --git a/src/rewriter/mod.rs b/src/rewriter/mod.rs index 73511b61..ac336960 100644 --- a/src/rewriter/mod.rs +++ b/src/rewriter/mod.rs @@ -446,6 +446,30 @@ mod tests { assert_eq!(res, ""); } + #[test] + fn rewrite_incorrect_self_closing() { + let res = rewrite_str::( + "
+

", + RewriteStrSettings { + element_content_handlers: vec![element!("*:not(svg)", |el| { + el.set_attribute("s", if el.is_self_closing() { "y" } else { "n" })?; + el.set_attribute("c", if el.can_have_content() { "y" } else { "n" })?; + el.append("…", ContentType::Text); + Ok(()) + })], + ..RewriteStrSettings::new() + }, + ) + .unwrap(); + + assert_eq!( + res, + r#"
+

"# + ); + } + #[test] fn rewrite_arbitrary_settings() { let res = rewrite_str("Some text", Settings::new()).unwrap();