6 releases

Uses old Rust 2015

0.2.2 Dec 19, 2019
0.2.1 Nov 22, 2018
0.1.2 Jun 14, 2018

#1113 in Encoding

Download history 19/week @ 2024-08-05 3/week @ 2024-08-19 19/week @ 2024-08-26 27/week @ 2024-09-02 136/week @ 2024-09-09 51/week @ 2024-09-16 22/week @ 2024-09-23 52/week @ 2024-09-30 42/week @ 2024-10-07 16/week @ 2024-10-14 7/week @ 2024-10-21 35/week @ 2024-10-28 74/week @ 2024-11-04

134 downloads per month

MIT license

10KB
72 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

~180KB