docs: Implement destroy() rather than dispose()
Remove the dispose() implementation and replace with destroy(). This should be promoted as the standard approach for implementing a composite actor, as it emits a signal when instances of the actor subclass are destroyed.
This commit is contained in:
parent
f63158c2a2
commit
e69d60e8b6
@ -56,32 +56,6 @@ enum {
|
|||||||
/* cache array for signals */
|
/* cache array for signals */
|
||||||
static guint cb_button_signals[LAST_SIGNAL] = { 0, };
|
static guint cb_button_signals[LAST_SIGNAL] = { 0, };
|
||||||
|
|
||||||
/* from http://mail.gnome.org/archives/gtk-devel-list/2004-July/msg00158.html:
|
|
||||||
*
|
|
||||||
* "The dispose method is supposed to release any references to resources
|
|
||||||
* when the object first knows it will be destroyed. The dispose method may
|
|
||||||
* be called any number of times, and thus the code therein should be safe
|
|
||||||
* in that case."
|
|
||||||
*/
|
|
||||||
static void
|
|
||||||
cb_button_dispose (GObject *gobject)
|
|
||||||
{
|
|
||||||
CbButtonPrivate *priv = CB_BUTTON (gobject)->priv;
|
|
||||||
|
|
||||||
/* we just dispose of the child, and let its dispose()
|
|
||||||
* function deal with its children; note that we have a guard
|
|
||||||
* here in case the child has already been destroyed
|
|
||||||
*/
|
|
||||||
if (priv->child)
|
|
||||||
{
|
|
||||||
clutter_actor_unparent (priv->child);
|
|
||||||
priv->child = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* call the parent class' dispose() method */
|
|
||||||
G_OBJECT_CLASS (cb_button_parent_class)->dispose (gobject);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* from http://mail.gnome.org/archives/gtk-devel-list/2004-July/msg00158.html:
|
/* from http://mail.gnome.org/archives/gtk-devel-list/2004-July/msg00158.html:
|
||||||
*
|
*
|
||||||
* "The finalize method finishes releasing the remaining
|
* "The finalize method finishes releasing the remaining
|
||||||
@ -149,10 +123,37 @@ cb_button_get_property (GObject *gobject,
|
|||||||
|
|
||||||
/* ClutterActor implementation
|
/* ClutterActor implementation
|
||||||
*
|
*
|
||||||
* we only implement get_preferred_height(), get_preferred_width(),
|
* we only implement destroy(), get_preferred_height(), get_preferred_width(),
|
||||||
* allocate(), and paint(), as this is the minimum we can get away with
|
* allocate(), and paint(), as this is the minimum we can get away with
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* composite actors should implement destroy(), and inside their
|
||||||
|
* implementation destroy any actors they are composed from;
|
||||||
|
* in this case, we just destroy the child ClutterBox
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
cb_button_destroy (ClutterActor *self)
|
||||||
|
{
|
||||||
|
CbButtonPrivate *priv = CB_BUTTON (self)->priv;
|
||||||
|
|
||||||
|
/* we just destroy the child, and let the child
|
||||||
|
* deal with destroying _its_ children; note that we have a guard
|
||||||
|
* here in case the child has already been destroyed
|
||||||
|
*/
|
||||||
|
if (priv->child)
|
||||||
|
{
|
||||||
|
clutter_actor_destroy (priv->child);
|
||||||
|
priv->child = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* chain up to destroy() on the parent ClutterActorClass;
|
||||||
|
* note that we check the parent class has a destroy() implementation
|
||||||
|
* before calling it
|
||||||
|
*/
|
||||||
|
if (CLUTTER_ACTOR_CLASS (cb_button_parent_class)->destroy)
|
||||||
|
CLUTTER_ACTOR_CLASS (cb_button_parent_class)->destroy (self);
|
||||||
|
}
|
||||||
|
|
||||||
/* get_preferred_height and get_preferred_width defer to the
|
/* get_preferred_height and get_preferred_width defer to the
|
||||||
* internal ClutterBox, adding 20px padding on each axis;
|
* internal ClutterBox, adding 20px padding on each axis;
|
||||||
* min_*_p is the minimum height or width the actor should occupy
|
* min_*_p is the minimum height or width the actor should occupy
|
||||||
@ -259,15 +260,15 @@ cb_button_class_init (CbButtonClass *klass)
|
|||||||
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
||||||
GParamSpec *pspec;
|
GParamSpec *pspec;
|
||||||
|
|
||||||
gobject_class->dispose = cb_button_dispose;
|
|
||||||
gobject_class->finalize = cb_button_finalize;
|
gobject_class->finalize = cb_button_finalize;
|
||||||
gobject_class->set_property = cb_button_set_property;
|
gobject_class->set_property = cb_button_set_property;
|
||||||
gobject_class->get_property = cb_button_get_property;
|
gobject_class->get_property = cb_button_get_property;
|
||||||
|
|
||||||
actor_class->allocate = cb_button_allocate;
|
actor_class->destroy = cb_button_destroy;
|
||||||
actor_class->paint = cb_button_paint;
|
|
||||||
actor_class->get_preferred_height = cb_button_get_preferred_height;
|
actor_class->get_preferred_height = cb_button_get_preferred_height;
|
||||||
actor_class->get_preferred_width = cb_button_get_preferred_width;
|
actor_class->get_preferred_width = cb_button_get_preferred_width;
|
||||||
|
actor_class->allocate = cb_button_allocate;
|
||||||
|
actor_class->paint = cb_button_paint;
|
||||||
|
|
||||||
g_type_class_add_private (klass, sizeof (CbButtonPrivate));
|
g_type_class_add_private (klass, sizeof (CbButtonPrivate));
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user