Crate musli_json
source ·Expand description
JSON support for Müsli suitable for network and usually browser communication.
JSON encoding is fully upgrade stable:
- ✔ Can tolerate missing fields if they are annotated with
#[musli(default)]
. - ✔ Can skip over unknown fields.
use musli::{Encode, Decode};
#[derive(Debug, PartialEq, Encode, Decode)]
struct Version1 {
name: String,
}
#[derive(Debug, PartialEq, Encode, Decode)]
struct Version2 {
name: String,
#[musli(default)]
age: Option<u32>,
}
let version2 = musli_json::to_vec(&Version2 {
name: String::from("Aristotle"),
age: Some(62),
})?;
let version1: Version1 = musli_json::from_slice(version2.as_slice())?;
assert_eq!(version1, Version1 {
name: String::from("Aristotle"),
});
Modules§
Structs§
- Setting up encoding with parameters.
- Error raised during json encoding.
Traits§
- Trait governing how JSON is parsed depending on the kind of buffer provided.
Functions§
- Decode the given type
T
from the given slice using theDEFAULT
configuration. - Decode the given type
T
from the given string using theDEFAULT
configuration. - Encode the given value to a fixed-size bytes using the
DEFAULT
configuration. - to_string
alloc
- to_vec
alloc
- to_writer
std
Type Aliases§
- Convenient result alias for use with
musli_json
.