[][src]Trait futures::io::AsyncRead

pub trait AsyncRead {
    fn poll_read(
        &mut self,
        waker: &Waker,
        buf: &mut [u8]
    ) -> Poll<Result<usize, Error>>; unsafe fn initializer(&self) -> Initializer { ... }
fn poll_vectored_read(
        &mut self,
        waker: &Waker,
        vec: &mut [&mut IoVec]
    ) -> Poll<Result<usize, Error>> { ... } }

Read bytes asynchronously.

This trait is analogous to the std::io::Read trait, but integrates with the asynchronous task system. In particular, the poll_read method, unlike Read::read, will automatically queue the current task for wakeup and return if data is not yet available, rather than blocking the calling thread.

Required methods

fn poll_read(
    &mut self,
    waker: &Waker,
    buf: &mut [u8]
) -> Poll<Result<usize, Error>>

Attempt to read from the AsyncRead into buf.

On success, returns Ok(Async::Ready(num_bytes_read)).

If no data is available for reading, the method returns Ok(Async::Pending) and arranges for the current task (via waker.wake()) to receive a notification when the object becomes readable or is closed.

Implementation

This function may not return errors of kind WouldBlock or Interrupted. Implementations must convert WouldBlock into Async::Pending and either internally retry or convert Interrupted into another error kind.

Loading content...

Provided methods

unsafe fn initializer(&self) -> Initializer

Determines if this AsyncReader can work with buffers of uninitialized memory.

The default implementation returns an initializer which will zero buffers.

Safety

This method is unsafe because and AsyncReader could otherwise return a non-zeroing Initializer from another AsyncRead type without an unsafe block.

fn poll_vectored_read(
    &mut self,
    waker: &Waker,
    vec: &mut [&mut IoVec]
) -> Poll<Result<usize, Error>>

Attempt to read from the AsyncRead into vec using vectored IO operations.

This method is similar to poll_read, but allows data to be read into multiple buffers using a single operation.

On success, returns Ok(Async::Ready(num_bytes_read)).

If no data is available for reading, the method returns Ok(Async::Pending) and arranges for the current task (via waker.wake()) to receive a notification when the object becomes readable or is closed. By default, this method delegates to using poll_read on the first buffer in vec. Objects which support vectored IO should override this method.

Implementation

This function may not return errors of kind WouldBlock or Interrupted. Implementations must convert WouldBlock into Async::Pending and either internally retry or convert Interrupted into another error kind.

Loading content...

Implementations on Foreign Types

impl<St> AsyncRead for IntoAsyncRead<St> where
    St: TryStream<Error = Error> + Unpin,
    <St as TryStream>::Ok: AsRef<[u8]>, 
[src]

unsafe fn initializer(&self) -> Initializer[src]

fn poll_vectored_read(
    &mut self,
    waker: &Waker,
    vec: &mut [&mut IoVec]
) -> Poll<Result<usize, Error>>
[src]

impl AsyncRead for Repeat[src]

fn poll_vectored_read(
    &mut self,
    waker: &Waker,
    vec: &mut [&mut IoVec]
) -> Poll<Result<usize, Error>>
[src]

impl<'a> AsyncRead for &'a [u8][src]

fn poll_vectored_read(
    &mut self,
    waker: &Waker,
    vec: &mut [&mut IoVec]
) -> Poll<Result<usize, Error>>
[src]

impl<'a, T> AsyncRead for &'a mut T where
    T: AsyncRead + ?Sized
[src]

impl<T> AsyncRead for Cursor<T> where
    T: AsRef<[u8]>, 
[src]

fn poll_vectored_read(
    &mut self,
    waker: &Waker,
    vec: &mut [&mut IoVec]
) -> Poll<Result<usize, Error>>
[src]

impl<T> AsyncRead for Box<T> where
    T: AsyncRead + ?Sized
[src]

Loading content...

Implementors

impl<R> AsyncRead for Compat01As03<R> where
    R: AsyncRead
[src]

fn poll_vectored_read(
    &mut self,
    waker: &Waker,
    vec: &mut [&mut IoVec]
) -> Poll<Result<usize, Error>>
[src]

impl<R> AsyncRead for ReadHalf<R> where
    R: AsyncRead
[src]

unsafe fn initializer(&self) -> Initializer[src]

impl<T> AsyncRead for AllowStdIo<T> where
    T: Read
[src]

unsafe fn initializer(&self) -> Initializer[src]

fn poll_vectored_read(
    &mut self,
    waker: &Waker,
    vec: &mut [&mut IoVec]
) -> Poll<Result<usize, Error>>
[src]

Loading content...