return if the window was restacked
Dana Jansens danakj@orodu.net
2 files changed,
19 insertions(+),
7 deletions(-)
M
openbox/stacking.c
→
openbox/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.h
→
openbox/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