}
/* 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 */
}
/* 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;
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))
}
} 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)) {
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();