zenoh_codec/core/
encoding.rsuse zenoh_buffers::{
reader::{DidntRead, Reader},
writer::{DidntWrite, Writer},
};
use zenoh_protocol::{
common::imsg,
core::encoding::{flag, Encoding, EncodingId},
};
use crate::{LCodec, RCodec, WCodec, Zenoh080, Zenoh080Bounded};
impl LCodec<&Encoding> for Zenoh080 {
fn w_len(self, x: &Encoding) -> usize {
let mut len = self.w_len((x.id as u32) << 1);
if let Some(schema) = x.schema.as_ref() {
len += self.w_len(schema.as_slice());
}
len
}
}
impl<W> WCodec<&Encoding, &mut W> for Zenoh080
where
W: Writer,
{
type Output = Result<(), DidntWrite>;
fn write(self, writer: &mut W, x: &Encoding) -> Self::Output {
let mut id = (x.id as u32) << 1;
if x.schema.is_some() {
id |= flag::S;
}
let zodec = Zenoh080Bounded::<u32>::new();
zodec.write(&mut *writer, id)?;
if let Some(schema) = x.schema.as_ref() {
let zodec = Zenoh080Bounded::<u8>::new();
zodec.write(&mut *writer, schema)?;
}
Ok(())
}
}
impl<R> RCodec<Encoding, &mut R> for Zenoh080
where
R: Reader,
{
type Error = DidntRead;
fn read(self, reader: &mut R) -> Result<Encoding, Self::Error> {
let zodec = Zenoh080Bounded::<u32>::new();
let id: u32 = zodec.read(&mut *reader)?;
let (id, has_schema) = (
(id >> 1) as EncodingId,
imsg::has_flag(id as u8, flag::S as u8),
);
let mut schema = None;
if has_schema {
let zodec = Zenoh080Bounded::<u8>::new();
schema = Some(zodec.read(&mut *reader)?);
}
let encoding = Encoding { id, schema };
Ok(encoding)
}
}