aboutsummaryrefslogtreecommitdiff
path: root/sway/config
diff options
context:
space:
mode:
authorDaniel Eklöf <daniel@ekloef.se>2021-06-02 19:55:03 +0200
committerSimon Ser <contact@emersion.fr>2021-06-05 11:50:11 +0200
commit3bf99198a66e794502d338f3d4ee790f9798a01b (patch)
tree4626e592663471cb9eb8ec0b99f9774fa27a7f0f /sway/config
parent1dd6df6a5df3924d42a25bd17dab0ef8beecad61 (diff)
sway: restore SIGPIPE handler before exec:ing swaybar
Sway ignores SIGPIPE (by installing a SIG_IGN handler), in order to “prevent IPC from crashing Sway”. SIG_IGN handlers are the *only* signal handlers inherited in sub-processes. As such, we should be a good citizen and restore the SIGPIPE handler to its default handler. Original bug report: https://www.mail-archive.com/debian-bugs-dist@lists.debian.org/msg1806907.html
Diffstat (limited to 'sway/config')
-rw-r--r--sway/config/bar.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/sway/config/bar.c b/sway/config/bar.c
index 8970f3fd..e09add44 100644
--- a/sway/config/bar.c
+++ b/sway/config/bar.c
@@ -217,6 +217,7 @@ static void invoke_swaybar(struct bar_config *bar) {
sigset_t set;
sigemptyset(&set);
sigprocmask(SIG_SETMASK, &set, NULL);
+ signal(SIGPIPE, SIG_DFL);
pid = fork();
if (pid < 0) {