io
only.Expand description
Asynchronous I/O.
This module is the asynchronous version of std::io
. It defines four
traits, AsyncRead
, AsyncWrite
, AsyncSeek
, and AsyncBufRead
,
which mirror the Read
, Write
, Seek
, and BufRead
traits of the
standard library. However, these traits integrate with the asynchronous
task system, so that if an I/O object isn’t ready for reading (or writing),
the thread is not blocked, and instead the current task is queued to be
woken when I/O is ready.
In addition, the AsyncReadExt
, AsyncWriteExt
, AsyncSeekExt
, and
AsyncBufReadExt
extension traits offer a variety of useful combinators
for operating with asynchronous I/O objects, including ways to work with
them using futures, streams and sinks.
This module is only available when the std
feature of this
library is activated, and it is activated by default.
Re-exports§
pub use std::io::Error;
pub use std::io::ErrorKind;
pub use std::io::IoSlice;
pub use std::io::IoSliceMut;
pub use std::io::Result;
pub use std::io::SeekFrom;
Structs§
- Allow
StdIo - A simple wrapper type which allows types which implement only
implement
std::io::Read
orstd::io::Write
to be used in contexts which expect anAsyncRead
orAsyncWrite
. - BufReader
- The
BufReader
struct adds buffering to any reader. - BufWriter
- Wraps a writer and buffers its output.
- Chain
- Reader for the
chain
method. - Close
- Future for the
close
method. - Copy
- Future for the
copy()
function. - CopyBuf
- Future for the
copy_buf()
function. - Copy
BufAbortable - Future for the
copy_buf_abortable()
function. - Cursor
- A
Cursor
wraps an in-memory buffer and provides it with aAsyncSeek
implementation. - Empty
- Reader for the
empty()
function. - FillBuf
- Future for the
fill_buf
method. - Flush
- Future for the
flush
method. - Into
Sink sink
- Sink for the
into_sink
method. - Line
Writer - Wrap a writer, like
BufWriter
does, but prioritizes buffering lines - Lines
- Stream for the
lines
method. - Read
- Future for the
read
method. - Read
Exact - Future for the
read_exact
method. - Read
Half - The readable half of an object returned from
AsyncRead::split
. - Read
Line - Future for the
read_line
method. - Read
ToEnd - Future for the
read_to_end
method. - Read
ToString - Future for the
read_to_string
method. - Read
Until - Future for the
read_until
method. - Read
Vectored - Future for the
read_vectored
method. - Repeat
- Reader for the
repeat()
function. - Reunite
Error - Error indicating a
ReadHalf<T>
andWriteHalf<T>
were not two halves of aAsyncRead + AsyncWrite
, and thus could not bereunite
d. - SeeK
Relative - Future for the
BufReader::seek_relative
method. - Seek
- Future for the
seek
method. - Sink
- Writer for the
sink()
function. - Take
- Reader for the
take
method. - Window
- An owned window around an underlying buffer.
- Write
- Future for the
write
method. - Write
All - Future for the
write_all
method. - Write
AllVectored - Future for the
write_all_vectored
method. - Write
Half - The writable half of an object returned from
AsyncRead::split
. - Write
Vectored - Future for the
write_vectored
method.
Traits§
- Async
BufRead - Read bytes asynchronously.
- Async
BufRead Ext - An extension trait which adds utility methods to
AsyncBufRead
types. - Async
Read - Read bytes asynchronously.
- Async
Read Ext - An extension trait which adds utility methods to
AsyncRead
types. - Async
Seek - Seek bytes asynchronously.
- Async
Seek Ext - An extension trait which adds utility methods to
AsyncSeek
types. - Async
Write - Write bytes asynchronously.
- Async
Write Ext - An extension trait which adds utility methods to
AsyncWrite
types.
Functions§
- copy
- Creates a future which copies all the bytes from one object to another.
- copy_
buf - Creates a future which copies all the bytes from one object to another.
- copy_
buf_ abortable - Creates a future which copies all the bytes from one object to another, with its
AbortHandle
. - empty
- Constructs a new handle to an empty reader.
- repeat
- Creates an instance of a reader that infinitely repeats one byte.
- sink
- Creates an instance of a writer which will successfully consume all data.