Crates.io | musli-descriptive |
lib.rs | musli-descriptive |
version | 0.0.117 |
source | src |
created_at | 2022-05-24 06:51:14.245138 |
updated_at | 2024-04-20 08:48:30.868151 |
description | A fully self-descriptive format for Müsli. |
homepage | https://github.com/udoprog/musli |
repository | https://github.com/udoprog/musli |
max_upload_size | |
id | 592545 |
size | 77,836 |
A fully self-descriptive format for Müsli.
Descriptive encoding is fully upgrade stable:
#[musli(default)]
.This means that it's suitable as a wire and general interchange format. It's also suitable for dynamically translating to and from different wire formats such as JSON without having access to the data model.
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_descriptive::to_vec(&Version2 {
name: String::from("Aristotle"),
age: Some(62),
})?;
let version1: Version1 = musli_descriptive::decode(version2.as_slice())?;
assert_eq!(version1, Version1 {
name: String::from("Aristotle"),
});
To configure the behavior of the wire format you can use the Encoding
type:
use musli_descriptive::Encoding;
use musli::{Encode, Decode};
const CONFIG: Encoding = Encoding::new();
#[derive(Debug, PartialEq, Encode, Decode)]
struct Struct<'a> {
name: &'a str,
age: u32,
}
let mut out = Vec::new();
let expected = Struct {
name: "Aristotle",
age: 61,
};
CONFIG.encode(&mut out, &expected)?;
let actual = CONFIG.decode(&out[..])?;
assert_eq!(expected, actual);
Each field is prefix typed with a single byte tag that describes exactly the type which is contained in the field.