attempt to grab the keyboard only 1000 times, not forever.
authorAnselm R. Garbe <arg@suckless.org>
Wed, 7 Mar 2007 10:01:14 +0000 (11:01 +0100)
committerAnselm R. Garbe <arg@suckless.org>
Wed, 7 Mar 2007 10:01:14 +0000 (11:01 +0100)
config.mk
main.c

index 07b323b2d9ac8c07e0d8e85e36ca3ddb0cfd617e..75cc46df6df5e3db24c518cf636096b8caf52e3e 100644 (file)
--- a/config.mk
+++ b/config.mk
@@ -1,5 +1,5 @@
 # dmenu version
-VERSION = 2.7
+VERSION = 2.8
 
 # Customize below to fit your system
 
diff --git a/main.c b/main.c
index 0f07773029c7912ced5e4122d6fc2c3ce547442f..fa03ec8775ab6ea6d41cb898c83fcdb081041acb 100644 (file)
--- a/main.c
+++ b/main.c
@@ -108,11 +108,17 @@ drawmenu(void) {
        XFlush(dpy);
 }
 
-static void
+static Bool
 grabkeyboard(void) {
-       while(XGrabKeyboard(dpy, root, True, GrabModeAsync,
-                        GrabModeAsync, CurrentTime) != GrabSuccess)
+       unsigned int len;
+
+       for(len = 1000; len; len--) {
+               if(XGrabKeyboard(dpy, root, True, GrabModeAsync, GrabModeAsync, CurrentTime)
+                       == GrabSuccess)
+                       break;
                usleep(1000);
+       }
+       return len > 0;
 }
 
 static unsigned long
@@ -456,10 +462,10 @@ main(int argc, char *argv[]) {
        root = RootWindow(dpy, screen);
        if(isatty(STDIN_FILENO)) {
                maxname = readstdin();
-               grabkeyboard();
+               running = grabkeyboard();
        }
        else { /* prevent keypress loss */
-               grabkeyboard();
+               running = grabkeyboard();
                maxname = readstdin();
        }
        /* init modifier map */