summaryrefslogtreecommitdiff
path: root/openbox
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2007-05-06 06:01:52 +0000
committerDana Jansens <danakj@orodu.net>2007-05-06 06:01:52 +0000
commit2b658f3d9bbb78ed3904edb44826b27380e80a1a (patch)
tree8b0028b5546eea51723cc42e4ea559f592c724cf /openbox
parenta7f65a818c48e272aa9c8c49f2339b46b794078e (diff)
show the desktop in the focus popup if its not on the current desktop
Diffstat (limited to 'openbox')
-rw-r--r--openbox/focus.c25
1 files changed, 17 insertions, 8 deletions
diff --git a/openbox/focus.c b/openbox/focus.c
index 755b6cea..fbac20ec 100644
--- a/openbox/focus.c
+++ b/openbox/focus.c
@@ -295,8 +295,10 @@ static void popup_cycle(ObClient *c, gboolean show)
icon_popup_hide(focus_cycle_popup);
} else {
Rect *a;
- ObClient *p = c;
+ ObClient *p;
+ gchar *text;
gchar *title = NULL;
+ const gchar *desk = NULL;
a = screen_physical_area_monitor(0);
icon_popup_position(focus_cycle_popup, CenterGravity,
@@ -305,20 +307,27 @@ static void popup_cycle(ObClient *c, gboolean show)
icon_popup_height(focus_cycle_popup, POPUP_HEIGHT);
/* use the transient's parent's title/icon */
- while (p->transient_for && p->transient_for != OB_TRAN_GROUP)
- p = p->transient_for;
+ p = client_search_top_parent(c);
+
+ if (c->desktop != DESKTOP_ALL && c->desktop != screen_desktop)
+ desk = screen_desktop_names[c->desktop];
if (p != c && !strcmp("", (c->iconic ? c->icon_title : c->title)))
title = g_strdup(p->iconic ? p->icon_title : p->title);
- /*title = g_strconcat((c->iconic ? c->icon_title : c->title),
+ /*ptitle = g_strconcat((c->iconic ? c->icon_title : c->title),
" - ",
(p->iconic ? p->icon_title : p->title),
NULL);
*/
- icon_popup_show(focus_cycle_popup,
- (title ? title :
- (c->iconic ? c->icon_title : c->title)),
- client_icon(p, 48, 48));
+ if (title == NULL)
+ title = g_strdup(c->iconic ? c->icon_title : c->title);
+ if (desk)
+ text = g_strdup_printf("%s [%s]", title, desk);
+ else
+ text = g_strdup(title);
+
+ icon_popup_show(focus_cycle_popup, text, client_icon(p, 48, 48));
+ g_free(text);
g_free(title);
}
}