dwm-meillo
changeset 491:12395ef46d97
added configure(), but this doesn't really fix those frking broken SDL apps
author | arg@mmvi |
---|---|
date | Tue, 26 Sep 2006 07:40:19 +0200 (2006-09-26) |
parents | 303d3384720e |
children | 5df494262dfd |
files | client.c dwm.h event.c |
diffstat | 3 files changed, 27 insertions(+), 13 deletions(-) [+] |
line diff
1.1 --- a/client.c Mon Sep 25 21:28:00 2006 +0200 1.2 +++ b/client.c Tue Sep 26 07:40:19 2006 +0200 1.3 @@ -81,6 +81,23 @@ 1.4 } 1.5 1.6 void 1.7 +configure(Client *c) { 1.8 + XEvent synev; 1.9 + 1.10 + synev.type = ConfigureNotify; 1.11 + synev.xconfigure.display = dpy; 1.12 + synev.xconfigure.event = c->win; 1.13 + synev.xconfigure.window = c->win; 1.14 + synev.xconfigure.x = c->x; 1.15 + synev.xconfigure.y = c->y; 1.16 + synev.xconfigure.width = c->w; 1.17 + synev.xconfigure.height = c->h; 1.18 + synev.xconfigure.border_width = c->border; 1.19 + synev.xconfigure.above = None; 1.20 + XSendEvent(dpy, c->win, True, NoEventMask, &synev); 1.21 +} 1.22 + 1.23 +void 1.24 focus(Client *c) { 1.25 Client *old; 1.26 1.27 @@ -299,6 +316,7 @@ 1.28 else 1.29 wc.border_width = 1; 1.30 XConfigureWindow(dpy, c->win, CWX | CWY | CWWidth | CWHeight | CWBorderWidth, &wc); 1.31 + configure(c); 1.32 XSync(dpy, False); 1.33 } 1.34
2.1 --- a/dwm.h Mon Sep 25 21:28:00 2006 +0200 2.2 +++ b/dwm.h Tue Sep 26 07:40:19 2006 +0200 2.3 @@ -109,6 +109,7 @@ 2.4 2.5 /* client.c */ 2.6 extern void ban(Client *c); /* ban c from screen */ 2.7 +extern void configure(Client *c); /* send synthetic configure event */ 2.8 extern void focus(Client *c); /* focus c, c may be NULL */ 2.9 extern Client *getclient(Window w); /* return client of w */ 2.10 extern Client *getctitle(Window w); /* return client of title window */
3.1 --- a/event.c Mon Sep 25 21:28:00 2006 +0200 3.2 +++ b/event.c Tue Sep 26 07:40:19 2006 +0200 3.3 @@ -1,3 +1,4 @@ 3.4 +#include <stdio.h> 3.5 /* 3.6 * (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com> 3.7 * See LICENSE file for license details. 3.8 @@ -38,6 +39,7 @@ 3.9 XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev); 3.10 switch (ev.type) { 3.11 case ButtonRelease: 3.12 + resize(c, True, TopLeft); 3.13 XUngrabPointer(dpy, CurrentTime); 3.14 return; 3.15 case Expose: 3.16 @@ -71,6 +73,7 @@ 3.17 XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev); 3.18 switch(ev.type) { 3.19 case ButtonRelease: 3.20 + resize(c, True, TopLeft); 3.21 XUngrabPointer(dpy, CurrentTime); 3.22 return; 3.23 case Expose: 3.24 @@ -151,6 +154,7 @@ 3.25 XEvent synev; 3.26 XWindowChanges wc; 3.27 3.28 + fputs("configurerequest\n", stderr); 3.29 if((c = getclient(ev->window))) { 3.30 c->ismax = False; 3.31 gravitate(c, True); 3.32 @@ -172,19 +176,8 @@ 3.33 newmask = ev->value_mask & (~(CWSibling | CWStackMode | CWBorderWidth)); 3.34 if(newmask) 3.35 XConfigureWindow(dpy, c->win, newmask, &wc); 3.36 - else { 3.37 - synev.type = ConfigureNotify; 3.38 - synev.xconfigure.display = dpy; 3.39 - synev.xconfigure.event = c->win; 3.40 - synev.xconfigure.window = c->win; 3.41 - synev.xconfigure.x = c->x; 3.42 - synev.xconfigure.y = c->y; 3.43 - synev.xconfigure.width = c->w; 3.44 - synev.xconfigure.height = c->h; 3.45 - synev.xconfigure.border_width = c->border; 3.46 - synev.xconfigure.above = None; 3.47 - XSendEvent(dpy, c->win, True, NoEventMask, &synev); 3.48 - } 3.49 + else 3.50 + configure(c); 3.51 XSync(dpy, False); 3.52 if(c->isfloat) 3.53 resize(c, False, TopLeft); 3.54 @@ -218,6 +211,7 @@ 3.55 Client *c; 3.56 XCrossingEvent *ev = &e->xcrossing; 3.57 3.58 + fputs("enternotify\n", stderr); 3.59 if(ev->mode != NotifyNormal || ev->detail == NotifyInferior) 3.60 return; 3.61 3.62 @@ -305,6 +299,7 @@ 3.63 Window trans; 3.64 XPropertyEvent *ev = &e->xproperty; 3.65 3.66 + fputs("propertynotify\n", stderr); 3.67 if(ev->state == PropertyDelete) 3.68 return; /* ignore */ 3.69