Crates.io | serde_ub_json |
lib.rs | serde_ub_json |
version | 0.1.0 |
source | src |
created_at | 2022-09-03 05:50:01.793032 |
updated_at | 2022-09-03 05:50:01.793032 |
description | UBJSON (Universal Binary JSON) serialization file format |
homepage | |
repository | https://github.com/x2bool/serde_ub_json |
max_upload_size | |
id | 657763 |
size | 94,000 |
serde_ub_json is UBJSON serialization format implementation for Rust/Serde
Structure: this format is structurally equivalent to JSON, and has the same set of data types (numbers, booleans, strings, arrays and objects).
Size: null, true and false values are 75% smaller, large numeric values are ~50% smaller, array and object containers are 1-byte-per-value smaller.
Parsing: boolean and numeric values are not encoded as strings - they are represented as bytes and do not require parsing, strings are byte arrays with length, which means they can always be safely deserialized as string slices without data copying.
cargo add serde_ub_json
Or add as a dependency in Cargo.toml:
[dependencies]
serde_ub_json = "0.1"
use serde::{Deserialize, Serialize};
use serde_ub_json::{Result, to_bytes, from_bytes};
//...
#[derive(Serialize, Deserialize)]
struct Person {
name: String,
age: u8,
}
//...
let p = Person { name: "John Doe", age: 43 };
let bytes = to_bytes(&p)?; // serialize
let person = from_bytes::<'_, Person>(&bytes)?; // deserialize
assert_eq!(p.name, person.name);
assert_eq!(p.age, person.age);
This projects aims to be a complete implementation of UBJSON standard.