5 releases

0.1.5 Mar 22, 2024
0.1.4 Mar 21, 2024
0.1.2 Mar 30, 2023
0.1.1 Feb 13, 2023
0.1.0 Dec 19, 2022

#267 in Procedural macros

Download history 392/week @ 2023-12-18 273/week @ 2023-12-25 541/week @ 2024-01-01 559/week @ 2024-01-08 412/week @ 2024-01-15 435/week @ 2024-01-22 573/week @ 2024-01-29 407/week @ 2024-02-05 519/week @ 2024-02-12 466/week @ 2024-02-19 501/week @ 2024-02-26 321/week @ 2024-03-04 223/week @ 2024-03-11 437/week @ 2024-03-18 239/week @ 2024-03-25 68/week @ 2024-04-01

991 downloads per month

Custom license

40KB
940 lines

prost-serde-derive is a procedural macro for serializing/deserializing structs generated by Prost with Serde.

How to use

When using tonic-build, add type attribute to the structs/enums like following:

fn main() {
    tonic_build::configure()
        .type_attribute("some.proto.SomeStruct", "#[derive(prost_serde_derive::Deserialize, prost_serde_derive::Serialize)]")
        // Add following if you have to allow missing non-nullable fields when deserializing (will be filled with the default value)
        .type_attribute("some.proto.SomeStruct", "#[prost_serde_derive(use_default_for_missing_fields)]")
        // Add following if you have to allow deserializing even if there are type errors
        .type_attribute("some.proto.SomeStruct", "#[prost_serde_derive(omit_type_errors)]")
        // Serializing/deserializing Prost enumerations are also available
        .type_attribute("some.proto.SomeEnum", "#[derive(prost_serde_derive::Deserialize, prost_serde_derive::Serialize)]")
        .compile(...);
}

Make sure to include base64 to your dependencies when bytes type is used in your proto.

Dependencies

~2.5MB
~50K SLoC