From 1a04aa6f963b7d20cbcfbce05a87e2c0287297e4 Mon Sep 17 00:00:00 2001 From: bnewbold Date: Tue, 11 Oct 2016 02:53:18 -0700 Subject: more work in progress --- src/main.rs | 25 +++++++++++++++++-------- 1 file changed, 17 insertions(+), 8 deletions(-) (limited to 'src') diff --git a/src/main.rs b/src/main.rs index 918a37d..4e994c3 100644 --- a/src/main.rs +++ b/src/main.rs @@ -172,6 +172,7 @@ fn shepard(mut cfg: EinConfig, signal_rx: Receiver) { } //// infinite select() loop over timers, signals + let mut run = true; loop { chan_select! { timer_rx.recv() -> action => match action.expect("Error with timer thread") { @@ -221,12 +222,13 @@ fn shepard(mut cfg: EinConfig, signal_rx: Receiver) { }, }, signal_rx.recv() -> sig => match sig.expect("Error with signal handler") { - Signal::USR1 => { // USING AS PLACEHOLDER FOR SIGCHLD + Signal::CHLD => { loop { - let res = nix::sys::wait::waitpid(-1, Some(nix::sys::wait::WNOWAIT)); + let res = nix::sys::wait::waitpid(-1, Some(nix::sys::wait::WNOHANG)); match res { - Ok(nix::sys::wait::WaitStatus::Exited(pid, status)) => { - println!("PID {} exited with status {}", pid, status); + Ok(nix::sys::wait::WaitStatus::Exited(pid, _)) | + Ok(nix::sys::wait::WaitStatus::Signaled(pid, _, _)) => { + println!("PID {} exited", pid); if let Some(mut o) = brood.remove(&(pid as u32)) { match o.state { OffspringState::Infancy => { if o.attempts + 1 >= cfg.retries { @@ -248,9 +250,15 @@ fn shepard(mut cfg: EinConfig, signal_rx: Receiver) { } } }; }, + Ok(nix::sys::wait::WaitStatus::StillAlive) => break, Ok(_) => { println!("Some other thing we don't care about happened: {:?}", res); }, + Err(nix::Error::Sys(nix::Errno::ECHILD)) => { + println!("all children are dead, bailing"); + run = false; + break; + }, Err(e) => { println!("waitpid err: {}", e); break; @@ -267,16 +275,17 @@ fn shepard(mut cfg: EinConfig, signal_rx: Receiver) { for (_, o) in brood.iter_mut() { o.terminate(&mut cfg, &mut timer, timer_tx.clone()); } - break; + run = false; }, _ => () }, } + if !run { break; } } - println!("Waiting for all children to die"); + println!("Reaping children... (count={})", brood.len()); for (_, o) in brood.iter_mut() { - o.process.wait().unwrap(); + o.process.wait().ok(); } println!("Done."); } @@ -411,7 +420,7 @@ fn main() { println!("Registering signal handlers..."); let signal_rx = chan_signal::notify(&[Signal::INT, Signal::TERM, - //Signal::CHLD, // XXX: PR has been submitted + Signal::CHLD, // XXX: PR has been submitted Signal::USR2, Signal::HUP]); -- cgit v1.2.3