pub trait FixedEncodable {
type EncodeError: Error + Send + Sync + 'static;
type DecodeError: Error + Send + Sync + 'static;
// Required methods
fn encode<B: BufMut>(self, buffer: &mut B) -> Result<(), Self::EncodeError>;
fn decode<B: Buf + Clone>(buffer: B) -> Result<Self, Self::DecodeError>
where Self: Sized;
// Provided method
fn encoded_size(&self) -> Option<usize> { ... }
}
Expand description
An object that can encode and decode itself to and from a buffer, with a fixed representation.
This trait is a companion trait to Encodable
that provides a blanket implementation of
Encodable
that does not use or care about encoding metadata. It fulfills the necessary
methods to work in Encodable
contexts without requiring any of the boilerplate.
§Warning
You should not typically use this trait unless you’re trying to implement Encodable
for
testing purposes where you won’t be dealing with a need for versioning payloads, etc.
For any types that will potentially be encoded in real use cases, Encodable
should be
preferred as it requires an upfront decision to be made about metadata and how it’s dealt with.
Required Associated Types§
type EncodeError: Error + Send + Sync + 'static
type DecodeError: Error + Send + Sync + 'static
Required Methods§
sourcefn encode<B: BufMut>(self, buffer: &mut B) -> Result<(), Self::EncodeError>
fn encode<B: BufMut>(self, buffer: &mut B) -> Result<(), Self::EncodeError>
Attempts to encode this value into the given buffer.
§Errors
If there is an error while attempting to encode this value, an error variant will be returned describing the error.
Practically speaking, based on the API, encoding errors should generally only occur if there is insufficient space in the buffer to fully encode this value. However, this is not guaranteed.
sourcefn decode<B: Buf + Clone>(buffer: B) -> Result<Self, Self::DecodeError>where
Self: Sized,
fn decode<B: Buf + Clone>(buffer: B) -> Result<Self, Self::DecodeError>where
Self: Sized,
Attempts to decode an instance of this type from the given buffer.
§Errors
If there is an error while attempting to decode a value from the given buffer, an error variant will be returned describing the error.
Provided Methods§
sourcefn encoded_size(&self) -> Option<usize>
fn encoded_size(&self) -> Option<usize>
Gets the encoded size, in bytes, of this value, if available.
Not all types can know ahead of time how many bytes they will occupy when encoded, hence the fallibility of this method.