don't set the above member in synthetic configurenotify events
add more output in confignotify test
This commit is contained in:
parent
9d50361708
commit
2521fd24c5
2 changed files with 57 additions and 42 deletions
|
@ -2872,7 +2872,7 @@ void client_configure(ObClient *self, gint x, gint y, gint w, gint h, gint b,
|
||||||
event.xconfigure.width = w;
|
event.xconfigure.width = w;
|
||||||
event.xconfigure.height = h;
|
event.xconfigure.height = h;
|
||||||
event.xconfigure.border_width = self->border_width;
|
event.xconfigure.border_width = self->border_width;
|
||||||
event.xconfigure.above = self->frame->plate;
|
event.xconfigure.above = None;
|
||||||
event.xconfigure.override_redirect = FALSE;
|
event.xconfigure.override_redirect = FALSE;
|
||||||
XSendEvent(event.xconfigure.display, event.xconfigure.window,
|
XSendEvent(event.xconfigure.display, event.xconfigure.window,
|
||||||
FALSE, StructureNotifyMask, &event);
|
FALSE, StructureNotifyMask, &event);
|
||||||
|
|
|
@ -21,50 +21,65 @@
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
|
|
||||||
int main () {
|
int main () {
|
||||||
Display *display;
|
Display *display;
|
||||||
Window win;
|
Window win;
|
||||||
XEvent report;
|
XEvent report;
|
||||||
XEvent msg;
|
XEvent msg;
|
||||||
int x=10,y=10,h=100,w=100;
|
int x=10,y=10,h=100,w=100;
|
||||||
|
|
||||||
display = XOpenDisplay(NULL);
|
display = XOpenDisplay(NULL);
|
||||||
|
|
||||||
if (display == NULL) {
|
if (display == NULL) {
|
||||||
fprintf(stderr, "couldn't connect to X server :0\n");
|
fprintf(stderr, "couldn't connect to X server :0\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
|
|
||||||
win = XCreateWindow(display, RootWindow(display, 0),
|
|
||||||
x, y, w, h, 10, CopyFromParent, CopyFromParent,
|
|
||||||
CopyFromParent, 0, NULL);
|
|
||||||
|
|
||||||
XSetWindowBackground(display,win,WhitePixel(display,0));
|
|
||||||
|
|
||||||
XSelectInput(display, win, ExposureMask | StructureNotifyMask);
|
|
||||||
|
|
||||||
XMapWindow(display, win);
|
|
||||||
XFlush(display);
|
|
||||||
|
|
||||||
while (1) {
|
|
||||||
XNextEvent(display, &report);
|
|
||||||
|
|
||||||
switch (report.type) {
|
|
||||||
case MapNotify:
|
|
||||||
printf("map notify\n");
|
|
||||||
break;
|
|
||||||
case Expose:
|
|
||||||
printf("exposed\n");
|
|
||||||
break;
|
|
||||||
case ConfigureNotify:
|
|
||||||
x = report.xconfigure.x;
|
|
||||||
y = report.xconfigure.y;
|
|
||||||
w = report.xconfigure.width;
|
|
||||||
h = report.xconfigure.height;
|
|
||||||
printf("confignotify %i,%i-%ix%i\n",x,y,w,h);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
win = XCreateWindow(display, RootWindow(display, 0),
|
||||||
|
x, y, w, h, 10, CopyFromParent, CopyFromParent,
|
||||||
|
CopyFromParent, 0, NULL);
|
||||||
|
|
||||||
return 1;
|
XSetWindowBackground(display,win,WhitePixel(display,0));
|
||||||
|
|
||||||
|
XSelectInput(display, win, (ExposureMask | StructureNotifyMask |
|
||||||
|
GravityNotify));
|
||||||
|
|
||||||
|
XMapWindow(display, win);
|
||||||
|
XFlush(display);
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
XNextEvent(display, &report);
|
||||||
|
|
||||||
|
switch (report.type) {
|
||||||
|
case MapNotify:
|
||||||
|
printf("map notify\n");
|
||||||
|
break;
|
||||||
|
case Expose:
|
||||||
|
printf("exposed\n");
|
||||||
|
break;
|
||||||
|
case GravityNotify:
|
||||||
|
printf("gravity notify event 0x%x window 0x%x x %d y %d\n",
|
||||||
|
report.xgravity.event, report.xgravity.window,
|
||||||
|
report.xgravity.x, report.xgravity.y);
|
||||||
|
break;
|
||||||
|
case ConfigureNotify: {
|
||||||
|
int se = report.xconfigure.send_event;
|
||||||
|
int event = report.xconfigure.event;
|
||||||
|
int window = report.xconfigure.window;
|
||||||
|
int x = report.xconfigure.x;
|
||||||
|
int y = report.xconfigure.y;
|
||||||
|
int w = report.xconfigure.width;
|
||||||
|
int h = report.xconfigure.height;
|
||||||
|
int bw = report.xconfigure.border_width;
|
||||||
|
int above = report.xconfigure.above;
|
||||||
|
int or = report.xconfigure.override_redirect;
|
||||||
|
printf("confignotify send %d ev 0x%x win 0x%x %i,%i-%ix%i bw %i\n"
|
||||||
|
" above 0x%x ovrd %d\n",
|
||||||
|
se,event,window,x,y,w,h,bw,above,or);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue