websocket_base::codec::ws

Struct DataFrameCodec

Source
pub struct DataFrameCodec<D> { /* private fields */ }
Expand description

A codec for decoding and encoding websocket dataframes.

This codec decodes dataframes into the crates default implementation of Dataframe but can encode and send any struct that implements the ws::Dataframe trait. The type of struct to encode is given by the D type parameter in the struct.

Using dataframes directly is meant for users who want low-level access to the connection. If you don’t want to do anything low-level please use the MessageCodec codec instead, or better yet use the ClientBuilder to make clients and the Server to make servers.

Implementations§

Source§

impl DataFrameCodec<DataFrame>

Source

pub fn default(context: Context) -> Self

Create a new DataFrameCodec struct using the crate’s implementation of dataframes for reading and writing dataframes.

Use this method if you don’t want to provide a custom implementation for your dataframes.

Source§

impl<D> DataFrameCodec<D>

Source

pub fn new(context: Context) -> DataFrameCodec<D>

Create a new DataFrameCodec struct using any implementation of ws::Dataframe you want. This is useful if you want to manipulate the websocket layer very specifically.

If you only want to be able to send and receive the crate’s DataFrame struct use .default(Context) instead.

There is a default dataframe size limit imposed. Use new_with_limits to override it

Source

pub fn new_with_limits( context: Context, max_dataframe_size: usize, ) -> DataFrameCodec<D>

Trait Implementations§

Source§

impl<D> Decoder for DataFrameCodec<D>

Source§

type Item = DataFrame

The type of decoded frames.
Source§

type Error = WebSocketError

The type of unrecoverable frame decoding errors. Read more
Source§

fn decode( &mut self, src: &mut BytesMut, ) -> Result<Option<Self::Item>, Self::Error>

Attempts to decode a frame from the provided buffer of bytes. Read more
Source§

fn decode_eof( &mut self, buf: &mut BytesMut, ) -> Result<Option<Self::Item>, Self::Error>

A default method available to be called when there are no more bytes available to be read from the underlying I/O. Read more
Source§

fn framed<T>(self, io: T) -> Framed<T, Self>
where T: AsyncRead + AsyncWrite, Self: Sized + Encoder,

Provides a Stream and Sink interface for reading and writing to this Io object, using Decode and Encode to read and write the raw data. Read more
Source§

impl<D> Encoder for DataFrameCodec<D>
where D: Borrow<dyn DataFrameTrait>,

Source§

type Item = D

The type of items consumed by the Encoder
Source§

type Error = WebSocketError

The type of encoding errors. Read more
Source§

fn encode( &mut self, item: Self::Item, dst: &mut BytesMut, ) -> Result<(), Self::Error>

Encodes a frame into the buffer provided. Read more

Auto Trait Implementations§

§

impl<D> Freeze for DataFrameCodec<D>

§

impl<D> RefUnwindSafe for DataFrameCodec<D>
where D: RefUnwindSafe,

§

impl<D> Send for DataFrameCodec<D>
where D: Send,

§

impl<D> Sync for DataFrameCodec<D>
where D: Sync,

§

impl<D> Unpin for DataFrameCodec<D>
where D: Unpin,

§

impl<D> UnwindSafe for DataFrameCodec<D>
where D: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.