added configure(), but this doesn't really fix those frking broken SDL apps
authorarg@mmvi <unknown>
Tue, 26 Sep 2006 05:40:19 +0000 (07:40 +0200)
committerarg@mmvi <unknown>
Tue, 26 Sep 2006 05:40:19 +0000 (07:40 +0200)
client.c
dwm.h
event.c

index d5bc30eba90bf642b0318c2817608bbe14716087..87c2f76a33dfec775274d34f5e04ad5bbf6aaa3e 100644 (file)
--- a/client.c
+++ b/client.c
@@ -80,6 +80,23 @@ ban(Client *c) {
        XMoveWindow(dpy, c->twin, c->tx + 2 * sw, c->ty);
 }
 
+void
+configure(Client *c) {
+       XEvent synev;
+
+       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);
+}
+
 void
 focus(Client *c) {
        Client *old;
@@ -299,6 +316,7 @@ resize(Client *c, Bool sizehints, Corner sticky) {
        else
                wc.border_width = 1;
        XConfigureWindow(dpy, c->win, CWX | CWY | CWWidth | CWHeight | CWBorderWidth, &wc);
+       configure(c);
        XSync(dpy, False);
 }
 
diff --git a/dwm.h b/dwm.h
index c30f2b3f17bcb457173b0ab8e92e6834597c5d28..269c78e9819c11ccd218dbbe4f7582c84775cffe 100644 (file)
--- a/dwm.h
+++ b/dwm.h
@@ -109,6 +109,7 @@ extern Window root, barwin;
 
 /* client.c */
 extern void ban(Client *c);                    /* ban c from screen */
+extern void configure(Client *c);              /* send synthetic configure event */
 extern void focus(Client *c);                  /* focus c, c may be NULL */
 extern Client *getclient(Window w);            /* return client of w */
 extern Client *getctitle(Window w);            /* return client of title window */
diff --git a/event.c b/event.c
index cf89428f86f3345c303dfe5e2d0858683002ecbf..50c59a0c9ef78db7b4dd1d1907c9c0eab7756fe8 100644 (file)
--- a/event.c
+++ b/event.c
@@ -1,3 +1,4 @@
+#include <stdio.h>
 /*
  * (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
  * See LICENSE file for license details.
@@ -38,6 +39,7 @@ movemouse(Client *c) {
                XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
                switch (ev.type) {
                case ButtonRelease:
+                       resize(c, True, TopLeft);
                        XUngrabPointer(dpy, CurrentTime);
                        return;
                case Expose:
@@ -71,6 +73,7 @@ resizemouse(Client *c) {
                XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
                switch(ev.type) {
                case ButtonRelease:
+                       resize(c, True, TopLeft);
                        XUngrabPointer(dpy, CurrentTime);
                        return;
                case Expose:
@@ -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 */