Crate musli_json

source ·
Expand description

github crates.io docs.rs

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§

  • Module that defines Encoding whith allows for customization of the encoding format, and the DEFAULT encoding configuration.

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§

Type Aliases§

  • Convenient result alias for use with musli_json.