sway

i3-compatible Wayland compositor
git clone https://git.awy.one/sway
Log | Files | Refs | README | LICENSE

commit 85ec7002068277fe82dcc139ebb401b515ca5d80
parent 64e0731cc7206e8becfe6f80bc58362aa53f07b6
Author: emersion <contact@emersion.fr>
Date:   Fri, 27 Apr 2018 08:18:26 +0100

Merge pull request #1866 from ggreer/swaybar-cmd-sh

invoke_swaybar: Set process group id
Diffstat:
Msway/config/bar.c | 9+++++----
1 file changed, 5 insertions(+), 4 deletions(-)

diff --git a/sway/config/bar.c b/sway/config/bar.c @@ -17,7 +17,7 @@ static void terminate_swaybar(pid_t pid) { wlr_log(L_DEBUG, "Terminating swaybar %d", pid); - int ret = kill(pid, SIGTERM); + int ret = kill(-pid, SIGTERM); if (ret != 0) { wlr_log_errno(L_ERROR, "Unable to terminate swaybar %d", pid); } else { @@ -163,6 +163,7 @@ void invoke_swaybar(struct bar_config *bar) { bar->pid = fork(); if (bar->pid == 0) { + setpgid(0, 0); close(filedes[0]); // run custom swaybar @@ -172,9 +173,9 @@ void invoke_swaybar(struct bar_config *bar) { char *command = malloc(len + 1); if (!command) { const char msg[] = "Unable to allocate swaybar command string"; - size_t len = sizeof(msg); - if (write(filedes[1], &len, sizeof(int))) {}; - if (write(filedes[1], msg, len)) {}; + size_t msg_len = sizeof(msg); + if (write(filedes[1], &msg_len, sizeof(int))) {}; + if (write(filedes[1], msg, msg_len)) {}; close(filedes[1]); exit(1); }