refactor(eventloop): Pipe handling

This commit is contained in:
Michael Carlberg 2016-06-14 12:12:09 +02:00
parent 266705e016
commit 3bc408e3cf
5 changed files with 26 additions and 17 deletions

View file

@ -29,8 +29,6 @@ class EventLoop
int fd_stdout = STDOUT_FILENO;
std::string pipe_filename;
sigset_t wait_mask;
// <tag, module_name>
// std::map<std::string, std::string> stdin_subs;
std::vector<std::string> stdin_subs;

View file

@ -31,6 +31,7 @@ namespace proc
pid_t wait(int *status);
pid_t wait_for_completion(pid_t pid, int *status, int options = 0);
pid_t wait_for_completion(int *status, int options = 0);
pid_t wait_for_completion(pid_t pid);
pid_t wait_for_completion_nohang(pid_t pid, int *status);
pid_t wait_for_completion_nohang(int *status);
pid_t wait_for_completion_nohang();

View file

@ -75,16 +75,20 @@ void EventLoop::wait()
int sig = 0;
sigemptyset(&this->wait_mask);
sigaddset(&this->wait_mask, SIGINT);
sigaddset(&this->wait_mask, SIGQUIT);
sigaddset(&this->wait_mask, SIGTERM);
sigset_t wait_mask;
sigemptyset(&wait_mask);
sigaddset(&wait_mask, SIGINT);
sigaddset(&wait_mask, SIGQUIT);
sigaddset(&wait_mask, SIGTERM);
if (pthread_sigmask(SIG_BLOCK, &this->wait_mask, nullptr) == -1)
if (pthread_sigmask(SIG_BLOCK, &wait_mask, nullptr) == -1)
logger->fatal(StrErrno());
// Ignore SIGPIPE since we'll handle it manually
signal(SIGPIPE, SIG_IGN);
// Wait for termination signal
sigwait(&this->wait_mask, &sig);
sigwait(&wait_mask, &sig);
this->logger->info("Termination signal received... Shutting down");
}
@ -134,6 +138,11 @@ void EventLoop::loop_write()
this->write_stdout();
} catch (Exception &e) {
this->logger->error(e.what());
auto pid = proc::get_process_id();
proc::kill(pid, SIGTERM);
proc::wait_for_completion(pid);
return;
}
}
@ -207,11 +216,10 @@ void EventLoop::write_stdout()
if (!this->running())
return;
// dprintf(this->fd_stdout, "\033[2J\033[1;1H\033[0mCleared! \033[35;1m %s\n", data.c_str());
dprintf(this->fd_stdout, "%s\n", data.c_str());
if (dprintf(this->fd_stdout, "%s\n", data.c_str()) == -1)
throw EventLoopTerminate("Failed to write to stdout");
} catch (RegistryError &e) {
this->logger->error(e.what());
return;
}
}

View file

@ -51,12 +51,6 @@ int main(int argc, char **argv)
int retval = EXIT_SUCCESS;
auto logger = get_logger();
sigset_t pipe_mask;
sigemptyset(&pipe_mask);
sigaddset(&pipe_mask, SIGPIPE);
if (pthread_sigmask(SIG_BLOCK, &pipe_mask, nullptr) == -1)
logger->fatal(StrErrno());
try {
auto usage = "Usage: "+ std::string(argv[0]) + " bar_name [OPTION...]";
@ -201,5 +195,7 @@ int main(int argc, char **argv)
while (proc::wait_for_completion_nohang() > 0);
log_trace("Reached end of application");
return retval;
}

View file

@ -95,6 +95,12 @@ namespace proc
return wait_for_completion(-1, status, options);
}
pid_t wait_for_completion(pid_t pid)
{
int status;
return wait_for_completion(pid, &status);
}
pid_t wait_for_completion_nohang(pid_t pid, int *status) {
return wait_for_completion(pid, status, WNOHANG);
}