Crate multi_structs [−] [src]
A macro for generating a merged struct from multiple sub-structs.
Example
#[macro_use] extern crate multi_structs; multi_structs! { /// The merged struct. #[derive(Debug)] struct Merged { /// Foo #[derive(Debug)] foo: struct Foo { /// a a: i32, /// b b: i64, } /// Bar #[derive(Debug)] bar: struct Bar { /// c c: usize, /// d d: String, } } } fn main() { let foo = Foo { a: 1, b: 2 }; let bar = Bar { c: 3, d: "aaa".to_string() }; println!("{:?}, {:?}", foo, bar); let merged = Merged::new(foo, bar); println!("{:?}", merged); let (foo, bar) = merged.split(); println!("{:?}, {:?}", foo, bar); }
See example_generated for
documentation of code generated by the above multi_structs!
expansion.
Visibility
All structs and fields involved are currently pub. This will
likely gets changed in the future.
Attributes
Attributes can be attached to any struct and field involved.
Methods
The following methods are defined for the merged struct:
new: create the new merged struct from multiple sub-structs.split: split the merged struct into the sub-structs.
Modules
| example_generated |
This module shows an example of code generated by the macro. IT MUST NOT BE USED OUTSIDE THIS CRATE. |
Macros
| multi_structs |