1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
use proc_macro::TokenStream;
use quote::quote;
mod bound;
mod derive_clone;
mod derive_debug;
mod derive_eq;
mod derive_load;
mod derive_store;
mod internals;
#[derive(Copy, Clone, Eq, PartialEq)]
enum Derive {
Debug,
}
#[proc_macro_derive(CustomClone, attributes(bounds))]
pub fn derive_clone(input: TokenStream) -> TokenStream {
let input = syn::parse_macro_input!(input as syn::DeriveInput);
derive_clone::impl_derive(input)
.unwrap_or_else(to_compile_errors)
.into()
}
#[proc_macro_derive(CustomDebug, attributes(debug, bounds))]
pub fn derive_debug(input: TokenStream) -> TokenStream {
let input = syn::parse_macro_input!(input as syn::DeriveInput);
derive_debug::impl_derive(input)
.unwrap_or_else(to_compile_errors)
.into()
}
#[proc_macro_derive(CustomEq, attributes(bounds))]
pub fn derive_eq(input: TokenStream) -> TokenStream {
let input = syn::parse_macro_input!(input as syn::DeriveInput);
derive_eq::impl_derive(input)
.unwrap_or_else(to_compile_errors)
.into()
}
#[proc_macro_derive(Load, attributes(bounds, tlb))]
pub fn derive_load(input: TokenStream) -> TokenStream {
let input = syn::parse_macro_input!(input as syn::DeriveInput);
derive_load::impl_derive(input)
.unwrap_or_else(to_compile_errors)
.into()
}
#[proc_macro_derive(Store, attributes(bounds, tlb))]
pub fn derive_store(input: TokenStream) -> TokenStream {
let input = syn::parse_macro_input!(input as syn::DeriveInput);
derive_store::impl_derive(input)
.unwrap_or_else(to_compile_errors)
.into()
}
fn to_compile_errors(errors: Vec<syn::Error>) -> proc_macro2::TokenStream {
let compile_errors = errors.iter().map(syn::Error::to_compile_error);
quote!(#(#compile_errors)*)
}