]> Dogcows Code - chaz/openbox/commitdiff
only change the group info if the group flag is set
authorDana Jansens <danakj@orodu.net>
Wed, 16 Apr 2003 01:02:29 +0000 (01:02 +0000)
committerDana Jansens <danakj@orodu.net>
Wed, 16 Apr 2003 01:02:29 +0000 (01:02 +0000)
openbox/client.c

index 45ed49c579f1b23fd0996a13fb7c60a7a3c2b7ad..18dfe0cffac1cce6550ff29e87e0c196f742d189 100644 (file)
@@ -1033,38 +1033,40 @@ void client_update_wmhints(Client *self)
        if (hints->flags & XUrgencyHint)
            ur = TRUE;
 
-       if (!(hints->flags & WindowGroupHint))
-            hints->window_group = None; /* no group */
-        /* did the group state change? */
-        if (hints->window_group != (self->group ? self->group->leader : None)){
-            /* remove from the old group if there was one */
-            if (self->group != NULL) {
-                /* remove transients of the group */
-                for (it = self->group->members; it; it = it->next)
-                    if (it->data != self &&
-                        ((Client*)it->data)->transient_for == TRAN_GROUP) {
-                        self->transients = g_slist_remove(self->transients,
-                                                          it->data);
-                    }
-                group_remove(self->group, self);
-                self->group = NULL;
-            }
-            if (hints->window_group != None) {
-                self->group = group_add(hints->window_group, self);
+       if (hints->flags & WindowGroupHint) {
+            /* did the group state change? */
+            if (hints->window_group !=
+                (self->group ? self->group->leader : None)) {
+                /* remove from the old group if there was one */
+                if (self->group != NULL) {
+                    /* remove transients of the group */
+                    for (it = self->group->members; it; it = it->next)
+                        if (it->data != self &&
+                            ((Client*)it->data)->transient_for == TRAN_GROUP) {
+                            self->transients = g_slist_remove(self->transients,
+                                                              it->data);
+                        }
+                    group_remove(self->group, self);
+                    self->group = NULL;
+                }
+                if (hints->window_group != None) {
+                    self->group = group_add(hints->window_group, self);
+
+                    /* add other transients of the group that are already
+                       set up */
+                    for (it = self->group->members; it; it = it->next)
+                        if (it->data != self &&
+                            ((Client*)it->data)->transient_for == TRAN_GROUP)
+                            self->transients = g_slist_append(self->transients,
+                                                              it->data);
+                }
 
-                /* add other transients of the group that are already set up */
-                for (it = self->group->members; it; it = it->next)
-                    if (it->data != self &&
-                        ((Client*)it->data)->transient_for == TRAN_GROUP)
-                        self->transients = g_slist_append(self->transients,
-                                                          it->data);
+                /* because the self->transient flag wont change from this call,
+                   we don't need to update the window's type and such, only its
+                   transient_for, and the transients lists of other windows in
+                   the group may be affected */
+                client_update_transient_for(self);
             }
-
-            /* because the self->transient flag wont change from this call,
-               we don't need to update the window's type and such, only its
-               transient_for, and the transients lists of other windows in the
-               group may be affected */
-            client_update_transient_for(self);
         }
 
        if (hints->flags & IconPixmapHint) {
This page took 0.025904 seconds and 4 git commands to generate.