Struct Patch
A lib help you patch Rust instance, and easy to partial update configures.
Introduction
This crate provides the Patch
trait and an accompanying derive macro.
Deriving Patch
on a struct will generate a struct similar to the original one, but with all fields wrapped in an Option
.
An instance of such a patch struct can be applied onto the original struct, replacing values only if they are set to Some
, leaving them unchanged otherwise.
Quick Example
use Patch;
use ;
Documentation and Examples
Also, you can modify the patch structure by defining #[patch(...)]
attributes on the original struct or fields.
Struct attributes:
#[patch(name = "...")]
: change the name of the generated patch struct.#[patch(attribute(...))]
: add attributes to the generated patch struct.#[patch(attribute(derive(...)))]
: add derives to the generated patch struct.
Field attributes:
#[patch(skip)]
: skip the field in the generated patch struct.#[patch(name = "...")]
: change the type of the field in the generated patch struct.#[patch(attribute(...))]
: add attributes to the field in the generated patch struct.#[patch(attribute(derive(...)))]
: add derives to the field in the generated patch struct.
Please check the traits of document to learn more.
The examples demo following scenarios.
- diff two instance for a patch
- create a patch from json string
- rename the patch structure
- check a patch is empty or not
- add attribute to patch struct
Features
This crate also includes the following optional features:
status
(default): implements thePatchStatus
trait for the patch struct, which provides theis_empty
method.op
(default): provide operators<<
for instance and patch, and+
for patchesstd
(optional):box
: implements thePatch<Box<P>>
trait forT
whereT
implementsPatch<P>
. This let you patch a boxed (or not) struct with a boxed patch.option
: implements thePatch<Option<P>>
trait forOption<T>
whereT
implementsPatch<P>
.T
also needs to implementFrom<P>
. This let you patch structs containing fields with optional values.