woot sexy
This commit is contained in:
parent
e12d3c1e8a
commit
380af80a13
1 changed files with 20 additions and 5 deletions
|
@ -32,7 +32,7 @@ static Rect* pick_head(ObClient *c)
|
|||
}
|
||||
|
||||
/* 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;
|
||||
|
||||
/* 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 */
|
||||
if (diffhead && c->group && c->group->members->next) {
|
||||
if (diffhead && client_has_group_siblings(c)) {
|
||||
guint *num, most;
|
||||
GSList *it;
|
||||
|
||||
|
@ -219,8 +219,7 @@ static gboolean place_smart(ObClient *client, gint *x, gint *y,
|
|||
screen_desktop : client->desktop];
|
||||
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;
|
||||
|
||||
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) {
|
||||
/* has to be more than me in the group */
|
||||
if (!client->group || !client->group->members->next)
|
||||
if (!client_has_group_siblings(client))
|
||||
return FALSE;
|
||||
|
||||
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))
|
||||
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
|
||||
g_assert_not_reached();
|
||||
|
||||
|
|
Loading…
Reference in a new issue