Mercurial > audlegacy-plugins
view src/paranormal/pn/pnobject.c @ 12:3da1b8942b8b trunk
[svn] - remove src/Input src/Output src/Effect src/General src/Visualization src/Container
author | nenolod |
---|---|
date | Mon, 18 Sep 2006 03:14:20 -0700 |
parents | src/Visualization/paranormal/pn/pnobject.c@13389e613d67 |
children |
line wrap: on
line source
/* Paranormal - A highly customizable audio visualization library * Copyright (C) 2001 Jamie Gennis <jgennis@mindspring.com> * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include <config.h> #include "pnobject.h" enum { DESTROY, LAST_SIGNAL }; /* Initialization */ static void pn_object_class_init (PnObjectClass *class); static void pn_object_init (PnObject *object, PnObjectClass *class); /* GObject signals */ static void pn_object_finalize (GObject *gobject); static void pn_object_dispose (GObject *gobject); /* PnObject signals */ static void pn_object_real_destroy (PnObject *object); static GObjectClass *parent_class = NULL; static guint object_signals[LAST_SIGNAL] = { 0 }; GType pn_object_get_type (void) { static GType object_type = 0; if (! object_type) { static const GTypeInfo object_info = { sizeof (PnObjectClass), NULL, /* base_init */ NULL, /* base_finalize */ (GClassInitFunc) pn_object_class_init, NULL, /* class_finalize */ NULL, /* class_data */ sizeof (PnObject), 0, /* n_preallocs */ (GInstanceInitFunc) pn_object_init }; /* FIXME: should this be dynamic? */ object_type = g_type_register_static (G_TYPE_OBJECT, "PnObject", &object_info, G_TYPE_FLAG_ABSTRACT); } return object_type; } static void pn_object_class_init (PnObjectClass *class) { GObjectClass *gobject_class; gobject_class = (GObjectClass *) class; parent_class = g_type_class_peek_parent (class); gobject_class->dispose = pn_object_dispose; gobject_class->finalize = pn_object_finalize; class->destroy = pn_object_real_destroy; object_signals[DESTROY] = g_signal_new ("destroy", G_TYPE_FROM_CLASS (class), G_SIGNAL_RUN_CLEANUP | G_SIGNAL_NO_RECURSE | G_SIGNAL_NO_HOOKS, G_STRUCT_OFFSET (PnObjectClass, destroy), NULL, NULL, g_cclosure_marshal_VOID__VOID, G_TYPE_NONE, 0); } static void pn_object_init (PnObject *object, PnObjectClass *class) { object->flags = PN_FLOATING; } void pn_object_destroy (PnObject *object) { g_return_if_fail (object != NULL); g_return_if_fail (PN_IS_OBJECT (object)); if (!PN_OBJECT_DESTROYED (object)) { /* need to hold a reference count around all class method * invocations. */ g_object_run_dispose (G_OBJECT (object)); } } static void pn_object_dispose (GObject *gobject) { PnObject *object = PN_OBJECT (gobject); /* guard against reinvocations during * destruction with the PN_DESTROYED flag. */ if (!PN_OBJECT_DESTROYED (object)) { PN_OBJECT_SET_FLAGS (object, PN_DESTROYED); g_signal_emit (object, object_signals[DESTROY], 0); PN_OBJECT_UNSET_FLAGS (object, PN_DESTROYED); } G_OBJECT_CLASS (parent_class)->dispose (gobject); } static void pn_object_real_destroy (PnObject *object) { g_signal_handlers_destroy (G_OBJECT (object)); } static void pn_object_finalize (GObject *gobject) { PnObject *object; object = PN_OBJECT (gobject); G_OBJECT_CLASS (parent_class)->finalize (gobject); } /** * pn_object_sink * @object: a #PnObject * * Removes floating reference on an object. Any newly created object has * a refcount of 1 and is FLOATING. This function should be used when * creating a new object to symbolically 'take ownership of' the object. */ void pn_object_sink (PnObject *object) { g_return_if_fail (object != NULL); g_return_if_fail (PN_IS_OBJECT (object)); if (PN_OBJECT_FLOATING (object)) { PN_OBJECT_UNSET_FLAGS (object, PN_FLOATING); pn_object_unref (object); } } /** * pn_object_ref * @object: a #PnObject * * Increments the reference count on an object * * Returns: A pointer to the object */ PnObject* pn_object_ref (PnObject *object) { g_return_val_if_fail (object != NULL, NULL); g_return_val_if_fail (PN_IS_OBJECT (object), NULL); g_object_ref ((GObject*) object); return object; } /** * pn_object_unref * @object: a #PnObject * * Decrements the reference count on an object. If the object's reference * count becomes 0, the object is freed from memory. */ void pn_object_unref (PnObject *object) { g_return_if_fail (object != NULL); g_return_if_fail (PN_IS_OBJECT (object)); g_object_unref ((GObject*) object); }