An I/O handle is closed when the last remaining reference to it disappears.
Public Methods | |
iohandle () | |
Creates an empty handle. | |
iohandle (int fd) | |
Creates a handler from a file descriptor. | |
int | read (void *buf, unsigned int count) |
Attempts to read bytes into a data buffer. | |
operator bool () const | |
Returns true if this iohandle is valid. | |
int | read_fully (void *buf, unsigned int count) |
Reads bytes into a data buffer, retrying continually until either end-of-stream or an error condition. | |
int | write (const void *buf, int count) |
Attempts to write bytes from a data buffer. | |
int | write_fully (const void *buf, unsigned int count) |
Writes bytes from a data buffer, retrying continually until either end-of-stream or an error condition. | |
int | read (databuf buf, unsigned int count) |
Reads up to count bytes into a data buffer, setting the buffer's length to the number of bytes actually read. | |
int | read_fully (databuf buf, unsigned int count) |
Reads count bytes into a data buffer, retrying continually until either end-of-stream or an error condition. | |
int | read (databuf buf) |
Reads up to count bytes into a data buffer, up to the maximum length of the buffer. | |
int | read_fully (databuf buf) |
Fills up a data buffer, retrying continually until either end-of-stream or an error condition. | |
int | write (constbuf in) |
Attempts to write bytes from a data buffer. | |
int | write_fully (constbuf in) |
Writes bytes from a data buffer, retrying continually until either end-of-stream or an error condition. | |
bool | set_blocking (bool block) |
Sets a handle into blocking or non-blocking mode. | |
status | stat () const |
Returns the status of the handle. | |
int | get_fd () const |
Returns the file descriptor. | |
string | as_string () const |
Static Public Methods | |
pair< iohandle, iohandle > | pipe () |
Protected Methods | |
void | set_status (const status &s) |
|
Creates an empty handle.
|
|
Creates a handler from a file descriptor. This should only be invoked once per file descriptor. |
|
|
|
Returns the file descriptor.
|
|
Returns true if this iohandle is valid.
|
|
|
|
Reads up to count bytes into a data buffer, up to the maximum length of the buffer. Sets the buffer's length to the number of bytes actually read.
|
|
Reads up to count bytes into a data buffer, setting the buffer's length to the number of bytes actually read.
|
|
Attempts to read bytes into a data buffer. This call may block if the handler has not been put into non-blocking mode.
|
|
Fills up a data buffer, retrying continually until either end-of-stream or an error condition. Sets buf's length to the number of bytes read, which is always either buf.max_length() or 0. This should never be called on a non-blocking socket because it may consume large of CPU time waiting for bytes.
|
|
Reads count bytes into a data buffer, retrying continually until either end-of-stream or an error condition. Sets buf's length to the number of bytes read, which is always either count or 0. This should never be called on a non-blocking socket because it may consume large of CPU time waiting for bytes.
|
|
Reads bytes into a data buffer, retrying continually until either end-of-stream or an error condition. This should never be called on a non-blocking socket because it may consume large of CPU time waiting for bytes.
|
|
Sets a handle into blocking or non-blocking mode.
|
|
|
|
Returns the status of the handle.
|
|
Attempts to write bytes from a data buffer. This call may block if the handler has not been put into non-blocking mode.
|
|
Attempts to write bytes from a data buffer. This call may block if the handler has not been put into non-blocking mode.
|
|
Writes bytes from a data buffer, retrying continually until either end-of-stream or an error condition. This should never be called on a non-blocking socket because it may consume large of CPU time waiting for bytes.
|
|
Writes bytes from a data buffer, retrying continually until either end-of-stream or an error condition. This should never be called on a non-blocking socket because it may consume large of CPU time waiting for bytes.
|