#[macro_use]
extern crate pest_derive;
#[macro_use]
extern crate proc_macro_error;
mod bind;
mod component;
mod css_parser;
mod get_target_dir;
mod html_parser;
mod include_static;
mod js_expression;
mod jsjson;
mod main_wrap;
mod store;
mod trace_tailwind;
mod utils;
mod wasm_path;
use proc_macro::TokenStream;
use quote::quote;
use crate::{
bind::{bind_inner, bind_rc_inner, bind_spawn_inner},
component::component_inner,
css_parser::generate_css_string,
html_parser::{dom_element_inner, dom_inner},
include_static::include_static_inner,
js_expression::js_expression,
main_wrap::main_wrap,
store::store_inner,
trace_tailwind::trace_tailwind,
};
#[proc_macro]
#[proc_macro_error]
pub fn dom(input: TokenStream) -> TokenStream {
dom_inner(input).into()
}
#[proc_macro]
#[proc_macro_error]
pub fn dom_element(input: TokenStream) -> TokenStream {
dom_element_inner(input).into()
}
#[proc_macro]
#[proc_macro_error]
pub fn dom_debug(input: TokenStream) -> TokenStream {
let stream = dom_inner(input);
emit_warning!("debug: {:?}", stream);
stream.into()
}
#[proc_macro]
#[proc_macro_error]
pub fn css_block(input: TokenStream) -> TokenStream {
let (css_str, _, refs) = generate_css_string(input);
let result = quote! {{
#refs
#css_str
}};
result.into()
}
#[proc_macro]
#[proc_macro_error]
pub fn css(input: TokenStream) -> TokenStream {
let (css_str, is_dynamic, refs) = generate_css_string(input);
let result = if is_dynamic {
quote! {{
#refs
vertigo::Css::string(#css_str)
}}
} else {
quote! {
vertigo::Css::str(#css_str)
}
};
result.into()
}
#[proc_macro_derive(AutoJsJson, attributes(js_json))]
#[proc_macro_error]
pub fn auto_js_json(input: TokenStream) -> TokenStream {
let Ok(ast) = syn::parse(input) else {
emit_call_site_error!("Failed to parse input");
return quote! {}.into();
};
match jsjson::impl_js_json_derive(&ast) {
Ok(result) => result,
Err(message) => {
emit_call_site_error!("{}", message);
return quote! {}.into();
}
}
}
#[proc_macro]
#[proc_macro_error]
pub fn tw(input: TokenStream) -> TokenStream {
match trace_tailwind(input) {
Ok(token_stream) => token_stream,
Err(err) => abort_call_site!(err),
}
}
#[proc_macro]
#[proc_macro_error]
pub fn include_static(input: TokenStream) -> TokenStream {
include_static_inner(input)
}
#[proc_macro]
#[proc_macro_error]
pub fn bind(input: TokenStream) -> TokenStream {
convert_to_tokens(bind_inner(input.into()))
}
#[proc_macro]
#[proc_macro_error]
pub fn bind_spawn(input: TokenStream) -> TokenStream {
convert_to_tokens(bind_spawn_inner(input.into()))
}
#[proc_macro]
#[proc_macro_error]
pub fn bind_rc(input: TokenStream) -> TokenStream {
convert_to_tokens(bind_rc_inner(input.into()))
}
#[proc_macro_attribute]
#[proc_macro_error]
pub fn main(_attr: TokenStream, input: TokenStream) -> TokenStream {
main_wrap(input)
}
#[proc_macro_attribute]
#[proc_macro_error]
pub fn component(attrs: TokenStream, input: TokenStream) -> TokenStream {
component_inner(attrs, input)
}
#[proc_macro]
#[proc_macro_error]
pub fn js_inner(input: TokenStream) -> TokenStream {
js_expression(input)
}
fn convert_to_tokens(input: Option<proc_macro2::TokenStream>) -> TokenStream {
match input {
Some(body) => body.into(),
None => quote! {}.into(),
}
}
#[proc_macro_attribute]
#[proc_macro_error]
pub fn store(attr: TokenStream, item: TokenStream) -> TokenStream {
store_inner(attr.into(), item.into())
.unwrap_or_else(|err| err.to_compile_error())
.into()
}