#meta #syn #struct #parse #parser #to-tokens

syn-unnamed-struct

Extends syn expressions and meta structs with unnamed structs and meta lists

1 unstable release

0.1.0 Apr 3, 2022

#2022 in Procedural macros

Download history 128/week @ 2024-03-13 79/week @ 2024-03-20 59/week @ 2024-03-27 63/week @ 2024-04-03 50/week @ 2024-04-10 47/week @ 2024-04-17 69/week @ 2024-04-24 35/week @ 2024-05-01 63/week @ 2024-05-08 59/week @ 2024-05-15 97/week @ 2024-05-22 104/week @ 2024-05-29 64/week @ 2024-06-05 56/week @ 2024-06-12 60/week @ 2024-06-19 45/week @ 2024-06-26

244 downloads per month
Used in derive-from-ext

MIT/Apache

18KB
432 lines

syn_unnamed_struct

Parse and convert structs with no name to tokens. For usage in attribute macro arguments in place of Meta attributes to allow more structured data to be used (nested objects).

Usage in derive macro definition

use syn_unnamed_struct::Meta;

#[proc_macro_derive(CustomMacro, attributes(customMacro))]
pub fn derive(tokens: TokenStream) -> TokenStream {
    let input = parse_macro_input!(tokens);
    
    input.attrs.map(|attr| {
        let obj: Meta = attr.parse().expect("Coult not parse attribute");
        
        //can now interact and extract the properties from the Meta enum
        //...
    });
}

Example macro usage

#[derive(CustomMacro)]
#[customMacro(name="something", other={ entry1: "val1", entry2: "val2" })]
struct MyStruct {
    //...
}

Supported attributes

  • Unnamed structs
#[customMacro({ prop1: 123, prop2: 245 })]
  • Nested unnamed structs
#[customMacro({ prop1: 123, prop2: { prop2a: 123, prop2b: 245 } })]
  • Unnamed struct in Meta value
#[customMacro(prop1=123, prop2={ prop2a: 123, prop2b: 245 })]
  • Unnamed Meta list
#[customMacro(prop1, prop2, (prop3a=123, prop3b=245)))]
  • Nested unnamed Meta lists
#[customMacro(prop1=123, prop2=(prop2a=123, prop2b=245)))]

Notes

  • Cannot use darling since it is entwined with the syn Meta structs

Dependencies

~1.5MB
~35K SLoC