derive-with

Crates.ioderive-with
lib.rsderive-with
version0.6.1
created_at2023-10-18 16:32:16.070477+00
updated_at2025-05-27 07:53:09.131302+00
description`#[derive(With)]` generates with-constructor for each field in struct.
homepage
repositoryhttps://github.com/systemxlabs/derive-with
max_upload_size
id1006947
size26,144
张林伟 (lewiszlw)

documentation

README

A custom derive implementation for #[derive(With)]

License Crates.io

Get started

1.Generate with-constructor for each field on named struct.

#[derive(With)]
pub struct Foo {
    pub a: i32,
    pub b: String,
}

This will generate code

#[automatically_derived]
impl Foo {
    pub fn with_a(self, a: impl Into<i32>) -> Self {
        Self {
            a: a.into(),
            ..self
        }
    }
    pub fn with_b(self, b: impl Into<String>) -> Self {
        Self {
            b: b.into(),
            ..self
        }
    }
}

2.Generate with-constructor for each field on tuple struct.

#[derive(With)]
pub struct Bar (i32, String);

This will generate code

#[automatically_derived]
impl Bar {
    pub fn with_0(mut self, field_0: impl Into<i32>) -> Self {
        self.0 = field_0.into();
        self
    }
    pub fn with_1(mut self, field_1: impl Into<String>) -> Self {
        self.1 = field_1.into();
        self
    }
}

3.Generate with-constructor for specific fields on named struct.

#[derive(With)]
#[with(a)]
pub struct Foo {
    pub a: i32,
    pub b: String,
}

This will generate code

#[automatically_derived]
impl Foo {
    pub fn with_a(self, a: impl Into<i32>) -> Self {
        Self {
            a: a.into(),
            ..self
        }
    }
}

4.Generate with-constructor for specific fields on tuple struct.

#[derive(With)]
#[with(1)]
pub struct Bar (i32, String);

This will generate code

#[automatically_derived]
impl Bar {
    pub fn with_1(mut self, field_1: impl Into<String>) -> Self {
        self.1 = field_1.into();
        self
    }
}

5.Generate with-constructor for generic fields

#[derive(With, Default)]
pub struct Foo<T: Default, Z: Default>
where
    Z: std::fmt::Debug,
{
    pub a: T,
    pub b: Z,
}

This will generate code

#[automatically_derived]
impl<T: Default, Z: Default> Foo<T, Z>
where
    Z: std::fmt::Debug,
{
    pub fn with_a<WT: Default>(self, a: WT) -> Foo<WT, Z> {
        Foo { a, b: self.b }
    }
    pub fn with_b<WZ: Default>(self, b: WZ) -> Foo<T, WZ>
    where
        WZ: std::fmt::Debug,
    {
        Foo { a: self.a, b }
    }
}

More examples can be found in tests

References

Commit count: 28

cargo fmt