X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=event.c;h=c5e5f400ba179be229bab548e63ebaef31c2db55;hb=fe3dfbbe90f813294bb69e41f996a000f63c1560;hp=1a8de56b208373c5e94b7100278f5583c51c0d39;hpb=95766d6241a401b3665ac1ad528b90c55e7b6810;p=dwm.git diff --git a/event.c b/event.c index 1a8de56..c5e5f40 100644 --- a/event.c +++ b/event.c @@ -4,6 +4,7 @@ */ #include "dwm.h" #include +#include #include #include @@ -118,21 +119,24 @@ buttonpress(XEvent *e) } } else if((c = getclient(ev->window))) { - higher(c); focus(c); switch(ev->button) { default: break; case Button1: - if(!c->ismax && (arrange == dofloat || c->isfloat)) + if(!c->ismax && (arrange == dofloat || c->isfloat)) { + restack(c); movemouse(c); + } break; case Button2: zoom(NULL); break; case Button3: - if(!c->ismax && (arrange == dofloat || c->isfloat)) + if(!c->ismax && (arrange == dofloat || c->isfloat)) { + restack(c); resizemouse(c); + } break; } } @@ -251,13 +255,15 @@ keypress(XEvent *e) XKeyEvent *ev = &e->xkey; keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0); - for(i = 0; i < len; i++) + for(i = 0; i < len; i++) { if(keysym == key[i].keysym && - CLEANMASK(key[i].mod) == CLEANMASK(ev->state)) { + CLEANMASK(key[i].mod) == CLEANMASK(ev->state)) + { if(key[i].func) key[i].func(&key[i].arg); return; } + } } static void @@ -355,6 +361,11 @@ grabkeys() unsigned int i; KeyCode code; + while(XGrabKeyboard(dpy, root, True, GrabModeAsync, + GrabModeAsync, CurrentTime) != GrabSuccess) + usleep(1000); + XUngrabKeyboard(dpy, CurrentTime); + for(i = 0; i < len; i++) { code = XKeysymToKeycode(dpy, key[i].keysym); XGrabKey(dpy, code, key[i].mod, root, True,