0.1.1 |
|
---|---|
0.1.0 |
|
#11 in #standardized
41KB
852 lines
Serde Multi
This library exposes a standardized API across a number of file formats, as well as providing traits to make it possible to dynamically choose file serialization/deserialization format at runtime or based on generics.
Each file format is toggled via feature, all of which are disabled by default.
Currently the only supported file formats are:
- Bincode (via
bincode
) - CBOR (via
serde_cbor
) - JSON (via
serde_json
) - MessagePack (via
rmp
andrmp-serde
) - RON (via
ron
) - TOML (via
toml
) - XML (via
serde-xml-rs
)
If you would like to add more file formats, feel free to make a pull request.
Example Usage
use serde_multi::{SerdeText, Error};
use serde_multi::formats::json::Json;
use std::collections::HashMap;
let mut value: HashMap<String, i32> = HashMap::new();
value.insert("foo".to_owned(), -193);
value.insert("bar".to_owned(), 3058);
// `Json` can be swapped out for any value that implements `SerdeText` here.
let s = Json.to_string(&value).expect("failed to serialize");
println!("serialized: {}", s);
Dependencies
~0.1–1MB
~20K SLoC