From 301d6098481c59e81a98b884b9672422a11e0b0e Mon Sep 17 00:00:00 2001 From: Chinedu Francis Nwafili Date: Mon, 3 Jun 2024 14:00:50 -0400 Subject: [PATCH] `html!` macro support hyphens in attributes (#199) This commit makes it possible to use hyphenated attribute names when creating elements using the `html!` macro. For example, the following is now possible: ```rust html! { // ... } ``` Before this commit trying to add a "stroke-width" attribute would have led to a compile time error. --- crates/html-macro-test/src/tests/all_tests.rs | 84 ++++----- crates/html-macro/src/parser/open_tag.rs | 12 +- .../html-macro/src/parser/open_tag/event.rs | 4 +- crates/html-macro/src/tag.rs | 162 +++++++++++++----- crates/percy-dom/tests/text.rs | 19 +- .../src/book_example.rs | 4 +- .../virtual-node/src/event/virtual_events.rs | 2 +- .../isomorphic/server/src/actix_server.rs | 7 +- 8 files changed, 187 insertions(+), 107 deletions(-) diff --git a/crates/html-macro-test/src/tests/all_tests.rs b/crates/html-macro-test/src/tests/all_tests.rs index dcbac239..9b6ff367 100644 --- a/crates/html-macro-test/src/tests/all_tests.rs +++ b/crates/html-macro-test/src/tests/all_tests.rs @@ -7,7 +7,7 @@ use html_macro::html; use std::collections::HashMap; -use virtual_node::{IterableNodes, VElement, VText, View, VirtualNode}; +use virtual_node::{AttributeValue, IterableNodes, VElement, VText, View, VirtualNode}; #[must_use] pub(crate) struct HtmlMacroTest { @@ -28,7 +28,7 @@ fn empty_div() { generated: html! {
}, expected: VirtualNode::element("div"), } - .test(); + .test(); } #[test] @@ -43,7 +43,7 @@ fn one_attr() { generated: html! {
}, expected: expected.into(), } - .test(); + .test(); } #[test] @@ -55,7 +55,7 @@ fn child_node() { generated: html! {
}, expected: expected.into(), } - .test(); + .test(); } #[test] @@ -67,7 +67,7 @@ fn sibling_child_nodes() { generated: html! {
}, expected: expected.into(), } - .test(); + .test(); } /// Nested 3 nodes deep @@ -83,16 +83,15 @@ fn three_nodes_deep() { generated: html! {
}, expected: expected.into(), } - .test() + .test() } - // TODO: Requires proc macro APIs that are currently unstable - https://github.com/rust-lang/rust/issues/54725 // #[test] // fn sibling_text_nodes() { // let mut expected = VElement::new("div"); // expected.children = vec![VirtualNode::text("This is a text node")]; -// +// // HtmlMacroTest { // generated: html! {
This is a text node
}, // expected: expected.into(), @@ -116,7 +115,7 @@ fn nested_macro() { }, expected: expected.into(), } - .test(); + .test(); } /// If the first thing we see is a block then we grab whatever is inside it. @@ -132,7 +131,7 @@ fn block_root() { }, expected, } - .test(); + .test(); } // TODO: Requires proc macro APIs that are currently unstable - https://github.com/rust-lang/rust/issues/54725 @@ -140,13 +139,13 @@ fn block_root() { // #[test] // fn text_next_to_block() { // let child = html! { }; -// +// // let mut expected = VElement::new("div"); // expected.children = vec![ // VirtualNode::text(" A bit of text "), // VirtualNode::element("ul"), // ]; -// +// // HtmlMacroTest { // generated: html! { //
@@ -165,7 +164,7 @@ fn block_root() { // #[test] // fn punctuation_token() { // let text = "Hello, World"; -// +// // HtmlMacroTest { // generated: html! { Hello, World }, // expected: VirtualNode::text(text), @@ -184,22 +183,29 @@ fn vec_of_nodes() { generated: html! {
{ children }
}, expected: expected.into(), } - .test(); + .test(); } /// Just make sure that this compiles since as, async, for, loop, and type are keywords #[test] fn keyword_attribute() { - html! { } - ; - html! {