Signal

Enum Signal 

Source
#[non_exhaustive]
#[repr(i32)]
pub enum Signal {
Show 31 variants SIGHUP = 1, SIGINT = 2, SIGQUIT = 3, SIGILL = 4, SIGTRAP = 5, SIGABRT = 6, SIGBUS = 7, SIGFPE = 8, SIGKILL = 9, SIGUSR1 = 10, SIGSEGV = 11, SIGUSR2 = 12, SIGPIPE = 13, SIGALRM = 14, SIGTERM = 15, SIGSTKFLT = 16, SIGCHLD = 17, SIGCONT = 18, SIGSTOP = 19, SIGTSTP = 20, SIGTTIN = 21, SIGTTOU = 22, SIGURG = 23, SIGXCPU = 24, SIGXFSZ = 25, SIGVTALRM = 26, SIGPROF = 27, SIGWINCH = 28, SIGIO = 29, SIGPWR = 30, SIGSYS = 31,
}
Available on crate features aio or signal only.
Expand description

Types of operating system signals

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

SIGHUP = 1

Hangup

§

SIGINT = 2

Interrupt

§

SIGQUIT = 3

Quit

§

SIGILL = 4

Illegal instruction (not reset when caught)

§

SIGTRAP = 5

Trace trap (not reset when caught)

§

SIGABRT = 6

Abort

§

SIGBUS = 7

Bus error

§

SIGFPE = 8

Floating point exception

§

SIGKILL = 9

Kill (cannot be caught or ignored)

§

SIGUSR1 = 10

User defined signal 1

§

SIGSEGV = 11

Segmentation violation

§

SIGUSR2 = 12

User defined signal 2

§

SIGPIPE = 13

Write on a pipe with no one to read it

§

SIGALRM = 14

Alarm clock

§

SIGTERM = 15

Software termination signal from kill

§

SIGSTKFLT = 16

Stack fault (obsolete)

§

SIGCHLD = 17

To parent on child stop or exit

§

SIGCONT = 18

Continue a stopped process

§

SIGSTOP = 19

Sendable stop signal not from tty

§

SIGTSTP = 20

Stop signal from tty

§

SIGTTIN = 21

To readers pgrp upon background tty read

§

SIGTTOU = 22

Like TTIN if (tp->t_local&LTOSTOP)

§

SIGURG = 23

Urgent condition on IO channel

§

SIGXCPU = 24

Exceeded CPU time limit

§

SIGXFSZ = 25

Exceeded file size limit

§

SIGVTALRM = 26

Virtual time alarm

§

SIGPROF = 27

Profiling time alarm

§

SIGWINCH = 28

Window size changes

§

SIGIO = 29

Input/output possible signal

§

SIGPWR = 30

Power failure imminent.

§

SIGSYS = 31

Bad system call

Implementations§

Source§

impl Signal

Source

pub const fn as_str(self) -> &'static str

Returns name of signal.

This function is equivalent to <Signal as AsRef<str>>::as_ref(), with difference that returned string is 'static and not bound to self’s lifetime.

Source§

impl Signal

Source

pub const fn iterator() -> SignalIterator

Available on crate feature signal only.

Iterate through all signals defined by this OS

Trait Implementations§

Source§

impl AsRef<str> for Signal

Source§

fn as_ref(&self) -> &str

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl BitOr<Signal> for SigSet

Available on crate feature signal only.
Source§

type Output = SigSet

The resulting type after applying the | operator.
Source§

fn bitor(self, rhs: Signal) -> Self::Output

Performs the | operation. Read more
Source§

impl BitOr for Signal

Available on crate feature signal only.
Source§

type Output = SigSet

The resulting type after applying the | operator.
Source§

fn bitor(self, rhs: Self) -> Self::Output

Performs the | operation. Read more
Source§

impl Clone for Signal

Source§

fn clone(&self) -> Signal

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Signal

Source§

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

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

impl Display for Signal

Source§

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

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

impl Extend<Signal> for SigSet

Available on crate feature signal only.
Source§

fn extend<T>(&mut self, iter: T)
where T: IntoIterator<Item = Signal>,

Extends a collection with the contents of an iterator. Read more
Source§

fn extend_one(&mut self, item: A)

🔬This is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
Source§

fn extend_reserve(&mut self, additional: usize)

🔬This is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
Source§

impl From<Signal> for SigSet

Available on crate feature signal only.
Source§

fn from(signal: Signal) -> SigSet

Converts to this type from the input type.
Source§

impl FromIterator<Signal> for SigSet

Available on crate feature signal only.
Source§

fn from_iter<T>(iter: T) -> Self
where T: IntoIterator<Item = Signal>,

Creates a value from an iterator. Read more
Source§

impl FromStr for Signal

Source§

type Err = Errno

The associated error which can be returned from parsing.
Source§

fn from_str(s: &str) -> Result<Signal>

Parses a string s to return a value of this type. Read more
Source§

impl Hash for Signal

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Ord for Signal

Source§

fn cmp(&self, other: &Signal) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq for Signal

Source§

fn eq(&self, other: &Signal) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for Signal

Source§

fn partial_cmp(&self, other: &Signal) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl TryFrom<i32> for Signal

Source§

type Error = Errno

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

fn try_from(x: i32) -> Result<Self>

Performs the conversion.
Source§

impl Copy for Signal

Source§

impl Eq for Signal

Source§

impl StructuralPartialEq for Signal

Auto Trait Implementations§

§

impl Freeze for Signal

§

impl RefUnwindSafe for Signal

§

impl Send for Signal

§

impl Sync for Signal

§

impl Unpin for Signal

§

impl UnwindSafe for Signal

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 4 bytes

Size for each variant:

  • SIGHUP: 0 bytes
  • SIGINT: 0 bytes
  • SIGQUIT: 0 bytes
  • SIGILL: 0 bytes
  • SIGTRAP: 0 bytes
  • SIGABRT: 0 bytes
  • SIGBUS: 0 bytes
  • SIGFPE: 0 bytes
  • SIGKILL: 0 bytes
  • SIGUSR1: 0 bytes
  • SIGSEGV: 0 bytes
  • SIGUSR2: 0 bytes
  • SIGPIPE: 0 bytes
  • SIGALRM: 0 bytes
  • SIGTERM: 0 bytes
  • SIGSTKFLT: 0 bytes
  • SIGCHLD: 0 bytes
  • SIGCONT: 0 bytes
  • SIGSTOP: 0 bytes
  • SIGTSTP: 0 bytes
  • SIGTTIN: 0 bytes
  • SIGTTOU: 0 bytes
  • SIGURG: 0 bytes
  • SIGXCPU: 0 bytes
  • SIGXFSZ: 0 bytes
  • SIGVTALRM: 0 bytes
  • SIGPROF: 0 bytes
  • SIGWINCH: 0 bytes
  • SIGIO: 0 bytes
  • SIGPWR: 0 bytes
  • SIGSYS: 0 bytes