diff options
author | rafa_99 <rafa99@protonmail.com> | 2020-07-04 23:23:24 +0000 |
---|---|---|
committer | rafa_99 <rafa99@protonmail.com> | 2021-04-13 03:36:19 +0100 |
commit | d27978d598eca99d285be2959d2fd37fe0a4b7bb (patch) | |
tree | d354fa50a9c68cc9acd5e24f154ad8b880cf18ad /dwm.c | |
parent | d928ad0830b0cc1f9cea3f9638460a17465ac5a0 (diff) |
Restart Signal
Diffstat (limited to 'dwm.c')
-rw-r--r-- | dwm.c | 22 |
1 files changed, 22 insertions, 0 deletions
@@ -206,6 +206,8 @@ static void setup(void); static void seturgent(Client *c, int urg); static void showhide(Client *c); static void sigchld(int unused); +static void sighup(int unused); +static void sigterm(int unused); static void spawn(const Arg *arg); static void tag(const Arg *arg); static void tagmon(const Arg *arg); @@ -267,6 +269,7 @@ static void (*handler[LASTEvent]) (XEvent *) = { [UnmapNotify] = unmapnotify }; static Atom wmatom[WMLast], netatom[NetLast]; +static int restart = 0; static int running = 1; static Cur *cursor[CurLast]; static Clr **scheme; @@ -1367,6 +1370,7 @@ propertynotify(XEvent *e) void quit(const Arg *arg) { + if(arg->i) restart = 1; running = 0; } @@ -1655,6 +1659,9 @@ setup(void) /* clean up any zombies immediately */ sigchld(0); + signal(SIGHUP, sighup); + signal(SIGTERM, sigterm); + /* init screen */ screen = DefaultScreen(dpy); sw = DisplayWidth(dpy, screen); @@ -1756,6 +1763,20 @@ sigchld(int unused) } void +sighup(int unused) +{ + Arg a = {.i = 1}; + quit(&a); +} + +void +sigterm(int unused) +{ + Arg a = {.i = 0}; + quit(&a); +} + +void spawn(const Arg *arg) { if (arg->v == dmenucmd) @@ -2308,6 +2329,7 @@ main(int argc, char *argv[]) #endif /* __OpenBSD__ */ scan(); run(); + if(restart) execvp(argv[0], argv); cleanup(); XCloseDisplay(dpy); return EXIT_SUCCESS; |