facet-postcard-legacy

Crates.iofacet-postcard-legacy
lib.rsfacet-postcard-legacy
version0.36.0
created_at2025-12-29 20:40:22.050172+00
updated_at2025-12-29 20:40:22.050172+00
descriptionLegacy Postcard binary serialization for Facet types - use facet-postcard instead
homepagehttps://facet.rs
repositoryhttps://github.com/facet-rs/facet
max_upload_size
id2011315
size342,794
Amos Wenger (fasterthanlime)

documentation

README

facet-postcard-legacy

Coverage Status crates.io documentation MIT/Apache-2.0 licensed Discord

facet-postcard

Postcard serialization and deserialization for Facet types.

Postcard is a compact, efficient binary serialization format designed for embedded and no_std environments. This crate provides byte-for-byte compatible output with the standard postcard crate, while using Facet's reflection capabilities instead of serde.

Features

  • Compact binary format optimized for size
  • Byte-for-byte compatibility with the postcard crate
  • no_std support with the alloc feature
  • Zero-copy deserialization where possible

Usage

use facet::Facet;
use facet_postcard_legacy::{to_vec, from_slice};

#[derive(Debug, Facet)]
struct Message {
    id: u32,
    payload: Vec<u8>,
}

// Serialize
let msg = Message { id: 42, payload: vec![1, 2, 3] };
let bytes = to_vec(&msg).unwrap();

// Deserialize
let decoded: Message = from_slice(&bytes).unwrap();

For no_std environments without an allocator, use to_slice:

# use facet::Facet;
# #[derive(Debug, Facet)]
# struct Message { id: u32, payload: Vec<u8> }
# let msg = Message { id: 42, payload: vec![1, 2, 3] };
let mut buf = [0u8; 64];
let used = facet_postcard_legacy::to_slice(&msg, &mut buf).unwrap();

Feature Flags

  • std (default): Enables standard library support

  • alloc: Enables heap allocation without full std (for no_std with allocator)

Sponsors

Thanks to all individual sponsors:

GitHub Sponsors Patreon

...along with corporate sponsors:

AWS Zed Depot

...without whom this work could not exist.

Special thanks

The facet logo was drawn by Misiasart.

License

Licensed under either of:

at your option.

Commit count: 3380

cargo fmt