#struct #update #attributes #macro-derive #named #partially #exclude

derive-merge-struct

A derive macro to partially update a named struct

5 releases

new 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

#1316 in Rust patterns

Download history 1/week @ 2024-11-19 48/week @ 2024-12-10 16/week @ 2024-12-17 58/week @ 2025-02-04 132/week @ 2025-02-11 168/week @ 2025-02-18 79/week @ 2025-02-25 248/week @ 2025-03-04

668 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

~195–620KB
~15K SLoC