Struct JoinReadWrite

Source
pub struct JoinReadWrite<R: AsyncRead, W: AsyncWrite> { /* private fields */ }
Expand description

Async readable/writeable that dispatches reads to R and writes to W

AsyncRead is forwarded to R. AsyncWrite is forwarded to W.

JoinReadWrite::new() is the converse of AsyncReadExt::split(). But, if R and W came from splitting a single AsyncRead + AsyncWrite, you probably want the reunite or unsplit method, instead of JoinReadWrite.

Does not implement any kind of flushing behaviour when switching between reading and writing.

§Example

use tor_async_utils::JoinReadWrite;
use futures::{AsyncReadExt as _, AsyncWriteExt as _};

let read = b"hello\n";
let mut read = &read[..];
let mut write = Vec::<u8>::new();

let mut joined = JoinReadWrite::new(read, write);

let mut got = String::new();
let _: usize = joined.read_to_string(&mut got).await.unwrap();
assert_eq!(got, "hello\n");

let () = joined.write_all(b"some data").await.unwrap();

let (r, w) = joined.into_parts();
assert_eq!(w, b"some data");

Implementations§

Source§

impl<R: AsyncRead, W: AsyncWrite> JoinReadWrite<R, W>

Source

pub fn new(r: R, w: W) -> Self

Join an AsyncRead and an AsyncWrite into a single impl AsyncRead + AsyncWrite

Source

pub fn into_parts(self) -> (R, W)

Dismantle a JoinReadWrite into its constituent AsyncRead and AsyncWrite

Trait Implementations§

Source§

impl<R: AsyncRead, W: AsyncWrite> AsyncRead for JoinReadWrite<R, W>

Source§

fn poll_read( self: Pin<&mut Self>, c: &mut Context<'_>, out: &mut [u8], ) -> Poll<Result<usize, Error>>

Attempt to read from the AsyncRead into buf. Read more
§

fn poll_read_vectored( self: Pin<&mut Self>, cx: &mut Context<'_>, bufs: &mut [IoSliceMut<'_>], ) -> Poll<Result<usize, Error>>

Attempt to read from the AsyncRead into bufs using vectored IO operations. Read more
Source§

impl<R: AsyncRead, W: AsyncWrite> AsyncWrite for JoinReadWrite<R, W>

Source§

fn poll_write( self: Pin<&mut Self>, c: &mut Context<'_>, data: &[u8], ) -> Poll<Result<usize, Error>>

Attempt to write bytes from buf into the object. Read more
Source§

fn poll_flush( self: Pin<&mut Self>, c: &mut Context<'_>, ) -> Poll<Result<(), Error>>

Attempt to flush the object, ensuring that any buffered data reach their destination. Read more
Source§

fn poll_close( self: Pin<&mut Self>, c: &mut Context<'_>, ) -> Poll<Result<(), Error>>

Attempt to close the object. Read more
§

fn poll_write_vectored( self: Pin<&mut Self>, cx: &mut Context<'_>, bufs: &[IoSlice<'_>], ) -> Poll<Result<usize, Error>>

Attempt to write bytes from bufs into the object using vectored IO operations. Read more
Source§

impl<'pin, R: AsyncRead, W: AsyncWrite> Unpin for JoinReadWrite<R, W>
where PinnedFieldsOf<__JoinReadWrite<'pin, R, W>>: Unpin,

Auto Trait Implementations§

§

impl<R, W> Freeze for JoinReadWrite<R, W>
where R: Freeze, W: Freeze,

§

impl<R, W> RefUnwindSafe for JoinReadWrite<R, W>

§

impl<R, W> Send for JoinReadWrite<R, W>
where R: Send, W: Send,

§

impl<R, W> Sync for JoinReadWrite<R, W>
where R: Sync, W: Sync,

§

impl<R, W> UnwindSafe for JoinReadWrite<R, W>
where R: UnwindSafe, W: 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
§

impl<R> AsyncReadExt for R
where R: AsyncRead + ?Sized,

§

fn chain<R>(self, next: R) -> Chain<Self, R>
where Self: Sized, R: AsyncRead,

Creates an adaptor which will chain this stream with another. Read more
§

fn read<'a>(&'a mut self, buf: &'a mut [u8]) -> Read<'a, Self>
where Self: Unpin,

Tries to read some bytes directly into the given buf in asynchronous manner, returning a future type. Read more
§

fn read_vectored<'a>( &'a mut self, bufs: &'a mut [IoSliceMut<'a>], ) -> ReadVectored<'a, Self>
where Self: Unpin,

Creates a future which will read from the AsyncRead into bufs using vectored IO operations. Read more
§

fn read_exact<'a>(&'a mut self, buf: &'a mut [u8]) -> ReadExact<'a, Self>
where Self: Unpin,

Creates a future which will read exactly enough bytes to fill buf, returning an error if end of file (EOF) is hit sooner. Read more
§

fn read_to_end<'a>(&'a mut self, buf: &'a mut Vec<u8>) -> ReadToEnd<'a, Self>
where Self: Unpin,

Creates a future which will read all the bytes from this AsyncRead. Read more
§

fn read_to_string<'a>( &'a mut self, buf: &'a mut String, ) -> ReadToString<'a, Self>
where Self: Unpin,

Creates a future which will read all the bytes from this AsyncRead. Read more
§

fn split(self) -> (ReadHalf<Self>, WriteHalf<Self>)
where Self: Sized + AsyncWrite,

Helper method for splitting this read/write object into two halves. Read more
§

fn take(self, limit: u64) -> Take<Self>
where Self: Sized,

Creates an AsyncRead adapter which will read at most limit bytes from the underlying reader. Read more
§

impl<W> AsyncWriteExt for W
where W: AsyncWrite + ?Sized,

§

fn flush(&mut self) -> Flush<'_, Self>
where Self: Unpin,

Creates a future which will entirely flush this AsyncWrite. Read more
§

fn close(&mut self) -> Close<'_, Self>
where Self: Unpin,

Creates a future which will entirely close this AsyncWrite.
§

fn write<'a>(&'a mut self, buf: &'a [u8]) -> Write<'a, Self>
where Self: Unpin,

Creates a future which will write bytes from buf into the object. Read more
§

fn write_vectored<'a>( &'a mut self, bufs: &'a [IoSlice<'a>], ) -> WriteVectored<'a, Self>
where Self: Unpin,

Creates a future which will write bytes from bufs into the object using vectored IO operations. Read more
§

fn write_all<'a>(&'a mut self, buf: &'a [u8]) -> WriteAll<'a, Self>
where Self: Unpin,

Write data into this object. Read more
§

fn into_sink<Item>(self) -> IntoSink<Self, Item>
where Item: AsRef<[u8]>, Self: Sized,

Allow using an [AsyncWrite] as a Sink<Item: AsRef<[u8]>>. 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, 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.