woot sexy

This commit is contained in:
Dana Jansens 2003-10-12 19:06:46 +00:00
parent e12d3c1e8a
commit 380af80a13

View file

@ -32,7 +32,7 @@ static Rect* pick_head(ObClient *c)
} }
/* more than one guy in his group (more than just him) */ /* more than one guy in his group (more than just him) */
if (c->group && c->group->members->next) { if (client_has_group_siblings(c)) {
GSList *it; GSList *it;
/* try on the client's desktop */ /* try on the client's desktop */
@ -160,7 +160,7 @@ static gint area_cmp(gconstpointer p1, gconstpointer p2, gpointer data)
} }
/* has to be more than me in the group */ /* has to be more than me in the group */
if (diffhead && c->group && c->group->members->next) { if (diffhead && client_has_group_siblings(c)) {
guint *num, most; guint *num, most;
GSList *it; GSList *it;
@ -219,8 +219,7 @@ static gboolean place_smart(ObClient *client, gint *x, gint *y,
screen_desktop : client->desktop]; screen_desktop : client->desktop];
foc = list ? list->data : NULL; foc = list ? list->data : NULL;
for (it = stacking_list; it && !stop; it = g_list_next(it)) for (it = stacking_list; it && !stop; it = g_list_next(it)) {
{
ObClient *c; ObClient *c;
if (WINDOW_IS_CLIENT(it->data)) if (WINDOW_IS_CLIENT(it->data))
@ -242,7 +241,7 @@ static gboolean place_smart(ObClient *client, gint *x, gint *y,
} }
} else if (type == SMART_GROUP) { } else if (type == SMART_GROUP) {
/* has to be more than me in the group */ /* has to be more than me in the group */
if (!client->group || !client->group->members->next) if (!client_has_group_siblings(client))
return FALSE; return FALSE;
for (sit = client->group->members; sit; sit = g_slist_next(sit)) { for (sit = client->group->members; sit; sit = g_slist_next(sit)) {
@ -250,6 +249,22 @@ static gboolean place_smart(ObClient *client, gint *x, gint *y,
if (!SMART_IGNORE(client, c)) if (!SMART_IGNORE(client, c))
spaces = area_remove(spaces, &c->frame->area); spaces = area_remove(spaces, &c->frame->area);
} }
/* stay out from under windows in higher layers */
for (it = stacking_list; it; it = g_list_next(it)) {
ObClient *c;
if (WINDOW_IS_CLIENT(it->data))
c = it->data;
else
continue;
if (c->layer > client->layer) {
if (!SMART_IGNORE(client, c))
spaces = area_remove(spaces, &c->frame->area);
} else
break;
}
} else } else
g_assert_not_reached(); g_assert_not_reached();