pub struct EventedFd<'a>(pub &'a RawFd);
Adapter for RawFd
providing an Evented
implementation.
EventedFd
enables registering any type with an FD with Poll
.
While only implementations for TCP and UDP are provided, Mio supports
registering any FD that can be registered with the underlying OS selector.
EventedFd
provides the necessary bridge.
Note that EventedFd
takes a &RawFd
. This is because EventedFd
does
not take ownership of the FD. Specifically, it will not manage any
lifecycle related operations, such as closing the FD on drop. It is expected
that the EventedFd
is constructed right before a call to
Poll::register
. See the examples for more detail.
Basic usage
use mio::{Ready, Poll, PollOpt, Token};
use mio::unix::EventedFd;
use std::os::unix::io::AsRawFd;
use std::net::TcpListener;
let listener = TcpListener::bind("127.0.0.1:0")?;
let poll = Poll::new()?;
poll.register(&EventedFd(&listener.as_raw_fd()),
Token(0), Ready::readable(), PollOpt::edge())?;
Implementing Evented
for a custom type backed by a RawFd
.
use mio::{Ready, Poll, PollOpt, Token};
use mio::event::Evented;
use mio::unix::EventedFd;
use std::os::unix::io::RawFd;
use std::io;
pub struct MyIo {
fd: RawFd,
}
impl Evented for MyIo {
fn register(&self, poll: &Poll, token: Token, interest: Ready, opts: PollOpt)
-> io::Result<()>
{
EventedFd(&self.fd).register(poll, token, interest, opts)
}
fn reregister(&self, poll: &Poll, token: Token, interest: Ready, opts: PollOpt)
-> io::Result<()>
{
EventedFd(&self.fd).reregister(poll, token, interest, opts)
}
fn deregister(&self, poll: &Poll) -> io::Result<()> {
EventedFd(&self.fd).deregister(poll)
}
}
Register self
with the given Poll
instance. Read more
Re-register self
with the given Poll
instance. Read more
Deregister self
from the given Poll
instance Read more
Formats the value using the given formatter. Read more
🔬 This is a nightly-only experimental API. (try_from
)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (try_from
)
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more
type Error = <U as TryFrom<T>>::Error
🔬 This is a nightly-only experimental API. (try_from
)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (try_from
)
🔬 This is a nightly-only experimental API. (get_type_id
)
this method will likely be replaced by an associated static