Struct ShutdownMonitor

Source
pub struct ShutdownMonitor { /* private fields */ }
Expand description

A ShutdownMonitor listens for the shutdown signal from a ShutdownController and tracks that the signal has been received.

Callers may query for whether the shutdown signal has been received or not.

§Examples

use shutdown_async::ShutdownMonitor;

async fn run(monitor: &mut ShutdownMonitor) {
  while !monitor.is_shutdown() {
      tokio::select! {
       _ = monitor.recv() => { println!("shutdown initiated"); }
       _ = async { /* do work */ } => { println!("one year has passed!"); }
      }
  }
}

Implementations§

Source§

impl ShutdownMonitor

Source

pub fn is_shutdown(&self) -> bool

Returns true if the shutdown signal has been received, and false otherwise.

§Examples
#[tokio::main]
async fn main() {
  let shutdown = shutdown_async::ShutdownController::new();
  let mut monitor = shutdown.subscribe();

  // Assert that the monitor has not yet received the shutdown signal
  assert!(!monitor.is_shutdown());
}
Source

pub async fn recv(&mut self)

Receive the shutdown notice, waiting if necessary.

§Examples
async fn long_lived_task(mut monitor: shutdown_async::ShutdownMonitor) {
   // Wait for the shutdown signal
   monitor.recv().await;
}

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.