X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;ds=sidebyside;f=event.c;h=50c59a0c9ef78db7b4dd1d1907c9c0eab7756fe8;hb=b4d53bf194f9f9214b6c79d397d723ba53663b4b;hp=fe25deebc27835bb9147232c54f6c4f347bc7966;hpb=bcb07de75000e75a450e4dddf851e9ce69966f59;p=dwm.git diff --git a/event.c b/event.c index fe25dee..50c59a0 100644 --- a/event.c +++ b/event.c @@ -1,3 +1,4 @@ +#include /* * (C)opyright MMVI Anselm R. Garbe * See LICENSE file for license details. @@ -37,6 +38,10 @@ movemouse(Client *c) { for(;;) { XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev); switch (ev.type) { + case ButtonRelease: + resize(c, True, TopLeft); + XUngrabPointer(dpy, CurrentTime); + return; case Expose: handler[Expose](&ev); break; @@ -46,9 +51,6 @@ movemouse(Client *c) { c->y = ocy + (ev.xmotion.y - y1); resize(c, False, TopLeft); break; - case ButtonRelease: - XUngrabPointer(dpy, CurrentTime); - return; } } } @@ -70,6 +72,10 @@ resizemouse(Client *c) { for(;;) { XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev); switch(ev.type) { + case ButtonRelease: + resize(c, True, TopLeft); + XUngrabPointer(dpy, CurrentTime); + return; case Expose: handler[Expose](&ev); break; @@ -87,9 +93,6 @@ resizemouse(Client *c) { sticky = (ocy <= ev.xmotion.y) ? TopRight : BotRight; resize(c, True, sticky); break; - case ButtonRelease: - XUngrabPointer(dpy, CurrentTime); - return; } } } @@ -151,6 +154,7 @@ configurerequest(XEvent *e) { XEvent synev; XWindowChanges wc; + fputs("configurerequest\n", stderr); if((c = getclient(ev->window))) { c->ismax = False; gravitate(c, True); @@ -172,19 +176,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; - XSendEvent(dpy, c->win, True, NoEventMask, &synev); - } + else + configure(c); XSync(dpy, False); if(c->isfloat) resize(c, False, TopLeft); @@ -218,6 +211,7 @@ enternotify(XEvent *e) { Client *c; XCrossingEvent *ev = &e->xcrossing; + fputs("enternotify\n", stderr); if(ev->mode != NotifyNormal || ev->detail == NotifyInferior) return; @@ -305,6 +299,7 @@ propertynotify(XEvent *e) { Window trans; XPropertyEvent *ev = &e->xproperty; + fputs("propertynotify\n", stderr); if(ev->state == PropertyDelete) return; /* ignore */