core_crypto_macros/
lib.rs1extern crate proc_macro;
2
3use crate::entity_derive::KeyStoreEntity;
4use proc_macro::TokenStream;
5use proc_macro2::Ident;
6use quote::quote;
7use syn::{
8 Attribute, Block, FnArg, ItemFn, ReturnType, Visibility, parse_macro_input, punctuated::Punctuated, token::Comma,
9};
10
11mod durable;
12mod entity_derive;
13mod idempotent;
14
15#[proc_macro_derive(Entity, attributes(entity, id))]
18pub fn derive_entity(input: TokenStream) -> TokenStream {
19 let parsed = parse_macro_input!(input as KeyStoreEntity).flatten();
20 TokenStream::from(quote! { #parsed })
21}
22
23#[proc_macro_attribute]
38pub fn durable(_args: TokenStream, item: TokenStream) -> TokenStream {
39 durable::durable(item)
40}
41
42#[proc_macro_attribute]
49pub fn idempotent(_args: TokenStream, item: TokenStream) -> TokenStream {
50 idempotent::idempotent(item)
51}
52
53#[proc_macro_attribute]
56pub fn dispotent(_args: TokenStream, item: TokenStream) -> TokenStream {
57 idempotent::dispotent(item)
58}
59
60pub(crate) fn doc_attributes(ast: &ItemFn) -> Vec<Attribute> {
61 ast.attrs
62 .iter()
63 .filter(|attr| attr.path().is_ident("doc"))
64 .cloned()
65 .collect::<Vec<syn::Attribute>>()
66}
67
68pub(crate) fn compile_error(mut item: TokenStream, err: syn::Error) -> TokenStream {
69 let compile_err = TokenStream::from(err.to_compile_error());
70 item.extend(compile_err);
71 item
72}
73
74#[allow(clippy::type_complexity)]
75pub(crate) fn items(
76 ast: &ItemFn,
77) -> (
78 &ReturnType,
79 &Ident,
80 &Punctuated<FnArg, Comma>,
81 &Box<Block>,
82 &Vec<Attribute>,
83 &Visibility,
84) {
85 let ret = &ast.sig.output;
86 let name = &ast.sig.ident;
87 let inputs = &ast.sig.inputs;
88 let body = &ast.block;
89 let attrs = &ast.attrs;
90 let vis = &ast.vis;
91 (ret, name, inputs, body, attrs, vis)
92}