pub fn from_slice_opaque<'mem>(
poke: Poke<'mem>,
msgpack: &[u8],
) -> Result<Opaque<'mem>, Error>Expand description
Deserializes MessagePack-encoded data into a Facet Partial.
This function takes a MessagePack byte array and populates a Partial object according to the shape description provided by the Partial.
§Example
use facet::Facet;
use facet_msgpack::from_str;
#[derive(Debug, Facet, PartialEq)]
struct User {
id: u64,
username: String,
}
// MessagePack binary data (equivalent to {"id": 42, "username": "user123"})
let msgpack_data = [
0x82, 0xa2, 0x69, 0x64, 0x2a, 0xa8, 0x75, 0x73,
0x65, 0x72, 0x6e, 0x61, 0x6d, 0x65, 0xa7, 0x75,
0x73, 0x65, 0x72, 0x31, 0x32, 0x33
];
let user: User = from_str(&msgpack_data).unwrap();
assert_eq!(user, User { id: 42, username: "user123".to_string() });§Parameters
partial- A mutable reference to a Partial object that will be filled with deserialized datamsgpack- A byte slice containing MessagePack-encoded data
§Returns
Ok(())if deserialization was successfulErr(DecodeError)if an error occurred during deserialization
§MessagePack Format
This implementation follows the MessagePack specification: https://github.com/msgpack/msgpack/blob/master/spec.md