blob: ba1971d5d7b59ffffaabe2cdffb54cbfe38e492e [file] [log] [blame]
use {Poll, Ready, PollOpt, Token};
// Re-export the io::Result / Error types for convenience
pub use std::io::{Read, Write, Result, Error, ErrorKind};
/// A value that may be registered with an `EventLoop`
pub trait Evented {
fn register(&self, poll: &Poll, token: Token, interest: Ready, opts: PollOpt) -> Result<()>;
fn reregister(&self, poll: &Poll, token: Token, interest: Ready, opts: PollOpt) -> Result<()>;
fn deregister(&self, poll: &Poll) -> Result<()>;
}
// TODO: Delete this
/// A helper trait to provide the map_non_block function on Results.
pub trait MapNonBlock<T> {
/// Maps a `Result<T>` to a `Result<Option<T>>` by converting
/// operation-would-block errors into `Ok(None)`.
fn map_non_block(self) -> Result<Option<T>>;
}
impl<T> MapNonBlock<T> for Result<T> {
fn map_non_block(self) -> Result<Option<T>> {
use std::io::ErrorKind::WouldBlock;
match self {
Ok(value) => Ok(Some(value)),
Err(err) => {
if let WouldBlock = err.kind() {
Ok(None)
} else {
Err(err)
}
}
}
}
}
#[cfg(unix)]
const WOULDBLOCK: i32 = ::libc::EAGAIN;
#[cfg(windows)]
const WOULDBLOCK: i32 = ::winapi::winerror::WSAEWOULDBLOCK as i32;
/// Returns a std `WouldBlock` error without allocating
pub fn would_block() -> ::std::io::Error {
::std::io::Error::from_raw_os_error(WOULDBLOCK)
}