added configure(), but this doesn't really fix those frking broken SDL apps
This commit is contained in:
parent
67bc08d1b9
commit
b4d53bf194
3 changed files with 27 additions and 13 deletions
18
client.c
18
client.c
|
@ -80,6 +80,23 @@ ban(Client *c) {
|
||||||
XMoveWindow(dpy, c->twin, c->tx + 2 * sw, c->ty);
|
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
|
void
|
||||||
focus(Client *c) {
|
focus(Client *c) {
|
||||||
Client *old;
|
Client *old;
|
||||||
|
@ -299,6 +316,7 @@ resize(Client *c, Bool sizehints, Corner sticky) {
|
||||||
else
|
else
|
||||||
wc.border_width = 1;
|
wc.border_width = 1;
|
||||||
XConfigureWindow(dpy, c->win, CWX | CWY | CWWidth | CWHeight | CWBorderWidth, &wc);
|
XConfigureWindow(dpy, c->win, CWX | CWY | CWWidth | CWHeight | CWBorderWidth, &wc);
|
||||||
|
configure(c);
|
||||||
XSync(dpy, False);
|
XSync(dpy, False);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
1
dwm.h
1
dwm.h
|
@ -109,6 +109,7 @@ extern Window root, barwin;
|
||||||
|
|
||||||
/* client.c */
|
/* client.c */
|
||||||
extern void ban(Client *c); /* ban c from screen */
|
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 void focus(Client *c); /* focus c, c may be NULL */
|
||||||
extern Client *getclient(Window w); /* return client of w */
|
extern Client *getclient(Window w); /* return client of w */
|
||||||
extern Client *getctitle(Window w); /* return client of title window */
|
extern Client *getctitle(Window w); /* return client of title window */
|
||||||
|
|
21
event.c
21
event.c
|
@ -1,3 +1,4 @@
|
||||||
|
#include <stdio.h>
|
||||||
/*
|
/*
|
||||||
* (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
|
* (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
|
||||||
* See LICENSE file for license details.
|
* See LICENSE file for license details.
|
||||||
|
@ -38,6 +39,7 @@ movemouse(Client *c) {
|
||||||
XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
|
XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
|
||||||
switch (ev.type) {
|
switch (ev.type) {
|
||||||
case ButtonRelease:
|
case ButtonRelease:
|
||||||
|
resize(c, True, TopLeft);
|
||||||
XUngrabPointer(dpy, CurrentTime);
|
XUngrabPointer(dpy, CurrentTime);
|
||||||
return;
|
return;
|
||||||
case Expose:
|
case Expose:
|
||||||
|
@ -71,6 +73,7 @@ resizemouse(Client *c) {
|
||||||
XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
|
XMaskEvent(dpy, MOUSEMASK | ExposureMask, &ev);
|
||||||
switch(ev.type) {
|
switch(ev.type) {
|
||||||
case ButtonRelease:
|
case ButtonRelease:
|
||||||
|
resize(c, True, TopLeft);
|
||||||
XUngrabPointer(dpy, CurrentTime);
|
XUngrabPointer(dpy, CurrentTime);
|
||||||
return;
|
return;
|
||||||
case Expose:
|
case Expose:
|
||||||
|
@ -151,6 +154,7 @@ configurerequest(XEvent *e) {
|
||||||
XEvent synev;
|
XEvent synev;
|
||||||
XWindowChanges wc;
|
XWindowChanges wc;
|
||||||
|
|
||||||
|
fputs("configurerequest\n", stderr);
|
||||||
if((c = getclient(ev->window))) {
|
if((c = getclient(ev->window))) {
|
||||||
c->ismax = False;
|
c->ismax = False;
|
||||||
gravitate(c, True);
|
gravitate(c, True);
|
||||||
|
@ -172,19 +176,8 @@ configurerequest(XEvent *e) {
|
||||||
newmask = ev->value_mask & (~(CWSibling | CWStackMode | CWBorderWidth));
|
newmask = ev->value_mask & (~(CWSibling | CWStackMode | CWBorderWidth));
|
||||||
if(newmask)
|
if(newmask)
|
||||||
XConfigureWindow(dpy, c->win, newmask, &wc);
|
XConfigureWindow(dpy, c->win, newmask, &wc);
|
||||||
else {
|
else
|
||||||
synev.type = ConfigureNotify;
|
configure(c);
|
||||||
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);
|
|
||||||
}
|
|
||||||
XSync(dpy, False);
|
XSync(dpy, False);
|
||||||
if(c->isfloat)
|
if(c->isfloat)
|
||||||
resize(c, False, TopLeft);
|
resize(c, False, TopLeft);
|
||||||
|
@ -218,6 +211,7 @@ enternotify(XEvent *e) {
|
||||||
Client *c;
|
Client *c;
|
||||||
XCrossingEvent *ev = &e->xcrossing;
|
XCrossingEvent *ev = &e->xcrossing;
|
||||||
|
|
||||||
|
fputs("enternotify\n", stderr);
|
||||||
if(ev->mode != NotifyNormal || ev->detail == NotifyInferior)
|
if(ev->mode != NotifyNormal || ev->detail == NotifyInferior)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -305,6 +299,7 @@ propertynotify(XEvent *e) {
|
||||||
Window trans;
|
Window trans;
|
||||||
XPropertyEvent *ev = &e->xproperty;
|
XPropertyEvent *ev = &e->xproperty;
|
||||||
|
|
||||||
|
fputs("propertynotify\n", stderr);
|
||||||
if(ev->state == PropertyDelete)
|
if(ev->state == PropertyDelete)
|
||||||
return; /* ignore */
|
return; /* ignore */
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue