From 2919512d47c18a70134d2ad30af4d1218a4eafb7 Mon Sep 17 00:00:00 2001 From: Tristan Cacqueray Date: Sat, 14 Oct 2023 18:38:15 +0000 Subject: [PATCH] Fix some doc sample to make them buildable --- src/fragment.rs | 10 ++++++--- src/macros.rs | 56 ++++++++++++++++++++++++++++++------------------- 2 files changed, 42 insertions(+), 24 deletions(-) diff --git a/src/fragment.rs b/src/fragment.rs index 75c436a..aa6846c 100644 --- a/src/fragment.rs +++ b/src/fragment.rs @@ -139,10 +139,12 @@ impl<'a> FragmentBuilder<'a> { /// /// You can then insert the fragment into a [`DomBuilder`]: /// -/// ```no_compile +/// ```no_run +/// # use dominator::{html, fragment}; +/// # let x = fragment!(); /// html!("div", { /// .fragment(&x) -/// }) +/// }); /// ``` /// /// The fragment is inlined, so it is exactly the same as if you had written this, @@ -183,7 +185,9 @@ impl<'a> FragmentBuilder<'a> { /// /// When returning a fragment from a function, you will usually need to use the `move` syntax: /// -/// ```no_compile +/// ```rust +/// # use dominator::{fragment, Fragment}; +/// # fn some_string() -> String { "".to_string() } /// fn my_fragment() -> impl Fragment { /// let x = some_string(); /// diff --git a/src/macros.rs b/src/macros.rs index a1a41d3..90ff9db 100644 --- a/src/macros.rs +++ b/src/macros.rs @@ -214,7 +214,8 @@ macro_rules! __internal_builder { /// Sometimes you need to access the real DOM node, for example to call /// DOM methods. You can use `with_node!` to do that: /// -/// ```no_compile +/// ```no_run +/// # use dominator::{html, with_node, events}; /// html!("input" => web_sys::HtmlInputElement, { /// .with_node!(element => { /// .event(move |_: events::Input| { @@ -223,7 +224,7 @@ macro_rules! __internal_builder { /// let value = element.value_as_number(); /// }) /// }) -/// }) +/// }); /// ``` #[macro_export] macro_rules! with_node { @@ -579,12 +580,14 @@ macro_rules! __internal_clone_split { /// /// You can achieve the same thing by using the `clone!` macro instead: /// -/// ```no_compile +/// ```no_run +/// # use dominator::{html, events, clone}; +/// # let (app, state, other_state) = (true, true, true); /// html!("div", { /// .event(clone!(app, state, other_state => move |_: events::Click| { /// // Use app, state, and other_state /// })) -/// }) +/// }); /// ``` #[macro_export] macro_rules! clone { @@ -621,35 +624,38 @@ macro_rules! __internal_process_keys { /// /// Instead of writing this... /// -/// ```no_compile +/// ```no_run +/// # use dominator::html; /// html!("div", { /// .attr("foo", "bar") /// .attr("qux", "corge") /// .attr("yes", "no") -/// }) +/// }); /// ``` /// /// ...you can instead write this: /// -/// ```no_compile +/// ```no_run +/// # use dominator::{attrs, html}; /// html!("div", { /// .attrs! { /// foo: "bar", /// qux: "corge", /// yes: "no", /// } -/// }) +/// }); /// ``` /// /// You can also use string literals as keys: /// -/// ```no_compile +/// ```no_run +/// # use dominator::{attrs, html}; /// html!("div", { /// .attrs! { /// foo: "bar", /// "aria-label": "Qux", /// } -/// }) +/// }); /// ``` #[macro_export] macro_rules! attrs { @@ -673,17 +679,20 @@ macro_rules! __internal_attrs { /// /// Instead of writing this... /// -/// ```no_compile +/// ```no_run +/// # use dominator::html; /// html!("div", { /// .prop("foo", "bar") /// .prop("qux", "corge") /// .prop("yes", "no") -/// }) +/// }); /// ``` /// /// ...you can instead write this: /// -/// ```no_compile +/// ```no_run +/// # use dominator::{html, props}; +/// # fn test() -> dominator::Dom { /// html!("div", { /// .props! { /// foo: "bar", @@ -691,17 +700,19 @@ macro_rules! __internal_attrs { /// yes: "no", /// } /// }) +/// # } /// ``` /// /// You can also use string literals as keys: /// -/// ```no_compile +/// ```no_run +/// # use dominator::{html, props}; /// html!("div", { /// .props! { /// foo: "bar", /// "qux-corge": "Qux", /// } -/// }) +/// }); /// ``` #[macro_export] macro_rules! props { @@ -725,35 +736,38 @@ macro_rules! __internal_props { /// /// Instead of writing this... /// -/// ```no_compile +/// ```no_run +/// # use dominator::html; /// html!("div", { /// .style("display", "flex") /// .style("color", "red") /// .style("opacity", "0") -/// }) +/// }); /// ``` /// /// ...you can instead write this: /// -/// ```no_compile +/// ```no_run +/// # use dominator::{html, styles}; /// html!("div", { /// .styles! { /// display: "flex", /// color: "red", /// opacity: "0", /// } -/// }) +/// }); /// ``` /// /// You can also use string literals as keys: /// -/// ```no_compile +/// ```no_run +/// # use dominator::{html, styles}; /// html!("div", { /// .styles! { /// color: "red", /// "background-color": "green", /// } -/// }) +/// }); /// ``` #[macro_export] macro_rules! styles {