asynchronous_codec/codec/bytes.rs
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
use crate::{Decoder, Encoder};
use bytes::{Bytes, BytesMut};
use std::io::Error;
/// A simple codec that ships bytes around
///
/// # Example
///
/// ```
/// # futures::executor::block_on(async move {
/// use bytes::Bytes;
/// use futures::{SinkExt, TryStreamExt};
/// use futures::io::Cursor;
/// use asynchronous_codec::{BytesCodec, Framed};
///
/// let mut buf = vec![];
/// // Cursor implements AsyncRead and AsyncWrite
/// let cur = Cursor::new(&mut buf);
/// let mut framed = Framed::new(cur, BytesCodec);
///
/// framed.send(Bytes::from("Hello World!")).await?;
///
/// while let Some(bytes) = framed.try_next().await? {
/// dbg!(bytes);
/// }
/// # Ok::<_, std::io::Error>(())
/// # }).unwrap();
/// ```
pub struct BytesCodec;
impl Encoder for BytesCodec {
type Item = Bytes;
type Error = Error;
fn encode(&mut self, src: Self::Item, dst: &mut BytesMut) -> Result<(), Self::Error> {
dst.extend_from_slice(&src);
Ok(())
}
}
impl Decoder for BytesCodec {
type Item = Bytes;
type Error = Error;
fn decode(&mut self, src: &mut BytesMut) -> Result<Option<Self::Item>, Self::Error> {
let len = src.len();
if len > 0 {
Ok(Some(src.split_to(len).freeze()))
} else {
Ok(None)
}
}
}