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 */
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,
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);
if (iconic)
client_iconify(self, TRUE, FALSE, TRUE);
- if (fullscreen)
- client_fullscreen(self, TRUE);
if (undecorated)
client_set_undecorated(self, TRUE);
if (shaded)
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
#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;
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 &&
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;
}