#macro-derive #macro-helpers #macro #proc-macro #helper #create #inclusive

derive-elves

Writing inclusive derive macros is tedious, this creates provides helper functions that make it easier

3 releases

0.1.2 Mar 26, 2024
0.1.1 Mar 23, 2023
0.1.0 Mar 3, 2023

#173 in Procedural macros

Download history 3/week @ 2024-02-07 9/week @ 2024-02-14 31/week @ 2024-02-21 11/week @ 2024-02-28 4/week @ 2024-03-06 6/week @ 2024-03-13 196/week @ 2024-03-20 241/week @ 2024-03-27 66/week @ 2024-04-03 39/week @ 2024-04-10 55/week @ 2024-04-17 49/week @ 2024-04-24 43/week @ 2024-05-01 55/week @ 2024-05-08

208 downloads per month
Used in 4 crates (2 directly)

MIT license

8KB
81 lines

derive-elves

Writing inclusive derive macros is tedious, this creates provides helper functions that make it easier.

type aware impl

The type_aware_impl function makes it easy to write derive macros that take the generics of the underlying type into consideration.

Example

Considering this simple derive macro.

#[proc_macro_derive(Append)]
pub fn push(input_stream: TokenStream) -> TokenStream {
    let input_type = parse_macro_input!(input_stream as DeriveInput);

    let ident = &input_type.ident;

    type_aware_impl(
        quote! {
            impl<T: Append<T>> Append<T> for #ident {
                fn append(&self, l: T) {
                    todo!()
                }
            }
        },
        &input_type,
    )
}

The the following anotated struct,

#[derive(Append)]
struct Foo<S: ToString> {
    bar: S
}

would expand to this:

struct Foo<S: ToString> {
    bar: S
}

impl<T: Append<T>, S: ToString> Append<T> for Foo<S> {
    fn append(&self, l: T) {
        todo!()
    }
}

The above also works for more complex patterns, like the following:

impl Trait for & #ident
impl Trait for &mut #ident
impl Trait for [#ident]
impl Trait for (#ident, A, B, C)

License: MIT

Dependencies

~325–790KB
~19K SLoC