#messagepack #extension #dynamic #pure #binary-data

msgpack_simple

Simplified, easy to use, pure Rust MessagePack implementation focused on handling dynamic data structures

3 stable releases

1.0.2 Aug 29, 2020
1.0.0 Jan 31, 2019

#821 in Data structures

Download history 4411/week @ 2024-06-16 6921/week @ 2024-06-23 6221/week @ 2024-06-30 6472/week @ 2024-07-07 2616/week @ 2024-07-14 5057/week @ 2024-07-21 3621/week @ 2024-07-28 3931/week @ 2024-08-04 7646/week @ 2024-08-11 8974/week @ 2024-08-18 13742/week @ 2024-08-25 7627/week @ 2024-09-01 10055/week @ 2024-09-08 7309/week @ 2024-09-15 9113/week @ 2024-09-22 16700/week @ 2024-09-29

43,803 downloads per month
Used in gibberish

MIT license

55KB
778 lines

Simplified, easy to use, pure Rust MessagePack implementation focused on handling dynamic data structures.

Documentation

Example usage:

use msgpack_simple::{MsgPack, MapElement, Extension};

let message = MsgPack::Map(vec![
    MapElement {
        key: MsgPack::String(String::from("hello")),
        value: MsgPack::Int(42)
    },
    MapElement {
        key: MsgPack::String(String::from("world")),
        value: MsgPack::Array(vec![
            MsgPack::Boolean(true),
            MsgPack::Nil,
            MsgPack::Binary(vec![0x42, 0xff]),
            MsgPack::Extension(Extension {
                type_id: 2,
                value: vec![0x32, 0x4a, 0x67, 0x11]
            })
        ])
    }
]);

let encoded = message.encode(); // encoded is a Vec<u8>
let decoded = MsgPack::parse(&encoded).unwrap();

println!("{}", decoded);
assert_eq!(message, decoded);
assert!(message.is_map());

let mut map = message.as_map().unwrap(); // map is a Vec<MapElement>
let second_element = map.remove(1);

assert!(second_element.key.is_string());
assert_eq!(second_element.key.as_string().unwrap(), "world".to_string());

assert!(second_element.value.is_array());

let mut array = second_element.value.as_array().unwrap(); // array is a Vec<MsgPack>
let nil = array.remove(1);

assert!(nil.is_nil());

This library abstracts MessagePack data into a single MsgPack enum which can correspond to any encodable data type and handle nested data structures dynamically. It's not as performant as static solutions, for that, mneumann's rust-msgpack and 3Hren's RMP crates are recommended, but it is able to parse messages without full prior knowledge of their structure.

For more details, check out the documentation.

Contributing, license, and other stuff

As always, pull requests, bug reports, suggestions, and other kinds of improvements are welcome. Just be respectful towards each other, and maybe run or create tests as appropriate.

msgpack_simple is available under the MIT license.

Dependencies

~140KB