X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=event.c;h=e97abadcb4ad61644d16db81a6aa0d30987a9351;hb=05fbbbd8dc3f990f07fe2055693bef0031fd4623;hp=125c6a20353b881589033721d616104ae40c9822;hpb=823fb1118a30ae18a41650cf650df6b67861130b;p=dwm.git diff --git a/event.c b/event.c index 125c6a2..e97abad 100644 --- a/event.c +++ b/event.c @@ -18,7 +18,7 @@ typedef struct { KEYS -#define CLEANMASK(mask) (mask & ~(NUMLOCKMASK | LockMask)) +#define CLEANMASK(mask) (mask & ~(numlockmask | LockMask)) static void movemouse(Client *c) @@ -109,16 +109,29 @@ buttonpress(XEvent *e) for(a.i = 0; a.i < ntags; a.i++) { x += textw(tags[a.i]); if(ev->x < x) { - if(ev->button == Button3) - toggleview(&a); - else + switch(ev->button) { + case Button1: view(&a); + break; + case Button2: + toggletag(&a); + break; + case Button3: + toggleview(&a); + break; + } return; } } + if(ev->x < x + bmw) { + if(ev->button == Button1) + togglemode(NULL); + } } else if((c = getclient(ev->window))) { focus(c); + if(CLEANMASK(ev->state) != MODKEY) + return; switch(ev->button) { default: break; @@ -142,15 +155,37 @@ buttonpress(XEvent *e) } static void +synconfig(Client *c, int x, int y, int w, int h, unsigned int border) +{ + XEvent synev; + + synev.type = ConfigureNotify; + synev.xconfigure.display = dpy; + synev.xconfigure.event = c->win; + synev.xconfigure.window = c->win; + synev.xconfigure.x = x; + synev.xconfigure.y = y; + synev.xconfigure.width = w; + synev.xconfigure.height = h; + synev.xconfigure.border_width = border; + synev.xconfigure.above = None; + XSendEvent(dpy, c->win, True, NoEventMask, &synev); +} + +static void configurerequest(XEvent *e) { + unsigned long newmask; Client *c; XConfigureRequestEvent *ev = &e->xconfigurerequest; - XEvent synev; XWindowChanges wc; - unsigned long newmask; if((c = getclient(ev->window))) { + if(!c->isfloat && (arrange != dofloat) && c->ismax) { + synconfig(c, sx, sy + bh, sw - 2, sh - 2 - bh, ev->border_width); + XSync(dpy, False); + return; + } gravitate(c, True); if(ev->value_mask & CWX) c->x = ev->x; @@ -170,20 +205,8 @@ configurerequest(XEvent *e) newmask = ev->value_mask & (~(CWSibling | CWStackMode | CWBorderWidth)); if(newmask) XConfigureWindow(dpy, c->win, newmask, &wc); - else { - synev.type = ConfigureNotify; - synev.xconfigure.display = dpy; - synev.xconfigure.event = c->win; - synev.xconfigure.window = c->win; - synev.xconfigure.x = c->x; - synev.xconfigure.y = c->y; - synev.xconfigure.width = c->w; - synev.xconfigure.height = c->h; - synev.xconfigure.border_width = c->border; - synev.xconfigure.above = None; - /* Send synthetic ConfigureNotify */ - XSendEvent(dpy, c->win, True, NoEventMask, &synev); - } + else + synconfig(c, c->x, c->y, c->w, c->h, c->border); XSync(dpy, False); if(c->isfloat) resize(c, False, TopLeft); @@ -378,9 +401,22 @@ grabkeys() GrabModeAsync, GrabModeAsync); XGrabKey(dpy, code, key[i].mod | LockMask, root, True, GrabModeAsync, GrabModeAsync); - XGrabKey(dpy, code, key[i].mod | NUMLOCKMASK, root, True, + XGrabKey(dpy, code, key[i].mod | numlockmask, root, True, GrabModeAsync, GrabModeAsync); - XGrabKey(dpy, code, key[i].mod | NUMLOCKMASK | LockMask, root, True, + XGrabKey(dpy, code, key[i].mod | numlockmask | LockMask, root, True, GrabModeAsync, GrabModeAsync); } } + +void +procevent() +{ + XEvent ev; + + while(XPending(dpy)) { + XNextEvent(dpy, &ev); + if(handler[ev.type]) + (handler[ev.type])(&ev); /* call handler */ + } +} +