pub struct LayeredDuplexer<Inner> { /* private fields */ }
Expand description

Adapts an Read + Write to implement HalfDuplexLayered.

Implementations§

source§

impl<Inner: Read + Write> LayeredDuplexer<Inner>

source

pub fn new(inner: Inner) -> Self

Construct a new LayeredDuplexer which wraps inner with default settings.

source

pub fn with_eos_as_push(inner: Inner) -> Self

Construct a new LayeredDuplexer which wraps inner. When inner reports end of stream (by returning 0), report a push but keep the stream open and continue to read data on it.

For example, when reading a file, when the reader reaches the end of the file it will report it, but consumers may wish to continue reading in case additional data is appended to the file.

source

pub fn line_by_line(inner: Inner) -> Self

Construct a new LayeredDuplexer which wraps an inner which reads its input line-by-line, such as stdin on a terminal.

source

pub fn close_into_inner(self) -> Result<Inner>

Close this LayeredDuplexer and return the inner stream.

source

pub fn abandon_into_inner(self) -> Option<Inner>

Consume this LayeredDuplexer and return the inner stream.

Trait Implementations§

source§

impl<Inner: Duplex + AsRawReadWriteHandleOrSocket> AsRawReadWriteHandleOrSocket for LayeredDuplexer<Inner>

source§

fn as_raw_read_handle_or_socket(&self) -> RawHandleOrSocket

Extracts the raw handle or socket for reading. Read more
source§

fn as_raw_write_handle_or_socket(&self) -> RawHandleOrSocket

Extracts the raw handle or socket for writing. Read more
source§

impl<Inner: Duplex + AsReadWriteHandleOrSocket> AsReadWriteHandleOrSocket for LayeredDuplexer<Inner>

source§

fn as_read_handle_or_socket(&self) -> BorrowedHandleOrSocket<'_>

Extracts the handle or socket for reading. Read more
source§

fn as_write_handle_or_socket(&self) -> BorrowedHandleOrSocket<'_>

Extracts the handle or socket for writing. Read more
source§

impl<Inner> Bufferable for LayeredDuplexer<Inner>

source§

fn abandon(&mut self)

Close the resource and abandon any pending buffered contents or errors.
source§

fn suggested_buffer_size(&self) -> usize

A suggested size, in bytes, for buffering for performance.
source§

impl<Inner: Debug> Debug for LayeredDuplexer<Inner>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Inner> Drop for LayeredDuplexer<Inner>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<Inner: Read + Write> Read for LayeredDuplexer<Inner>

source§

fn read(&mut self, buf: &mut [u8]) -> Result<usize>

Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
source§

fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize>

Like read, except that it reads into a slice of buffers. Read more
source§

fn is_read_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
source§

fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize>

Read all bytes until EOF in this source, placing them into buf. Read more
source§

fn read_to_string(&mut self, buf: &mut String) -> Result<usize>

Read all bytes until EOF in this source, appending them to buf. Read more
source§

fn read_exact(&mut self, buf: &mut [u8]) -> Result<()>

Read the exact number of bytes required to fill buf. Read more
source§

fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
source§

fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Read the exact number of bytes required to fill cursor. Read more
1.0.0 · source§

fn by_ref(&mut self) -> &mut Self
where Self: Sized,

Creates a “by reference” adaptor for this instance of Read. Read more
1.0.0 · source§

fn bytes(self) -> Bytes<Self>
where Self: Sized,

Transforms this Read instance to an Iterator over its bytes. Read more
1.0.0 · source§

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

Creates an adapter which will chain this stream with another. Read more
1.0.0 · source§

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

Creates an adapter which will read at most limit bytes from it. Read more
source§

impl<Inner: Read + Write> ReadLayered for LayeredDuplexer<Inner>

source§

fn read_with_status(&mut self, buf: &mut [u8]) -> Result<(usize, Status)>

Like Read::read, but also returns a Status.
source§

fn read_vectored_with_status( &mut self, bufs: &mut [IoSliceMut<'_>] ) -> Result<(usize, Status)>

Like Read::read_vectored, but also returns a Status.
source§

fn read_exact_using_status(&mut self, buf: &mut [u8]) -> Result<Status>

Like Read::read_exact, but uses read_with_status to avoid performing an extra read at the end.
source§

fn minimum_buffer_size(&self) -> usize

Some streams require a buffer of at least a certain size.
source§

impl<Inner: Read + Write> Write for LayeredDuplexer<Inner>

source§

fn write(&mut self, buf: &[u8]) -> Result<usize>

Write a buffer into this writer, returning how many bytes were written. Read more
source§

fn flush(&mut self) -> Result<()>

Flush this output stream, ensuring that all intermediately buffered contents reach their destination. Read more
source§

fn write_vectored(&mut self, bufs: &[IoSlice<'_>]) -> Result<usize>

Like write, except that it writes from a slice of buffers. Read more
source§

fn is_write_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Writer has an efficient write_vectored implementation. Read more
source§

fn write_all(&mut self, buf: &[u8]) -> Result<()>

Attempts to write an entire buffer into this writer. Read more
source§

fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<()>

🔬This is a nightly-only experimental API. (write_all_vectored)
Attempts to write multiple buffers into this writer. Read more
source§

fn write_fmt(&mut self, fmt: Arguments<'_>) -> Result<()>

Writes a formatted string into this writer, returning any error encountered. Read more
1.0.0 · source§

fn by_ref(&mut self) -> &mut Self
where Self: Sized,

Creates a “by reference” adapter for this instance of Write. Read more
source§

impl<Inner: Read + Write> WriteLayered for LayeredDuplexer<Inner>

source§

fn close(&mut self) -> Result<()>

Flush any buffers and declare the end of the stream. Subsequent writes will fail.
source§

fn flush_with_status(&mut self, status: Status) -> Result<()>

Like Write::flush, but has a status parameter describing the future of the stream: Read more
source§

impl<Inner: Read + Write + Duplex> Duplex for LayeredDuplexer<Inner>

Auto Trait Implementations§

§

impl<Inner> Freeze for LayeredDuplexer<Inner>
where Inner: Freeze,

§

impl<Inner> RefUnwindSafe for LayeredDuplexer<Inner>
where Inner: RefUnwindSafe,

§

impl<Inner> Send for LayeredDuplexer<Inner>
where Inner: Send,

§

impl<Inner> Sync for LayeredDuplexer<Inner>
where Inner: Sync,

§

impl<Inner> Unpin for LayeredDuplexer<Inner>
where Inner: Unpin,

§

impl<Inner> UnwindSafe for LayeredDuplexer<Inner>
where Inner: 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> AsRawReadWriteGrip for T

source§

fn as_raw_read_grip(&self) -> RawHandleOrSocket

Extracts the grip for reading. Read more
source§

fn as_raw_write_grip(&self) -> RawHandleOrSocket

Extracts the grip for writing. Read more
source§

impl<T> AsReadWriteGrip for T

source§

fn as_read_grip(&self) -> BorrowedHandleOrSocket<'_>

Extracts the grip for reading. Read more
source§

fn as_write_grip(&self) -> BorrowedHandleOrSocket<'_>

Extracts the grip for writing. 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>,

§

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>,

§

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.
source§

impl<T> HalfDuplex for T
where T: Duplex + Read + Write,

source§

impl<T> HalfDuplexLayered for T