aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/cmd/rio/client.c4
-rw-r--r--src/cmd/rio/main.c11
2 files changed, 8 insertions, 7 deletions
diff --git a/src/cmd/rio/client.c b/src/cmd/rio/client.c
index 5222f210..16168b49 100644
--- a/src/cmd/rio/client.c
+++ b/src/cmd/rio/client.c
@@ -23,11 +23,11 @@ setactive(Client *c, int on)
XUngrabButton(dpy, AnyButton, AnyModifier, c->parent);
XSetInputFocus(dpy, c->window, RevertToPointerRoot, timestamp());
if (c->proto & Ptakefocus)
- sendcmessage(c->window, wm_protocols, wm_take_focus, 0);
+ sendcmessage(c->window, wm_protocols, wm_take_focus, 0, 0);
cmapfocus(c);
} else {
if (c->proto & Plosefocus)
- sendcmessage(c->window, wm_protocols, wm_lose_focus, 0);
+ sendcmessage(c->window, wm_protocols, wm_lose_focus, 0, 0);
XGrabButton(dpy, AnyButton, AnyModifier, c->parent, False,
ButtonMask, GrabModeAsync, GrabModeSync, None, None);
}
diff --git a/src/cmd/rio/main.c b/src/cmd/rio/main.c
index 22395d70..7c7e7146 100644
--- a/src/cmd/rio/main.c
+++ b/src/cmd/rio/main.c
@@ -143,12 +143,12 @@ main(int argc, char *argv[])
curtime = -1; /* don't care */
if (do_exit) {
- sendcmessage(DefaultRootWindow(dpy), exit_rio, 0L, 1);
+ sendcmessage(DefaultRootWindow(dpy), exit_rio, 0L, 1, 1);
XSync(dpy, False);
exit(0);
}
if (do_restart) {
- sendcmessage(DefaultRootWindow(dpy), restart_rio, 0L, 1);
+ sendcmessage(DefaultRootWindow(dpy), restart_rio, 0L, 1, 1);
XSync(dpy, False);
exit(0);
}
@@ -398,7 +398,7 @@ timestamp(void)
}
void
-sendcmessage(Window w, Atom a, long x, int isroot)
+sendcmessage(Window w, Atom a, long x, int isroot, int usemask)
{
XEvent ev;
int status;
@@ -411,8 +411,9 @@ sendcmessage(Window w, Atom a, long x, int isroot)
ev.xclient.format = 32;
ev.xclient.data.l[0] = x;
ev.xclient.data.l[1] = timestamp();
- mask = 0L;
- if (isroot)
+ if (usemask == 0)
+ mask = 0;
+ else if (isroot)
mask = SubstructureRedirectMask; /* magic! */
else
mask = ExposureMask; /* not really correct but so be it */