track window groups

iconify all its transients when a window is iconified
This commit is contained in:
Dana Jansens 2003-04-07 05:47:20 +00:00
parent aaae49d629
commit 5f42ecfacb
5 changed files with 96 additions and 7 deletions

View file

@ -9,6 +9,7 @@
#include "focus.h" #include "focus.h"
#include "stacking.h" #include "stacking.h"
#include "dispatch.h" #include "dispatch.h"
#include "group.h"
#include <glib.h> #include <glib.h>
#include <X11/Xutil.h> #include <X11/Xutil.h>
@ -319,6 +320,10 @@ void client_unmanage(Client *client)
XMapWindow(ob_display, client->window); XMapWindow(ob_display, client->window);
} }
/* remoev from its group */
if (client->group)
group_remove(client->group, client);
/* free all data allocated in the client struct */ /* free all data allocated in the client struct */
g_slist_free(client->transients); g_slist_free(client->transients);
for (j = 0; j < client->nicons; ++j) for (j = 0; j < client->nicons; ++j)
@ -420,7 +425,7 @@ static void client_get_all(Client *self)
self->urgent = FALSE; self->urgent = FALSE;
self->positioned = FALSE; self->positioned = FALSE;
self->disabled_decorations = 0; self->disabled_decorations = 0;
self->group = None; self->group = NULL;
self->nicons = 0; self->nicons = 0;
client_get_area(self); client_get_area(self);
@ -940,10 +945,12 @@ void client_update_wmhints(Client *self)
ur = TRUE; ur = TRUE;
if (hints->flags & WindowGroupHint) { if (hints->flags & WindowGroupHint) {
if (hints->window_group != self->group) { if (hints->window_group !=
/* XXX: remove from the old group if there was one */ (self->group ? self->group->leader : None)) {
self->group = hints->window_group; /* remove from the old group if there was one */
/* XXX: do stuff with the group */ if (self->group != NULL)
group_remove(self->group, self);
self->group = group_add(hints->window_group, self);
} }
} else /* no group! */ } else /* no group! */
self->group = None; self->group = None;
@ -1554,6 +1561,14 @@ void client_iconify(Client *self, gboolean iconic, gboolean curdesk)
dispatch_client(iconic ? Event_Client_Unmapped : Event_Client_Mapped, dispatch_client(iconic ? Event_Client_Unmapped : Event_Client_Mapped,
self, 0, 0); self, 0, 0);
/* iconify all transients */
if (self->transients) {
GSList *it;
for (it = self->transients; it != NULL; it = it->next)
if (it->data != self) client_iconify(it->data, iconic, curdesk);
}
} }
void client_maximize(Client *self, gboolean max, int dir, gboolean savearea) void client_maximize(Client *self, gboolean max, int dir, gboolean savearea)

View file

@ -7,7 +7,7 @@
#include <X11/Xlib.h> #include <X11/Xlib.h>
struct Frame; struct Frame;
struct Group;
/*! Holds an icon in ARGB format */ /*! Holds an icon in ARGB format */
typedef struct Icon { typedef struct Icon {
@ -114,7 +114,7 @@ typedef struct Client {
int ignore_unmaps; int ignore_unmaps;
/*! The id of the group the window belongs to */ /*! The id of the group the window belongs to */
Window group; struct Group *group;
/*! Whether or not the client is a transient window. This is guaranteed to /*! Whether or not the client is a transient window. This is guaranteed to
be TRUE if transient_for != NULL, but not guaranteed to be FALSE if be TRUE if transient_for != NULL, but not guaranteed to be FALSE if
transient_for == NULL. */ transient_for == NULL. */

46
openbox/group.c Normal file
View file

@ -0,0 +1,46 @@
#include "group.h"
#include "client.h"
GHashTable *group_map = NULL;
static guint map_hash(Window *w) { return *w; }
static gboolean map_key_comp(Window *w1, Window *w2) { return *w1 == *w2; }
void group_startup()
{
group_map = g_hash_table_new((GHashFunc)map_hash,
(GEqualFunc)map_key_comp);
}
void group_shutdown()
{
g_hash_table_destroy(group_map);
}
Group *group_add(Window leader, Client *client)
{
Group *self;
self = g_hash_table_lookup(group_map, &leader);
if (self == NULL) {
self = g_new(Group, 1);
self->leader = leader;
self->members = NULL;
g_hash_table_insert(group_map, &self->leader, self);
g_message("NEW GROUP FOR %lx", leader);
} else
g_message("REUSING GROUP FOR %lx", leader);
self->members = g_slist_append(self->members, client);
return self;
}
void group_remove(Group *self, Client *client)
{
self->members = g_slist_remove(self->members, client);
if (self->members == NULL) {
g_hash_table_remove(group_map, &self->leader);
g_free(self);
}
}

25
openbox/group.h Normal file
View file

@ -0,0 +1,25 @@
#ifndef __group_h
#define __group_h
#include <X11/Xlib.h>
#include <glib.h>
struct Client;
typedef struct Group {
Window leader;
/* list of clients */
GSList *members;
} Group;
extern GHashTable *group_map;
void group_startup();
void group_shutdown();
Group *group_add(Window leader, struct Client *client);
void group_remove(Group *self, struct Client *client);
#endif

View file

@ -12,6 +12,7 @@
#include "engine.h" #include "engine.h"
#include "plugin.h" #include "plugin.h"
#include "timer.h" #include "timer.h"
#include "group.h"
#include "gettext.h" #include "gettext.h"
#include "../render/render.h" #include "../render/render.h"
#include "../render/font.h" #include "../render/font.h"
@ -172,6 +173,7 @@ int main(int argc, char **argv)
engine_load(); engine_load();
screen_startup(); screen_startup();
group_startup();
client_startup(); client_startup();
/* call startup for all the plugins */ /* call startup for all the plugins */
@ -189,6 +191,7 @@ int main(int argc, char **argv)
plugin_shutdown(); /* calls all the plugins' shutdown functions */ plugin_shutdown(); /* calls all the plugins' shutdown functions */
client_shutdown(); client_shutdown();
group_shutdown();
screen_shutdown(); screen_shutdown();
focus_shutdown(); focus_shutdown();
engine_shutdown(); engine_shutdown();