1 /* GTK - The GIMP Toolkit
2 * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Library General Public License for more details.
14 * You should have received a copy of the GNU Library General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 * Boston, MA 02111-1307, USA.
21 * Modified by the GTK+ Team and others 1997-1999. See the AUTHORS
22 * file for a list of people on the GTK+ Team. See the ChangeLog
23 * files for a list of changes. These files are distributed with
24 * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
30 #include "gtkobject.h"
31 #include "gtksignal.h"
44 ARG_OBJECT_SIGNAL_AFTER
48 void gtk_object_init_type (void);
49 static void gtk_object_base_class_init (GtkObjectClass *klass);
50 static void gtk_object_class_init (GtkObjectClass *klass);
51 static void gtk_object_init (GtkObject *object,
52 GtkObjectClass *klass);
53 static void gtk_object_set_arg (GtkObject *object,
56 static void gtk_object_get_arg (GtkObject *object,
59 static void gtk_object_shutdown (GtkObject *object);
60 static void gtk_object_real_destroy (GtkObject *object);
61 static void gtk_object_finalize (GtkObject *object);
62 static void gtk_object_notify_weaks (GtkObject *object);
64 static guint object_signals[LAST_SIGNAL] = { 0 };
66 static GHashTable *object_arg_info_ht = NULL;
68 static GQuark quark_user_data = 0;
69 static GQuark quark_weakrefs = 0;
70 static GQuark quark_carg_history = 0;
74 static guint obj_count = 0;
75 static GHashTable *living_objs_ht = NULL;
77 gtk_object_debug_foreach (gpointer key, gpointer value, gpointer user_data)
81 object = (GtkObject*) value;
82 g_message ("[%p] %s\tref_count=%d%s%s",
84 gtk_type_name (GTK_OBJECT_TYPE (object)),
86 GTK_OBJECT_FLOATING (object) ? " (floating)" : "",
87 GTK_OBJECT_DESTROYED (object) ? " (destroyed)" : "");
90 gtk_object_debug (void)
93 g_hash_table_foreach (living_objs_ht, gtk_object_debug_foreach, NULL);
95 g_message ("living objects count = %d", obj_count);
97 #endif /* G_ENABLE_DEBUG */
100 gtk_object_post_arg_parsing_init (void)
102 #ifdef G_ENABLE_DEBUG
103 if (gtk_debug_flags & GTK_DEBUG_OBJECTS)
104 g_atexit (gtk_object_debug);
105 #endif /* G_ENABLE_DEBUG */
108 /****************************************************
109 * GtkObject type, class and instance initialization
111 ****************************************************/
114 gtk_object_init_type (void)
116 static const GtkTypeInfo object_info =
120 sizeof (GtkObjectClass),
121 (GtkClassInitFunc) gtk_object_class_init,
122 (GtkObjectInitFunc) gtk_object_init,
123 /* reserved_1 */ NULL,
124 /* reserved_2 */ NULL,
125 (GtkClassInitFunc) gtk_object_base_class_init,
129 object_type = gtk_type_unique (0, &object_info);
130 g_assert (object_type == GTK_TYPE_OBJECT);
134 gtk_object_get_type (void)
136 return GTK_TYPE_OBJECT;
140 gtk_object_base_class_init (GtkObjectClass *class)
142 /* reset instance specific fields that don't get inherited */
143 class->signals = NULL;
146 class->construct_args = NULL;
148 /* reset instance specifc methods that don't get inherited */
149 class->get_arg = NULL;
150 class->set_arg = NULL;
154 gtk_object_class_init (GtkObjectClass *class)
156 quark_carg_history = g_quark_from_static_string ("gtk-construct-arg-history");
158 gtk_object_add_arg_type ("GtkObject::user_data",
162 gtk_object_add_arg_type ("GtkObject::signal",
166 gtk_object_add_arg_type ("GtkObject::signal_after",
170 gtk_object_add_arg_type ("GtkObject::object_signal",
174 gtk_object_add_arg_type ("GtkObject::object_signal_after",
177 ARG_OBJECT_SIGNAL_AFTER);
179 object_signals[DESTROY] =
180 gtk_signal_new ("destroy",
181 GTK_RUN_LAST | GTK_RUN_NO_HOOKS,
183 GTK_SIGNAL_OFFSET (GtkObjectClass, destroy),
184 gtk_marshal_NONE__NONE,
187 gtk_object_class_add_signals (class, object_signals, LAST_SIGNAL);
189 class->get_arg = gtk_object_get_arg;
190 class->set_arg = gtk_object_set_arg;
191 class->shutdown = gtk_object_shutdown;
192 class->destroy = gtk_object_real_destroy;
193 class->finalize = gtk_object_finalize;
197 gtk_object_init (GtkObject *object,
198 GtkObjectClass *klass)
200 gboolean needs_construction = FALSE;
202 GTK_OBJECT_FLAGS (object) = GTK_FLOATING;
205 needs_construction |= klass->construct_args != NULL;
206 klass = gtk_type_parent_class (klass->type);
208 while (klass && !needs_construction);
209 if (!needs_construction)
210 GTK_OBJECT_FLAGS (object) |= GTK_CONSTRUCTED;
212 object->ref_count = 1;
213 g_datalist_init (&object->object_data);
215 #ifdef G_ENABLE_DEBUG
216 if (gtk_debug_flags & GTK_DEBUG_OBJECTS)
221 living_objs_ht = g_hash_table_new (g_direct_hash, NULL);
223 g_hash_table_insert (living_objs_ht, object, object);
225 #endif /* G_ENABLE_DEBUG */
228 /********************************************
229 * Functions to end a GtkObject's life time
231 ********************************************/
233 gtk_object_destroy (GtkObject *object)
235 g_return_if_fail (object != NULL);
236 g_return_if_fail (GTK_IS_OBJECT (object));
237 g_return_if_fail (GTK_OBJECT_CONSTRUCTED (object));
239 if (!GTK_OBJECT_DESTROYED (object))
241 /* we will hold a reference on the object in this place, so
242 * to ease all classes shutdown and destroy implementations.
243 * i.e. they don't have to bother about referencing at all.
245 gtk_object_ref (object);
246 object->klass->shutdown (object);
247 gtk_object_unref (object);
252 gtk_object_shutdown (GtkObject *object)
254 GTK_OBJECT_SET_FLAGS (object, GTK_DESTROYED);
255 gtk_signal_emit (object, object_signals[DESTROY]);
259 gtk_object_real_destroy (GtkObject *object)
261 if (GTK_OBJECT_CONNECTED (object))
262 gtk_signal_handlers_destroy (object);
266 gtk_object_finalize (GtkObject *object)
268 gtk_object_notify_weaks (object);
270 g_datalist_clear (&object->object_data);
272 gtk_type_free (GTK_OBJECT_TYPE (object), object);
275 /*****************************************
276 * GtkObject argument handlers
278 *****************************************/
281 gtk_object_set_arg (GtkObject *object,
292 gtk_object_set_user_data (object, GTK_VALUE_POINTER (*arg));
294 case ARG_OBJECT_SIGNAL_AFTER:
296 case ARG_OBJECT_SIGNAL:
298 case ARG_SIGNAL_AFTER:
302 arg_name = gtk_arg_name_strip_type (arg->name);
304 arg_name[n] == ':' &&
305 arg_name[n + 1] == ':' &&
306 arg_name[n + 2] != 0)
308 gtk_signal_connect_full (object,
310 GTK_VALUE_SIGNAL (*arg).f, NULL,
311 GTK_VALUE_SIGNAL (*arg).d,
313 (arg_id == ARG_OBJECT_SIGNAL ||
314 arg_id == ARG_OBJECT_SIGNAL_AFTER),
315 (arg_id == ARG_OBJECT_SIGNAL_AFTER ||
316 arg_id == ARG_SIGNAL_AFTER));
319 g_warning ("gtk_object_set_arg(): invalid signal argument: \"%s\"\n", arg->name);
327 gtk_object_get_arg (GtkObject *object,
334 GTK_VALUE_POINTER (*arg) = gtk_object_get_user_data (object);
337 case ARG_OBJECT_SIGNAL:
339 arg->type = GTK_TYPE_INVALID;
344 /*****************************************
345 * gtk_object_class_add_signals:
350 *****************************************/
353 gtk_object_class_add_signals (GtkObjectClass *class,
357 g_return_if_fail (GTK_IS_OBJECT_CLASS (class));
360 g_return_if_fail (signals != NULL);
362 class->signals = g_renew (guint, class->signals, class->nsignals + nsignals);
363 memcpy (class->signals + class->nsignals, signals, nsignals * sizeof (guint));
364 class->nsignals += nsignals;
368 gtk_object_class_user_signal_new (GtkObjectClass *class,
370 GtkSignalRunType signal_flags,
371 GtkSignalMarshaller marshaller,
381 g_return_val_if_fail (class != NULL, 0);
385 params = g_new (GtkType, nparams);
387 va_start (args, nparams);
389 for (i = 0; i < nparams; i++)
390 params[i] = va_arg (args, GtkType);
397 signal_id = gtk_signal_newv (name,
409 gtk_object_class_add_signals (class, &signal_id, 1);
415 gtk_object_class_user_signal_newv (GtkObjectClass *class,
417 GtkSignalRunType signal_flags,
418 GtkSignalMarshaller marshaller,
425 g_return_val_if_fail (class != NULL, 0);
428 g_return_val_if_fail (params != NULL, 0);
430 signal_id = gtk_signal_newv (name,
440 gtk_object_class_add_signals (class, &signal_id, 1);
445 /*****************************************
451 *****************************************/
454 gtk_object_sink (GtkObject *object)
456 g_return_if_fail (object != NULL);
457 g_return_if_fail (GTK_IS_OBJECT (object));
459 if (GTK_OBJECT_FLOATING (object))
461 GTK_OBJECT_UNSET_FLAGS (object, GTK_FLOATING);
462 gtk_object_unref (object);
466 /*****************************************
469 * Weak refs are very similar to the old "destroy" signal. They allow
470 * one to register a callback that is called when the weakly
471 * referenced object is finalized.
473 * They are not implemented as a signal because they really are
474 * special and need to be used with great care. Unlike signals, which
475 * should be able to execute any code whatsoever.
477 * A weakref callback is not allowed to retain a reference to the
478 * object. Object data keys may be retrieved in a weak reference
481 * A weakref callback is called at most once.
483 *****************************************/
485 typedef struct _GtkWeakRef GtkWeakRef;
490 GtkDestroyNotify notify;
495 gtk_object_weakref (GtkObject *object,
496 GtkDestroyNotify notify,
501 g_return_if_fail (object != NULL);
502 g_return_if_fail (notify != NULL);
503 g_return_if_fail (GTK_IS_OBJECT (object));
506 quark_weakrefs = g_quark_from_static_string ("gtk-weakrefs");
508 weak = g_new (GtkWeakRef, 1);
509 weak->next = gtk_object_get_data_by_id (object, quark_weakrefs);
510 weak->notify = notify;
512 gtk_object_set_data_by_id (object, quark_weakrefs, weak);
516 gtk_object_weakunref (GtkObject *object,
517 GtkDestroyNotify notify,
520 GtkWeakRef *weaks, *w, **wp;
522 g_return_if_fail (object != NULL);
523 g_return_if_fail (GTK_IS_OBJECT (object));
528 weaks = gtk_object_get_data_by_id (object, quark_weakrefs);
529 for (wp = &weaks; *wp; wp = &(*wp)->next)
532 if (w->notify == notify && w->data == data)
535 gtk_object_set_data_by_id (object, quark_weakrefs, w->next);
545 gtk_object_notify_weaks (GtkObject *object)
551 w1 = gtk_object_get_data_by_id (object, quark_weakrefs);
555 w1->notify (w1->data);
563 /****************************************************
564 * GtkObject argument mechanism and object creation
566 ****************************************************/
569 gtk_object_new (GtkType object_type,
570 const gchar *first_arg_name,
575 GSList *arg_list = NULL;
576 GSList *info_list = NULL;
579 g_return_val_if_fail (GTK_FUNDAMENTAL_TYPE (object_type) == GTK_TYPE_OBJECT, NULL);
581 object = gtk_type_new (object_type);
583 va_start (var_args, first_arg_name);
584 error = gtk_object_args_collect (GTK_OBJECT_TYPE (object),
593 g_warning ("gtk_object_new(): %s", error);
601 slist_arg = arg_list;
602 slist_info = info_list;
605 gtk_object_arg_set (object, slist_arg->data, slist_info->data);
606 slist_arg = slist_arg->next;
607 slist_info = slist_info->next;
609 gtk_args_collect_cleanup (arg_list, info_list);
612 if (!GTK_OBJECT_CONSTRUCTED (object))
613 gtk_object_default_construct (object);
619 gtk_object_newv (GtkType object_type,
626 g_return_val_if_fail (GTK_FUNDAMENTAL_TYPE (object_type) == GTK_TYPE_OBJECT, NULL);
628 g_return_val_if_fail (args != NULL, NULL);
630 object = gtk_type_new (object_type);
632 for (max_args = args + n_args; args < max_args; args++)
633 gtk_object_arg_set (object, args, NULL);
635 if (!GTK_OBJECT_CONSTRUCTED (object))
636 gtk_object_default_construct (object);
642 gtk_object_setv (GtkObject *object,
648 g_return_if_fail (object != NULL);
649 g_return_if_fail (GTK_IS_OBJECT (object));
651 g_return_if_fail (args != NULL);
653 for (max_args = args + n_args; args < max_args; args++)
654 gtk_object_arg_set (object, args, NULL);
658 gtk_object_getv (GtkObject *object,
664 g_return_if_fail (object != NULL);
665 g_return_if_fail (GTK_IS_OBJECT (object));
667 g_return_if_fail (args != NULL);
669 for (max_args = args + n_args; args < max_args; args++)
670 gtk_object_arg_get (object, args, NULL);
674 gtk_object_get (GtkObject *object,
675 const gchar *first_arg_name,
681 g_return_if_fail (GTK_IS_OBJECT (object));
683 va_start (var_args, first_arg_name);
685 name = (gchar*) first_arg_name;
688 gpointer value_pointer = va_arg (var_args, gpointer);
696 error = gtk_arg_get_info (GTK_OBJECT_TYPE (object),
702 g_warning ("gtk_object_get(): %s", error);
708 gtk_object_arg_get (object, &arg, info);
709 gtk_arg_to_valueloc (&arg, value_pointer);
712 name = va_arg (var_args, gchar*);
717 gtk_object_set (GtkObject *object,
718 const gchar *first_arg_name,
722 GSList *arg_list = NULL;
723 GSList *info_list = NULL;
726 g_return_if_fail (object != NULL);
727 g_return_if_fail (GTK_IS_OBJECT (object));
729 va_start (var_args, first_arg_name);
730 error = gtk_object_args_collect (GTK_OBJECT_TYPE (object),
739 g_warning ("gtk_object_set(): %s", error);
747 slist_arg = arg_list;
748 slist_info = info_list;
751 gtk_object_arg_set (object, slist_arg->data, slist_info->data);
752 slist_arg = slist_arg->next;
753 slist_info = slist_info->next;
755 gtk_args_collect_cleanup (arg_list, info_list);
760 gtk_object_arg_set (GtkObject *object,
764 GtkObjectClass *oclass;
766 g_return_if_fail (object != NULL);
767 g_return_if_fail (GTK_IS_OBJECT (object));
768 g_return_if_fail (arg != NULL);
774 error = gtk_arg_get_info (GTK_OBJECT_TYPE (object),
780 g_warning ("gtk_object_arg_set(): %s", error);
786 if (info->arg_flags & GTK_ARG_CONSTRUCT_ONLY &&
787 GTK_OBJECT_CONSTRUCTED (object))
789 g_warning ("gtk_object_arg_set(): cannot set argument \"%s\" for constructed object",
793 if (!(info->arg_flags & GTK_ARG_WRITABLE))
795 g_warning ("gtk_object_arg_set(): argument \"%s\" is not writable",
799 if (info->type != arg->type)
801 g_warning ("gtk_object_arg_set(): argument \"%s\" has invalid type `%s'",
803 gtk_type_name (arg->type));
807 oclass = gtk_type_class (info->class_type);
808 g_assert (oclass->set_arg != NULL);
809 oclass->set_arg (object, arg, info->arg_id);
810 if (!GTK_OBJECT_CONSTRUCTED (object) &&
811 (info->arg_flags & GTK_ARG_CONSTRUCT_ONLY ||
812 info->arg_flags & GTK_ARG_CONSTRUCT))
816 slist = gtk_object_get_data_by_id (object, quark_carg_history);
817 gtk_object_set_data_by_id (object,
819 g_slist_prepend (slist, info));
824 gtk_object_arg_get (GtkObject *object,
828 GtkObjectClass *oclass;
830 g_return_if_fail (object != NULL);
831 g_return_if_fail (GTK_IS_OBJECT (object));
832 g_return_if_fail (arg != NULL);
838 error = gtk_arg_get_info (GTK_OBJECT_TYPE (object),
844 g_warning ("gtk_object_arg_get(): %s", error);
846 arg->type = GTK_TYPE_INVALID;
851 if (! (info->arg_flags & GTK_ARG_READABLE))
853 g_warning ("gtk_object_arg_get(): argument \"%s\" is not readable",
855 arg->type = GTK_TYPE_INVALID;
859 oclass = gtk_type_class (info->class_type);
860 g_assert (oclass->get_arg != NULL);
861 arg->type = info->type;
862 oclass->get_arg (object, arg, info->arg_id);
866 gtk_object_default_construct (GtkObject *object)
870 g_return_if_fail (object != NULL);
871 g_return_if_fail (GTK_IS_OBJECT (object));
873 if (!GTK_OBJECT_CONSTRUCTED (object))
875 for (slist = object->klass->construct_args;
876 slist && !GTK_OBJECT_CONSTRUCTED (object);
883 history = gtk_object_get_data_by_id (object, quark_carg_history);
884 if (!g_slist_find (history, info))
888 /* default application */
889 arg.type = info->type;
890 arg.name = info->name;
891 switch (gtk_type_get_varargs_type (arg.type))
894 GTK_VALUE_FLOAT (arg) = 0.0;
896 case GTK_TYPE_DOUBLE:
897 GTK_VALUE_DOUBLE (arg) = 0.0;
900 case GTK_TYPE_STRING:
901 case GTK_TYPE_POINTER:
902 case GTK_TYPE_OBJECT:
903 GTK_VALUE_POINTER (arg) = NULL;
906 memset (&arg.d, 0, sizeof (arg.d));
909 gtk_object_arg_set (object, &arg, info);
913 if (!GTK_OBJECT_CONSTRUCTED (object))
914 gtk_object_constructed (object);
919 gtk_object_constructed (GtkObject *object)
921 g_return_if_fail (object != NULL);
922 g_return_if_fail (GTK_IS_OBJECT (object));
923 g_return_if_fail (GTK_OBJECT_CONSTRUCTED (object) == FALSE);
925 g_slist_free (gtk_object_get_data_by_id (object, quark_carg_history));
926 gtk_object_set_data_by_id (object, quark_carg_history, NULL);
927 GTK_OBJECT_FLAGS (object) |= GTK_CONSTRUCTED;
931 gtk_object_add_arg_type (const char *arg_name,
938 g_return_if_fail (arg_name != NULL);
939 g_return_if_fail (arg_type > GTK_TYPE_NONE);
940 g_return_if_fail (arg_id > 0);
941 g_return_if_fail ((arg_flags & GTK_ARG_CHILD_ARG) == 0);
942 if (arg_flags & GTK_ARG_CONSTRUCT)
943 g_return_if_fail ((arg_flags & GTK_ARG_READWRITE) == GTK_ARG_READWRITE);
945 g_return_if_fail ((arg_flags & GTK_ARG_READWRITE) != 0);
946 if (arg_flags & GTK_ARG_CONSTRUCT_ONLY)
947 g_return_if_fail ((arg_flags & GTK_ARG_WRITABLE) == GTK_ARG_WRITABLE);
949 if (!object_arg_info_ht)
950 object_arg_info_ht = g_hash_table_new (gtk_arg_info_hash,
953 info = gtk_arg_type_new_static (GTK_TYPE_OBJECT,
955 GTK_STRUCT_OFFSET (GtkObjectClass, n_args),
961 (info->arg_flags & GTK_ARG_CONSTRUCT ||
962 info->arg_flags & GTK_ARG_CONSTRUCT_ONLY))
964 GtkObjectClass *class;
966 class = gtk_type_class (info->class_type);
967 if (info->arg_flags & GTK_ARG_CONSTRUCT_ONLY)
968 class->construct_args = g_slist_prepend (class->construct_args, info);
970 class->construct_args = g_slist_append (class->construct_args, info);
975 gtk_object_args_collect (GtkType object_type,
977 GSList **info_list_p,
978 const gchar *first_arg_name,
981 return gtk_args_collect (object_type,
990 gtk_object_arg_get_info (GtkType object_type,
991 const gchar *arg_name,
994 return gtk_arg_get_info (object_type,
1001 gtk_object_query_args (GtkType class_type,
1002 guint32 **arg_flags,
1005 g_return_val_if_fail (n_args != NULL, NULL);
1007 g_return_val_if_fail (GTK_FUNDAMENTAL_TYPE (class_type) == GTK_TYPE_OBJECT, NULL);
1009 return gtk_args_query (class_type, object_arg_info_ht, arg_flags, n_args);
1012 /*****************************************
1013 * GtkObject object_data mechanism
1015 *****************************************/
1018 gtk_object_set_data_by_id (GtkObject *object,
1022 g_return_if_fail (object != NULL);
1023 g_return_if_fail (GTK_IS_OBJECT (object));
1025 g_datalist_id_set_data (&object->object_data, data_id, data);
1029 gtk_object_set_data (GtkObject *object,
1033 g_return_if_fail (object != NULL);
1034 g_return_if_fail (GTK_IS_OBJECT (object));
1035 g_return_if_fail (key != NULL);
1037 g_datalist_set_data (&object->object_data, key, data);
1041 gtk_object_set_data_by_id_full (GtkObject *object,
1044 GtkDestroyNotify destroy)
1046 g_return_if_fail (object != NULL);
1047 g_return_if_fail (GTK_IS_OBJECT (object));
1049 g_datalist_id_set_data_full (&object->object_data, data_id, data, destroy);
1053 gtk_object_set_data_full (GtkObject *object,
1056 GtkDestroyNotify destroy)
1058 g_return_if_fail (object != NULL);
1059 g_return_if_fail (GTK_IS_OBJECT (object));
1060 g_return_if_fail (key != NULL);
1062 g_datalist_set_data_full (&object->object_data, key, data, destroy);
1066 gtk_object_get_data_by_id (GtkObject *object,
1069 g_return_val_if_fail (object != NULL, NULL);
1070 g_return_val_if_fail (GTK_IS_OBJECT (object), NULL);
1072 return g_datalist_id_get_data (&object->object_data, data_id);
1076 gtk_object_get_data (GtkObject *object,
1079 g_return_val_if_fail (object != NULL, NULL);
1080 g_return_val_if_fail (GTK_IS_OBJECT (object), NULL);
1081 g_return_val_if_fail (key != NULL, NULL);
1083 return g_datalist_get_data (&object->object_data, key);
1087 gtk_object_remove_data_by_id (GtkObject *object,
1090 g_return_if_fail (object != NULL);
1091 g_return_if_fail (GTK_IS_OBJECT (object));
1093 g_datalist_id_remove_data (&object->object_data, data_id);
1097 gtk_object_remove_data (GtkObject *object,
1100 g_return_if_fail (object != NULL);
1101 g_return_if_fail (GTK_IS_OBJECT (object));
1102 g_return_if_fail (key != NULL);
1104 g_datalist_remove_data (&object->object_data, key);
1108 gtk_object_remove_no_notify_by_id (GtkObject *object,
1111 g_return_if_fail (object != NULL);
1112 g_return_if_fail (GTK_IS_OBJECT (object));
1114 g_datalist_id_remove_no_notify (&object->object_data, key_id);
1118 gtk_object_remove_no_notify (GtkObject *object,
1121 g_return_if_fail (object != NULL);
1122 g_return_if_fail (GTK_IS_OBJECT (object));
1123 g_return_if_fail (key != NULL);
1125 g_datalist_remove_no_notify (&object->object_data, key);
1129 gtk_object_set_user_data (GtkObject *object,
1132 g_return_if_fail (object != NULL);
1133 g_return_if_fail (GTK_IS_OBJECT (object));
1135 if (!quark_user_data)
1136 quark_user_data = g_quark_from_static_string ("user_data");
1138 g_datalist_id_set_data (&object->object_data, quark_user_data, data);
1142 gtk_object_get_user_data (GtkObject *object)
1144 g_return_val_if_fail (object != NULL, NULL);
1145 g_return_val_if_fail (GTK_IS_OBJECT (object), NULL);
1147 return g_datalist_id_get_data (&object->object_data, quark_user_data);
1150 /*******************************************
1151 * GtkObject referencing and unreferencing
1153 *******************************************/
1155 #undef gtk_object_ref
1156 #undef gtk_object_unref
1159 gtk_object_ref (GtkObject *object)
1161 g_return_if_fail (object != NULL);
1162 g_return_if_fail (GTK_IS_OBJECT (object));
1163 g_return_if_fail (object->ref_count > 0);
1165 object->ref_count += 1;
1169 gtk_object_unref (GtkObject *object)
1171 g_return_if_fail (object != NULL);
1172 g_return_if_fail (GTK_IS_OBJECT (object));
1173 g_return_if_fail (object->ref_count > 0);
1175 if (object->ref_count == 1)
1177 gtk_object_destroy (object);
1179 g_return_if_fail (object->ref_count > 0);
1182 object->ref_count -= 1;
1184 if (object->ref_count == 0)
1186 #ifdef G_ENABLE_DEBUG
1187 if (gtk_debug_flags & GTK_DEBUG_OBJECTS)
1189 g_assert (g_hash_table_lookup (living_objs_ht, object) == object);
1190 g_hash_table_remove (living_objs_ht, object);
1193 #endif /* G_ENABLE_DEBUG */
1194 object->klass->finalize (object);
1198 static GtkObject *gtk_trace_object = NULL;
1200 gtk_trace_referencing (GtkObject *object,
1206 if (gtk_debug_flags & GTK_DEBUG_OBJECTS)
1208 gboolean exists = TRUE;
1210 g_return_if_fail (object != NULL);
1211 g_return_if_fail (GTK_IS_OBJECT (object));
1213 #ifdef G_ENABLE_DEBUG
1214 exists = g_hash_table_lookup (living_objs_ht, object) != NULL;
1215 #endif /* G_ENABLE_DEBUG */
1218 (object == gtk_trace_object ||
1219 gtk_trace_object == (void*)42))
1220 fprintf (stdout, "trace: object_%s: (%s:%p)->ref_count=%d %s (%s:%d)\n",
1221 do_ref ? "ref" : "unref",
1222 gtk_type_name (GTK_OBJECT_TYPE (object)),
1225 do_ref ? "+ 1" : "- 1",
1229 fprintf (stdout, "trace: object_%s(%p): no such object! (%s:%d)\n",
1230 do_ref ? "ref" : "unref",
1237 gtk_object_ref (object);
1239 gtk_object_unref (object);