[hackers] [dmenu] faster grab || Connor Lane Smith

From: <hg_AT_suckless.org>
Date: Sun, 15 May 2011 15:13:37 +0200 (CEST)

changeset: 404:f4b8a0b362b6
tag: tip
user: Connor Lane Smith <cls_AT_lubutu.com>
date: Sun May 15 14:13:31 2011 +0100
files: dmenu.c
description:
faster grab

diff -r 9772669b60f7 -r f4b8a0b362b6 dmenu.c
--- a/dmenu.c Sun May 15 13:58:54 2011 +0100
+++ b/dmenu.c Sun May 15 14:13:31 2011 +0100
@@ -57,7 +57,7 @@
 static Item *items = NULL;
 static Item *matches, *matchend;
 static Item *prev, *curr, *next, *sel;
-static Window root, win;
+static Window win;
 
 static int (*fstrncmp)(const char *, const char *, size_t) = strncmp;
 
@@ -104,14 +104,14 @@
         initfont(dc, font);
 
         if(fast) {
- setup();
+ grabkeyboard();
                 readstdin();
         }
         else {
                 readstdin();
- setup();
+ grabkeyboard();
         }
- match();
+ setup();
         run();
         return EXIT_FAILURE;
 
@@ -209,7 +209,8 @@
         int i;
 
         for(i = 0; i < 1000; i++) {
- if(!XGrabKeyboard(dc->dpy, root, True, GrabModeAsync, GrabModeAsync, CurrentTime))
+ if(XGrabKeyboard(dc->dpy, DefaultRootWindow(dc->dpy), True,
+ GrabModeAsync, GrabModeAsync, CurrentTime) == GrabSuccess)
                         return;
                 usleep(1000);
         }
@@ -487,22 +488,21 @@
 
 void
 setup(void) {
- int x, y, screen;
+ int x, y, screen = DefaultScreen(dc->dpy);
+ Window root = RootWindow(dc->dpy, screen);
         XSetWindowAttributes wa;
 #ifdef XINERAMA
         int n;
         XineramaScreenInfo *info;
 #endif
 
- screen = DefaultScreen(dc->dpy);
- root = RootWindow(dc->dpy, screen);
- utf8 = XInternAtom(dc->dpy, "UTF8_STRING", False);
-
         normcol[ColBG] = getcolor(dc, normbgcolor);
         normcol[ColFG] = getcolor(dc, normfgcolor);
         selcol[ColBG] = getcolor(dc, selbgcolor);
         selcol[ColFG] = getcolor(dc, selfgcolor);
 
+ utf8 = XInternAtom(dc->dpy, "UTF8_STRING", False);
+
         /* menu geometry */
         bh = dc->font.height + 2;
         lines = MAX(lines, 0);
@@ -539,9 +539,10 @@
                             DefaultVisual(dc->dpy, screen),
                             CWOverrideRedirect | CWBackPixmap | CWEventMask, &wa);
 
- grabkeyboard();
         resizedc(dc, mw, mh);
         inputw = MIN(inputw, mw/3);
         promptw = prompt ? textw(dc, prompt) : 0;
         XMapRaised(dc->dpy, win);
+ drawmenu();
+ match();
 }
Received on Sun May 15 2011 - 15:13:37 CEST

This archive was generated by hypermail 2.2.0 : Sun May 15 2011 - 15:24:04 CEST