From 8606560d411fd626523d7b7a6d19085b35c5ab9c Mon Sep 17 00:00:00 2001 From: Your Name Date: Wed, 21 Oct 2020 23:57:43 +0100 Subject: fixed signal func calling bug --- config.h | 42 ------------------------------------------ dwm.c | 55 +++++++++++++++++++++++++++++++++++++++++++++++++++++-- 2 files changed, 53 insertions(+), 44 deletions(-) diff --git a/config.h b/config.h index dc270f9..4a7321d 100644 --- a/config.h +++ b/config.h @@ -138,48 +138,6 @@ static Button buttons[] = { { ClkTagBar, MODKEY, Button3, toggletag, {0} }, }; -void -setlayoutex(const Arg *arg) -{ - setlayout(&((Arg) { .v = &layouts[arg->i] })); -} - -void -viewex(const Arg *arg) -{ - view(&((Arg) { .ui = 1 << (arg->ui - 1)})); -} - -void -viewall(const Arg *arg) -{ - view(&((Arg){.ui = ~0})); -} - -void -toggleviewex(const Arg *arg) -{ - toggleview(&((Arg) { .ui = 1 << (arg->ui - 1)})); -} - -void -tagex(const Arg *arg) -{ - tag(&((Arg) { .ui = 1 << (arg->ui - 1)})); -} - -void -toggletagex(const Arg *arg) -{ - toggletag(&((Arg) { .ui = 1 << (arg->ui - 1)})); -} - -void -tagall(const Arg *arg) -{ - tag(&((Arg){.ui = ~0})); -} - /* signal definitions */ /* signum must be greater than 0 */ /* trigger signals using `xsetroot -name "fsignal: [ ]"` */ diff --git a/dwm.c b/dwm.c index bf4f942..13eb462 100644 --- a/dwm.c +++ b/dwm.c @@ -157,6 +157,13 @@ static void arrange(Monitor *m); static void arrangemon(Monitor *m); static void attach(Client *c); static void attachstack(Client *c); +void setlayoutex(const Arg *arg); +void viewex(const Arg *arg); +void viewall(const Arg *arg); +void toggleviewex(const Arg *arg); +void tagex(const Arg *arg); +void toggletagex(const Arg *arg); +void tagall(const Arg *arg); static int fake_signal(void); static void buttonpress(XEvent *e); static void checkotherwm(void); @@ -1020,6 +1027,48 @@ keypress(XEvent *e) keys[i].func(&(keys[i].arg)); }**/ +void +setlayoutex(const Arg *arg) +{ + setlayout(&((Arg) { .v = &layouts[arg->i] })); +} + +void +viewex(const Arg *arg) +{ + view(&((Arg) { .ui = 1 << (arg->ui - 1)})); +} + +void +viewall(const Arg *arg) +{ + view(&((Arg){.ui = ~0})); +} + +void +toggleviewex(const Arg *arg) +{ + toggleview(&((Arg) { .ui = 1 << (arg->ui - 1)})); +} + +void +tagex(const Arg *arg) +{ + tag(&((Arg) { .ui = 1 << (arg->ui - 1)})); +} + +void +toggletagex(const Arg *arg) +{ + toggletag(&((Arg) { .ui = 1 << (arg->ui - 1)})); +} + +void +tagall(const Arg *arg) +{ + tag(&((Arg){.ui = ~0})); +} + int fake_signal(void) { @@ -1052,8 +1101,10 @@ fake_signal(void) // Check if a signal was found, and if so handle it for (i = 0; i < LENGTH(signals); i++) if (strncmp(str_sig, signals[i].sig, len_str_sig) == 0 && signals[i].func) - signals[i].func(&(arg)); - + { + signals[i].func(&(arg)); + return 1; + } // A fake signal was sent return 1; } -- cgit 1.4.1