Cleaned up MetaCompWindow disposal.

This commit is contained in:
Tomas Frydrych 2008-08-20 08:26:52 +01:00
parent 1ee1842638
commit 8589eab403

View File

@ -166,7 +166,7 @@ struct _MetaCompWindowPrivate
gboolean destroy_pending : 1; gboolean destroy_pending : 1;
gboolean argb32 : 1; gboolean argb32 : 1;
gboolean minimize_in_progress : 1; gboolean minimize_in_progress : 1;
gboolean disposed : 1;
}; };
enum enum
@ -180,18 +180,17 @@ static void meta_comp_window_class_init (MetaCompWindowClass *klass);
static void meta_comp_window_init (MetaCompWindow *self); static void meta_comp_window_init (MetaCompWindow *self);
static void meta_comp_window_dispose (GObject *object); static void meta_comp_window_dispose (GObject *object);
static void meta_comp_window_finalize (GObject *object); static void meta_comp_window_finalize (GObject *object);
static void meta_comp_window_constructed (MetaCompWindow *self); static void meta_comp_window_constructed (GObject *object);
static void meta_comp_window_set_property (GObject *object, static void meta_comp_window_set_property (GObject *object,
guint prop_id, guint prop_id,
const GValue *value, const GValue *value,
GParamSpec *pspec); GParamSpec *pspec);
static void meta_comp_window_get_property (GObject *object, static void meta_comp_window_get_property (GObject *object,
guint prop_id, guint prop_id,
GValue *value, GValue *value,
GParamSpec *pspec); GParamSpec *pspec);
static void meta_comp_window_get_window_type (MetaCompWindow *self); static void meta_comp_window_get_window_type (MetaCompWindow *self);
static void meta_comp_window_detach (MetaCompWindow *self);
GType meta_comp_window_get_type (void); GType meta_comp_window_get_type (void);
@ -257,8 +256,9 @@ static gboolean is_shaped (MetaDisplay *display, Window xwindow);
static gboolean meta_comp_window_has_shadow (MetaCompWindow *self); static gboolean meta_comp_window_has_shadow (MetaCompWindow *self);
static void static void
meta_comp_window_constructed (MetaCompWindow *self) meta_comp_window_constructed (GObject *object)
{ {
MetaCompWindow *self = META_COMP_WINDOW (object);
MetaCompWindowPrivate *priv = self->priv; MetaCompWindowPrivate *priv = self->priv;
MetaScreen *screen = priv->screen; MetaScreen *screen = priv->screen;
MetaDisplay *display = meta_screen_get_display (screen); MetaDisplay *display = meta_screen_get_display (screen);
@ -319,6 +319,43 @@ meta_comp_window_constructed (MetaCompWindow *self)
static void static void
meta_comp_window_dispose (GObject *object) meta_comp_window_dispose (GObject *object)
{ {
MetaCompWindow *self = META_COMP_WINDOW (object);
MetaCompWindowPrivate *priv = self->priv;
MetaScreen *screen;
MetaDisplay *display;
Display *xdisplay;
MetaCompScreen *info;
if (priv->disposed)
return;
priv->disposed = TRUE;
screen = priv->screen;
display = meta_screen_get_display (screen);
xdisplay = meta_display_get_xdisplay (display);
info = meta_screen_get_compositor_data (screen);
meta_comp_window_detach (self);
if (priv->damage != None)
{
meta_error_trap_push (display);
XDamageDestroy (xdisplay, priv->damage);
meta_error_trap_pop (display, FALSE);
priv->damage = None;
}
/*
* Check we are not in the dock list -- FIXME (do this in a cleaner way)
*/
if (priv->type == META_COMP_WINDOW_DOCK)
info->dock_windows = g_slist_remove (info->dock_windows, self);
info->windows = g_list_remove (info->windows, (gconstpointer) self);
g_hash_table_remove (info->windows_by_xid, (gpointer) priv->xwindow);
G_OBJECT_CLASS (meta_comp_window_parent_class)->dispose (object); G_OBJECT_CLASS (meta_comp_window_parent_class)->dispose (object);
} }
@ -605,70 +642,33 @@ clutter_cmp_destroy (MetaCompositor *compositor)
} }
static void static void
free_win (MetaCompWindow *self, meta_comp_window_detach (MetaCompWindow *self)
gboolean destroy)
{ {
MetaCompWindowPrivate *priv = self->priv; MetaCompWindowPrivate *priv = self->priv;
MetaScreen *screen = priv->screen; MetaScreen *screen = priv->screen;
MetaDisplay *display = meta_screen_get_display (screen); MetaDisplay *display = meta_screen_get_display (screen);
Display *xdisplay = meta_display_get_xdisplay (display); Display *xdisplay = meta_display_get_xdisplay (display);
MetaCompScreen *info = meta_screen_get_compositor_data (screen);
/* See comment in map_win */ if (priv->back_pixmap)
if (priv->back_pixmap && destroy)
{ {
XFreePixmap (xdisplay, priv->back_pixmap); XFreePixmap (xdisplay, priv->back_pixmap);
priv->back_pixmap = None; priv->back_pixmap = None;
} }
if (destroy)
{
if (priv->damage != None)
{
meta_error_trap_push (display);
XDamageDestroy (xdisplay, priv->damage);
meta_error_trap_pop (display, FALSE);
priv->damage = None;
} }
/* The window may not have been added to the list in this case,
but we can check anyway */
if (priv->type == META_COMP_WINDOW_DOCK)
info->dock_windows = g_slist_remove (info->dock_windows, self);
clutter_actor_destroy (CLUTTER_ACTOR (self));
}
}
static void static void
destroy_win (MetaDisplay *display, destroy_win (MetaDisplay *display, Window xwindow)
Window xwindow,
gboolean gone)
{ {
MetaScreen *screen;
MetaCompScreen *info;
MetaCompWindow *cw; MetaCompWindow *cw;
MetaCompWindowPrivate *priv;
cw = find_window_in_display (display, xwindow); cw = find_window_in_display (display, xwindow);
if (cw == NULL) if (cw == NULL)
return; return;
priv = cw->priv;
meta_verbose ("destroying a window... 0x%x (%p)\n", (guint) xwindow, cw); meta_verbose ("destroying a window... 0x%x (%p)\n", (guint) xwindow, cw);
screen = priv->screen; clutter_actor_destroy (CLUTTER_ACTOR (cw));
info = meta_screen_get_compositor_data (screen);
info->windows = g_list_remove (info->windows, (gconstpointer) cw);
g_hash_table_remove (info->windows_by_xid, (gpointer) xwindow);
free_win (cw, TRUE);
} }
static void static void
@ -810,7 +810,7 @@ unmap_win (MetaDisplay *display,
priv->attrs.map_state = IsUnmapped; priv->attrs.map_state = IsUnmapped;
free_win (cw, FALSE); meta_comp_window_detach (cw);
if (!priv->minimize_in_progress) if (!priv->minimize_in_progress)
{ {
@ -1038,7 +1038,7 @@ process_reparent (MetaCompositorClutter *compositor,
{ {
meta_verbose ("reparent: destroying a window 0%x\n", meta_verbose ("reparent: destroying a window 0%x\n",
(guint)event->window); (guint)event->window);
destroy_win (compositor->display, event->window, FALSE); destroy_win (compositor->display, event->window);
} }
} }
@ -1046,7 +1046,7 @@ static void
process_destroy (MetaCompositorClutter *compositor, process_destroy (MetaCompositorClutter *compositor,
XDestroyWindowEvent *event) XDestroyWindowEvent *event)
{ {
destroy_win (compositor->display, event->window, FALSE); destroy_win (compositor->display, event->window);
} }
static void static void
@ -1492,9 +1492,7 @@ static void
on_destroy_effect_complete (ClutterActor *actor, on_destroy_effect_complete (ClutterActor *actor,
gpointer user_data) gpointer user_data)
{ {
MetaCompWindow *cw = (MetaCompWindow *)user_data; clutter_actor_destroy (actor);
free_win (cw, TRUE);
} }
static void static void