Expand description
Efficient binary storage encoding for Müsli.
The storage encoding is partially upgrade safe:
- ✔ Can tolerate missing fields if they are annotated with
#[musli(default)]. - ✗ Cannot skip over extra unrecognized fields.
This means that it’s suitable as a storage format, since the data model only evolves in one place. But unsuitable as a wire format since it cannot allow clients to upgrade independent of each other.
See wire or descriptive for formats which are upgrade stable.
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::storage::to_vec(&Version2 {
name: String::from("Aristotle"),
age: Some(61),
})?;
assert!(musli::storage::decode::<_, Version1>(version2.as_slice()).is_err());
let version1 = musli::storage::to_vec(&Version1 {
name: String::from("Aristotle"),
})?;
let version2: Version2 = musli::storage::decode(version1.as_slice())?;
assert_eq!(version2, Version2 {
name: String::from("Aristotle"),
age: None,
});§Configuring
To tweak the behavior of the storage format you can use the Encoding
type:
use musli::{Encode, Decode};
use musli::mode::Binary;
use musli::options::{self, Options, Integer};
use musli::storage::Encoding;
const OPTIONS: Options = options::new().integer(Integer::Fixed).build();
const CONFIG: Encoding<OPTIONS> = Encoding::new().with_options();
#[derive(Debug, PartialEq, Encode, Decode)]
struct Person<'a> {
name: &'a str,
age: u32,
}
let mut out = Vec::new();
let expected = Person {
name: "Aristotle",
age: 61,
};
CONFIG.encode(&mut out, &expected)?;
let actual = CONFIG.decode(&out[..])?;
assert_eq!(expected, actual);Structs§
Constants§
- OPTIONS
- The default options for the storage encoding.
Functions§
- decode
- Decode the given type
Tfrom the givenReaderusing the defaultEncoding. - encode
- Encode the given value to the given
Writerusing the defaultEncoding. - from_
slice - Decode the given type
Tfrom the given slice using the defaultEncoding. - to_
fixed_ bytes - Encode the given value to a fixed-size bytes using the default
Encoding. - to_
slice - Encode the given value to the given slice using the default
Encodingand return the number of bytes encoded. - to_vec
- Encode the given value to a
Vecusing the defaultEncoding. - to_
writer - Encode the given value to the given
Writeusing the defaultEncoding.
Type Aliases§
- Result
- Convenient result alias for use with
musli::storage.