libdd_trace_utils/msgpack_decoder/decode/
buffer.rs1use crate::msgpack_decoder::decode::error::DecodeError;
5use crate::span::DeserializableTraceData;
6use rmp::decode;
7use rmp::decode::DecodeStringError;
8
9use std::borrow::Borrow;
10use std::ops::Deref;
11
12#[inline]
17pub fn read_string_ref_nomut(buf: &[u8]) -> Result<(&str, &[u8]), DecodeError> {
18 decode::read_str_from_slice(buf).map_err(|e| match e {
19 DecodeStringError::InvalidMarkerRead(e) => DecodeError::InvalidFormat(e.to_string()),
20 DecodeStringError::InvalidDataRead(e) => DecodeError::InvalidConversion(e.to_string()),
21 DecodeStringError::TypeMismatch(marker) => {
22 DecodeError::InvalidType(format!("Type mismatch at marker {marker:?}"))
23 }
24 DecodeStringError::InvalidUtf8(_, e) => DecodeError::Utf8Error(e.to_string()),
25 _ => DecodeError::IOError,
26 })
27}
28
29pub struct Buffer<T: DeserializableTraceData>(T::Bytes);
32
33impl<T: DeserializableTraceData> Buffer<T> {
34 pub fn new(data: T::Bytes) -> Self {
35 Buffer(data)
36 }
37
38 pub fn as_mut_slice(&mut self) -> &mut &'static [u8] {
40 T::get_mut_slice(&mut self.0)
41 }
42
43 pub fn try_slice_and_advance(&mut self, bytes: usize) -> Option<T::Bytes> {
45 T::try_slice_and_advance(&mut self.0, bytes)
46 }
47
48 pub fn read_string(&mut self) -> Result<T::Text, DecodeError> {
53 T::read_string(&mut self.0)
54 }
55}
56
57impl<T: DeserializableTraceData> Deref for Buffer<T> {
58 type Target = [u8];
59
60 fn deref(&self) -> &Self::Target {
61 self.0.borrow()
62 }
63}