diff options
| author | Dana Jansens <danakj@orodu.net> | 2007-05-27 14:49:44 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2007-05-27 14:49:44 +0000 |
| commit | 2521fd24c59d1f526cb355952801c3afcf7b9e1f (patch) | |
| tree | 94ecefae6f809046c2ab8c32aa789071a3966a7f | |
| parent | 9d503617085b4f886a2fb5af3c96439669912789 (diff) | |
don't set the above member in synthetic configurenotify events
add more output in confignotify test
| -rw-r--r-- | openbox/client.c | 2 | ||||
| -rw-r--r-- | tests/confignotify.c | 101 |
2 files changed, 59 insertions, 44 deletions
diff --git a/openbox/client.c b/openbox/client.c index 146b0bf5..1683c608 100644 --- a/openbox/client.c +++ b/openbox/client.c @@ -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.height = h; event.xconfigure.border_width = self->border_width; - event.xconfigure.above = self->frame->plate; + event.xconfigure.above = None; event.xconfigure.override_redirect = FALSE; XSendEvent(event.xconfigure.display, event.xconfigure.window, FALSE, StructureNotifyMask, &event); diff --git a/tests/confignotify.c b/tests/confignotify.c index cf6e7639..4d4a7cc5 100644 --- a/tests/confignotify.c +++ b/tests/confignotify.c @@ -21,50 +21,65 @@ #include <X11/Xlib.h> int main () { - Display *display; - Window win; - XEvent report; - XEvent msg; - int x=10,y=10,h=100,w=100; - - display = XOpenDisplay(NULL); - - if (display == NULL) { - fprintf(stderr, "couldn't connect to X server :0\n"); - 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; + Display *display; + Window win; + XEvent report; + XEvent msg; + int x=10,y=10,h=100,w=100; + + display = XOpenDisplay(NULL); + + if (display == NULL) { + fprintf(stderr, "couldn't connect to X server :0\n"); + 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 | + 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; + return 1; } |
