aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEthan Marshall <ethan@ethanjmarshall.co.uk>2022-08-09 14:55:04 +0100
committerEthan Marshall <ethan@ethanjmarshall.co.uk>2022-08-09 14:58:20 +0100
commit96edcd2d020a3f088d70ca0f872602a25957f15c (patch)
tree80c9727eb47b474384e01838a0f9f0fb3e65cc88
parentMerge branch 'dfuehrer-fastscroll_fix' (diff)
downloaddwmblocks-96edcd2d020a3f088d70ca0f872602a25957f15c.tar.gz
dwmblocks-96edcd2d020a3f088d70ca0f872602a25957f15c.tar.bz2
dwmblocks-96edcd2d020a3f088d70ca0f872602a25957f15c.tar.xz
dwmblocks-96edcd2d020a3f088d70ca0f872602a25957f15c.tar.zst
dwmblocks-96edcd2d020a3f088d70ca0f872602a25957f15c.zip
Fix statusbar freezing
Block signal handlers from running recursively (when a handler is already running) to avoid deadlock on Xorg connection.
-rw-r--r--dwmblocks.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/dwmblocks.c b/dwmblocks.c
index 0969ed7..b7f38a7 100644
--- a/dwmblocks.c
+++ b/dwmblocks.c
@@ -183,6 +183,14 @@ int getstatus(char *str, char *last)
void setroot()
{
+ /* block all signals until after root updated */
+ sigset_t new, old;
+ sigfillset(&new);
+ if (sigprocmask(SIG_SETMASK, &new, &old) < 0) {
+ perror("sigset");
+ exit(1);
+ }
+
if (!getstatus(statusstr[0], statusstr[1]))//Only set root if text has changed.
return;
Display *d = XOpenDisplay(NULL);
@@ -192,7 +200,10 @@ void setroot()
screen = DefaultScreen(dpy);
root = RootWindow(dpy, screen);
XStoreName(dpy, root, statusstr[0]);
- XCloseDisplay(dpy);
+ XCloseDisplay(d);
+
+ /* restore signals to default */
+ sigprocmask(SIG_SETMASK, &old, NULL);
}
void pstdout()