#struct #force #exclude #derive

derive-merge-struct

A derive macro to partially update a named struct

5 releases

0.2.3 Mar 12, 2025
0.2.2 Mar 12, 2025
0.2.1 Aug 20, 2024
0.2.0 Aug 20, 2024
0.1.0 Sep 23, 2022

#178 in Procedural macros

Download history 2/week @ 2024-12-04 49/week @ 2024-12-11 13/week @ 2024-12-18 73/week @ 2025-02-05 123/week @ 2025-02-12 241/week @ 2025-02-19 352/week @ 2025-03-05 937/week @ 2025-03-12 107/week @ 2025-03-19

1,475 downloads per month

MIT license

6KB
51 lines

README

The trait is designed for named struct.

  • If the field of struct has attribute #[exclude], this.field remain the same.
  • ElIf the field of struct is not Option: this.field = that.field.clone()
  • ElIf the field of struct has attribute #[force]: this.field = that.field.clone()
  • ElIf the field of struct is Option and doesn't have attribute #[force]:
    • If that.field.is_some(): this.field = that.field.clone()
    • If that.field.is_none(): this.field remain the same.
pub trait MergeProto {
    fn merge_proto(&mut self, another: &Self);
}

#[derive(MergeProto)]
struct TestStruct {
    a: Option<i32>,
    b: Option<String>,
    c: Option<u32>,
    #[force]
    d: Option<i32>,
    #[exclude]
    e: Option<i32>
}
let mut this = TestStruct {
    a: Some(1),
    b: None,
    c: Some(1),
    d: Some(1),
    e: None
};
let that = TestStruct {
    a: Some(2),
    b: Some("hello".to_string()),
    c: None,
    d: None,
    e: Some(1)
};

this.merge_proto(&that);
assert_eq!(this.a, Some(2));
assert_eq!(this.b, Some("hello".to_string()));
assert_eq!(this.c, Some(1));
assert_eq!(this.d, None);
assert_eq!(this.e, None);

Dependencies

~205–640KB
~15K SLoC