use corcovado::event::Evented;
use corcovado::stream;
use corcovado::{Poll, PollOpt, Ready, Token};
use std::io::Error;
macro_rules! implement_signals_with_pipe {
($pipe:path) => {
use std::borrow::Borrow;
use signal_hook::iterator::backend::{self, SignalDelivery};
use signal_hook::iterator::exfiltrator::{Exfiltrator, SignalOnly};
use $pipe as Pipe;
use libc::c_int;
pub struct SignalsInfo<E: Exfiltrator = SignalOnly>(SignalDelivery<Pipe, E>);
pub use backend::Pending;
impl<E: Exfiltrator> SignalsInfo<E> {
pub fn new<I, S>(signals: I) -> Result<Self, Error>
where
I: IntoIterator<Item = S>,
S: Borrow<c_int>,
E: Default,
{
Self::with_exfiltrator(signals, E::default())
}
pub fn with_exfiltrator<I, S>(
signals: I,
exfiltrator: E,
) -> Result<Self, Error>
where
I: IntoIterator<Item = S>,
S: Borrow<c_int>,
{
let (read, write) = Pipe::pair()?;
let delivery =
SignalDelivery::with_pipe(read, write, exfiltrator, signals)?;
Ok(Self(delivery))
}
#[allow(unused)]
pub fn add_signal(&self, signal: c_int) -> Result<(), Error> {
self.0.handle().add_signal(signal)
}
pub fn pending(&mut self) -> Pending<E> {
self.0.pending()
}
}
pub type Signals = SignalsInfo<SignalOnly>;
};
}
implement_signals_with_pipe!(stream::UnixStream);
impl Evented for Signals {
fn register(
&self,
poll: &Poll,
token: Token,
interest: Ready,
opts: PollOpt,
) -> Result<(), Error> {
self.0.get_read().register(poll, token, interest, opts)
}
fn reregister(
&self,
poll: &Poll,
token: Token,
interest: Ready,
opts: PollOpt,
) -> Result<(), Error> {
self.0.get_read().reregister(poll, token, interest, opts)
}
fn deregister(&self, poll: &Poll) -> Result<(), Error> {
self.0.get_read().deregister(poll)
}
}