dioxus/packages/core-macro/src/lib.rs

100 lines
3 KiB
Rust
Raw Normal View History

2021-02-28 22:30:10 +00:00
use proc_macro::TokenStream;
2021-03-04 17:03:22 +00:00
use quote::ToTokens;
use syn::parse_macro_input;
2021-01-20 17:04:27 +00:00
2021-05-31 22:55:56 +00:00
pub(crate) mod fc;
pub(crate) mod htm;
pub(crate) mod ifmt;
pub(crate) mod props;
2021-06-03 14:42:28 +00:00
pub(crate) mod rsx;
2021-05-31 22:55:56 +00:00
pub(crate) mod rsxtemplate;
pub(crate) mod util;
2021-02-28 22:30:10 +00:00
/// The html! macro makes it easy for developers to write jsx-style markup in their components.
/// We aim to keep functional parity with html templates.
#[proc_macro]
pub fn html(s: TokenStream) -> TokenStream {
2021-03-04 17:03:22 +00:00
match syn::parse::<htm::HtmlRender>(s) {
Err(e) => e.to_compile_error().into(),
Ok(s) => s.to_token_stream().into(),
}
2021-02-28 22:30:10 +00:00
}
2021-03-01 05:16:48 +00:00
/// The html! macro makes it easy for developers to write jsx-style markup in their components.
2021-07-01 18:14:59 +00:00
/// ```
/// rsx! {
/// div {
/// class: "some special class"
/// h1 { "Children too" }
/// }
/// }
/// ```
2021-03-01 05:16:48 +00:00
#[proc_macro]
pub fn rsx(s: TokenStream) -> TokenStream {
2021-06-03 14:42:28 +00:00
match syn::parse::<rsx::RsxRender>(s) {
2021-03-04 17:03:22 +00:00
Err(e) => e.to_compile_error().into(),
Ok(s) => s.to_token_stream().into(),
}
2021-03-01 05:16:48 +00:00
}
2021-05-31 22:55:56 +00:00
/// The html! macro makes it easy for developers to write jsx-style markup in their components.
/// We aim to keep functional parity with html templates.
#[proc_macro]
pub fn rsx_template(s: TokenStream) -> TokenStream {
match syn::parse::<rsxtemplate::RsxTemplate>(s) {
Err(e) => e.to_compile_error().into(),
Ok(s) => s.to_token_stream().into(),
}
}
/// The html! macro makes it easy for developers to write jsx-style markup in their components.
/// We aim to keep functional parity with html templates.
#[proc_macro]
pub fn html_template(s: TokenStream) -> TokenStream {
match syn::parse::<rsxtemplate::RsxTemplate>(s) {
Err(e) => e.to_compile_error().into(),
Ok(s) => s.to_token_stream().into(),
}
}
2021-03-08 02:28:20 +00:00
// #[proc_macro_attribute]
// pub fn fc(attr: TokenStream, item: TokenStream) -> TokenStream {
2021-01-21 07:25:44 +00:00
/// Label a function or static closure as a functional component.
/// This macro reduces the need to create a separate properties struct.
2021-03-08 02:28:20 +00:00
///
/// Using this macro is fun and simple
///
/// ```ignore
///
/// #[fc]
2021-06-26 01:15:33 +00:00
/// fn Example(cx: Context, name: &str) -> VNode {
/// cx.render(rsx! { h1 {"hello {name}"} })
2021-03-08 02:28:20 +00:00
/// }
/// ```
2021-01-21 07:25:44 +00:00
#[proc_macro_attribute]
2021-03-11 00:42:31 +00:00
pub fn fc(_attr: TokenStream, item: TokenStream) -> TokenStream {
2021-03-08 02:28:20 +00:00
match syn::parse::<fc::FunctionComponent>(item) {
Err(e) => e.to_compile_error().into(),
Ok(s) => s.to_token_stream().into(),
}
2021-01-21 07:25:44 +00:00
}
2021-01-20 17:04:27 +00:00
#[proc_macro]
2021-02-28 22:30:10 +00:00
pub fn format_args_f(input: TokenStream) -> TokenStream {
use ifmt::*;
let item = parse_macro_input!(input as IfmtInput);
2021-03-08 02:28:20 +00:00
format_args_f_impl(item)
.unwrap_or_else(|err| err.to_compile_error())
.into()
2021-01-20 17:04:27 +00:00
}
#[proc_macro_derive(Props, attributes(builder))]
pub fn derive_typed_builder(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
let input = parse_macro_input!(input as syn::DeriveInput);
match props::impl_my_derive(&input) {
Ok(output) => output.into(),
Err(error) => error.to_compile_error().into(),
}
}