summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2007-05-07 16:57:02 +0000
committerDana Jansens <danakj@orodu.net>2007-05-07 16:57:02 +0000
commite1081644c1eea458aab0901c76ebc7a112d280d7 (patch)
treee5fbb15b59c99daf6088fb9169ed1120a0c14e12
parent37e2be2a57a218bd671e2e4b056643fbb248ad02 (diff)
show the right icon
-rw-r--r--openbox/focus.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/openbox/focus.c b/openbox/focus.c
index 5d9e0fe4..eea8d148 100644
--- a/openbox/focus.c
+++ b/openbox/focus.c
@@ -295,7 +295,6 @@ static gchar *popup_get_name(ObClient *c, ObClient **nametarget)
/* find our highest direct parent, including non-normal windows */
for (p = c; p->transient_for && p->transient_for != OB_TRAN_GROUP;
p = p->transient_for);
- if (nametarget) *nametarget = p;
if (c->desktop != DESKTOP_ALL && c->desktop != screen_desktop)
desk = screen_desktop_names[c->desktop];
@@ -315,6 +314,8 @@ static gchar *popup_get_name(ObClient *c, ObClient **nametarget)
}
g_free(title);
+ /* set this only if we're returning true and they asked for it */
+ if (ret && nametarget) *nametarget = p;
return ret;
}
@@ -361,13 +362,15 @@ static void popup_cycle(ObClient *c, gboolean show,
/* make it null terminated so we can use g_strfreev */
names = g_new(char*, n+1);
for (it = targets, i = 0; it; it = g_list_next(it), ++i) {
- ObClient *ft = it->data;
- names[i] = popup_get_name(ft, &showtarget);
+ ObClient *ft = it->data, *t;
+ names[i] = popup_get_name(ft, &t);
- /* little optimization.. save this text so we dont have to get it
- again */
- if (ft == c)
+ /* little optimization.. save this text and client, so we dont
+ have to get it again */
+ if (ft == c) {
showtext = g_strdup(names[i]);
+ showtarget = t;
+ }
}
names[n] = NULL;