scuffle_signal

Struct SignalHandler

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

A handler for listening to multiple Unix signals, and providing a future for receiving them.

This is useful for applications that need to listen for multiple signals, and want to react to them in a non-blocking way. Typically you would need to use a tokio::select{} to listen for multiple signals, but this provides a more ergonomic interface for doing so.

After a signal is received you can poll the handler again to wait for another signal. Dropping the handle will cancel the signal subscription

Implementations§

Source§

impl SignalHandler

Source

pub const fn new() -> Self

Create a new SignalHandler with no signals.

Source

pub fn with_signals(signals: impl IntoIterator<Item = SignalKind>) -> Self

Create a new SignalHandler with the given signals.

Source

pub fn with_signal(self, kind: SignalKind) -> Self

Add a signal to the handler.

If the signal is already in the handler, it will not be added again.

Source

pub fn add_signal(&mut self, kind: SignalKind) -> &mut Self

Add a signal to the handler.

If the signal is already in the handler, it will not be added again.

Source

pub async fn recv(&mut self) -> SignalKind

Wait for a signal to be received. This is equivilant to calling (&mut handler).await, but is more ergonomic if you want to not take ownership of the handler.

Source

pub fn poll_recv(&mut self, cx: &mut Context<'_>) -> Poll<SignalKind>

Poll for a signal to be received. Does not require Pinning the handler.

Trait Implementations§

Source§

impl Debug for SignalHandler

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for SignalHandler

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Future for SignalHandler

Source§

type Output = SignalKind

The type of value produced on completion.
Source§

fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output>

Attempts to resolve the future to a final value, registering the current task for wakeup if the value is not yet available. Read more

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<F> IntoFuture for F
where F: Future,

Source§

type Output = <F as Future>::Output

The output that the future will produce on completion.
Source§

type IntoFuture = F

Which kind of future are we turning this into?
Source§

fn into_future(self) -> <F as IntoFuture>::IntoFuture

Creates a future from a value. Read more
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.