#shim #serde #mime

mime_serde_shim

Community Driven Serde Shims

3 releases

Uses old Rust 2015

0.2.2 Nov 23, 2018
0.2.1 Nov 22, 2018
0.2.0 Nov 22, 2018

#1840 in Encoding

Download history 613/week @ 2024-03-16 256/week @ 2024-03-23 371/week @ 2024-03-30 464/week @ 2024-04-06 670/week @ 2024-04-13 335/week @ 2024-04-20 443/week @ 2024-04-27 596/week @ 2024-05-04 540/week @ 2024-05-11 500/week @ 2024-05-18 474/week @ 2024-05-25 318/week @ 2024-06-01 300/week @ 2024-06-08 337/week @ 2024-06-15 373/week @ 2024-06-22 149/week @ 2024-06-29

1,179 downloads per month
Used in 9 crates (4 directly)

MIT license

7KB
126 lines

serde_shims Build Status

Community Driven Serde Shims

Documentation

Many crates prefer to avoid natively providing Serde integration on the basis it could be unstable in the future, be annoying to maintain, or stifles innovation if there is ever a Serde competitor in the Rust serialization world.

However, keeping track of dozens or hundreds of lines of custom shim functions in my own projects has proven to be as much or more frustrating than if I were to add that functionality to those crates directly. The innability to share code between binaries or libraries is especially painful.

So, as a compromise, I present this crate as a way to provide serialize_with/deserialize_with functions or implementation macros for crates without native Serde implementations.

To enable these shims, simply add the crate to your Cargo.toml:

[dependencies]
bitflags_serde_shim = "0.2"
enum_primitive_serde_shim = "0.2"
mime_serde_shim = "0.2"
std_serde_shims = "0.2"

or as a legacy feature-based import with the meta crate:

[dependencies]
serde_shims = { version = "0.2", features = ["std", "mime"] }

If there is a crate you'd like to have a Serde shim for, or would like to contribute your own, feel free to open an issue or pull request!

Dependencies

~140–385KB