pub trait Source {
fn register(
&mut self,
registry: &Registry,
token: Token,
interests: Interest
) -> Result<()>;
fn reregister(
&mut self,
registry: &Registry,
token: Token,
interests: Interest
) -> Result<()>;
fn deregister(&mut self, registry: &Registry) -> Result<()>;
}
Expand description
An event source that may be registered with Registry
.
Types that implement event::Source
can be registered with
Registry
. Users of Mio should not use the event::Source
trait
functions directly. Instead, the equivalent functions on Registry
should
be used.
See Registry
for more details.
Implementing event::Source
Event sources are always backed by system handles, such as sockets or other
system handles. These event::Source
s will be monitored by the system
selector. An implementation of Source
will almost always delegates to a
lower level handle. Examples of this are TcpStream
s, or the unix only
SourceFd
.
Dropping event::Source
s
All event::Source
s, unless otherwise specified, need to be deregistered
before being dropped for them to not leak resources. This goes against the
normal drop behaviour of types in Rust which cleanup after themselves, e.g.
a File
will close itself. However since deregistering needs access to
Registry
this cannot be done while being dropped.
Examples
Implementing Source
on a struct containing a socket:
use mio::{Interest, Registry, Token};
use mio::event::Source;
use mio::net::TcpStream;
use std::io;
pub struct MySource {
socket: TcpStream,
}
impl Source for MySource {
fn register(&mut self, registry: &Registry, token: Token, interests: Interest)
-> io::Result<()>
{
// Delegate the `register` call to `socket`
self.socket.register(registry, token, interests)
}
fn reregister(&mut self, registry: &Registry, token: Token, interests: Interest)
-> io::Result<()>
{
// Delegate the `reregister` call to `socket`
self.socket.reregister(registry, token, interests)
}
fn deregister(&mut self, registry: &Registry) -> io::Result<()> {
// Delegate the `deregister` call to `socket`
self.socket.deregister(registry)
}
}
Required methods
Register self
with the given Registry
instance.
This function should not be called directly. Use Registry::register
instead. Implementors should handle registration by delegating the call
to another Source
type.
Re-register self
with the given Registry
instance.
This function should not be called directly. Use
Registry::reregister
instead. Implementors should handle
re-registration by either delegating the call to another Source
type.
fn deregister(&mut self, registry: &Registry) -> Result<()>
fn deregister(&mut self, registry: &Registry) -> Result<()>
Deregister self
from the given Registry
instance.
This function should not be called directly. Use
Registry::deregister
instead. Implementors should handle
deregistration by delegating the call to another Source
type.