From: Anselm R. Garbe <arg@suckless.org>
Date: Fri, 2 Mar 2007 20:50:05 +0000 (+0100)
Subject: grab on the slock window instead on the root window
X-Git-Url: https://git.danieliu.xyz/?a=commitdiff_plain;h=8322f22871ee1da82546dfcdea484ef9db6d4942;p=slock.git

grab on the slock window instead on the root window
---

diff --git a/slock.c b/slock.c
index ba75493..97a80c5 100644
--- a/slock.c
+++ b/slock.c
@@ -86,15 +86,16 @@ main(int argc, char **argv) {
 	pmap = XCreateBitmapFromData(dpy, w, curs, 8, 8);
 	invisible = XCreatePixmapCursor(dpy, pmap, pmap, &black, &black, 0, 0);
 	XDefineCursor(dpy, w, invisible);
+	XMapRaised(dpy, w);
 	for(len = 1000; len; len--) {
-		if(XGrabPointer(dpy, root, False, ButtonPressMask | ButtonReleaseMask | PointerMotionMask,
+		if(XGrabPointer(dpy, w, False, ButtonPressMask | ButtonReleaseMask | PointerMotionMask,
 			GrabModeAsync, GrabModeSync, None, invisible, CurrentTime) == GrabSuccess)
 			break;
 		usleep(1000);
 	}
 	if((running = running && (len > 0))) {
 		for(len = 1000; len; len--) {
-			if(XGrabKeyboard(dpy, root, True, GrabModeAsync, GrabModeAsync, CurrentTime)
+			if(XGrabKeyboard(dpy, w, True, GrabModeAsync, GrabModeAsync, CurrentTime)
 				== GrabSuccess)
 				break;
 			usleep(1000);
@@ -102,7 +103,6 @@ main(int argc, char **argv) {
 		running = (len > 0);
 	}
 	len = 0;
-	XMapRaised(dpy, w);
 	XSync(dpy, False);
 
 	/* main event loop */