From 49721ef98e86ebec4334ae9e705e5429daf5ef5b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=B7=D0=B0=D0=BB=D0=B8=D1=8F=20=D0=A1=D0=BC=D0=B0?= =?UTF-8?q?=D1=80=D0=B0=D0=B3=D0=B4=D0=BE=D0=B2=D0=B0?= Date: Mon, 17 Jun 2024 00:09:30 +0500 Subject: [PATCH] Setting real-time signal awareness feature for Linux only --- src/sys/signal.rs | 68 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) diff --git a/src/sys/signal.rs b/src/sys/signal.rs index 2de78593ec..cc9ab74bb5 100644 --- a/src/sys/signal.rs +++ b/src/sys/signal.rs @@ -369,6 +369,7 @@ const SIGNALS: [Signal; 31] = [ // Support for real-time signals /// Operating system signal value +#[cfg(target_os = "linux")] #[cfg(any(feature = "signal"))] #[derive(Clone, Copy, Debug, PartialEq, Eq, PartialOrd, Ord, Hash)] pub enum SignalValue { @@ -378,8 +379,19 @@ pub enum SignalValue { Realtime(libc::c_int), } +// Support for real-time signals +/// Operating system signal value +#[cfg(not(target_os = "linux"))] +#[cfg(any(feature = "signal"))] +#[derive(Clone, Copy, Debug, PartialEq, Eq, PartialOrd, Ord, Hash)] +pub enum SignalValue { + /// Standard signal (passed as a Signal enum value) + Standard(Signal), +} + #[cfg(feature = "signal")] impl SignalValue { + #[cfg(target_os = "linux")] unsafe fn convert_to_int_unchecked(self) -> libc::c_int { match self { SignalValue::Standard(s) => s as libc::c_int, @@ -387,7 +399,15 @@ impl SignalValue { } } + #[cfg(not(target_os = "linux"))] + unsafe fn convert_to_int_unchecked(self) -> libc::c_int { + match self { + SignalValue::Standard(s) => s as libc::c_int, + } + } + /// Check whether this enum contains a valid signal for this operating system + #[cfg(target_os = "linux")] pub fn is_valid(&self) -> bool { match self { SignalValue::Standard(_) => true, @@ -397,9 +417,18 @@ impl SignalValue { } } } + + /// Check whether this enum contains a valid signal for this operating system + #[cfg(not(target_os = "linux"))] + pub fn is_valid(&self) -> bool { + match self { + SignalValue::Standard(_) => true, + } + } } impl From for String { + #[cfg(target_os = "linux")] fn from(x: SignalValue) -> Self { match x { SignalValue::Standard(s) => s.to_string(), @@ -408,11 +437,19 @@ impl From for String { } } } + + #[cfg(not(target_os = "linux"))] + fn from(x: SignalValue) -> Self { + match x { + SignalValue::Standard(s) => s.to_string(), + } + } } impl TryFrom for SignalValue { type Error = Errno; + #[cfg(target_os = "linux")] fn try_from(x: i32) -> Result { if x < libc::SIGRTMIN() { match Signal::try_from(x) { @@ -423,11 +460,20 @@ impl TryFrom for SignalValue { Ok(SignalValue::Realtime(x - libc::SIGRTMIN())) } } + + #[cfg(not(target_os = "linux"))] + fn try_from(x: i32) -> Result { + match Signal::try_from(x) { + Ok(s) => Ok(SignalValue::Standard(s)), + Err(e) => Err(e), + } + } } impl TryFrom for i32 { type Error = Errno; + #[cfg(target_os = "linux")] fn try_from(x: SignalValue) -> Result { match x { SignalValue::Standard(s) => Ok(s as i32), @@ -441,6 +487,13 @@ impl TryFrom for i32 { } } } + + #[cfg(not(target_os = "linux"))] + fn try_from(x: SignalValue) -> Result { + match x { + SignalValue::Standard(s) => Ok(s as i32), + } + } } impl From for SignalValue { @@ -492,6 +545,7 @@ impl Iterator for SignalIterator { impl Iterator for SignalValueIterator { type Item = SignalValue; + #[cfg(target_os = "linux")] fn next(&mut self) -> Option { let next_signal = match SignalValue::try_from(self.next) { Ok(s) => { @@ -507,6 +561,20 @@ impl Iterator for SignalValueIterator { }; if next_signal.is_valid() { Some(next_signal) } else { None } } + + #[cfg(not(target_os = "linux"))] + fn next(&mut self) -> Option { + let next_signal = match SignalValue::try_from(self.next) { + Ok(s) => { + self.next += 1; + s + } + Err(_) => { + return None; + }, + }; + if next_signal.is_valid() { Some(next_signal) } else { None } + } } impl Signal {