all repos — openbox @ e61ad3581fa4e640c32fb78408a17712a7155aa1

openbox fork - make it a bit more like ryudo

return if the window was restacked
Dana Jansens danakj@orodu.net
commit

e61ad3581fa4e640c32fb78408a17712a7155aa1

parent

7dd5fa0a7eab78a2cc15ee1b58cd711d79545dac

2 files changed, 19 insertions(+), 7 deletions(-)

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

@@ -551,9 +551,11 @@ }

return occludes; } -void stacking_restack_request(ObClient *client, ObClient *sibling, - gint detail, gboolean activate) +gboolean stacking_restack_request(ObClient *client, ObClient *sibling, + gint detail, gboolean activate) { + gboolean ret = FALSE; + if (sibling && ((client->desktop != sibling->desktop && client->desktop != DESKTOP_ALL && sibling->desktop != DESKTOP_ALL) ||

@@ -570,6 +572,7 @@ ob_debug("Restack request Below for client %s sibling %s\n",

client->title, sibling ? sibling->title : "(all)"); /* just lower it */ stacking_lower(CLIENT_AS_WINDOW(client)); + ret = TRUE; break; case BottomIf: ob_debug("Restack request BottomIf for client %s sibling "

@@ -577,8 +580,10 @@ "%s\n",

client->title, sibling ? sibling->title : "(all)"); /* if this client occludes sibling (or anything if NULL), then lower it to the bottom */ - if (stacking_occludes(client, sibling)) + if (stacking_occludes(client, sibling)) { stacking_lower(CLIENT_AS_WINDOW(client)); + ret = TRUE; + } break; case Above: ob_debug("Restack request Above for client %s sibling %s\n",

@@ -589,6 +594,7 @@ for this */

client_activate(client, FALSE, TRUE); else stacking_raise(CLIENT_AS_WINDOW(client)); + ret = TRUE; break; case TopIf: ob_debug("Restack request TopIf for client %s sibling %s\n",

@@ -600,6 +606,7 @@ for this */

client_activate(client, FALSE, TRUE); else stacking_raise(CLIENT_AS_WINDOW(client)); + ret = TRUE; } break; case Opposite:

@@ -613,9 +620,13 @@ for this */

client_activate(client, FALSE, TRUE); else stacking_raise(CLIENT_AS_WINDOW(client)); + ret = TRUE; } - else if (stacking_occludes(client, sibling)) + else if (stacking_occludes(client, sibling)) { stacking_lower(CLIENT_AS_WINDOW(client)); + ret = TRUE; + } break; } + return ret; }
M openbox/stacking.hopenbox/stacking.h

@@ -67,11 +67,12 @@ windows

@param detail One of Above, Below, TopIf, BottomIf, Opposite @param activate If TRUE, and if the window is going to be raised, it will be activated instead + @return TRUE if the client was restacked See http://tronche.com/gui/x/xlib/window/configure.html for details on how each detail works with and without a sibling. */ -void stacking_restack_request(struct _ObClient *client, - struct _ObClient *sibling, - gint detail, gboolean activate); +gboolean stacking_restack_request(struct _ObClient *client, + struct _ObClient *sibling, + gint detail, gboolean activate); #endif