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>,