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;
use self::id::*;
use self::tl_read::*;
use self::tl_write::*;
mod bound;
mod dummy;
mod id;
mod internals;
mod scheme_loader;
mod tl_read;
mod tl_write;
#[derive(Copy, Clone, Eq, PartialEq)]
enum Derive {
Write,
Read,
}
#[proc_macro]
pub fn id(input: TokenStream) -> TokenStream {
let meta = {
let input = input.clone();
syn::parse_macro_input!(input as Vec<syn::NestedMeta>)
};
impl_id(&input.into(), &meta)
.unwrap_or_else(to_compile_errors)
.into()
}
#[proc_macro_derive(TlWrite, attributes(tl))]
pub fn derive_tl_write(input: TokenStream) -> TokenStream {
let input = syn::parse_macro_input!(input as syn::DeriveInput);
impl_derive_tl_write(input)
.unwrap_or_else(to_compile_errors)
.into()
}
#[proc_macro_derive(TlRead, attributes(tl))]
pub fn derive_tl_read(input: TokenStream) -> TokenStream {
let input = syn::parse_macro_input!(input as syn::DeriveInput);
impl_derive_tl_read(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)*)
}