all repos — openbox @ eb1fb5580e6a4c3620dfefdfd5704f9927f82ab1

openbox fork - make it a bit more like ryudo

keep apps from moving/maping their titlebar underneath left/top panels
Dana Jansens danakj@orodu.net
commit

eb1fb5580e6a4c3620dfefdfd5704f9927f82ab1

parent

7da335f944257f81e2adfe7924430d1996d1af6d

2 files changed, 48 insertions(+), 2 deletions(-)

jump to
M openbox/client.copenbox/client.c

@@ -891,7 +891,22 @@ SIZE_SET(self->max_size, G_MAXINT, G_MAXINT);

/* get the hints from the window */ if (XGetWMNormalHints(ob_display, self->window, &size, &ret)) { - self->positioned = !!(size.flags & (PPosition|USPosition)); + if (size.flags & (PPosition|USPosition)) { + Rect *a; + + /* this is my MOZILLA BITCHSLAP. oh ya it fucking feels good. + Java can suck it too. */ + + /* dont let windows map above/left into the strut unless they + are bigger than the available area */ + a = screen_area(self->desktop); + if (self->area.width <= a->width && self->area.x < a->x) + self->area.x = a->x; + if (self->area.height <= a->height && self->area.y < a->y) + self->area.y = a->y; + + self->positioned = TRUE; + } if (size.flags & PWinGravity) { self->gravity = size.win_gravity;
M openbox/event.copenbox/event.c

@@ -658,6 +658,7 @@ client_iconify(client, TRUE, TRUE);

frame_adjust_focus(client->frame, FALSE); break; case EnterNotify: + con = frame_context(client, e->xcrossing.subwindow); if (client_normal(client)) { if (ob_state() == OB_STATE_STARTING) { /* move it to the top of the focus order */

@@ -711,7 +712,8 @@ if (e->xconfigurerequest.value_mask & (CWWidth | CWHeight |

CWX | CWY)) { int x, y, w, h; ObCorner corner; - + Rect *a; + x = (e->xconfigurerequest.value_mask & CWX) ? e->xconfigurerequest.x : client->area.x; y = (e->xconfigurerequest.value_mask & CWY) ?

@@ -720,6 +722,16 @@ w = (e->xconfigurerequest.value_mask & CWWidth) ?

e->xconfigurerequest.width : client->area.width; h = (e->xconfigurerequest.value_mask & CWHeight) ? e->xconfigurerequest.height : client->area.height; + + /* dont let windows move above/left into the strut unless they are + bigger than the available area */ + a = screen_area(client->desktop); + if (e->xconfigurerequest.value_mask & CWX && + w <= a->width && x < a->x) + x = a->x; + if (e->xconfigurerequest.value_mask & CWY && + h <= a->height && y < a->y) + y = a->y; switch (client->gravity) { case NorthEastGravity:

@@ -885,6 +897,7 @@ }

} else if (msgtype == prop_atoms.net_moveresize_window) { int oldg = client->gravity; int tmpg, x, y, w, h; + Rect *a; if (e->xclient.data.l[0] & 0xff) tmpg = e->xclient.data.l[0] & 0xff;

@@ -908,8 +921,26 @@ h = e->xclient.data.l[4];

else h = client->area.y; client->gravity = tmpg; + + /* get the frame position */ + frame_client_gravity(client->frame, &x, &y); + + /* dont let windows move above/left into the strut unless they are + bigger than the available area */ + a = screen_area(client->desktop); + if (e->xconfigurerequest.value_mask & CWX && + w <= a->width && x < a->x) + x = a->x; + if (e->xconfigurerequest.value_mask & CWY && + h <= a->height && y < a->y) + y = a->y; + + /* go back to the client position */ + frame_frame_gravity(client->frame, &x, &y); + client_configure(client, OB_CORNER_TOPLEFT, x, y, w, h, FALSE, TRUE); + client->gravity = oldg; } break;