1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
// At lower level I generally prefer to work with slices as more efficient than Read/Write streams
// eg: Read for & [u8] is implemented with memcpy but here is more than enough to just get a
// pointer to the original data
// ANche se enum decode sarebbe faclie da implementare non viene fatto dato che ogni messaggio puo
// essere derivato dal suo numero!
use crate::Error;
pub mod decodable;
pub mod encodable;
mod impls;
#[cfg(feature = "with_buffer_pool")]
use buffer_sv2::Slice;
/// Return the encoded byte size or a `Decodable`
pub trait SizeHint {
fn size_hint(data: &[u8], offset: usize) -> Result<usize, Error>;
fn size_hint_(&self, data: &[u8], offset: usize) -> Result<usize, Error>;
}
/// Return the encoded byte size of an `Encodable` comprehensive of the header, if any
pub trait GetSize {
fn get_size(&self) -> usize;
}
#[cfg(feature = "with_buffer_pool")]
impl GetSize for Slice {
fn get_size(&self) -> usize {
self.len()
}
}
/// Implemented by all the primitives with a fixed size
pub trait Fixed {
const SIZE: usize;
}
pub trait Variable {
const HEADER_SIZE: usize;
//const ELEMENT_SIZE: usize;
const MAX_SIZE: usize;
fn inner_size(&self) -> usize;
// That could be [u8; Self::HEADER_SIZE] but rust do not allow it
fn get_header(&self) -> Vec<u8>;
}
impl<T: Fixed> SizeHint for T {
/// Total size of the encoded data type compreensive of the header when present
fn size_hint(_data: &[u8], _offset: usize) -> Result<usize, Error> {
Ok(Self::SIZE)
}
fn size_hint_(&self, _: &[u8], _offset: usize) -> Result<usize, Error> {
Ok(Self::SIZE)
}
}
impl<T: Fixed> GetSize for T {
fn get_size(&self) -> usize {
Self::SIZE
}
}