summaryrefslogtreecommitdiffstats
path: root/proc.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2017-07-12 13:39:59 +0100
committerThomas Adam <thomas@xteddy.org>2017-07-12 13:43:08 +0100
commit1076a2e26c224d17c32a2d1770997d8718903f20 (patch)
tree2a51f6e719b9cbff0e37d7a887e56992ffb875bd /proc.c
parentfbbf5a108b01c742ca11e779845a4d19a1c5edd1 (diff)
parent51112221eeb31ced907f0dfcf077582996c20c07 (diff)
Merge branch 'obsd-master'
Conflicts: cmd-pipe-pane.c proc.c tmux.c window.c
Diffstat (limited to 'proc.c')
-rw-r--r--proc.c95
1 files changed, 67 insertions, 28 deletions
diff --git a/proc.c b/proc.c
index fa2b61b7..31d195a8 100644
--- a/proc.c
+++ b/proc.c
@@ -22,6 +22,7 @@
#include <errno.h>
#include <event.h>
+#include <signal.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
@@ -33,6 +34,14 @@ struct tmuxproc {
int exit;
void (*signalcb)(int);
+
+ struct event ev_sighup;
+ struct event ev_sigchld;
+ struct event ev_sigcont;
+ struct event ev_sigterm;
+ struct event ev_sigusr1;
+ struct event ev_sigusr2;
+ struct event ev_sigwinch;
};
struct tmuxpeer {
@@ -159,36 +168,12 @@ proc_send(struct tmuxpeer *peer, enum msgtype type, int fd, const void *buf,
return (0);
}
-int
-proc_send_s(struct tmuxpeer *peer, enum msgtype type, const char *s)
-{
- return (proc_send(peer, type, -1, s, strlen(s) + 1));
-}
-
struct tmuxproc *
-proc_start(const char *name, struct event_base *base, int forkflag,
- void (*signalcb)(int))
+proc_start(const char *name)
{
struct tmuxproc *tp;
struct utsname u;
- if (forkflag) {
- switch (fork()) {
- case -1:
- fatal("fork failed");
- case 0:
- break;
- default:
- return (NULL);
- }
- if (daemon(1, 0) != 0)
- fatal("daemon failed");
-
- clear_signals(0);
- if (event_reinit(base) != 0)
- fatalx("event_reinit failed");
- }
-
log_open(name);
setproctitle("%s (%s)", name, socket_path);
@@ -203,9 +188,6 @@ proc_start(const char *name, struct event_base *base, int forkflag,
tp = xcalloc(1, sizeof *tp);
tp->name = xstrdup(name);
- tp->signalcb = signalcb;
- set_signals(proc_signal_cb, tp);
-
return (tp);
}
@@ -225,6 +207,63 @@ proc_exit(struct tmuxproc *tp)
tp->exit = 1;
}
+void
+proc_set_signals(struct tmuxproc *tp, void (*signalcb)(int))
+{
+ struct sigaction sa;
+
+ tp->signalcb = signalcb;
+
+ memset(&sa, 0, sizeof sa);
+ sigemptyset(&sa.sa_mask);
+ sa.sa_flags = SA_RESTART;
+ sa.sa_handler = SIG_IGN;
+
+ sigaction(SIGINT, &sa, NULL);
+ sigaction(SIGPIPE, &sa, NULL);
+ sigaction(SIGUSR2, &sa, NULL);
+ sigaction(SIGTSTP, &sa, NULL);
+
+ signal_set(&tp->ev_sighup, SIGHUP, proc_signal_cb, tp);
+ signal_add(&tp->ev_sighup, NULL);
+ signal_set(&tp->ev_sigchld, SIGCHLD, proc_signal_cb, tp);
+ signal_add(&tp->ev_sigchld, NULL);
+ signal_set(&tp->ev_sigcont, SIGCONT, proc_signal_cb, tp);
+ signal_add(&tp->ev_sigcont, NULL);
+ signal_set(&tp->ev_sigterm, SIGTERM, proc_signal_cb, tp);
+ signal_add(&tp->ev_sigterm, NULL);
+ signal_set(&tp->ev_sigusr1, SIGUSR1, proc_signal_cb, tp);
+ signal_add(&tp->ev_sigusr1, NULL);
+ signal_set(&tp->ev_sigusr2, SIGUSR2, proc_signal_cb, tp);
+ signal_add(&tp->ev_sigusr2, NULL);
+ signal_set(&tp->ev_sigwinch, SIGWINCH, proc_signal_cb, tp);
+ signal_add(&tp->ev_sigwinch, NULL);
+}
+
+void
+proc_clear_signals(struct tmuxproc *tp)
+{
+ struct sigaction sa;
+
+ memset(&sa, 0, sizeof sa);
+ sigemptyset(&sa.sa_mask);
+ sa.sa_flags = SA_RESTART;
+ sa.sa_handler = SIG_DFL;
+
+ sigaction(SIGINT, &sa, NULL);
+ sigaction(SIGPIPE, &sa, NULL);
+ sigaction(SIGUSR2, &sa, NULL);
+ sigaction(SIGTSTP, &sa, NULL);
+
+ event_del(&tp->ev_sighup);
+ event_del(&tp->ev_sigchld);
+ event_del(&tp->ev_sigcont);
+ event_del(&tp->ev_sigterm);
+ event_del(&tp->ev_sigusr1);
+ event_del(&tp->ev_sigusr2);
+ event_del(&tp->ev_sigwinch);
+}
+
struct tmuxpeer *
proc_add_peer(struct tmuxproc *tp, int fd,
void (*dispatchcb)(struct imsg *, void *), void *arg)