Crate structype_derive[][src]

This is a derive procedural macro that will let you add custom derive and attributes over structs, enums and unions. This derive will add two impl on the type. The as_string() method returns a json serialized string representation of the type with any meta information annotated with structype_meta("key"=val) attribute, while the print_fields() method will print the same to STDOUT. This macro will panic at compile time if annotated over tuple and unit structs.

Example:

use structype_derive::StrucType;
#[derive(StrucType)]
// #[structype_meta("labelover_ride=name")] This will panic the macro
struct UserStruct {
    #[structype_meta(override_name="Primary ID", order="1")]
    id: i64,
    #[structype_meta(override_name="name", order="0")]
    username: String,
    org: String,
    details: Details,
}

#[derive(StrucType)]
struct Details {
    user_attributes: std::collections::HashMap<String, String>,
}

fn print_struct_fields() {
    UserStruct::print_fields();
    let data = UserStruct::as_string();
    println!("{}", data);
    Details::print_fields();
    let data = Details::as_string();
    println!("{}", data);
}

The above will generate and return a json serialized string representation where the key is the struct’s field name and the value is a HashMap<String, String> of structype_meta’s key-val. If the structype_meta is absent, the field’s associated value would be an empty {}.

Output:

 [
     {
         "id": {
             "override_name": "Primary ID",
             "order": "1"
         }
     },
     {
         "username": {
             "override_name": "name",
             "order": "0"
         }
     },
     {
         "org": {}
     },
     {
         "details": {}
     }
 ]

Derive Macros

StrucType