Struct event_listener::EventListener [−][src]
A guard waiting for a notification from an Event
.
There are two ways for a listener to wait for a notification:
- In an asynchronous manner using
.await
. - In a blocking manner by calling
EventListener::wait()
on it.
If a notified listener is dropped without receiving a notification, dropping will notify another active listener. Whether one additional listener will be notified depends on what kind of notification was delivered.
Implementations
impl EventListener
[src]
pub fn wait(self)
[src]
Blocks until a notification is received.
Examples
use event_listener::Event; let event = Event::new(); let listener = event.listen(); // Notify `listener`. event.notify(1); // Receive the notification. listener.wait();
pub fn wait_timeout(self, timeout: Duration) -> bool
[src]
Blocks until a notification is received or a timeout is reached.
Returns true
if a notification was received.
Examples
use std::time::Duration; use event_listener::Event; let event = Event::new(); let listener = event.listen(); // There are no notification so this times out. assert!(!listener.wait_timeout(Duration::from_secs(1)));
pub fn wait_deadline(self, deadline: Instant) -> bool
[src]
Blocks until a notification is received or a deadline is reached.
Returns true
if a notification was received.
Examples
use std::time::{Duration, Instant}; use event_listener::Event; let event = Event::new(); let listener = event.listen(); // There are no notification so this times out. assert!(!listener.wait_deadline(Instant::now() + Duration::from_secs(1)));
pub fn discard(self) -> bool
[src]
Drops this listener and discards its notification (if any) without notifying another active listener.
Returns true
if a notification was discarded.
Examples
use event_listener::Event; let event = Event::new(); let listener1 = event.listen(); let listener2 = event.listen(); event.notify(1); assert!(listener1.discard()); assert!(!listener2.discard());
pub fn listens_to(&self, event: &Event) -> bool
[src]
Returns true
if this listener listens to the given Event
.
Examples
use event_listener::Event; let event = Event::new(); let listener = event.listen(); assert!(listener.listens_to(&event));
pub fn same_event(&self, other: &EventListener) -> bool
[src]
Returns true
if both listeners listen to the same Event
.
Examples
use event_listener::Event; let event = Event::new(); let listener1 = event.listen(); let listener2 = event.listen(); assert!(listener1.same_event(&listener2));
Trait Implementations
impl Debug for EventListener
[src]
impl Drop for EventListener
[src]
impl Future for EventListener
[src]
type Output = ()
The type of value produced on completion.
fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output>
[src]
impl RefUnwindSafe for EventListener
[src]
impl Send for EventListener
[src]
impl Sync for EventListener
[src]
impl UnwindSafe for EventListener
[src]
Auto Trait Implementations
impl Unpin for EventListener
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<F> IntoFuture for F where
F: Future,
[src]
F: Future,
type Output = <F as Future>::Output
into_future
)The output that the future will produce on completion.
type Future = F
into_future
)Which kind of future are we turning this into?
pub fn into_future(self) -> <F as IntoFuture>::Future
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,