#messagepack #serialization #serde #byte-buffer

picodata-rmp-serde

Serde bindings for RMP (forked from rmp-serde)

1 stable release

1.0.0 Apr 22, 2024

#610 in Encoding

Download history 184/week @ 2024-04-19 42/week @ 2024-04-26 18/week @ 2024-05-03 77/week @ 2024-05-10 156/week @ 2024-05-17 281/week @ 2024-05-24 353/week @ 2024-05-31 387/week @ 2024-06-07 322/week @ 2024-06-14 324/week @ 2024-06-21 445/week @ 2024-06-28 317/week @ 2024-07-05 251/week @ 2024-07-12 316/week @ 2024-07-19

1,388 downloads per month
Used in 9 crates (2 directly)

MIT license

95KB
2K SLoC

RMP - Rust MessagePack

This is a fork of https://github.com/3Hren/msgpack-rust.

RMP is a pure Rust MessagePack implementation.

Build Status Coverage Status

This repository consists of three separate crates: the RMP core and two implementations to ease serializing and deserializing Rust structs.

crates.rs API Documentation
rmp RMP
rmps RMP Serde
rmpv RMP Value

Features

  • Convenient API

    RMP is designed to be lightweight and straightforward. There are low-level API, which gives you full control on data encoding/decoding process and makes no heap allocations. On the other hand there are high-level API, which provides you convenient interface using Rust standard library and compiler reflection, allowing to encode/decode structures using derive attribute.

  • Zero-copy value decoding

    RMP allows to decode bytes from a buffer in a zero-copy manner easily and blazingly fast, while Rust static checks guarantees that the data will be valid as long as the buffer lives.

  • Clear error handling

    RMP's error system guarantees that you never receive an error enum with unreachable variant.

  • Robust and tested

    This project is developed using TDD and CI, so any found bugs will be fixed without breaking existing functionality.

Requirements

  • Rust 1.53.0 or later

Dependencies

~380–710KB
~13K SLoC