diff options
| -rw-r--r-- | openbox/client.c | 26 | ||||
| -rw-r--r-- | openbox/frame.c | 9 | ||||
| -rw-r--r-- | openbox/frame.h | 3 | ||||
| -rw-r--r-- | tests/extentsrequest.c | 136 |
4 files changed, 89 insertions, 85 deletions
diff --git a/openbox/client.c b/openbox/client.c index 4cba7f11..11982dcb 100644 --- a/openbox/client.c +++ b/openbox/client.c @@ -245,11 +245,6 @@ void client_manage(Window window, ObPrompt *prompt) that needs to be freed with g_free(). */ settings = client_get_settings_state(self); - /* now we have all of the window's information so we can set this up. - do this before creating the frame, so it can tell that we are still - mapping and doesn't go applying things right away */ - client_setup_decor_and_functions(self, FALSE); - /* specify that if we exit, the window should not be destroyed and should be reparented back to root automatically, unless we are managing an internal ObPrompt window */ @@ -520,11 +515,11 @@ ObClient *client_fake_manage(Window window) uses too. this returns a shallow copy that needs to be freed */ settings = client_get_settings_state(self); - client_setup_decor_and_functions(self, FALSE); - /* create the decoration frame for the client window and adjust its size */ self->frame = frame_new(self); - frame_adjust_area(self->frame, FALSE, TRUE, TRUE); + + client_apply_startup_state(self, self->area.x, self->area.y, + self->area.width, self->area.height); ob_debug("gave extents left %d right %d top %d bottom %d", self->frame->size.left, self->frame->size.right, @@ -1103,9 +1098,16 @@ static void client_get_all(ObClient *self, gboolean real) client_get_mwm_hints(self); /* this can change the mwmhints for special cases */ client_get_type_and_transientness(self); - client_get_state(self); client_update_normal_hints(self); + /* set up the decor/functions before getting the state. the states may + affect which functions are available, but we want to know the maximum + decor/functions are available to this window, so we can then apply them + in client_apply_startup_state() */ + client_setup_decor_and_functions(self, FALSE); + + client_get_state(self); + /* get the session related properties, these can change decorations from per-app settings */ client_get_session_ids(self); @@ -2734,8 +2736,6 @@ static void client_apply_startup_state(ObClient *self, if (iconic) client_iconify(self, TRUE, FALSE, TRUE); - if (fullscreen) - client_fullscreen(self, TRUE); if (undecorated) client_set_undecorated(self, TRUE); if (shaded) @@ -2750,6 +2750,10 @@ static void client_apply_startup_state(ObClient *self, else if (max_horz) client_maximize(self, TRUE, 1); + /* fullscreen removes the ability to apply other states */ + if (fullscreen) + client_fullscreen(self, TRUE); + /* if the window hasn't been configured yet, then do so now, in fact the x,y,w,h may _not_ be the same as the area rect, which can end up meaning that the client isn't properly moved/resized by the fullscreen diff --git a/openbox/frame.c b/openbox/frame.c index c6a47b08..1623a834 100644 --- a/openbox/frame.c +++ b/openbox/frame.c @@ -190,7 +190,7 @@ ObFrame *frame_new(ObClient *client) /* make sure the size will be different the first time, so the extent hints will be set */ - STRUT_SET(self->size, -1, -1, -1, -1); + STRUT_SET(self->oldsize, -1, -1, -1, -1); set_theme_statics(self); @@ -330,10 +330,6 @@ void frame_adjust_shape(ObFrame *self) void frame_adjust_area(ObFrame *self, gboolean moved, gboolean resized, gboolean fake) { - Strut oldsize; - - oldsize = self->size; - if (resized) { /* do this before changing the frame's status like max_horz max_vert */ frame_adjust_cursors(self); @@ -849,7 +845,7 @@ void frame_adjust_area(ObFrame *self, gboolean moved, frame_adjust_shape(self); } - if (!STRUT_EQUAL(self->size, oldsize)) { + if (!STRUT_EQUAL(self->size, self->oldsize)) { gulong vals[4]; vals[0] = self->size.left; vals[1] = self->size.right; @@ -859,6 +855,7 @@ void frame_adjust_area(ObFrame *self, gboolean moved, CARDINAL, vals, 4); OBT_PROP_SETA32(self->client->window, KDE_NET_WM_FRAME_STRUT, CARDINAL, vals, 4); + self->oldsize = self->size; } /* if this occurs while we are focus cycling, the indicator needs to diff --git a/openbox/frame.h b/openbox/frame.h index b0d99690..0e28b9f1 100644 --- a/openbox/frame.h +++ b/openbox/frame.h @@ -84,7 +84,8 @@ struct _ObFrame Window window; - Strut size; + Strut size; /* the size of the frame */ + Strut oldsize; /* the size of the frame last told to the client */ Rect area; gboolean visible; diff --git a/tests/extentsrequest.c b/tests/extentsrequest.c index 3fb0c7ac..055624d5 100644 --- a/tests/extentsrequest.c +++ b/tests/extentsrequest.c @@ -21,35 +21,8 @@ #include <X11/Xlib.h> #include <X11/Xatom.h> -int main () { - Display *display; - Window win; - XEvent report; - Atom _request, _extents, _type, _normal, _desktop; +void request (Display *display, Atom _request, Atom _extents, Window win) { XEvent msg; - int x=10,y=10,h=100,w=400; - - display = XOpenDisplay(NULL); - - if (display == NULL) { - fprintf(stderr, "couldn't connect to X server :0\n"); - return 0; - } - - _type = XInternAtom(display, "_NET_WM_WINDOW_TYPE", False); - _normal = XInternAtom(display, "_NET_WM_WINDOW_TYPE_NORMAL", False); - _desktop = XInternAtom(display, "_NET_WM_WINDOW_TYPE_DESKTOP", False); - _request = XInternAtom(display, "_NET_REQUEST_FRAME_EXTENTS", False); - _extents = XInternAtom(display, "_NET_FRAME_EXTENTS", False); - - win = XCreateWindow(display, RootWindow(display, 0), - x, y, w, h, 10, CopyFromParent, CopyFromParent, - CopyFromParent, 0, NULL); - XSelectInput(display, win, PropertyChangeMask); - - printf("requesting for type normal\n"); - XChangeProperty(display, win, _type, XA_ATOM, 32, - PropModeReplace, (unsigned char*)&_normal, 1); msg.xclient.type = ClientMessage; msg.xclient.message_type = _request; msg.xclient.display = display; @@ -63,9 +36,12 @@ int main () { XSendEvent(display, RootWindow(display, 0), False, SubstructureNotifyMask | SubstructureRedirectMask, &msg); XFlush(display); +} - printf("waiting for extents\n"); +void reply (Display* display, Atom _extents) { + printf(" waiting for extents\n"); while (1) { + XEvent report; XNextEvent(display, &report); if (report.type == PropertyNotify && @@ -75,57 +51,83 @@ int main () { int ret_format; unsigned long ret_items, ret_bytesleft; unsigned long *prop_return; - XGetWindowProperty(display, win, _extents, 0, 4, + XGetWindowProperty(display, report.xproperty.window, _extents, 0, 4, False, XA_CARDINAL, &ret_type, &ret_format, &ret_items, &ret_bytesleft, (unsigned char**) &prop_return); if (ret_type == XA_CARDINAL && ret_format == 32 && ret_items == 4) - printf("got new extents %d, %d, %d, %d\n", + printf(" got new extents %d, %d, %d, %d\n", prop_return[0], prop_return[1], prop_return[2], prop_return[3]); break; } } +} - printf("requesting for type desktop\n"); - XChangeProperty(display, win, _type, XA_ATOM, 32, - PropModeReplace, (unsigned char*)&_desktop, 1); - msg.xclient.type = ClientMessage; - msg.xclient.message_type = _request; - msg.xclient.display = display; - msg.xclient.window = win; - msg.xclient.format = 32; - msg.xclient.data.l[0] = 0l; - msg.xclient.data.l[1] = 0l; - msg.xclient.data.l[2] = 0l; - msg.xclient.data.l[3] = 0l; - msg.xclient.data.l[4] = 0l; - XSendEvent(display, RootWindow(display, 0), False, - SubstructureNotifyMask | SubstructureRedirectMask, &msg); - XFlush(display); +int main () { + Display *display; + Window win; + Atom _request, _extents, _type, _normal, _desktop, _state; + Atom _state_fs, _state_mh, _state_mv; + int x=10,y=10,h=100,w=400; - printf("waiting for extents\n"); - while (1) { - XNextEvent(display, &report); + display = XOpenDisplay(NULL); - if (report.type == PropertyNotify && - report.xproperty.atom == _extents) - { - Atom ret_type; - int ret_format; - unsigned long ret_items, ret_bytesleft; - unsigned long *prop_return; - XGetWindowProperty(display, win, _extents, 0, 4, - False, XA_CARDINAL, &ret_type, &ret_format, - &ret_items, &ret_bytesleft, - (unsigned char**) &prop_return); - if (ret_type == XA_CARDINAL && ret_format == 32 && ret_items == 4) - printf("got new extents %d, %d, %d, %d\n", - prop_return[0], prop_return[1], prop_return[2], - prop_return[3]); - break; - } + if (display == NULL) { + fprintf(stderr, "couldn't connect to X server :0\n"); + return 0; } + _type = XInternAtom(display, "_NET_WM_WINDOW_TYPE", False); + _normal = XInternAtom(display, "_NET_WM_WINDOW_TYPE_NORMAL", False); + _desktop = XInternAtom(display, "_NET_WM_WINDOW_TYPE_DESKTOP", False); + _request = XInternAtom(display, "_NET_REQUEST_FRAME_EXTENTS", False); + _extents = XInternAtom(display, "_NET_FRAME_EXTENTS", False); + _state = XInternAtom(display, "_NET_WM_STATE", False); + _state_fs = XInternAtom(display, "_NET_WM_STATE_FULLSCREEN", False); + _state_mh = XInternAtom(display, "_NET_WM_STATE_MAXIMIZED_HORZ", False); + _state_mv = XInternAtom(display, "_NET_WM_STATE_MAXIMIZED_VERT", False); + + win = XCreateWindow(display, RootWindow(display, 0), + x, y, w, h, 10, CopyFromParent, CopyFromParent, + CopyFromParent, 0, NULL); + XSelectInput(display, win, PropertyChangeMask); + + printf("requesting for type normal\n"); + XChangeProperty(display, win, _type, XA_ATOM, 32, + PropModeReplace, (unsigned char*)&_normal, 1); + request(display, _request, _extents, win); + reply(display, _extents); + + printf("requesting for type normal+fullscreen\n"); + XChangeProperty(display, win, _type, XA_ATOM, 32, + PropModeReplace, (unsigned char*)&_normal, 1); + XChangeProperty(display, win, _state, XA_ATOM, 32, + PropModeReplace, (unsigned char*)&_state_fs, 1); + request(display, _request, _extents, win); + reply(display, _extents); + + printf("requesting for type normal+maxv\n"); + XChangeProperty(display, win, _type, XA_ATOM, 32, + PropModeReplace, (unsigned char*)&_normal, 1); + XChangeProperty(display, win, _state, XA_ATOM, 32, + PropModeReplace, (unsigned char*)&_state_mv, 1); + request(display, _request, _extents, win); + reply(display, _extents); + + printf("requesting for type normal+maxh\n"); + XChangeProperty(display, win, _type, XA_ATOM, 32, + PropModeReplace, (unsigned char*)&_normal, 1); + XChangeProperty(display, win, _state, XA_ATOM, 32, + PropModeReplace, (unsigned char*)&_state_mh, 1); + request(display, _request, _extents, win); + reply(display, _extents); + + printf("requesting for type desktop\n"); + XChangeProperty(display, win, _type, XA_ATOM, 32, + PropModeReplace, (unsigned char*)&_desktop, 1); + request(display, _request, _extents, win); + reply(display, _extents); + return 1; } |
