#serialization #error #derse

derse

A simple binary serialization protocol for Rust

28 releases

0.1.33 Jan 23, 2025
0.1.32 Jan 20, 2025
0.1.31 Nov 12, 2024
0.1.28 Aug 6, 2024
0.1.4 Apr 25, 2024

#371 in Embedded development

Download history 5/week @ 2025-01-04 4/week @ 2025-01-11 213/week @ 2025-01-18 26/week @ 2025-01-25 15/week @ 2025-02-01 1/week @ 2025-02-08 231/week @ 2025-02-22 828/week @ 2025-03-01 528/week @ 2025-03-08 329/week @ 2025-03-15 178/week @ 2025-03-22 110/week @ 2025-03-29 135/week @ 2025-04-05 152/week @ 2025-04-12 57/week @ 2025-04-19

472 downloads per month
Used in 2 crates

MIT/Apache

64KB
1.5K SLoC

derse

Rust Crates.io Version codecov

A simple binary serialization protocol for Rust.

Usage

To use this library, add the following to your Cargo.toml:

[dependencies]
derse = "0.1"

Then, you can import and use the components as follows:

use derse::{Deserialize, DownwardBytes, Serialize};

// 1. serialization for basic types.
let ser = "hello world!";
let bytes = ser.serialize::<DownwardBytes>().unwrap();
let der = String::deserialize(&bytes[..]).unwrap();
assert_eq!(ser, der);

// 2. serialization for custom structs.
#[derive(Debug, Default, Deserialize, Serialize, PartialEq)]
pub struct Demo {
    a: i32,
    b: String,
    c: Vec<String>,
}
let ser = Demo::default();
let bytes = ser.serialize::<DownwardBytes>().unwrap();
let der = Demo::deserialize(&bytes[..]).unwrap();
assert_eq!(ser, der);

Dependencies

~2.1–3MB
~68K SLoC