Struct mio::SetReadiness
source · [−]pub struct SetReadiness { /* private fields */ }
Expand description
Updates the readiness state of the associated Registration
.
See Registration
for more documentation on using SetReadiness
and
Poll
for high level polling documentation.
Implementations
sourceimpl SetReadiness
impl SetReadiness
sourcepub fn readiness(&self) -> Ready
pub fn readiness(&self) -> Ready
Returns the registration’s current readiness.
Note
There is no guarantee that readiness
establishes any sort of memory
ordering. Any concurrent data access must be synchronized using another
strategy.
Examples
use mio::{Registration, Ready};
let (registration, set_readiness) = Registration::new2();
assert!(set_readiness.readiness().is_empty());
set_readiness.set_readiness(Ready::readable())?;
assert!(set_readiness.readiness().is_readable());
sourcepub fn set_readiness(&self, ready: Ready) -> Result<()>
pub fn set_readiness(&self, ready: Ready) -> Result<()>
Set the registration’s readiness
If the associated Registration
is registered with a Poll
instance
and has requested readiness events that include ready
, then a future
call to Poll::poll
will receive a readiness event representing the
readiness state change.
Note
There is no guarantee that readiness
establishes any sort of memory
ordering. Any concurrent data access must be synchronized using another
strategy.
There is also no guarantee as to when the readiness event will be delivered to poll. A best attempt will be made to make the delivery in a “timely” fashion. For example, the following is not guaranteed to work:
use mio::{Events, Registration, Ready, Poll, PollOpt, Token};
let poll = Poll::new()?;
let (registration, set_readiness) = Registration::new2();
poll.register(®istration,
Token(0),
Ready::readable(),
PollOpt::edge())?;
// Set the readiness, then immediately poll to try to get the readiness
// event
set_readiness.set_readiness(Ready::readable())?;
let mut events = Events::with_capacity(1024);
poll.poll(&mut events, None)?;
// There is NO guarantee that the following will work. It is possible
// that the readiness event will be delivered at a later time.
let event = events.get(0).unwrap();
assert_eq!(event.token(), Token(0));
assert!(event.readiness().is_readable());
Examples
A simple example, for a more elaborate example, see the Evented
documentation.
use mio::{Registration, Ready};
let (registration, set_readiness) = Registration::new2();
assert!(set_readiness.readiness().is_empty());
set_readiness.set_readiness(Ready::readable())?;
assert!(set_readiness.readiness().is_readable());
Trait Implementations
sourceimpl Clone for SetReadiness
impl Clone for SetReadiness
sourcefn clone(&self) -> SetReadiness
fn clone(&self) -> SetReadiness
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
sourceimpl Debug for SetReadiness
impl Debug for SetReadiness
impl Send for SetReadiness
impl Sync for SetReadiness
Auto Trait Implementations
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcepub fn to_owned(&self) -> T
pub fn to_owned(&self) -> T
Creates owned data from borrowed data, usually by cloning. Read more
sourcepub fn clone_into(&self, target: &mut T)
pub fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more