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
extern crate proc_macro;

use {
    proc_macro::TokenStream,
    quote::quote,
    syn::{parse_macro_input, DeriveInput},
};

// Since unable to implement TryFrom<ConsumeFailure<T>> for T due to T not being covered, this macro implements that functionality.
/// Makes type able to be T in ConsumeFailure<T>.
#[proc_macro_derive(ConsumeFault)]
pub fn derive_consume_fault(item: TokenStream) -> TokenStream {
    let input = parse_macro_input!(item as DeriveInput);
    let ident = input.ident;
    let (impl_generics, ty_generics, where_clause) = input.generics.split_for_impl();

    let output = quote! {
        #[allow(unused_qualifications)]
        impl #impl_generics core::convert::TryFrom<market::ConsumeFailure<#ident #ty_generics>> for #ident #ty_generics #where_clause {
            type Error = ();

            #[inline]
            #[fehler::throws(())]
            fn try_from(failure: market::ConsumeFailure<Self>) -> Self {
                if let market::ConsumeFailure::Fault(fault) = failure {
                    fault
                } else {
                    fehler::throw!(())
                }
            }
        }
    };

    output.into()
}

// Since unable to implement TryFrom<ProduceFailure<T>> for T due to T not being covered, this macro implements that functionality.
/// Makes type able to be T in ProduceFailure<T>.
#[proc_macro_derive(ProduceFault)]
pub fn derive_produce_fault(item: TokenStream) -> TokenStream {
    let input = parse_macro_input!(item as DeriveInput);
    let ident = input.ident;
    let (impl_generics, ty_generics, where_clause) = input.generics.split_for_impl();

    let output = quote! {
        #[allow(unused_qualifications)]
        impl #impl_generics core::convert::TryFrom<market::ProduceFailure<#ident #ty_generics>> for #ident #ty_generics #where_clause {
            type Error = ();

            #[inline]
            #[fehler::throws(())]
            fn try_from(failure: market::ProduceFailure<Self>) -> Self {
                if let market::ProduceFailure::Fault(fault) = failure {
                    fault
                } else {
                    fehler::throw!(())
                }
            }
        }
    };

    output.into()
}