commit | 30b3cf7e7606eb9105350535e19fa0fa4f162d39 | [log] [tgz] |
---|---|---|
author | Callum Oakley <c.oakley108@gmail.com> | Mon Dec 31 12:44:41 2018 +0000 |
committer | Callum Oakley <c.oakley108@gmail.com> | Mon Dec 31 12:44:41 2018 +0000 |
tree | 2245fc64d869a36c85f56fa55312e5c044eec535 | |
parent | e855e7d84be0476cf76544400b0195159169a0a7 [diff] |
upgrade to edition 2018
A Rust JSON5 serializer and deserializer which speaks Serde.
Deserialize a JSON5 string with from_str
. Go the other way with to_string
. The serializer is very basic at the moment, it just produces plain old JSON. See the Serde documentation for details on implementing Serialize
and Deserialize
. (Usually it's just a case of sprinkling in some derives.)
The Serde data model is mostly supported, with the exception of bytes and borrowed strings.
Read some config into a struct.
extern crate json5; #[macro_use] extern crate serde_derive; #[derive(Deserialize, Debug, PartialEq)] struct Config { message: String, n: i32, } fn main() { let config = " { // A traditional message. message: 'hello world', // A number for some reason. n: 42, } "; assert_eq!( json5::from_str(config), Ok(Config { message: "hello world".to_string(), n: 42, }), ); }