| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | /* GObject - GLib Type, Object, Parameter and Signal Library
 | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |  * Copyright (C) 1998-1999, 2000-2001 Tim Janik and Red Hat, Inc. | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * This library is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  |  * modify it under the terms of the GNU Lesser General Public | 
					
						
							|  |  |  |  |  * License as published by the Free Software Foundation; either | 
					
						
							| 
									
										
										
										
											2017-01-05 14:09:06 +01:00
										 |  |  |  |  * version 2.1 of the License, or (at your option) any later version. | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * 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 | 
					
						
							|  |  |  |  |  * Lesser General Public License for more details. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * You should have received a copy of the GNU Lesser General | 
					
						
							| 
									
										
										
										
											2014-01-23 12:58:29 +01:00
										 |  |  |  |  * Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-06-22 14:29:25 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /*
 | 
					
						
							|  |  |  |  |  * MT safe with regards to reference counting. | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #include "config.h"
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #include <string.h>
 | 
					
						
							|  |  |  |  | #include <signal.h>
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #include "gobject.h"
 | 
					
						
							| 
									
										
										
										
											2011-06-02 17:14:58 -04:00
										 |  |  |  | #include "gtype-private.h"
 | 
					
						
							| 
									
										
										
										
											2008-06-22 14:29:25 +00:00
										 |  |  |  | #include "gvaluecollector.h"
 | 
					
						
							|  |  |  |  | #include "gsignal.h"
 | 
					
						
							|  |  |  |  | #include "gparamspecs.h"
 | 
					
						
							|  |  |  |  | #include "gvaluetypes.h"
 | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  | #include "gobject_trace.h"
 | 
					
						
							| 
									
										
										
										
											2012-02-10 08:24:28 -05:00
										 |  |  |  | #include "gconstructor.h"
 | 
					
						
							| 
									
										
										
										
											2008-06-22 14:29:25 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * SECTION:objects | 
					
						
							| 
									
										
										
										
											2011-12-09 08:01:12 -05:00
										 |  |  |  |  * @title: GObject | 
					
						
							| 
									
										
										
										
											2008-07-02 03:43:13 +00:00
										 |  |  |  |  * @short_description: The base object type | 
					
						
							|  |  |  |  |  * @see_also: #GParamSpecObject, g_param_spec_object() | 
					
						
							| 
									
										
										
										
											2008-06-22 14:29:25 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * GObject is the fundamental type providing the common attributes and | 
					
						
							|  |  |  |  |  * methods for all object types in GTK+, Pango and other libraries | 
					
						
							|  |  |  |  |  * based on GObject.  The GObject class provides methods for object | 
					
						
							|  |  |  |  |  * construction and destruction, property access methods, and signal | 
					
						
							| 
									
										
										
										
											2014-02-08 12:26:56 -05:00
										 |  |  |  |  * support.  Signals are described in detail [here][gobject-Signals]. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:29:25 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2015-01-16 09:44:27 +00:00
										 |  |  |  |  * For a tutorial on implementing a new GObject class, see [How to define and | 
					
						
							|  |  |  |  |  * implement a new GObject][howto-gobject]. For a list of naming conventions for | 
					
						
							|  |  |  |  |  * GObjects and their methods, see the [GType conventions][gtype-conventions]. | 
					
						
							|  |  |  |  |  * For the high-level concepts behind GObject, read [Instantiable classed types: | 
					
						
							|  |  |  |  |  * Objects][gtype-instantiable-classed]. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-06 16:48:49 -05:00
										 |  |  |  |  * ## Floating references # {#floating-ref} | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-06-05 19:07:06 -04:00
										 |  |  |  |  * GInitiallyUnowned is derived from GObject. The only difference between | 
					
						
							|  |  |  |  |  * the two is that the initial reference of a GInitiallyUnowned is flagged | 
					
						
							| 
									
										
										
										
											2014-02-05 22:57:27 -05:00
										 |  |  |  |  * as a "floating" reference. This means that it is not specifically | 
					
						
							|  |  |  |  |  * claimed to be "owned" by any code portion. The main motivation for | 
					
						
							|  |  |  |  |  * providing floating references is C convenience. In particular, it | 
					
						
							|  |  |  |  |  * allows code to be written as: | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2011-06-05 19:07:06 -04:00
										 |  |  |  |  * container = create_container (); | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * container_add_child (container, create_child()); | 
					
						
							|  |  |  |  |  * ]| | 
					
						
							| 
									
										
										
										
											2014-01-31 21:56:33 -05:00
										 |  |  |  |  * If container_add_child() calls g_object_ref_sink() on the passed-in child, | 
					
						
							|  |  |  |  |  * no reference of the newly created child is leaked. Without floating | 
					
						
							|  |  |  |  |  * references, container_add_child() can only g_object_ref() the new child, | 
					
						
							|  |  |  |  |  * so to implement this code without reference leaks, it would have to be | 
					
						
							|  |  |  |  |  * written as: | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Child *child; | 
					
						
							| 
									
										
										
										
											2011-06-05 19:07:06 -04:00
										 |  |  |  |  * container = create_container (); | 
					
						
							|  |  |  |  |  * child = create_child (); | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * container_add_child (container, child); | 
					
						
							|  |  |  |  |  * g_object_unref (child); | 
					
						
							|  |  |  |  |  * ]| | 
					
						
							| 
									
										
										
										
											2014-01-31 21:56:33 -05:00
										 |  |  |  |  * The floating reference can be converted into an ordinary reference by | 
					
						
							|  |  |  |  |  * calling g_object_ref_sink(). For already sunken objects (objects that | 
					
						
							|  |  |  |  |  * don't have a floating reference anymore), g_object_ref_sink() is equivalent | 
					
						
							|  |  |  |  |  * to g_object_ref() and returns a new reference. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since floating references are useful almost exclusively for C convenience, | 
					
						
							|  |  |  |  |  * language bindings that provide automated reference and memory ownership | 
					
						
							| 
									
										
										
										
											2011-06-05 19:07:06 -04:00
										 |  |  |  |  * maintenance (such as smart pointers or garbage collection) should not | 
					
						
							|  |  |  |  |  * expose floating references in their API. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:29:25 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Some object implementations may need to save an objects floating state | 
					
						
							| 
									
										
										
										
											2011-06-05 19:07:06 -04:00
										 |  |  |  |  * across certain code portions (an example is #GtkMenu), to achieve this, | 
					
						
							|  |  |  |  |  * the following sequence can be used: | 
					
						
							| 
									
										
										
										
											2008-06-22 14:29:25 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2014-02-14 21:33:36 -05:00
										 |  |  |  |  * // save floating state
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * gboolean was_floating = g_object_is_floating (object); | 
					
						
							|  |  |  |  |  * g_object_ref_sink (object); | 
					
						
							| 
									
										
										
										
											2014-02-14 21:33:36 -05:00
										 |  |  |  |  * // protected code portion
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * ... | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * // restore floating state
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * if (was_floating) | 
					
						
							|  |  |  |  |  *   g_object_force_floating (object); | 
					
						
							| 
									
										
										
										
											2012-11-12 17:07:39 +01:00
										 |  |  |  |  * else | 
					
						
							| 
									
										
										
										
											2014-02-14 21:33:36 -05:00
										 |  |  |  |  *   g_object_unref (object); // release previously acquired reference
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * ]| | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2006-09-30 13:59:01 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /* --- macros --- */ | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | #define PARAM_SPEC_PARAM_ID(pspec)		((pspec)->param_id)
 | 
					
						
							|  |  |  |  | #define	PARAM_SPEC_SET_PARAM_ID(pspec, id)	((pspec)->param_id = (id))
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | #define OBJECT_HAS_TOGGLE_REF_FLAG 0x1
 | 
					
						
							|  |  |  |  | #define OBJECT_HAS_TOGGLE_REF(object) \
 | 
					
						
							| 
									
										
										
										
											2010-09-08 11:58:42 +03:00
										 |  |  |  |     ((g_datalist_get_flags (&(object)->qdata) & OBJECT_HAS_TOGGLE_REF_FLAG) != 0) | 
					
						
							| 
									
										
										
										
											2005-11-23 17:54:41 +00:00
										 |  |  |  | #define OBJECT_FLOATING_FLAG 0x2
 | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-19 17:21:18 +02:00
										 |  |  |  | #define CLASS_HAS_PROPS_FLAG 0x1
 | 
					
						
							|  |  |  |  | #define CLASS_HAS_PROPS(class) \
 | 
					
						
							|  |  |  |  |     ((class)->flags & CLASS_HAS_PROPS_FLAG) | 
					
						
							| 
									
										
										
										
											2009-10-08 20:01:15 +02:00
										 |  |  |  | #define CLASS_HAS_CUSTOM_CONSTRUCTOR(class) \
 | 
					
						
							|  |  |  |  |     ((class)->constructor != g_object_constructor) | 
					
						
							| 
									
										
										
										
											2011-01-12 19:45:40 +01:00
										 |  |  |  | #define CLASS_HAS_CUSTOM_CONSTRUCTED(class) \
 | 
					
						
							|  |  |  |  |     ((class)->constructed != g_object_constructed) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 19:27:48 +02:00
										 |  |  |  | #define CLASS_HAS_DERIVED_CLASS_FLAG 0x2
 | 
					
						
							|  |  |  |  | #define CLASS_HAS_DERIVED_CLASS(class) \
 | 
					
						
							|  |  |  |  |     ((class)->flags & CLASS_HAS_DERIVED_CLASS_FLAG) | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | /* --- signals --- */ | 
					
						
							|  |  |  |  | enum { | 
					
						
							|  |  |  |  |   NOTIFY, | 
					
						
							|  |  |  |  |   LAST_SIGNAL | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /* --- properties --- */ | 
					
						
							|  |  |  |  | enum { | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |   PROP_NONE | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | /* --- prototypes --- */ | 
					
						
							|  |  |  |  | static void	g_object_base_class_init		(GObjectClass	*class); | 
					
						
							|  |  |  |  | static void	g_object_base_class_finalize		(GObjectClass	*class); | 
					
						
							|  |  |  |  | static void	g_object_do_class_init			(GObjectClass	*class); | 
					
						
							| 
									
										
										
										
											2009-08-19 17:22:32 +02:00
										 |  |  |  | static void	g_object_init				(GObject	*object, | 
					
						
							|  |  |  |  | 							 GObjectClass	*class); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | static GObject*	g_object_constructor			(GType                  type, | 
					
						
							|  |  |  |  | 							 guint                  n_construct_properties, | 
					
						
							|  |  |  |  | 							 GObjectConstructParam *construct_params); | 
					
						
							| 
									
										
										
										
											2011-01-12 19:45:40 +01:00
										 |  |  |  | static void     g_object_constructed                    (GObject        *object); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | static void	g_object_real_dispose			(GObject	*object); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | static void	g_object_finalize			(GObject	*object); | 
					
						
							|  |  |  |  | static void	g_object_do_set_property		(GObject        *object, | 
					
						
							|  |  |  |  | 							 guint           property_id, | 
					
						
							|  |  |  |  | 							 const GValue   *value, | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 							 GParamSpec     *pspec); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | static void	g_object_do_get_property		(GObject        *object, | 
					
						
							|  |  |  |  | 							 guint           property_id, | 
					
						
							|  |  |  |  | 							 GValue         *value, | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 							 GParamSpec     *pspec); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | static void	g_value_object_init			(GValue		*value); | 
					
						
							|  |  |  |  | static void	g_value_object_free_value		(GValue		*value); | 
					
						
							|  |  |  |  | static void	g_value_object_copy_value		(const GValue	*src_value, | 
					
						
							|  |  |  |  | 							 GValue		*dest_value); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | static void	g_value_object_transform_value		(const GValue	*src_value, | 
					
						
							|  |  |  |  | 							 GValue		*dest_value); | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | static gpointer g_value_object_peek_pointer             (const GValue   *value); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | static gchar*	g_value_object_collect_value		(GValue		*value, | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  | 							 guint           n_collect_values, | 
					
						
							|  |  |  |  | 							 GTypeCValue    *collect_values, | 
					
						
							|  |  |  |  | 							 guint           collect_flags); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | static gchar*	g_value_object_lcopy_value		(const GValue	*value, | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  | 							 guint           n_collect_values, | 
					
						
							|  |  |  |  | 							 GTypeCValue    *collect_values, | 
					
						
							|  |  |  |  | 							 guint           collect_flags); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | static void	g_object_dispatch_properties_changed	(GObject	*object, | 
					
						
							|  |  |  |  | 							 guint		 n_pspecs, | 
					
						
							|  |  |  |  | 							 GParamSpec    **pspecs); | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  | static guint               object_floating_flag_handler (GObject        *object, | 
					
						
							|  |  |  |  |                                                          gint            job); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-02 13:58:25 -04:00
										 |  |  |  | static void object_interface_check_properties           (gpointer        check_data, | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | 							 gpointer        g_iface); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  | /* --- typedefs --- */ | 
					
						
							|  |  |  |  | typedef struct _GObjectNotifyQueue            GObjectNotifyQueue; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | struct _GObjectNotifyQueue | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-11-16 15:41:06 +00:00
										 |  |  |  |   GSList  *pspecs; | 
					
						
							|  |  |  |  |   guint16  n_pspecs; | 
					
						
							|  |  |  |  |   guint16  freeze_count; | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  | }; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | /* --- variables --- */ | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  | G_LOCK_DEFINE_STATIC (closure_array_mutex); | 
					
						
							|  |  |  |  | G_LOCK_DEFINE_STATIC (weak_refs_mutex); | 
					
						
							|  |  |  |  | G_LOCK_DEFINE_STATIC (toggle_refs_mutex); | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | static GQuark	            quark_closure_array = 0; | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | static GQuark	            quark_weak_refs = 0; | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | static GQuark	            quark_toggle_refs = 0; | 
					
						
							| 
									
										
										
										
											2011-11-16 15:41:06 +00:00
										 |  |  |  | static GQuark               quark_notify_queue; | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  | static GQuark               quark_in_construction; | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | static GParamSpecPool      *pspec_pool = NULL; | 
					
						
							|  |  |  |  | static gulong	            gobject_signals[LAST_SIGNAL] = { 0, }; | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  | static guint (*floating_flag_handler) (GObject*, gint) = object_floating_flag_handler; | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | /* qdata pointing to GSList<GWeakRef *>, protected by weak_locations_lock */ | 
					
						
							|  |  |  |  | static GQuark	            quark_weak_locations = 0; | 
					
						
							|  |  |  |  | static GRWLock              weak_locations_lock; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  | G_LOCK_DEFINE_STATIC(notify_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /* --- functions --- */ | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_notify_queue_free (gpointer data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObjectNotifyQueue *nqueue = data; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_slist_free (nqueue->pspecs); | 
					
						
							|  |  |  |  |   g_slice_free (GObjectNotifyQueue, nqueue); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-16 15:46:19 +00:00
										 |  |  |  | static GObjectNotifyQueue* | 
					
						
							| 
									
										
										
										
											2011-11-16 15:42:36 +00:00
										 |  |  |  | g_object_notify_queue_freeze (GObject  *object, | 
					
						
							|  |  |  |  |                               gboolean  conditional) | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   GObjectNotifyQueue *nqueue; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   G_LOCK(notify_lock); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:41:06 +00:00
										 |  |  |  |   nqueue = g_datalist_id_get_data (&object->qdata, quark_notify_queue); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  |   if (!nqueue) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-11-16 15:42:36 +00:00
										 |  |  |  |       if (conditional) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           G_UNLOCK(notify_lock); | 
					
						
							|  |  |  |  |           return NULL; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  |       nqueue = g_slice_new0 (GObjectNotifyQueue); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:41:06 +00:00
										 |  |  |  |       g_datalist_id_set_data_full (&object->qdata, quark_notify_queue, | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  |                                    nqueue, g_object_notify_queue_free); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (nqueue->freeze_count >= 65535) | 
					
						
							|  |  |  |  |     g_critical("Free queue for %s (%p) is larger than 65535," | 
					
						
							|  |  |  |  |                " called g_object_freeze_notify() too often." | 
					
						
							|  |  |  |  |                " Forgot to call g_object_thaw_notify() or infinite loop", | 
					
						
							|  |  |  |  |                G_OBJECT_TYPE_NAME (object), object); | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     nqueue->freeze_count++; | 
					
						
							|  |  |  |  |   G_UNLOCK(notify_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return nqueue; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-16 15:46:19 +00:00
										 |  |  |  | static void | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  | g_object_notify_queue_thaw (GObject            *object, | 
					
						
							|  |  |  |  |                             GObjectNotifyQueue *nqueue) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GParamSpec *pspecs_mem[16], **pspecs, **free_me = NULL; | 
					
						
							|  |  |  |  |   GSList *slist; | 
					
						
							|  |  |  |  |   guint n_pspecs = 0; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (nqueue->freeze_count > 0); | 
					
						
							|  |  |  |  |   g_return_if_fail (g_atomic_int_get(&object->ref_count) > 0); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   G_LOCK(notify_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Just make sure we never get into some nasty race condition */ | 
					
						
							|  |  |  |  |   if (G_UNLIKELY(nqueue->freeze_count == 0)) { | 
					
						
							|  |  |  |  |     G_UNLOCK(notify_lock); | 
					
						
							|  |  |  |  |     g_warning ("%s: property-changed notification for %s(%p) is not frozen", | 
					
						
							|  |  |  |  |                G_STRFUNC, G_OBJECT_TYPE_NAME (object), object); | 
					
						
							|  |  |  |  |     return; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   nqueue->freeze_count--; | 
					
						
							|  |  |  |  |   if (nqueue->freeze_count) { | 
					
						
							|  |  |  |  |     G_UNLOCK(notify_lock); | 
					
						
							|  |  |  |  |     return; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   pspecs = nqueue->n_pspecs > 16 ? free_me = g_new (GParamSpec*, nqueue->n_pspecs) : pspecs_mem; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   for (slist = nqueue->pspecs; slist; slist = slist->next) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       pspecs[n_pspecs++] = slist->data; | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-16 15:41:06 +00:00
										 |  |  |  |   g_datalist_id_set_data (&object->qdata, quark_notify_queue, NULL); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   G_UNLOCK(notify_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (n_pspecs) | 
					
						
							| 
									
										
										
										
											2011-11-16 15:41:06 +00:00
										 |  |  |  |     G_OBJECT_GET_CLASS (object)->dispatch_properties_changed (object, n_pspecs, pspecs); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  |   g_free (free_me); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-16 15:46:19 +00:00
										 |  |  |  | static void | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  | g_object_notify_queue_add (GObject            *object, | 
					
						
							|  |  |  |  |                            GObjectNotifyQueue *nqueue, | 
					
						
							|  |  |  |  |                            GParamSpec         *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-11-16 15:38:25 +00:00
										 |  |  |  |   G_LOCK(notify_lock); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:36:57 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-07 19:57:53 -04:00
										 |  |  |  |   g_assert (nqueue->n_pspecs < 65535); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-16 15:38:25 +00:00
										 |  |  |  |   if (g_slist_find (nqueue->pspecs, pspec) == NULL) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       nqueue->pspecs = g_slist_prepend (nqueue->pspecs, pspec); | 
					
						
							|  |  |  |  |       nqueue->n_pspecs++; | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-16 15:38:25 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   G_UNLOCK(notify_lock); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:31:58 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 19:25:03 -05:00
										 |  |  |  | #ifdef	G_ENABLE_DEBUG
 | 
					
						
							|  |  |  |  | G_LOCK_DEFINE_STATIC     (debug_objects); | 
					
						
							|  |  |  |  | static guint		 debug_objects_count = 0; | 
					
						
							|  |  |  |  | static GHashTable	*debug_objects_ht = NULL; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | debug_objects_foreach (gpointer key, | 
					
						
							|  |  |  |  | 		       gpointer value, | 
					
						
							|  |  |  |  | 		       gpointer user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObject *object = value; | 
					
						
							| 
									
										
										
										
											2001-02-04 07:03:52 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_message ("[%p] stale %s\tref_count=%u", | 
					
						
							|  |  |  |  | 	     object, | 
					
						
							|  |  |  |  | 	     G_OBJECT_TYPE_NAME (object), | 
					
						
							|  |  |  |  | 	     object->ref_count); | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-10 08:24:28 -05:00
										 |  |  |  | #ifdef G_HAS_CONSTRUCTORS
 | 
					
						
							|  |  |  |  | #ifdef G_DEFINE_DESTRUCTOR_NEEDS_PRAGMA
 | 
					
						
							|  |  |  |  | #pragma G_DEFINE_DESTRUCTOR_PRAGMA_ARGS(debug_objects_atexit)
 | 
					
						
							|  |  |  |  | #endif
 | 
					
						
							|  |  |  |  | G_DEFINE_DESTRUCTOR(debug_objects_atexit) | 
					
						
							|  |  |  |  | #endif /* G_HAS_CONSTRUCTORS */
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | debug_objects_atexit (void) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2014-05-25 22:32:17 +08:00
										 |  |  |  |   GOBJECT_IF_DEBUG (OBJECTS, | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-02-04 07:03:52 +00:00
										 |  |  |  |       G_LOCK (debug_objects); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |       g_message ("stale GObjects: %u", debug_objects_count); | 
					
						
							|  |  |  |  |       g_hash_table_foreach (debug_objects_ht, debug_objects_foreach, NULL); | 
					
						
							| 
									
										
										
										
											2001-02-04 07:03:52 +00:00
										 |  |  |  |       G_UNLOCK (debug_objects); | 
					
						
							| 
									
										
										
										
											2014-05-25 22:32:17 +08:00
										 |  |  |  |     }); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							| 
									
										
										
										
											2001-02-04 07:03:52 +00:00
										 |  |  |  | #endif	/* G_ENABLE_DEBUG */
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | void | 
					
						
							| 
									
										
										
										
											2011-06-02 17:14:58 -04:00
										 |  |  |  | _g_object_type_init (void) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   static gboolean initialized = FALSE; | 
					
						
							|  |  |  |  |   static const GTypeFundamentalInfo finfo = { | 
					
						
							|  |  |  |  |     G_TYPE_FLAG_CLASSED | G_TYPE_FLAG_INSTANTIATABLE | G_TYPE_FLAG_DERIVABLE | G_TYPE_FLAG_DEEP_DERIVABLE, | 
					
						
							|  |  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2011-11-29 22:02:00 -05:00
										 |  |  |  |   GTypeInfo info = { | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |     sizeof (GObjectClass), | 
					
						
							|  |  |  |  |     (GBaseInitFunc) g_object_base_class_init, | 
					
						
							|  |  |  |  |     (GBaseFinalizeFunc) g_object_base_class_finalize, | 
					
						
							|  |  |  |  |     (GClassInitFunc) g_object_do_class_init, | 
					
						
							|  |  |  |  |     NULL	/* class_destroy */, | 
					
						
							|  |  |  |  |     NULL	/* class_data */, | 
					
						
							|  |  |  |  |     sizeof (GObject), | 
					
						
							|  |  |  |  |     0		/* n_preallocs */, | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |     (GInstanceInitFunc) g_object_init, | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |     NULL,	/* value_table */ | 
					
						
							|  |  |  |  |   }; | 
					
						
							|  |  |  |  |   static const GTypeValueTable value_table = { | 
					
						
							|  |  |  |  |     g_value_object_init,	  /* value_init */ | 
					
						
							|  |  |  |  |     g_value_object_free_value,	  /* value_free */ | 
					
						
							|  |  |  |  |     g_value_object_copy_value,	  /* value_copy */ | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |     g_value_object_peek_pointer,  /* value_peek_pointer */ | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  |     "p",			  /* collect_format */ | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |     g_value_object_collect_value, /* collect_value */ | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  |     "p",			  /* lcopy_format */ | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |     g_value_object_lcopy_value,	  /* lcopy_value */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   }; | 
					
						
							|  |  |  |  |   GType type; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   g_return_if_fail (initialized == FALSE); | 
					
						
							|  |  |  |  |   initialized = TRUE; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   /* G_TYPE_OBJECT
 | 
					
						
							|  |  |  |  |    */ | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |   info.value_table = &value_table; | 
					
						
							| 
									
										
										
										
											2005-08-31 14:38:18 +00:00
										 |  |  |  |   type = g_type_register_fundamental (G_TYPE_OBJECT, g_intern_static_string ("GObject"), &info, &finfo, 0); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_assert (type == G_TYPE_OBJECT); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |   g_value_register_transform_func (G_TYPE_OBJECT, G_TYPE_OBJECT, g_value_object_transform_value); | 
					
						
							| 
									
										
										
										
											2016-08-04 09:33:25 +01:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | #if G_ENABLE_DEBUG
 | 
					
						
							|  |  |  |  |   /* We cannot use GOBJECT_IF_DEBUG here because of the G_HAS_CONSTRUCTORS
 | 
					
						
							|  |  |  |  |    * conditional in between, as the C spec leaves conditionals inside macro | 
					
						
							|  |  |  |  |    * expansions as undefined behavior. Only GCC and Clang are known to work | 
					
						
							|  |  |  |  |    * but compilation breaks on MSVC. | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * See: https://bugzilla.gnome.org/show_bug.cgi?id=769504
 | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |   if (_g_type_debug_flags & G_TYPE_DEBUG_OBJECTS) \ | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |     { | 
					
						
							|  |  |  |  |       debug_objects_ht = g_hash_table_new (g_direct_hash, NULL); | 
					
						
							| 
									
										
										
										
											2016-08-04 09:33:25 +01:00
										 |  |  |  | # ifndef G_HAS_CONSTRUCTORS
 | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |       g_atexit (debug_objects_atexit); | 
					
						
							| 
									
										
										
										
											2016-08-04 09:33:25 +01:00
										 |  |  |  | # endif /* G_HAS_CONSTRUCTORS */
 | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | #endif /* G_ENABLE_DEBUG */
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_base_class_init (GObjectClass *class) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   GObjectClass *pclass = g_type_class_peek_parent (class); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 19:27:48 +02:00
										 |  |  |  |   /* Don't inherit HAS_DERIVED_CLASS flag from parent class */ | 
					
						
							|  |  |  |  |   class->flags &= ~CLASS_HAS_DERIVED_CLASS_FLAG; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (pclass) | 
					
						
							|  |  |  |  |     pclass->flags |= CLASS_HAS_DERIVED_CLASS_FLAG; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   /* reset instance specific fields and methods that don't get inherited */ | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   class->construct_properties = pclass ? g_slist_copy (pclass->construct_properties) : NULL; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   class->get_property = NULL; | 
					
						
							|  |  |  |  |   class->set_property = NULL; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_base_class_finalize (GObjectClass *class) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   GList *list, *node; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
										
										
											2000-11-03 08:18:09 +00:00
										 |  |  |  |   _g_signals_destroy (G_OBJECT_CLASS_TYPE (class)); | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_slist_free (class->construct_properties); | 
					
						
							|  |  |  |  |   class->construct_properties = NULL; | 
					
						
							| 
									
										
										
										
											2001-06-28 17:05:12 +00:00
										 |  |  |  |   list = g_param_spec_pool_list_owned (pspec_pool, G_OBJECT_CLASS_TYPE (class)); | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   for (node = list; node; node = node->next) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |       GParamSpec *pspec = node->data; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |        | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |       g_param_spec_pool_remove (pspec_pool, pspec); | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |       PARAM_SPEC_SET_PARAM_ID (pspec, 0); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |       g_param_spec_unref (pspec); | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   g_list_free (list); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_do_class_init (GObjectClass *class) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2002-03-03 03:14:43 +00:00
										 |  |  |  |   /* read the comment about typedef struct CArray; on why not to change this quark */ | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |   quark_closure_array = g_quark_from_static_string ("GObject-closure-array"); | 
					
						
							| 
									
										
										
										
											2002-03-03 03:14:43 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   quark_weak_refs = g_quark_from_static_string ("GObject-weak-references"); | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |   quark_weak_locations = g_quark_from_static_string ("GObject-weak-locations"); | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  |   quark_toggle_refs = g_quark_from_static_string ("GObject-toggle-references"); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:41:06 +00:00
										 |  |  |  |   quark_notify_queue = g_quark_from_static_string ("GObject-notify-queue"); | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  |   quark_in_construction = g_quark_from_static_string ("GObject-in-construction"); | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   pspec_pool = g_param_spec_pool_new (TRUE); | 
					
						
							| 
									
										
										
										
											2011-01-12 19:45:40 +01:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   class->constructor = g_object_constructor; | 
					
						
							| 
									
										
										
										
											2011-01-12 19:45:40 +01:00
										 |  |  |  |   class->constructed = g_object_constructed; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   class->set_property = g_object_do_set_property; | 
					
						
							|  |  |  |  |   class->get_property = g_object_do_get_property; | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   class->dispose = g_object_real_dispose; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   class->finalize = g_object_finalize; | 
					
						
							|  |  |  |  |   class->dispatch_properties_changed = g_object_dispatch_properties_changed; | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   class->notify = NULL; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |   /**
 | 
					
						
							|  |  |  |  |    * GObject::notify: | 
					
						
							|  |  |  |  |    * @gobject: the object which received the signal. | 
					
						
							| 
									
										
										
										
											2009-01-02 06:09:26 +00:00
										 |  |  |  |    * @pspec: the #GParamSpec of the property which changed. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |    * | 
					
						
							|  |  |  |  |    * The notify signal is emitted on an object when one of its | 
					
						
							|  |  |  |  |    * properties has been changed. Note that getting this signal | 
					
						
							|  |  |  |  |    * doesn't guarantee that the value of the property has actually | 
					
						
							|  |  |  |  |    * changed, it may also be emitted when the setter for the property | 
					
						
							|  |  |  |  |    * is called to reinstate the previous value. | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * This signal is typically used to obtain change notification for a | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |    * single property, by specifying the property name as a detail in the | 
					
						
							|  |  |  |  |    * g_signal_connect() call, like this: | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |    * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |    * g_signal_connect (text_view->buffer, "notify::paste-target-list", | 
					
						
							|  |  |  |  |    *                   G_CALLBACK (gtk_text_view_target_list_notify), | 
					
						
							|  |  |  |  |    *                   text_view) | 
					
						
							|  |  |  |  |    * ]| | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |    * It is important to note that you must use | 
					
						
							| 
									
										
										
										
											2014-02-08 12:26:56 -05:00
										 |  |  |  |    * [canonical][canonical-parameter-name] parameter names as | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |    * detail strings for the notify signal. | 
					
						
							|  |  |  |  |    */ | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   gobject_signals[NOTIFY] = | 
					
						
							| 
									
										
										
										
											2005-08-31 19:42:51 +00:00
										 |  |  |  |     g_signal_new (g_intern_static_string ("notify"), | 
					
						
							| 
									
										
										
										
											2001-06-30 17:17:41 +00:00
										 |  |  |  | 		  G_TYPE_FROM_CLASS (class), | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 		  G_SIGNAL_RUN_FIRST | G_SIGNAL_NO_RECURSE | G_SIGNAL_DETAILED | G_SIGNAL_NO_HOOKS | G_SIGNAL_ACTION, | 
					
						
							| 
									
										
										
										
											2001-06-30 17:17:41 +00:00
										 |  |  |  | 		  G_STRUCT_OFFSET (GObjectClass, notify), | 
					
						
							|  |  |  |  | 		  NULL, NULL, | 
					
						
							|  |  |  |  | 		  g_cclosure_marshal_VOID__PARAM, | 
					
						
							|  |  |  |  | 		  G_TYPE_NONE, | 
					
						
							|  |  |  |  | 		  1, G_TYPE_PARAM); | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Install a check function that we'll use to verify that classes that
 | 
					
						
							|  |  |  |  |    * implement an interface implement all properties for that interface | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |   g_type_add_interface_check (NULL, object_interface_check_properties); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:30:08 -05:00
										 |  |  |  | static inline gboolean | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | install_property_internal (GType       g_type, | 
					
						
							|  |  |  |  | 			   guint       property_id, | 
					
						
							|  |  |  |  | 			   GParamSpec *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   if (g_param_spec_pool_lookup (pspec_pool, pspec->name, g_type, FALSE)) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-05-20 17:54:48 -03:00
										 |  |  |  |       g_warning ("When installing property: type '%s' already has a property named '%s'", | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | 		 g_type_name (g_type), | 
					
						
							|  |  |  |  | 		 pspec->name); | 
					
						
							| 
									
										
										
										
											2017-09-11 09:30:08 -05:00
										 |  |  |  |       return FALSE; | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-04 23:43:05 -04:00
										 |  |  |  |   g_param_spec_ref_sink (pspec); | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   PARAM_SPEC_SET_PARAM_ID (pspec, property_id); | 
					
						
							|  |  |  |  |   g_param_spec_pool_insert (pspec_pool, pspec, g_type); | 
					
						
							| 
									
										
										
										
											2017-09-11 09:30:08 -05:00
										 |  |  |  |   return TRUE; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  | static gboolean | 
					
						
							| 
									
										
										
										
											2017-09-11 09:41:28 -05:00
										 |  |  |  | validate_pspec_to_install (GParamSpec *pspec) | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_PARAM_SPEC (pspec), FALSE); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (PARAM_SPEC_PARAM_ID (pspec) == 0, FALSE);	/* paranoid */ | 
					
						
							| 
									
										
										
										
											2017-09-11 09:41:28 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:37:07 -05:00
										 |  |  |  |   g_return_val_if_fail (pspec->flags & (G_PARAM_READABLE | G_PARAM_WRITABLE), FALSE); | 
					
						
							| 
									
										
										
										
											2017-09-11 09:41:28 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  |   if (pspec->flags & G_PARAM_CONSTRUCT) | 
					
						
							|  |  |  |  |     g_return_val_if_fail ((pspec->flags & G_PARAM_CONSTRUCT_ONLY) == 0, FALSE); | 
					
						
							| 
									
										
										
										
											2017-09-11 09:41:28 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  |   if (pspec->flags & (G_PARAM_CONSTRUCT | G_PARAM_CONSTRUCT_ONLY)) | 
					
						
							|  |  |  |  |     g_return_val_if_fail (pspec->flags & G_PARAM_WRITABLE, FALSE); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:41:28 -05:00
										 |  |  |  |   return TRUE; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static gboolean | 
					
						
							|  |  |  |  | validate_and_install_class_property (GObjectClass *class, | 
					
						
							|  |  |  |  |                                      GType         oclass_type, | 
					
						
							|  |  |  |  |                                      GType         parent_type, | 
					
						
							|  |  |  |  |                                      guint         property_id, | 
					
						
							|  |  |  |  |                                      GParamSpec   *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   if (!validate_pspec_to_install (pspec)) | 
					
						
							|  |  |  |  |     return FALSE; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:35:53 -05:00
										 |  |  |  |   if (pspec->flags & G_PARAM_WRITABLE) | 
					
						
							|  |  |  |  |     g_return_val_if_fail (class->set_property != NULL, FALSE); | 
					
						
							|  |  |  |  |   if (pspec->flags & G_PARAM_READABLE) | 
					
						
							|  |  |  |  |     g_return_val_if_fail (class->get_property != NULL, FALSE); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  |   class->flags |= CLASS_HAS_PROPS_FLAG; | 
					
						
							| 
									
										
										
										
											2017-09-11 09:30:08 -05:00
										 |  |  |  |   if (install_property_internal (oclass_type, property_id, pspec)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       if (pspec->flags & (G_PARAM_CONSTRUCT | G_PARAM_CONSTRUCT_ONLY)) | 
					
						
							|  |  |  |  |         class->construct_properties = g_slist_append (class->construct_properties, pspec); | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:30:08 -05:00
										 |  |  |  |       /* for property overrides of construct properties, we have to get rid
 | 
					
						
							|  |  |  |  |        * of the overidden inherited construct property | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  |       pspec = g_param_spec_pool_lookup (pspec_pool, pspec->name, parent_type, TRUE); | 
					
						
							|  |  |  |  |       if (pspec && pspec->flags & (G_PARAM_CONSTRUCT | G_PARAM_CONSTRUCT_ONLY)) | 
					
						
							|  |  |  |  |         class->construct_properties = g_slist_remove (class->construct_properties, pspec); | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:30:08 -05:00
										 |  |  |  |       return TRUE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_class_install_property: | 
					
						
							|  |  |  |  |  * @oclass: a #GObjectClass | 
					
						
							|  |  |  |  |  * @property_id: the id for the new property | 
					
						
							|  |  |  |  |  * @pspec: the #GParamSpec for the new property | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-06-06 16:42:23 -04:00
										 |  |  |  |  * Installs a new property. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * All properties should be installed during the class initializer.  It | 
					
						
							|  |  |  |  |  * is possible to install properties after that, but doing so is not | 
					
						
							|  |  |  |  |  * recommend, and specifically, is not guaranteed to be thread-safe vs. | 
					
						
							|  |  |  |  |  * use of properties on the same type on other threads. | 
					
						
							| 
									
										
										
										
											2008-11-04 04:17:40 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Note that it is possible to redefine a property in a derived class, | 
					
						
							|  |  |  |  |  * by installing a property with the same name. This can be useful at times, | 
					
						
							|  |  |  |  |  * e.g. to change the range of allowed values or the default value. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | g_object_class_install_property (GObjectClass *class, | 
					
						
							|  |  |  |  | 				 guint	       property_id, | 
					
						
							|  |  |  |  | 				 GParamSpec   *pspec) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-09-11 09:02:23 -05:00
										 |  |  |  |   GType oclass_type, parent_type; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_OBJECT_CLASS (class)); | 
					
						
							| 
									
										
										
										
											2017-09-11 08:54:19 -05:00
										 |  |  |  |   g_return_if_fail (property_id > 0); | 
					
						
							| 
									
										
										
										
											2009-08-19 17:21:18 +02:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:02:23 -05:00
										 |  |  |  |   oclass_type = G_OBJECT_CLASS_TYPE (class); | 
					
						
							|  |  |  |  |   parent_type = g_type_parent (oclass_type); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 19:27:48 +02:00
										 |  |  |  |   if (CLASS_HAS_DERIVED_CLASS (class)) | 
					
						
							| 
									
										
										
										
											2013-04-22 17:37:18 -04:00
										 |  |  |  |     g_error ("Attempt to add property %s::%s to class after it was derived", G_OBJECT_CLASS_NAME (class), pspec->name); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  |   (void) validate_and_install_class_property (class, | 
					
						
							|  |  |  |  |                                               oclass_type, | 
					
						
							|  |  |  |  |                                               parent_type, | 
					
						
							|  |  |  |  |                                               property_id, | 
					
						
							|  |  |  |  |                                               pspec); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-18 15:32:27 +01:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_class_install_properties: | 
					
						
							|  |  |  |  |  * @oclass: a #GObjectClass | 
					
						
							| 
									
										
										
										
											2014-02-01 11:57:13 -05:00
										 |  |  |  |  * @n_pspecs: the length of the #GParamSpecs array | 
					
						
							|  |  |  |  |  * @pspecs: (array length=n_pspecs): the #GParamSpecs array | 
					
						
							| 
									
										
										
										
											2010-08-18 15:32:27 +01:00
										 |  |  |  |  *   defining the new properties | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-06-06 16:42:23 -04:00
										 |  |  |  |  * Installs new properties from an array of #GParamSpecs. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * All properties should be installed during the class initializer.  It | 
					
						
							|  |  |  |  |  * is possible to install properties after that, but doing so is not | 
					
						
							|  |  |  |  |  * recommend, and specifically, is not guaranteed to be thread-safe vs. | 
					
						
							|  |  |  |  |  * use of properties on the same type on other threads. | 
					
						
							| 
									
										
										
										
											2010-08-18 15:32:27 +01:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * The property id of each property is the index of each #GParamSpec in | 
					
						
							|  |  |  |  |  * the @pspecs array. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * The property id of 0 is treated specially by #GObject and it should not | 
					
						
							|  |  |  |  |  * be used to store a #GParamSpec. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This function should be used if you plan to use a static array of | 
					
						
							| 
									
										
										
										
											2014-02-01 11:57:13 -05:00
										 |  |  |  |  * #GParamSpecs and g_object_notify_by_pspec(). For instance, this | 
					
						
							| 
									
										
										
										
											2010-08-18 15:32:27 +01:00
										 |  |  |  |  * class initialization: | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2010-08-18 15:32:27 +01:00
										 |  |  |  |  * enum { | 
					
						
							|  |  |  |  |  *   PROP_0, PROP_FOO, PROP_BAR, N_PROPERTIES | 
					
						
							|  |  |  |  |  * }; | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * static GParamSpec *obj_properties[N_PROPERTIES] = { NULL, }; | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * static void | 
					
						
							|  |  |  |  |  * my_object_class_init (MyObjectClass *klass) | 
					
						
							|  |  |  |  |  * { | 
					
						
							|  |  |  |  |  *   GObjectClass *gobject_class = G_OBJECT_CLASS (klass); | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *   obj_properties[PROP_FOO] = | 
					
						
							|  |  |  |  |  *     g_param_spec_int ("foo", "Foo", "Foo", | 
					
						
							|  |  |  |  |  *                       -1, G_MAXINT, | 
					
						
							|  |  |  |  |  *                       0, | 
					
						
							|  |  |  |  |  *                       G_PARAM_READWRITE); | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *   obj_properties[PROP_BAR] = | 
					
						
							|  |  |  |  |  *     g_param_spec_string ("bar", "Bar", "Bar", | 
					
						
							|  |  |  |  |  *                          NULL, | 
					
						
							|  |  |  |  |  *                          G_PARAM_READWRITE); | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *   gobject_class->set_property = my_object_set_property; | 
					
						
							|  |  |  |  |  *   gobject_class->get_property = my_object_get_property; | 
					
						
							|  |  |  |  |  *   g_object_class_install_properties (gobject_class, | 
					
						
							|  |  |  |  |  *                                      N_PROPERTIES, | 
					
						
							|  |  |  |  |  *                                      obj_properties); | 
					
						
							|  |  |  |  |  * } | 
					
						
							|  |  |  |  |  * ]| | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * allows calling g_object_notify_by_pspec() to notify of property changes: | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2010-08-18 15:32:27 +01:00
										 |  |  |  |  * void | 
					
						
							|  |  |  |  |  * my_object_set_foo (MyObject *self, gint foo) | 
					
						
							|  |  |  |  |  * { | 
					
						
							|  |  |  |  |  *   if (self->foo != foo) | 
					
						
							|  |  |  |  |  *     { | 
					
						
							|  |  |  |  |  *       self->foo = foo; | 
					
						
							|  |  |  |  |  *       g_object_notify_by_pspec (G_OBJECT (self), obj_properties[PROP_FOO]); | 
					
						
							|  |  |  |  |  *     } | 
					
						
							|  |  |  |  |  *  } | 
					
						
							|  |  |  |  |  * ]| | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.26 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_object_class_install_properties (GObjectClass  *oclass, | 
					
						
							|  |  |  |  |                                    guint          n_pspecs, | 
					
						
							|  |  |  |  |                                    GParamSpec   **pspecs) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-10-08 16:09:10 +01:00
										 |  |  |  |   GType oclass_type, parent_type; | 
					
						
							| 
									
										
										
										
											2010-08-18 15:32:27 +01:00
										 |  |  |  |   gint i; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT_CLASS (oclass)); | 
					
						
							|  |  |  |  |   g_return_if_fail (n_pspecs > 1); | 
					
						
							|  |  |  |  |   g_return_if_fail (pspecs[0] == NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (CLASS_HAS_DERIVED_CLASS (oclass)) | 
					
						
							|  |  |  |  |     g_error ("Attempt to add properties to %s after it was derived", | 
					
						
							|  |  |  |  |              G_OBJECT_CLASS_NAME (oclass)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   oclass_type = G_OBJECT_CLASS_TYPE (oclass); | 
					
						
							| 
									
										
										
										
											2010-10-08 16:09:10 +01:00
										 |  |  |  |   parent_type = g_type_parent (oclass_type); | 
					
						
							| 
									
										
										
										
											2010-08-18 15:32:27 +01:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* we skip the first element of the array as it would have a 0 prop_id */ | 
					
						
							|  |  |  |  |   for (i = 1; i < n_pspecs; i++) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       GParamSpec *pspec = pspecs[i]; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:20:18 -05:00
										 |  |  |  |       if (!validate_and_install_class_property (oclass, | 
					
						
							|  |  |  |  |                                                 oclass_type, | 
					
						
							|  |  |  |  |                                                 parent_type, | 
					
						
							|  |  |  |  |                                                 i, | 
					
						
							|  |  |  |  |                                                 pspec)) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           break; | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-08-18 15:32:27 +01:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_interface_install_property: | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @g_iface: (type GObject.TypeInterface): any interface vtable for the | 
					
						
							|  |  |  |  |  *    interface, or the default | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  *  vtable for the interface. | 
					
						
							|  |  |  |  |  * @pspec: the #GParamSpec for the new property | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Add a property to an interface; this is only useful for interfaces | 
					
						
							|  |  |  |  |  * that are added to GObject-derived types. Adding a property to an | 
					
						
							|  |  |  |  |  * interface forces all objects classes with that interface to have a | 
					
						
							|  |  |  |  |  * compatible property. The compatible property could be a newly | 
					
						
							|  |  |  |  |  * created #GParamSpec, but normally | 
					
						
							|  |  |  |  |  * g_object_class_override_property() will be used so that the object | 
					
						
							|  |  |  |  |  * class only needs to provide an implementation and inherits the | 
					
						
							|  |  |  |  |  * property description, default value, bounds, and so forth from the | 
					
						
							|  |  |  |  |  * interface property. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * This function is meant to be called from the interface's default | 
					
						
							|  |  |  |  |  * vtable initialization function (the @class_init member of | 
					
						
							|  |  |  |  |  * #GTypeInfo.) It must not be called after after @class_init has | 
					
						
							|  |  |  |  |  * been called for any object types implementing this interface. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-02-14 15:11:11 +00:00
										 |  |  |  |  * If @pspec is a floating reference, it will be consumed. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since: 2.4 | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_interface_install_property (gpointer      g_iface, | 
					
						
							|  |  |  |  | 				     GParamSpec   *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GTypeInterface *iface_class = g_iface; | 
					
						
							|  |  |  |  | 	 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_TYPE_IS_INTERFACE (iface_class->g_type)); | 
					
						
							|  |  |  |  |   g_return_if_fail (!G_IS_PARAM_SPEC_OVERRIDE (pspec)); /* paranoid */ | 
					
						
							| 
									
										
										
										
											2017-09-11 09:34:52 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:41:28 -05:00
										 |  |  |  |   if (!validate_pspec_to_install (pspec)) | 
					
						
							|  |  |  |  |     return; | 
					
						
							| 
									
										
										
										
											2011-12-20 19:45:57 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-11 09:30:08 -05:00
										 |  |  |  |   (void) install_property_internal (iface_class->g_type, 0, pspec); | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_class_find_property: | 
					
						
							|  |  |  |  |  * @oclass: a #GObjectClass | 
					
						
							|  |  |  |  |  * @property_name: the name of the property to look up | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Looks up the #GParamSpec for a property of a class. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * Returns: (transfer none): the #GParamSpec for the property, or | 
					
						
							|  |  |  |  |  *          %NULL if the class doesn't have a property of that name | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | GParamSpec* | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | g_object_class_find_property (GObjectClass *class, | 
					
						
							|  |  |  |  | 			      const gchar  *property_name) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   GParamSpec *pspec; | 
					
						
							|  |  |  |  |   GParamSpec *redirect; | 
					
						
							|  |  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_return_val_if_fail (G_IS_OBJECT_CLASS (class), NULL); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_return_val_if_fail (property_name != NULL, NULL); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   pspec = g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 				    property_name, | 
					
						
							|  |  |  |  | 				    G_OBJECT_CLASS_TYPE (class), | 
					
						
							|  |  |  |  | 				    TRUE); | 
					
						
							|  |  |  |  |   if (pspec) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       redirect = g_param_spec_get_redirect_target (pspec); | 
					
						
							|  |  |  |  |       if (redirect) | 
					
						
							|  |  |  |  | 	return redirect; | 
					
						
							|  |  |  |  |       else | 
					
						
							|  |  |  |  | 	return pspec; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     return NULL; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_interface_find_property: | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @g_iface: (type GObject.TypeInterface): any interface vtable for the | 
					
						
							|  |  |  |  |  *  interface, or the default vtable for the interface | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @property_name: name of a property to lookup. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Find the #GParamSpec with the given name for an | 
					
						
							|  |  |  |  |  * interface. Generally, the interface vtable passed in as @g_iface | 
					
						
							|  |  |  |  |  * will be the default vtable from g_type_default_interface_ref(), or, | 
					
						
							|  |  |  |  |  * if you know the interface has already been loaded, | 
					
						
							|  |  |  |  |  * g_type_default_interface_peek(). | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since: 2.4 | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * Returns: (transfer none): the #GParamSpec for the property of the | 
					
						
							|  |  |  |  |  *          interface with the name @property_name, or %NULL if no | 
					
						
							|  |  |  |  |  *          such property exists. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | GParamSpec* | 
					
						
							|  |  |  |  | g_object_interface_find_property (gpointer      g_iface, | 
					
						
							|  |  |  |  | 				  const gchar  *property_name) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GTypeInterface *iface_class = g_iface; | 
					
						
							|  |  |  |  | 	 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_TYPE_IS_INTERFACE (iface_class->g_type), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (property_name != NULL, NULL); | 
					
						
							|  |  |  |  |    | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   return g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 				   property_name, | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | 				   iface_class->g_type, | 
					
						
							|  |  |  |  | 				   FALSE); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_class_override_property: | 
					
						
							|  |  |  |  |  * @oclass: a #GObjectClass | 
					
						
							|  |  |  |  |  * @property_id: the new property ID | 
					
						
							|  |  |  |  |  * @name: the name of a property registered in a parent class or | 
					
						
							|  |  |  |  |  *  in an interface of this class. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-05 22:57:27 -05:00
										 |  |  |  |  * Registers @property_id as referring to a property with the name | 
					
						
							|  |  |  |  |  * @name in a parent class or in an interface implemented by @oclass. | 
					
						
							|  |  |  |  |  * This allows this class to "override" a property implementation in | 
					
						
							|  |  |  |  |  * a parent class or to provide the implementation of a property from | 
					
						
							|  |  |  |  |  * an interface. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Internally, overriding is implemented by creating a property of type | 
					
						
							|  |  |  |  |  * #GParamSpecOverride; generally operations that query the properties of | 
					
						
							|  |  |  |  |  * the object class, such as g_object_class_find_property() or | 
					
						
							|  |  |  |  |  * g_object_class_list_properties() will return the overridden | 
					
						
							|  |  |  |  |  * property. However, in one case, the @construct_properties argument of | 
					
						
							|  |  |  |  |  * the @constructor virtual function, the #GParamSpecOverride is passed | 
					
						
							|  |  |  |  |  * instead, so that the @param_id field of the #GParamSpec will be | 
					
						
							|  |  |  |  |  * correct.  For virtually all uses, this makes no difference. If you | 
					
						
							|  |  |  |  |  * need to get the overridden property, you can call | 
					
						
							|  |  |  |  |  * g_param_spec_get_redirect_target(). | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since: 2.4 | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_class_override_property (GObjectClass *oclass, | 
					
						
							|  |  |  |  | 				  guint         property_id, | 
					
						
							|  |  |  |  | 				  const gchar  *name) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GParamSpec *overridden = NULL; | 
					
						
							|  |  |  |  |   GParamSpec *new; | 
					
						
							|  |  |  |  |   GType parent_type; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT_CLASS (oclass)); | 
					
						
							|  |  |  |  |   g_return_if_fail (property_id > 0); | 
					
						
							|  |  |  |  |   g_return_if_fail (name != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Find the overridden property; first check parent types
 | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |   parent_type = g_type_parent (G_OBJECT_CLASS_TYPE (oclass)); | 
					
						
							|  |  |  |  |   if (parent_type != G_TYPE_NONE) | 
					
						
							|  |  |  |  |     overridden = g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 					   name, | 
					
						
							|  |  |  |  | 					   parent_type, | 
					
						
							|  |  |  |  | 					   TRUE); | 
					
						
							|  |  |  |  |   if (!overridden) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       GType *ifaces; | 
					
						
							|  |  |  |  |       guint n_ifaces; | 
					
						
							|  |  |  |  |        | 
					
						
							|  |  |  |  |       /* Now check interfaces
 | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  |       ifaces = g_type_interfaces (G_OBJECT_CLASS_TYPE (oclass), &n_ifaces); | 
					
						
							|  |  |  |  |       while (n_ifaces-- && !overridden) | 
					
						
							|  |  |  |  | 	{ | 
					
						
							|  |  |  |  | 	  overridden = g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 						 name, | 
					
						
							|  |  |  |  | 						 ifaces[n_ifaces], | 
					
						
							|  |  |  |  | 						 FALSE); | 
					
						
							|  |  |  |  | 	} | 
					
						
							|  |  |  |  |        | 
					
						
							|  |  |  |  |       g_free (ifaces); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (!overridden) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_warning ("%s: Can't find property to override for '%s::%s'", | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 		 G_STRFUNC, G_OBJECT_CLASS_NAME (oclass), name); | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |       return; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   new = g_param_spec_override (name, overridden); | 
					
						
							|  |  |  |  |   g_object_class_install_property (oclass, property_id, new); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_class_list_properties: | 
					
						
							|  |  |  |  |  * @oclass: a #GObjectClass | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * @n_properties: (out): return location for the length of the returned array | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Get an array of #GParamSpec* for all properties of a class. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * Returns: (array length=n_properties) (transfer container): an array of | 
					
						
							| 
									
										
										
										
											2010-09-24 16:23:31 -03:00
										 |  |  |  |  *          #GParamSpec* which should be freed after use | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | GParamSpec** /* free result */ | 
					
						
							|  |  |  |  | g_object_class_list_properties (GObjectClass *class, | 
					
						
							|  |  |  |  | 				guint        *n_properties_p) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   GParamSpec **pspecs; | 
					
						
							|  |  |  |  |   guint n; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   g_return_val_if_fail (G_IS_OBJECT_CLASS (class), NULL); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   pspecs = g_param_spec_pool_list (pspec_pool, | 
					
						
							|  |  |  |  | 				   G_OBJECT_CLASS_TYPE (class), | 
					
						
							|  |  |  |  | 				   &n); | 
					
						
							|  |  |  |  |   if (n_properties_p) | 
					
						
							|  |  |  |  |     *n_properties_p = n; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   return pspecs; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_interface_list_properties: | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @g_iface: (type GObject.TypeInterface): any interface vtable for the | 
					
						
							|  |  |  |  |  *  interface, or the default vtable for the interface | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * @n_properties_p: (out): location to store number of properties returned. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Lists the properties of an interface.Generally, the interface | 
					
						
							|  |  |  |  |  * vtable passed in as @g_iface will be the default vtable from | 
					
						
							|  |  |  |  |  * g_type_default_interface_ref(), or, if you know the interface has | 
					
						
							|  |  |  |  |  * already been loaded, g_type_default_interface_peek(). | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since: 2.4 | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * Returns: (array length=n_properties_p) (transfer container): a | 
					
						
							|  |  |  |  |  *          pointer to an array of pointers to #GParamSpec | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  *          structures. The paramspecs are owned by GLib, but the | 
					
						
							|  |  |  |  |  *          array should be freed with g_free() when you are done with | 
					
						
							|  |  |  |  |  *          it. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							|  |  |  |  | GParamSpec** | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | g_object_interface_list_properties (gpointer      g_iface, | 
					
						
							|  |  |  |  | 				    guint        *n_properties_p) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GTypeInterface *iface_class = g_iface; | 
					
						
							|  |  |  |  |   GParamSpec **pspecs; | 
					
						
							|  |  |  |  |   guint n; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_TYPE_IS_INTERFACE (iface_class->g_type), NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   pspecs = g_param_spec_pool_list (pspec_pool, | 
					
						
							|  |  |  |  | 				   iface_class->g_type, | 
					
						
							|  |  |  |  | 				   &n); | 
					
						
							|  |  |  |  |   if (n_properties_p) | 
					
						
							|  |  |  |  |     *n_properties_p = n; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return pspecs; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-29 13:04:11 -04:00
										 |  |  |  | static inline gboolean | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  | object_in_construction (GObject *object) | 
					
						
							| 
									
										
										
										
											2013-04-29 13:04:11 -04:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  |   return g_datalist_id_get_data (&object->qdata, quark_in_construction) != NULL; | 
					
						
							| 
									
										
										
										
											2013-04-29 13:04:11 -04:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | static void | 
					
						
							| 
									
										
										
										
											2009-08-19 17:22:32 +02:00
										 |  |  |  | g_object_init (GObject		*object, | 
					
						
							|  |  |  |  | 	       GObjectClass	*class) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   object->ref_count = 1; | 
					
						
							| 
									
										
										
										
											2011-06-04 23:13:55 -04:00
										 |  |  |  |   object->qdata = NULL; | 
					
						
							| 
									
										
										
										
											2009-08-19 17:22:32 +02:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (CLASS_HAS_PROPS (class)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       /* freeze object's notification queue, g_object_newv() preserves pairedness */ | 
					
						
							| 
									
										
										
										
											2011-11-16 15:42:36 +00:00
										 |  |  |  |       g_object_notify_queue_freeze (object, FALSE); | 
					
						
							| 
									
										
										
										
											2009-08-19 17:22:32 +02:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-08 20:01:15 +02:00
										 |  |  |  |   if (CLASS_HAS_CUSTOM_CONSTRUCTOR (class)) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  |       /* mark object in-construction for notify_queue_thaw() and to allow construct-only properties */ | 
					
						
							|  |  |  |  |       g_datalist_id_set_data (&object->qdata, quark_in_construction, object); | 
					
						
							| 
									
										
										
										
											2009-10-08 20:01:15 +02:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2003-11-29 14:00:06 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-25 22:32:17 +08:00
										 |  |  |  |   GOBJECT_IF_DEBUG (OBJECTS, | 
					
						
							| 
									
										
										
										
											2000-07-06 20:18:12 +00:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-02-04 07:03:52 +00:00
										 |  |  |  |       G_LOCK (debug_objects); | 
					
						
							| 
									
										
										
										
											2000-07-06 20:18:12 +00:00
										 |  |  |  |       debug_objects_count++; | 
					
						
							| 
									
										
										
										
											2017-10-25 10:53:14 +01:00
										 |  |  |  |       g_hash_table_add (debug_objects_ht, object); | 
					
						
							| 
									
										
										
										
											2001-02-04 07:03:52 +00:00
										 |  |  |  |       G_UNLOCK (debug_objects); | 
					
						
							| 
									
										
										
										
											2014-05-25 22:32:17 +08:00
										 |  |  |  |     }); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_do_set_property (GObject      *object, | 
					
						
							|  |  |  |  | 			  guint         property_id, | 
					
						
							|  |  |  |  | 			  const GValue *value, | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 			  GParamSpec   *pspec) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   switch (property_id) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |     default: | 
					
						
							|  |  |  |  |       G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); | 
					
						
							|  |  |  |  |       break; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_do_get_property (GObject     *object, | 
					
						
							|  |  |  |  | 			  guint        property_id, | 
					
						
							|  |  |  |  | 			  GValue      *value, | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 			  GParamSpec  *pspec) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   switch (property_id) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |     default: | 
					
						
							|  |  |  |  |       G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); | 
					
						
							|  |  |  |  |       break; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_real_dispose (GObject *object) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_signal_handlers_destroy (object); | 
					
						
							|  |  |  |  |   g_datalist_id_set_data (&object->qdata, quark_closure_array, NULL); | 
					
						
							|  |  |  |  |   g_datalist_id_set_data (&object->qdata, quark_weak_refs, NULL); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_finalize (GObject *object) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  |   if (object_in_construction (object)) | 
					
						
							| 
									
										
										
										
											2013-04-29 13:04:11 -04:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-12-02 11:59:30 -05:00
										 |  |  |  |       g_critical ("object %s %p finalized while still in-construction", | 
					
						
							|  |  |  |  |                   G_OBJECT_TYPE_NAME (object), object); | 
					
						
							| 
									
										
										
										
											2013-04-29 13:04:11 -04:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   g_datalist_clear (&object->qdata); | 
					
						
							|  |  |  |  |    | 
					
						
							| 
									
										
										
										
											2014-05-25 22:32:17 +08:00
										 |  |  |  |   GOBJECT_IF_DEBUG (OBJECTS, | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |     { | 
					
						
							|  |  |  |  |       G_LOCK (debug_objects); | 
					
						
							| 
									
										
										
										
											2017-10-25 10:53:14 +01:00
										 |  |  |  |       g_assert (g_hash_table_contains (debug_objects_ht, object)); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |       g_hash_table_remove (debug_objects_ht, object); | 
					
						
							|  |  |  |  |       debug_objects_count--; | 
					
						
							|  |  |  |  |       G_UNLOCK (debug_objects); | 
					
						
							| 
									
										
										
										
											2014-05-25 22:32:17 +08:00
										 |  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_dispatch_properties_changed (GObject     *object, | 
					
						
							|  |  |  |  | 				      guint        n_pspecs, | 
					
						
							|  |  |  |  | 				      GParamSpec **pspecs) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   guint i; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   for (i = 0; i < n_pspecs; i++) | 
					
						
							| 
									
										
										
										
											2015-09-07 20:56:10 -04:00
										 |  |  |  |     g_signal_emit (object, gobject_signals[NOTIFY], g_param_spec_get_name_quark (pspecs[i]), pspecs[i]); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_run_dispose: | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Releases all references to other objects. This can be used to break | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * reference cycles. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2015-01-25 17:09:35 +00:00
										 |  |  |  |  * This function should only be called from object system implementations. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_run_dispose (GObject *object) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (object->ref_count > 0); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_ref (object); | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  |   TRACE (GOBJECT_OBJECT_DISPOSE(object,G_TYPE_FROM_INSTANCE(object), 0)); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   G_OBJECT_GET_CLASS (object)->dispose (object); | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  |   TRACE (GOBJECT_OBJECT_DISPOSE_END(object,G_TYPE_FROM_INSTANCE(object), 0)); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   g_object_unref (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_freeze_notify: | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-29 12:09:31 +00:00
										 |  |  |  |  * Increases the freeze count on @object. If the freeze count is | 
					
						
							|  |  |  |  |  * non-zero, the emission of "notify" signals on @object is | 
					
						
							|  |  |  |  |  * stopped. The signals are queued until the freeze count is decreased | 
					
						
							| 
									
										
										
										
											2012-05-27 22:40:44 +01:00
										 |  |  |  |  * to zero. Duplicate notifications are squashed so that at most one | 
					
						
							|  |  |  |  |  * #GObject::notify signal is emitted for each property modified while the | 
					
						
							|  |  |  |  |  * object is frozen. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * This is necessary for accessors that modify multiple properties to prevent | 
					
						
							|  |  |  |  |  * premature notification while the object is still being modified. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_freeze_notify (GObject *object) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-17 16:14:39 +00:00
										 |  |  |  |   if (g_atomic_int_get (&object->ref_count) == 0) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |     return; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_ref (object); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:42:36 +00:00
										 |  |  |  |   g_object_notify_queue_freeze (object, FALSE); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_object_unref (object); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-16 15:38:25 +00:00
										 |  |  |  | static GParamSpec * | 
					
						
							|  |  |  |  | get_notify_pspec (GParamSpec *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GParamSpec *redirected; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* we don't notify on non-READABLE parameters */ | 
					
						
							|  |  |  |  |   if (~pspec->flags & G_PARAM_READABLE) | 
					
						
							|  |  |  |  |     return NULL; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* if the paramspec is redirected, notify on the target */ | 
					
						
							|  |  |  |  |   redirected = g_param_spec_get_redirect_target (pspec); | 
					
						
							|  |  |  |  |   if (redirected != NULL) | 
					
						
							|  |  |  |  |     return redirected; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* else, notify normally */ | 
					
						
							|  |  |  |  |   return pspec; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-10 15:50:40 +01:00
										 |  |  |  | static inline void | 
					
						
							|  |  |  |  | g_object_notify_by_spec_internal (GObject    *object, | 
					
						
							|  |  |  |  | 				  GParamSpec *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-11-16 15:38:25 +00:00
										 |  |  |  |   GParamSpec *notify_pspec; | 
					
						
							| 
									
										
										
										
											2010-04-10 15:50:40 +01:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-16 15:38:25 +00:00
										 |  |  |  |   notify_pspec = get_notify_pspec (pspec); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (notify_pspec != NULL) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-11-16 13:02:23 +00:00
										 |  |  |  |       GObjectNotifyQueue *nqueue; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* conditional freeze: only increase freeze count if already frozen */ | 
					
						
							|  |  |  |  |       nqueue = g_object_notify_queue_freeze (object, TRUE); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       if (nqueue != NULL) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           /* we're frozen, so add to the queue and release our freeze */ | 
					
						
							|  |  |  |  |           g_object_notify_queue_add (object, nqueue, notify_pspec); | 
					
						
							|  |  |  |  |           g_object_notify_queue_thaw (object, nqueue); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       else | 
					
						
							|  |  |  |  |         /* not frozen, so just dispatch the notification directly */ | 
					
						
							|  |  |  |  |         G_OBJECT_GET_CLASS (object) | 
					
						
							|  |  |  |  |           ->dispatch_properties_changed (object, 1, ¬ify_pspec); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:38:25 +00:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-04-10 15:50:40 +01:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_notify: | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @property_name: the name of a property installed on the class of @object. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Emits a "notify" signal for the property @property_name on @object. | 
					
						
							| 
									
										
										
										
											2010-04-10 15:50:40 +01:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * When possible, eg. when signaling a property change from within the class | 
					
						
							|  |  |  |  |  * that registered the property, you should use g_object_notify_by_pspec() | 
					
						
							|  |  |  |  |  * instead. | 
					
						
							| 
									
										
										
										
											2013-11-23 16:44:31 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Note that emission of the notify signal may be blocked with | 
					
						
							|  |  |  |  |  * g_object_freeze_notify(). In this case, the signal emissions are queued | 
					
						
							|  |  |  |  |  * and will be emitted (in reverse order) when g_object_thaw_notify() is | 
					
						
							|  |  |  |  |  * called. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_notify (GObject     *object, | 
					
						
							|  |  |  |  | 		 const gchar *property_name) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   GParamSpec *pspec; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (property_name != NULL); | 
					
						
							| 
									
										
										
										
											2009-02-17 16:14:39 +00:00
										 |  |  |  |   if (g_atomic_int_get (&object->ref_count) == 0) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |     return; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_object_ref (object); | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   /* We don't need to get the redirect target
 | 
					
						
							|  |  |  |  |    * (by, e.g. calling g_object_class_find_property()) | 
					
						
							|  |  |  |  |    * because g_object_notify_queue_add() does that | 
					
						
							|  |  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   pspec = g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 				    property_name, | 
					
						
							|  |  |  |  | 				    G_OBJECT_TYPE (object), | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 				    TRUE); | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   if (!pspec) | 
					
						
							| 
									
										
										
										
											2013-05-20 17:54:48 -03:00
										 |  |  |  |     g_warning ("%s: object class '%s' has no property named '%s'", | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 	       G_STRFUNC, | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 	       G_OBJECT_TYPE_NAME (object), | 
					
						
							|  |  |  |  | 	       property_name); | 
					
						
							|  |  |  |  |   else | 
					
						
							| 
									
										
										
										
											2010-04-10 15:50:40 +01:00
										 |  |  |  |     g_object_notify_by_spec_internal (object, pspec); | 
					
						
							|  |  |  |  |   g_object_unref (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_notify_by_pspec: | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @pspec: the #GParamSpec of a property installed on the class of @object. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Emits a "notify" signal for the property specified by @pspec on @object. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This function omits the property name lookup, hence it is faster than | 
					
						
							|  |  |  |  |  * g_object_notify(). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * One way to avoid using g_object_notify() from within the | 
					
						
							|  |  |  |  |  * class that registered the properties, and using g_object_notify_by_pspec() | 
					
						
							|  |  |  |  |  * instead, is to store the GParamSpec used with | 
					
						
							|  |  |  |  |  * g_object_class_install_property() inside a static array, e.g.: | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  *|[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2010-04-10 15:50:40 +01:00
										 |  |  |  |  *   enum | 
					
						
							|  |  |  |  |  *   { | 
					
						
							|  |  |  |  |  *     PROP_0, | 
					
						
							|  |  |  |  |  *     PROP_FOO, | 
					
						
							|  |  |  |  |  *     PROP_LAST | 
					
						
							|  |  |  |  |  *   }; | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *   static GParamSpec *properties[PROP_LAST]; | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *   static void | 
					
						
							|  |  |  |  |  *   my_object_class_init (MyObjectClass *klass) | 
					
						
							|  |  |  |  |  *   { | 
					
						
							|  |  |  |  |  *     properties[PROP_FOO] = g_param_spec_int ("foo", "Foo", "The foo", | 
					
						
							|  |  |  |  |  *                                              0, 100, | 
					
						
							|  |  |  |  |  *                                              50, | 
					
						
							|  |  |  |  |  *                                              G_PARAM_READWRITE); | 
					
						
							|  |  |  |  |  *     g_object_class_install_property (gobject_class, | 
					
						
							|  |  |  |  |  *                                      PROP_FOO, | 
					
						
							|  |  |  |  |  *                                      properties[PROP_FOO]); | 
					
						
							|  |  |  |  |  *   } | 
					
						
							|  |  |  |  |  * ]| | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * and then notify a change on the "foo" property with: | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2010-04-10 15:50:40 +01:00
										 |  |  |  |  *   g_object_notify_by_pspec (self, properties[PROP_FOO]); | 
					
						
							|  |  |  |  |  * ]| | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.26 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_object_notify_by_pspec (GObject    *object, | 
					
						
							|  |  |  |  | 			  GParamSpec *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_PARAM_SPEC (pspec)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-07 21:01:00 +02:00
										 |  |  |  |   if (g_atomic_int_get (&object->ref_count) == 0) | 
					
						
							|  |  |  |  |     return; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-10 15:50:40 +01:00
										 |  |  |  |   g_object_ref (object); | 
					
						
							|  |  |  |  |   g_object_notify_by_spec_internal (object, pspec); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_object_unref (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_thaw_notify: | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-29 12:09:31 +00:00
										 |  |  |  |  * Reverts the effect of a previous call to | 
					
						
							|  |  |  |  |  * g_object_freeze_notify(). The freeze count is decreased on @object | 
					
						
							| 
									
										
										
										
											2012-05-27 22:40:44 +01:00
										 |  |  |  |  * and when it reaches zero, queued "notify" signals are emitted. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Duplicate notifications for each property are squashed so that at most one | 
					
						
							| 
									
										
										
										
											2013-11-23 16:44:31 -05:00
										 |  |  |  |  * #GObject::notify signal is emitted for each property, in the reverse order | 
					
						
							|  |  |  |  |  * in which they have been queued. | 
					
						
							| 
									
										
										
										
											2008-06-29 12:09:31 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * It is an error to call this function when the freeze count is zero. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_thaw_notify (GObject *object) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   GObjectNotifyQueue *nqueue; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |    | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							| 
									
										
										
										
											2009-02-17 16:14:39 +00:00
										 |  |  |  |   if (g_atomic_int_get (&object->ref_count) == 0) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |     return; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   g_object_ref (object); | 
					
						
							| 
									
										
										
										
											2010-07-22 21:20:35 +02:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* FIXME: Freezing is the only way to get at the notify queue.
 | 
					
						
							|  |  |  |  |    * So we freeze once and then thaw twice. | 
					
						
							|  |  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2011-11-16 15:42:36 +00:00
										 |  |  |  |   nqueue = g_object_notify_queue_freeze (object, FALSE); | 
					
						
							| 
									
										
										
										
											2010-07-22 21:20:35 +02:00
										 |  |  |  |   g_object_notify_queue_thaw (object, nqueue); | 
					
						
							|  |  |  |  |   g_object_notify_queue_thaw (object, nqueue); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_object_unref (object); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | consider_issuing_property_deprecation_warning (const GParamSpec *pspec) | 
					
						
							| 
									
										
										
										
											2014-06-24 16:13:30 -04:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   static GHashTable *already_warned_table; | 
					
						
							|  |  |  |  |   static const gchar *enable_diagnostic; | 
					
						
							|  |  |  |  |   static GMutex already_warned_lock; | 
					
						
							|  |  |  |  |   gboolean already; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (!(pspec->flags & G_PARAM_DEPRECATED)) | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  |     return; | 
					
						
							| 
									
										
										
										
											2014-06-24 16:13:30 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (g_once_init_enter (&enable_diagnostic)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       const gchar *value = g_getenv ("G_ENABLE_DIAGNOSTIC"); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       if (!value) | 
					
						
							| 
									
										
										
										
											2015-09-14 18:42:12 -04:00
										 |  |  |  |         value = "0"; | 
					
						
							| 
									
										
										
										
											2014-06-24 16:13:30 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       g_once_init_leave (&enable_diagnostic, value); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (enable_diagnostic[0] == '0') | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  |     return; | 
					
						
							| 
									
										
										
										
											2014-06-24 16:13:30 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* We hash only on property names: this means that we could end up in
 | 
					
						
							|  |  |  |  |    * a situation where we fail to emit a warning about a pair of | 
					
						
							|  |  |  |  |    * same-named deprecated properties used on two separate types. | 
					
						
							|  |  |  |  |    * That's pretty unlikely to occur, and even if it does, you'll still | 
					
						
							|  |  |  |  |    * have seen the warning for the first one... | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * Doing it this way lets us hash directly on the (interned) property | 
					
						
							|  |  |  |  |    * name pointers. | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |   g_mutex_lock (&already_warned_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (already_warned_table == NULL) | 
					
						
							|  |  |  |  |     already_warned_table = g_hash_table_new (NULL, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   already = g_hash_table_contains (already_warned_table, (gpointer) pspec->name); | 
					
						
							|  |  |  |  |   if (!already) | 
					
						
							|  |  |  |  |     g_hash_table_add (already_warned_table, (gpointer) pspec->name); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_mutex_unlock (&already_warned_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  |   if (!already) | 
					
						
							|  |  |  |  |     g_warning ("The property %s:%s is deprecated and shouldn't be used " | 
					
						
							|  |  |  |  |                "anymore. It will be removed in a future version.", | 
					
						
							|  |  |  |  |                g_type_name (pspec->owner_type), pspec->name); | 
					
						
							| 
									
										
										
										
											2014-06-24 16:13:30 -04:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | static inline void | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | object_get_property (GObject     *object, | 
					
						
							|  |  |  |  | 		     GParamSpec  *pspec, | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 		     GValue      *value) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   GObjectClass *class = g_type_class_peek (pspec->owner_type); | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   guint param_id = PARAM_SPEC_PARAM_ID (pspec); | 
					
						
							|  |  |  |  |   GParamSpec *redirect; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-02 19:22:25 +02:00
										 |  |  |  |   if (class == NULL) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_warning ("'%s::%s' is not a valid property name; '%s' is not a GObject subtype", | 
					
						
							|  |  |  |  |                  g_type_name (pspec->owner_type), pspec->name, g_type_name (pspec->owner_type)); | 
					
						
							|  |  |  |  |       return; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   redirect = g_param_spec_get_redirect_target (pspec); | 
					
						
							|  |  |  |  |   if (redirect) | 
					
						
							| 
									
										
										
										
											2014-06-24 16:13:30 -04:00
										 |  |  |  |     pspec = redirect; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  |   consider_issuing_property_deprecation_warning (pspec); | 
					
						
							| 
									
										
										
										
											2014-06-24 16:13:30 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   class->get_property (object, param_id, value, pspec); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | static inline void | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | object_set_property (GObject             *object, | 
					
						
							|  |  |  |  | 		     GParamSpec          *pspec, | 
					
						
							|  |  |  |  | 		     const GValue        *value, | 
					
						
							|  |  |  |  | 		     GObjectNotifyQueue  *nqueue) | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-30 17:19:50 +01:00
										 |  |  |  |   GValue tmp_value = G_VALUE_INIT; | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |   GObjectClass *class = g_type_class_peek (pspec->owner_type); | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   guint param_id = PARAM_SPEC_PARAM_ID (pspec); | 
					
						
							|  |  |  |  |   GParamSpec *redirect; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-02 19:22:25 +02:00
										 |  |  |  |   if (class == NULL) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_warning ("'%s::%s' is not a valid property name; '%s' is not a GObject subtype", | 
					
						
							|  |  |  |  |                  g_type_name (pspec->owner_type), pspec->name, g_type_name (pspec->owner_type)); | 
					
						
							|  |  |  |  |       return; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   redirect = g_param_spec_get_redirect_target (pspec); | 
					
						
							|  |  |  |  |   if (redirect) | 
					
						
							|  |  |  |  |     pspec = redirect; | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* provide a copy to work from, convert (if necessary) and validate */ | 
					
						
							| 
									
										
										
										
											2009-12-07 11:23:55 +01:00
										 |  |  |  |   g_value_init (&tmp_value, pspec->value_type); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |   if (!g_value_transform (value, &tmp_value)) | 
					
						
							| 
									
										
										
										
											2013-05-20 17:54:48 -03:00
										 |  |  |  |     g_warning ("unable to set property '%s' of type '%s' from value of type '%s'", | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	       pspec->name, | 
					
						
							| 
									
										
										
										
											2009-12-07 11:23:55 +01:00
										 |  |  |  | 	       g_type_name (pspec->value_type), | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	       G_VALUE_TYPE_NAME (value)); | 
					
						
							|  |  |  |  |   else if (g_param_value_validate (pspec, &tmp_value) && !(pspec->flags & G_PARAM_LAX_VALIDATION)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       gchar *contents = g_strdup_value_contents (value); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-20 17:54:48 -03:00
										 |  |  |  |       g_warning ("value \"%s\" of type '%s' is invalid or out of range for property '%s' of type '%s'", | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 		 contents, | 
					
						
							|  |  |  |  | 		 G_VALUE_TYPE_NAME (value), | 
					
						
							|  |  |  |  | 		 pspec->name, | 
					
						
							| 
									
										
										
										
											2009-12-07 11:23:55 +01:00
										 |  |  |  | 		 g_type_name (pspec->value_type)); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       g_free (contents); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |       class->set_property (object, param_id, &tmp_value, pspec); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:38:25 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-04 08:59:50 -04:00
										 |  |  |  |       if (~pspec->flags & G_PARAM_EXPLICIT_NOTIFY) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           GParamSpec *notify_pspec; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           notify_pspec = get_notify_pspec (pspec); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:38:25 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-04 08:59:50 -04:00
										 |  |  |  |           if (notify_pspec != NULL) | 
					
						
							|  |  |  |  |             g_object_notify_queue_add (object, nqueue, notify_pspec); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  |   g_value_unset (&tmp_value); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | static void | 
					
						
							| 
									
										
										
										
											2013-05-02 13:58:25 -04:00
										 |  |  |  | object_interface_check_properties (gpointer check_data, | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | 				   gpointer g_iface) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GTypeInterface *iface_class = g_iface; | 
					
						
							| 
									
										
										
										
											2010-12-27 23:41:10 -05:00
										 |  |  |  |   GObjectClass *class; | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   GType iface_type = iface_class->g_type; | 
					
						
							|  |  |  |  |   GParamSpec **pspecs; | 
					
						
							|  |  |  |  |   guint n; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-27 23:41:10 -05:00
										 |  |  |  |   class = g_type_class_ref (iface_class->g_instance_type); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-22 11:00:14 +02:00
										 |  |  |  |   if (class == NULL) | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |     return; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-22 11:00:14 +02:00
										 |  |  |  |   if (!G_IS_OBJECT_CLASS (class)) | 
					
						
							|  |  |  |  |     goto out; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   pspecs = g_param_spec_pool_list (pspec_pool, iface_type, &n); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   while (n--) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       GParamSpec *class_pspec = g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 							  pspecs[n]->name, | 
					
						
							|  |  |  |  | 							  G_OBJECT_CLASS_TYPE (class), | 
					
						
							|  |  |  |  | 							  TRUE); | 
					
						
							| 
									
										
										
										
											2010-12-27 23:41:10 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |       if (!class_pspec) | 
					
						
							|  |  |  |  | 	{ | 
					
						
							|  |  |  |  | 	  g_critical ("Object class %s doesn't implement property " | 
					
						
							|  |  |  |  | 		      "'%s' from interface '%s'", | 
					
						
							|  |  |  |  | 		      g_type_name (G_OBJECT_CLASS_TYPE (class)), | 
					
						
							|  |  |  |  | 		      pspecs[n]->name, | 
					
						
							|  |  |  |  | 		      g_type_name (iface_type)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 	  continue; | 
					
						
							|  |  |  |  | 	} | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-20 18:41:03 -05:00
										 |  |  |  |       /* We do a number of checks on the properties of an interface to
 | 
					
						
							|  |  |  |  |        * make sure that all classes implementing the interface are | 
					
						
							|  |  |  |  |        * overriding the properties in a sane way. | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * We do the checks in order of importance so that we can give | 
					
						
							|  |  |  |  |        * more useful error messages first. | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * First, we check that the implementation doesn't remove the | 
					
						
							|  |  |  |  |        * basic functionality (readability, writability) advertised by | 
					
						
							|  |  |  |  |        * the interface.  Next, we check that it doesn't introduce | 
					
						
							|  |  |  |  |        * additional restrictions (such as construct-only).  Finally, we | 
					
						
							|  |  |  |  |        * make sure the types are compatible. | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #define SUBSET(a,b,mask) (((a) & ~(b) & (mask)) == 0)
 | 
					
						
							|  |  |  |  |       /* If the property on the interface is readable then the
 | 
					
						
							|  |  |  |  |        * implementation must be readable.  If the interface is writable | 
					
						
							|  |  |  |  |        * then the implementation must be writable. | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  |       if (!SUBSET (pspecs[n]->flags, class_pspec->flags, G_PARAM_READABLE | G_PARAM_WRITABLE)) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           g_critical ("Flags for property '%s' on class '%s' remove functionality compared with the " | 
					
						
							|  |  |  |  |                       "property on interface '%s'\n", pspecs[n]->name, | 
					
						
							|  |  |  |  |                       g_type_name (G_OBJECT_CLASS_TYPE (class)), g_type_name (iface_type)); | 
					
						
							|  |  |  |  |           continue; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* If the property on the interface is writable then we need to
 | 
					
						
							|  |  |  |  |        * make sure the implementation doesn't introduce new restrictions | 
					
						
							|  |  |  |  |        * on that writability (ie: construct-only). | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * If the interface was not writable to begin with then we don't | 
					
						
							|  |  |  |  |        * really have any problems here because "writable at construct | 
					
						
							| 
									
										
										
										
											2015-09-10 20:46:21 -05:00
										 |  |  |  |        * time only" is still more permissive than "read only". | 
					
						
							| 
									
										
										
										
											2011-12-20 18:41:03 -05:00
										 |  |  |  |        */ | 
					
						
							|  |  |  |  |       if (pspecs[n]->flags & G_PARAM_WRITABLE) | 
					
						
							|  |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2011-12-20 19:33:02 -05:00
										 |  |  |  |           if (!SUBSET (class_pspec->flags, pspecs[n]->flags, G_PARAM_CONSTRUCT_ONLY)) | 
					
						
							| 
									
										
										
										
											2011-12-20 18:41:03 -05:00
										 |  |  |  |             { | 
					
						
							|  |  |  |  |               g_critical ("Flags for property '%s' on class '%s' introduce additional restrictions on " | 
					
						
							|  |  |  |  |                           "writability compared with the property on interface '%s'\n", pspecs[n]->name, | 
					
						
							|  |  |  |  |                           g_type_name (G_OBJECT_CLASS_TYPE (class)), g_type_name (iface_type)); | 
					
						
							|  |  |  |  |               continue; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | #undef SUBSET
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-20 18:26:14 -05:00
										 |  |  |  |       /* If the property on the interface is readable then we are
 | 
					
						
							|  |  |  |  |        * effectively advertising that reading the property will return a | 
					
						
							|  |  |  |  |        * value of a specific type.  All implementations of the interface | 
					
						
							|  |  |  |  |        * need to return items of this type -- but may be more | 
					
						
							|  |  |  |  |        * restrictive.  For example, it is legal to have: | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        *   GtkWidget *get_item(); | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * that is implemented by a function that always returns a | 
					
						
							|  |  |  |  |        * GtkEntry.  In short: readability implies that the | 
					
						
							|  |  |  |  |        * implementation  value type must be equal or more restrictive. | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * Similarly, if the property on the interface is writable then | 
					
						
							|  |  |  |  |        * must be able to accept the property being set to any value of | 
					
						
							|  |  |  |  |        * that type, including subclasses.  In this case, we may also be | 
					
						
							|  |  |  |  |        * less restrictive.  For example, it is legal to have: | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        *   set_item (GtkEntry *); | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * that is implemented by a function that will actually work with | 
					
						
							|  |  |  |  |        * any GtkWidget.  In short: writability implies that the | 
					
						
							|  |  |  |  |        * implementation value type must be equal or less restrictive. | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * In the case that the property is both readable and writable | 
					
						
							|  |  |  |  |        * then the only way that both of the above can be satisfied is | 
					
						
							|  |  |  |  |        * with a type that is exactly equal. | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |        */ | 
					
						
							| 
									
										
										
										
											2011-12-20 18:26:14 -05:00
										 |  |  |  |       switch (pspecs[n]->flags & (G_PARAM_READABLE | G_PARAM_WRITABLE)) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |         case G_PARAM_READABLE | G_PARAM_WRITABLE: | 
					
						
							|  |  |  |  |           /* class pspec value type must have exact equality with interface */ | 
					
						
							|  |  |  |  |           if (pspecs[n]->value_type != class_pspec->value_type) | 
					
						
							|  |  |  |  |             g_critical ("Read/writable property '%s' on class '%s' has type '%s' which is not exactly equal to the " | 
					
						
							|  |  |  |  |                         "type '%s' of the property on the interface '%s'\n", pspecs[n]->name, | 
					
						
							|  |  |  |  |                         g_type_name (G_OBJECT_CLASS_TYPE (class)), g_type_name (G_PARAM_SPEC_VALUE_TYPE (class_pspec)), | 
					
						
							|  |  |  |  |                         g_type_name (G_PARAM_SPEC_VALUE_TYPE (pspecs[n])), g_type_name (iface_type)); | 
					
						
							|  |  |  |  |           break; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         case G_PARAM_READABLE: | 
					
						
							|  |  |  |  |           /* class pspec value type equal or more restrictive than interface */ | 
					
						
							|  |  |  |  |           if (!g_type_is_a (class_pspec->value_type, pspecs[n]->value_type)) | 
					
						
							|  |  |  |  |             g_critical ("Read-only property '%s' on class '%s' has type '%s' which is not equal to or more " | 
					
						
							|  |  |  |  |                         "restrictive than the type '%s' of the property on the interface '%s'\n", pspecs[n]->name, | 
					
						
							|  |  |  |  |                         g_type_name (G_OBJECT_CLASS_TYPE (class)), g_type_name (G_PARAM_SPEC_VALUE_TYPE (class_pspec)), | 
					
						
							|  |  |  |  |                         g_type_name (G_PARAM_SPEC_VALUE_TYPE (pspecs[n])), g_type_name (iface_type)); | 
					
						
							|  |  |  |  |           break; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         case G_PARAM_WRITABLE: | 
					
						
							|  |  |  |  |           /* class pspec value type equal or less restrictive than interface */ | 
					
						
							|  |  |  |  |           if (!g_type_is_a (pspecs[n]->value_type, class_pspec->value_type)) | 
					
						
							|  |  |  |  |             g_critical ("Write-only property '%s' on class '%s' has type '%s' which is not equal to or less " | 
					
						
							|  |  |  |  |                         "restrictive than the type '%s' of the property on the interface '%s' \n", pspecs[n]->name, | 
					
						
							|  |  |  |  |                         g_type_name (G_OBJECT_CLASS_TYPE (class)), g_type_name (G_PARAM_SPEC_VALUE_TYPE (class_pspec)), | 
					
						
							|  |  |  |  |                         g_type_name (G_PARAM_SPEC_VALUE_TYPE (pspecs[n])), g_type_name (iface_type)); | 
					
						
							|  |  |  |  |           break; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         default: | 
					
						
							|  |  |  |  |           g_assert_not_reached (); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-12-27 23:41:10 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  |   g_free (pspecs); | 
					
						
							| 
									
										
										
										
											2010-12-27 23:41:10 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-22 11:00:14 +02:00
										 |  |  |  |  out: | 
					
						
							| 
									
										
										
										
											2010-12-27 23:41:10 -05:00
										 |  |  |  |   g_type_class_unref (class); | 
					
						
							| 
									
										
										
										
											2003-10-21 19:12:27 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-21 09:18:25 +00:00
										 |  |  |  | GType | 
					
						
							|  |  |  |  | g_object_get_type (void) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     return G_TYPE_OBJECT; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_new: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object_type: the type id of the #GObject subtype to instantiate | 
					
						
							|  |  |  |  |  * @first_property_name: the name of the first property | 
					
						
							|  |  |  |  |  * @...: the value of the first property, followed optionally by more | 
					
						
							|  |  |  |  |  *  name/value pairs, followed by %NULL | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Creates a new instance of a #GObject subtype and sets its properties. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Construction parameters (see #G_PARAM_CONSTRUCT, #G_PARAM_CONSTRUCT_ONLY) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * which are not explicitly specified are set to their default values. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-05-02 18:57:54 +05:30
										 |  |  |  |  * Returns: (transfer full) (type GObject.Object): a new instance of | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  *   @object_type | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | gpointer | 
					
						
							|  |  |  |  | g_object_new (GType	   object_type, | 
					
						
							|  |  |  |  | 	      const gchar *first_property_name, | 
					
						
							|  |  |  |  | 	      ...) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObject *object; | 
					
						
							|  |  |  |  |   va_list var_args; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
										
										
											2010-01-01 20:36:28 -08:00
										 |  |  |  |   /* short circuit for calls supplying no properties */ | 
					
						
							|  |  |  |  |   if (!first_property_name) | 
					
						
							| 
									
										
										
										
											2017-01-26 19:54:30 -05:00
										 |  |  |  |     return g_object_new_with_properties (object_type, 0, NULL, NULL); | 
					
						
							| 
									
										
										
										
											2010-01-01 20:36:28 -08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   va_start (var_args, first_property_name); | 
					
						
							|  |  |  |  |   object = g_object_new_valist (object_type, first_property_name, var_args); | 
					
						
							|  |  |  |  |   va_end (var_args); | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   return object; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  | static gpointer | 
					
						
							|  |  |  |  | g_object_new_with_custom_constructor (GObjectClass          *class, | 
					
						
							|  |  |  |  |                                       GObjectConstructParam *params, | 
					
						
							|  |  |  |  |                                       guint                  n_params) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObjectNotifyQueue *nqueue = NULL; | 
					
						
							|  |  |  |  |   gboolean newly_constructed; | 
					
						
							|  |  |  |  |   GObjectConstructParam *cparams; | 
					
						
							|  |  |  |  |   GObject *object; | 
					
						
							|  |  |  |  |   GValue *cvalues; | 
					
						
							|  |  |  |  |   gint n_cparams; | 
					
						
							|  |  |  |  |   gint cvals_used; | 
					
						
							|  |  |  |  |   GSList *node; | 
					
						
							|  |  |  |  |   gint i; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* If we have ->constructed() then we have to do a lot more work.
 | 
					
						
							|  |  |  |  |    * It's possible that this is a singleton and it's also possible | 
					
						
							|  |  |  |  |    * that the user's constructor() will attempt to modify the values | 
					
						
							|  |  |  |  |    * that we pass in, so we'll need to allocate copies of them. | 
					
						
							|  |  |  |  |    * It's also possible that the user may attempt to call | 
					
						
							|  |  |  |  |    * g_object_set() from inside of their constructor, so we need to | 
					
						
							|  |  |  |  |    * add ourselves to a list of objects for which that is allowed | 
					
						
							|  |  |  |  |    * while their constructor() is running. | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Create the array of GObjectConstructParams for constructor() */ | 
					
						
							|  |  |  |  |   n_cparams = g_slist_length (class->construct_properties); | 
					
						
							|  |  |  |  |   cparams = g_new (GObjectConstructParam, n_cparams); | 
					
						
							|  |  |  |  |   cvalues = g_new0 (GValue, n_cparams); | 
					
						
							|  |  |  |  |   cvals_used = 0; | 
					
						
							|  |  |  |  |   i = 0; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* As above, we may find the value in the passed-in params list.
 | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * If we have the value passed in then we can use the GValue from | 
					
						
							|  |  |  |  |    * it directly because it is safe to modify.  If we use the | 
					
						
							|  |  |  |  |    * default value from the class, we had better not pass that in | 
					
						
							|  |  |  |  |    * and risk it being modified, so we create a new one. | 
					
						
							|  |  |  |  |    * */ | 
					
						
							|  |  |  |  |   for (node = class->construct_properties; node; node = node->next) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       GParamSpec *pspec; | 
					
						
							|  |  |  |  |       GValue *value; | 
					
						
							|  |  |  |  |       gint j; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       pspec = node->data; | 
					
						
							|  |  |  |  |       value = NULL; /* to silence gcc... */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       for (j = 0; j < n_params; j++) | 
					
						
							|  |  |  |  |         if (params[j].pspec == pspec) | 
					
						
							|  |  |  |  |           { | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  |             consider_issuing_property_deprecation_warning (pspec); | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |             value = params[j].value; | 
					
						
							|  |  |  |  |             break; | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       if (j == n_params) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           value = &cvalues[cvals_used++]; | 
					
						
							|  |  |  |  |           g_value_init (value, pspec->value_type); | 
					
						
							|  |  |  |  |           g_param_value_set_default (pspec, value); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       cparams[i].pspec = pspec; | 
					
						
							|  |  |  |  |       cparams[i].value = value; | 
					
						
							|  |  |  |  |       i++; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* construct object from construction parameters */ | 
					
						
							|  |  |  |  |   object = class->constructor (class->g_type_class.g_type, n_cparams, cparams); | 
					
						
							|  |  |  |  |   /* free construction values */ | 
					
						
							|  |  |  |  |   g_free (cparams); | 
					
						
							|  |  |  |  |   while (cvals_used--) | 
					
						
							|  |  |  |  |     g_value_unset (&cvalues[cvals_used]); | 
					
						
							|  |  |  |  |   g_free (cvalues); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-26 11:27:51 -04:00
										 |  |  |  |   /* There is code in the wild that relies on being able to return NULL
 | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  |    * from its custom constructor.  This was never a supported operation, | 
					
						
							|  |  |  |  |    * but since the code is already out there... | 
					
						
							| 
									
										
										
										
											2013-04-26 11:27:51 -04:00
										 |  |  |  |    */ | 
					
						
							|  |  |  |  |   if (object == NULL) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  |       g_critical ("Custom constructor for class %s returned NULL (which is invalid). " | 
					
						
							|  |  |  |  |                   "Please use GInitable instead.", G_OBJECT_CLASS_NAME (class)); | 
					
						
							| 
									
										
										
										
											2013-04-26 11:27:51 -04:00
										 |  |  |  |       return NULL; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  |   /* g_object_init() will have marked the object as being in-construction.
 | 
					
						
							|  |  |  |  |    * Check if the returned object still is so marked, or if this is an | 
					
						
							|  |  |  |  |    * already-existing singleton (in which case we should not do 'constructed'). | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2013-10-20 09:27:11 -04:00
										 |  |  |  |   newly_constructed = object_in_construction (object); | 
					
						
							|  |  |  |  |   if (newly_constructed) | 
					
						
							|  |  |  |  |     g_datalist_id_set_data (&object->qdata, quark_in_construction, NULL); | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (CLASS_HAS_PROPS (class)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       /* If this object was newly_constructed then g_object_init()
 | 
					
						
							|  |  |  |  |        * froze the queue.  We need to freeze it here in order to get | 
					
						
							|  |  |  |  |        * the handle so that we can thaw it below (otherwise it will | 
					
						
							|  |  |  |  |        * be frozen forever). | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * We also want to do a freeze if we have any params to set, | 
					
						
							|  |  |  |  |        * even on a non-newly_constructed object. | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * It's possible that we have the case of non-newly created | 
					
						
							|  |  |  |  |        * singleton and all of the passed-in params were construct | 
					
						
							|  |  |  |  |        * properties so n_params > 0 but we will actually set no | 
					
						
							|  |  |  |  |        * properties.  This is a pretty lame case to optimise, so | 
					
						
							|  |  |  |  |        * just ignore it and freeze anyway. | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  |       if (newly_constructed || n_params) | 
					
						
							|  |  |  |  |         nqueue = g_object_notify_queue_freeze (object, FALSE); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* Remember: if it was newly_constructed then g_object_init()
 | 
					
						
							|  |  |  |  |        * already did a freeze, so we now have two.  Release one. | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  |       if (newly_constructed) | 
					
						
							|  |  |  |  |         g_object_notify_queue_thaw (object, nqueue); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* run 'constructed' handler if there is a custom one */ | 
					
						
							|  |  |  |  |   if (newly_constructed && CLASS_HAS_CUSTOM_CONSTRUCTED (class)) | 
					
						
							|  |  |  |  |     class->constructed (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* set remaining properties */ | 
					
						
							|  |  |  |  |   for (i = 0; i < n_params; i++) | 
					
						
							|  |  |  |  |     if (!(params[i].pspec->flags & (G_PARAM_CONSTRUCT | G_PARAM_CONSTRUCT_ONLY))) | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  |       { | 
					
						
							|  |  |  |  |         consider_issuing_property_deprecation_warning (params[i].pspec); | 
					
						
							|  |  |  |  |         object_set_property (object, params[i].pspec, params[i].value, nqueue); | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* If nqueue is non-NULL then we are frozen.  Thaw it. */ | 
					
						
							|  |  |  |  |   if (nqueue) | 
					
						
							|  |  |  |  |     g_object_notify_queue_thaw (object, nqueue); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return object; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static gpointer | 
					
						
							|  |  |  |  | g_object_new_internal (GObjectClass          *class, | 
					
						
							|  |  |  |  |                        GObjectConstructParam *params, | 
					
						
							|  |  |  |  |                        guint                  n_params) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObjectNotifyQueue *nqueue = NULL; | 
					
						
							|  |  |  |  |   GObject *object; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if G_UNLIKELY (CLASS_HAS_CUSTOM_CONSTRUCTOR (class)) | 
					
						
							|  |  |  |  |     return g_object_new_with_custom_constructor (class, params, n_params); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   object = (GObject *) g_type_create_instance (class->g_type_class.g_type); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (CLASS_HAS_PROPS (class)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       GSList *node; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* This will have been setup in g_object_init() */ | 
					
						
							|  |  |  |  |       nqueue = g_datalist_id_get_data (&object->qdata, quark_notify_queue); | 
					
						
							|  |  |  |  |       g_assert (nqueue != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* We will set exactly n_construct_properties construct
 | 
					
						
							|  |  |  |  |        * properties, but they may come from either the class default | 
					
						
							|  |  |  |  |        * values or the passed-in parameter list. | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  |       for (node = class->construct_properties; node; node = node->next) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           const GValue *value; | 
					
						
							|  |  |  |  |           GParamSpec *pspec; | 
					
						
							|  |  |  |  |           gint j; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           pspec = node->data; | 
					
						
							|  |  |  |  |           value = NULL; /* to silence gcc... */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           for (j = 0; j < n_params; j++) | 
					
						
							|  |  |  |  |             if (params[j].pspec == pspec) | 
					
						
							|  |  |  |  |               { | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  |                 consider_issuing_property_deprecation_warning (pspec); | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |                 value = params[j].value; | 
					
						
							|  |  |  |  |                 break; | 
					
						
							|  |  |  |  |               } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           if (j == n_params) | 
					
						
							|  |  |  |  |             value = g_param_spec_get_default_value (pspec); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           object_set_property (object, pspec, value, nqueue); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* run 'constructed' handler if there is a custom one */ | 
					
						
							|  |  |  |  |   if (CLASS_HAS_CUSTOM_CONSTRUCTED (class)) | 
					
						
							|  |  |  |  |     class->constructed (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (nqueue) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       gint i; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* Set remaining properties.  The construct properties will
 | 
					
						
							|  |  |  |  |        * already have been taken, so set only the non-construct | 
					
						
							|  |  |  |  |        * ones. | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  |       for (i = 0; i < n_params; i++) | 
					
						
							|  |  |  |  |         if (!(params[i].pspec->flags & (G_PARAM_CONSTRUCT | G_PARAM_CONSTRUCT_ONLY))) | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  |           { | 
					
						
							|  |  |  |  |             consider_issuing_property_deprecation_warning (params[i].pspec); | 
					
						
							|  |  |  |  |             object_set_property (object, params[i].pspec, params[i].value, nqueue); | 
					
						
							|  |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       g_object_notify_queue_thaw (object, nqueue); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return object; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:00:16 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | static inline gboolean | 
					
						
							|  |  |  |  | g_object_new_is_valid_property (GType                  object_type, | 
					
						
							|  |  |  |  |                                 GParamSpec            *pspec, | 
					
						
							|  |  |  |  |                                 const char            *name, | 
					
						
							|  |  |  |  |                                 GObjectConstructParam *params, | 
					
						
							|  |  |  |  |                                 int                    n_params) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   gint i; | 
					
						
							|  |  |  |  |   if (G_UNLIKELY (pspec == NULL)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_critical ("%s: object class '%s' has no property named '%s'", | 
					
						
							|  |  |  |  |                   G_STRFUNC, g_type_name (object_type), name); | 
					
						
							|  |  |  |  |       return FALSE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (G_UNLIKELY (~pspec->flags & G_PARAM_WRITABLE)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_critical ("%s: property '%s' of object class '%s' is not writable", | 
					
						
							|  |  |  |  |                   G_STRFUNC, pspec->name, g_type_name (object_type)); | 
					
						
							|  |  |  |  |       return FALSE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (G_UNLIKELY (pspec->flags & (G_PARAM_CONSTRUCT | G_PARAM_CONSTRUCT_ONLY))) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       for (i = 0; i < n_params; i++) | 
					
						
							|  |  |  |  |         if (params[i].pspec == pspec) | 
					
						
							|  |  |  |  |           break; | 
					
						
							|  |  |  |  |       if (G_UNLIKELY (i != n_params)) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           g_critical ("%s: property '%s' for type '%s' cannot be set twice", | 
					
						
							|  |  |  |  |                       G_STRFUNC, name, g_type_name (object_type)); | 
					
						
							|  |  |  |  |           return FALSE; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   return TRUE; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:29:44 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:54:30 -05:00
										 |  |  |  |  * g_object_new_with_properties: (rename-to g_object_new) | 
					
						
							| 
									
										
										
										
											2017-01-26 19:29:44 -05:00
										 |  |  |  |  * @object_type: the object type to instantiate | 
					
						
							|  |  |  |  |  * @n_properties: the number of properties | 
					
						
							|  |  |  |  |  * @names: (array length=n_properties): the names of each property to be set | 
					
						
							|  |  |  |  |  * @values: (array length=n_properties): the values of each property to be set | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Creates a new instance of a #GObject subtype and sets its properties using | 
					
						
							|  |  |  |  |  * the provided arrays. Both arrays must have exactly @n_properties elements, | 
					
						
							|  |  |  |  |  * and the names and values correspond by index. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Construction parameters (see %G_PARAM_CONSTRUCT, %G_PARAM_CONSTRUCT_ONLY) | 
					
						
							|  |  |  |  |  * which are not explicitly specified are set to their default values. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Returns: (type GObject.Object) (transfer full): a new instance of | 
					
						
							|  |  |  |  |  * @object_type | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-03-31 11:09:53 +01:00
										 |  |  |  |  * Since: 2.54 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:29:44 -05:00
										 |  |  |  |  */ | 
					
						
							|  |  |  |  | GObject * | 
					
						
							|  |  |  |  | g_object_new_with_properties (GType          object_type, | 
					
						
							|  |  |  |  |                               guint          n_properties, | 
					
						
							|  |  |  |  |                               const char    *names[], | 
					
						
							|  |  |  |  |                               const GValue   values[]) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObjectClass *class, *unref_class = NULL; | 
					
						
							|  |  |  |  |   GObject *object; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_TYPE_IS_OBJECT (object_type), NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Try to avoid thrashing the ref_count if we don't need to (since
 | 
					
						
							|  |  |  |  |    * it's a locked operation). | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |   class = g_type_class_peek_static (object_type); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (class == NULL) | 
					
						
							|  |  |  |  |     class = unref_class = g_type_class_ref (object_type); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (n_properties > 0) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       guint i, count = 0; | 
					
						
							|  |  |  |  |       GObjectConstructParam *params; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       params = g_newa (GObjectConstructParam, n_properties); | 
					
						
							|  |  |  |  |       for (i = 0; i < n_properties; i++) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           GParamSpec *pspec; | 
					
						
							|  |  |  |  |           pspec = g_param_spec_pool_lookup (pspec_pool, names[i], object_type, TRUE); | 
					
						
							|  |  |  |  |           if (!g_object_new_is_valid_property (object_type, pspec, names[i], params, count)) | 
					
						
							|  |  |  |  |             continue; | 
					
						
							|  |  |  |  |           params[count].pspec = pspec; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           /* Init GValue */ | 
					
						
							|  |  |  |  |           params[count].value = g_newa (GValue, 1); | 
					
						
							|  |  |  |  |           memset (params[count].value, 0, sizeof (GValue)); | 
					
						
							|  |  |  |  |           g_value_init (params[count].value, G_VALUE_TYPE (&values[i])); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           g_value_copy (&values[i], params[count].value); | 
					
						
							|  |  |  |  |           count++; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       object = g_object_new_internal (class, params, count); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       while (count--) | 
					
						
							|  |  |  |  |         g_value_unset (params[count].value); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     object = g_object_new_internal (class, NULL, 0); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (unref_class != NULL) | 
					
						
							|  |  |  |  |     g_type_class_unref (unref_class); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return object; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:54:30 -05:00
										 |  |  |  |  * g_object_newv: | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object_type: the type id of the #GObject subtype to instantiate | 
					
						
							|  |  |  |  |  * @n_parameters: the length of the @parameters array | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * @parameters: (array length=n_parameters): an array of #GParameter | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Creates a new instance of a #GObject subtype and sets its properties. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Construction parameters (see #G_PARAM_CONSTRUCT, #G_PARAM_CONSTRUCT_ONLY) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * which are not explicitly specified are set to their default values. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * Returns: (type GObject.Object) (transfer full): a new instance of | 
					
						
							|  |  |  |  |  * @object_type | 
					
						
							| 
									
										
										
										
											2017-01-26 19:54:30 -05:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-03-31 11:09:53 +01:00
										 |  |  |  |  * Deprecated: 2.54: Use g_object_new_with_properties() instead. | 
					
						
							| 
									
										
										
										
											2017-01-26 19:54:30 -05:00
										 |  |  |  |  * deprecated. See #GParameter for more information. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | gpointer | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | g_object_newv (GType       object_type, | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |                guint       n_parameters, | 
					
						
							|  |  |  |  |                GParameter *parameters) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |   GObjectClass *class, *unref_class = NULL; | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |   GObject *object; | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_return_val_if_fail (G_TYPE_IS_OBJECT (object_type), NULL); | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |   g_return_val_if_fail (n_parameters == 0 || parameters != NULL, NULL); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |   /* Try to avoid thrashing the ref_count if we don't need to (since
 | 
					
						
							|  |  |  |  |    * it's a locked operation). | 
					
						
							|  |  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |   class = g_type_class_peek_static (object_type); | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |   if (!class) | 
					
						
							|  |  |  |  |     class = unref_class = g_type_class_ref (object_type); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |   if (n_parameters) | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |       GObjectConstructParam *cparams; | 
					
						
							|  |  |  |  |       guint i, j; | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |       cparams = g_newa (GObjectConstructParam, n_parameters); | 
					
						
							|  |  |  |  |       j = 0; | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |       for (i = 0; i < n_parameters; i++) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           GParamSpec *pspec; | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |           pspec = g_param_spec_pool_lookup (pspec_pool, parameters[i].name, object_type, TRUE); | 
					
						
							| 
									
										
										
										
											2017-01-26 19:00:16 -05:00
										 |  |  |  |           if (!g_object_new_is_valid_property (object_type, pspec, parameters[i].name, cparams, j)) | 
					
						
							|  |  |  |  |             continue; | 
					
						
							| 
									
										
										
										
											2012-11-19 10:28:55 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |           cparams[j].pspec = pspec; | 
					
						
							|  |  |  |  |           cparams[j].value = ¶meters[i].value; | 
					
						
							|  |  |  |  |           j++; | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |       object = g_object_new_internal (class, cparams, j); | 
					
						
							| 
									
										
										
										
											2009-08-19 17:22:32 +02:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |   else | 
					
						
							|  |  |  |  |     /* Fast case: no properties passed in. */ | 
					
						
							|  |  |  |  |     object = g_object_new_internal (class, NULL, 0); | 
					
						
							| 
									
										
										
										
											2007-04-03 10:44:30 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |   if (unref_class) | 
					
						
							|  |  |  |  |     g_type_class_unref (unref_class); | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   return object; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_new_valist: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object_type: the type id of the #GObject subtype to instantiate | 
					
						
							|  |  |  |  |  * @first_property_name: the name of the first property | 
					
						
							|  |  |  |  |  * @var_args: the value of the first property, followed optionally by more | 
					
						
							|  |  |  |  |  *  name/value pairs, followed by %NULL | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Creates a new instance of a #GObject subtype and sets its properties. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Construction parameters (see #G_PARAM_CONSTRUCT, #G_PARAM_CONSTRUCT_ONLY) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * which are not explicitly specified are set to their default values. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Returns: a new instance of @object_type | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2001-09-10 18:32:52 +00:00
										 |  |  |  | GObject* | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  | g_object_new_valist (GType        object_type, | 
					
						
							|  |  |  |  |                      const gchar *first_property_name, | 
					
						
							|  |  |  |  |                      va_list      var_args) | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |   GObjectClass *class, *unref_class = NULL; | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   GObject *object; | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   g_return_val_if_fail (G_TYPE_IS_OBJECT (object_type), NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |   /* Try to avoid thrashing the ref_count if we don't need to (since
 | 
					
						
							|  |  |  |  |    * it's a locked operation). | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |   class = g_type_class_peek_static (object_type); | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |   if (!class) | 
					
						
							|  |  |  |  |     class = unref_class = g_type_class_ref (object_type); | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |   if (first_property_name) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |       GObjectConstructParam stack_params[16]; | 
					
						
							|  |  |  |  |       GObjectConstructParam *params; | 
					
						
							|  |  |  |  |       const gchar *name; | 
					
						
							|  |  |  |  |       gint n_params = 0; | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |       name = first_property_name; | 
					
						
							|  |  |  |  |       params = stack_params; | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |       do | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           gchar *error = NULL; | 
					
						
							|  |  |  |  |           GParamSpec *pspec; | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  |           pspec = g_param_spec_pool_lookup (pspec_pool, name, object_type, TRUE); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:00:16 -05:00
										 |  |  |  |           if (!g_object_new_is_valid_property (object_type, pspec, name, params, n_params)) | 
					
						
							|  |  |  |  |             break; | 
					
						
							| 
									
										
										
										
											2013-03-27 23:34:30 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |           if (n_params == 16) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               params = g_new (GObjectConstructParam, n_params + 1); | 
					
						
							|  |  |  |  |               memcpy (params, stack_params, sizeof stack_params); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |           else if (n_params > 16) | 
					
						
							|  |  |  |  |             params = g_renew (GObjectConstructParam, params, n_params + 1); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           params[n_params].pspec = pspec; | 
					
						
							|  |  |  |  |           params[n_params].value = g_newa (GValue, 1); | 
					
						
							|  |  |  |  |           memset (params[n_params].value, 0, sizeof (GValue)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           G_VALUE_COLLECT_INIT (params[n_params].value, pspec->value_type, var_args, 0, &error); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           if (error) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               g_critical ("%s: %s", G_STRFUNC, error); | 
					
						
							|  |  |  |  |               g_value_unset (params[n_params].value); | 
					
						
							|  |  |  |  |               g_free (error); | 
					
						
							|  |  |  |  |               break; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           n_params++; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       while ((name = va_arg (var_args, const gchar *))); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       object = g_object_new_internal (class, params, n_params); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       while (n_params--) | 
					
						
							|  |  |  |  |         g_value_unset (params[n_params].value); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       if (params != stack_params) | 
					
						
							|  |  |  |  |         g_free (params); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     /* Fast case: no properties passed in. */ | 
					
						
							|  |  |  |  |     object = g_object_new_internal (class, NULL, 0); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (unref_class) | 
					
						
							|  |  |  |  |     g_type_class_unref (unref_class); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   return object; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static GObject* | 
					
						
							|  |  |  |  | g_object_constructor (GType                  type, | 
					
						
							|  |  |  |  | 		      guint                  n_construct_properties, | 
					
						
							|  |  |  |  | 		      GObjectConstructParam *construct_params) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObject *object; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* create object */ | 
					
						
							|  |  |  |  |   object = (GObject*) g_type_create_instance (type); | 
					
						
							| 
									
										
										
										
											2003-11-29 14:00:06 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   /* set construction parameters */ | 
					
						
							|  |  |  |  |   if (n_construct_properties) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-11-16 15:42:36 +00:00
										 |  |  |  |       GObjectNotifyQueue *nqueue = g_object_notify_queue_freeze (object, FALSE); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |        | 
					
						
							|  |  |  |  |       /* set construct properties */ | 
					
						
							|  |  |  |  |       while (n_construct_properties--) | 
					
						
							|  |  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | 	  GValue *value = construct_params->value; | 
					
						
							|  |  |  |  | 	  GParamSpec *pspec = construct_params->pspec; | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 	  construct_params++; | 
					
						
							|  |  |  |  | 	  object_set_property (object, pspec, value, nqueue); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |       g_object_notify_queue_thaw (object, nqueue); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |       /* the notification queue is still frozen from g_object_init(), so
 | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |        * we don't need to handle it here, g_object_newv() takes | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |        * care of that | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return object; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-12 19:45:40 +01:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_object_constructed (GObject *object) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   /* empty default impl to allow unconditional upchaining */ | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:00:16 -05:00
										 |  |  |  | static inline gboolean | 
					
						
							|  |  |  |  | g_object_set_is_valid_property (GObject         *object, | 
					
						
							|  |  |  |  |                                 GParamSpec      *pspec, | 
					
						
							|  |  |  |  |                                 const char      *property_name) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   if (G_UNLIKELY (pspec == NULL)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_warning ("%s: object class '%s' has no property named '%s'", | 
					
						
							|  |  |  |  |                  G_STRFUNC, G_OBJECT_TYPE_NAME (object), property_name); | 
					
						
							|  |  |  |  |       return FALSE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   if (G_UNLIKELY (!(pspec->flags & G_PARAM_WRITABLE))) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_warning ("%s: property '%s' of object class '%s' is not writable", | 
					
						
							|  |  |  |  |                  G_STRFUNC, pspec->name, G_OBJECT_TYPE_NAME (object)); | 
					
						
							|  |  |  |  |       return FALSE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   if (G_UNLIKELY (((pspec->flags & G_PARAM_CONSTRUCT_ONLY) && !object_in_construction (object)))) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_warning ("%s: construct property \"%s\" for object '%s' can't be set after construction", | 
					
						
							|  |  |  |  |                  G_STRFUNC, pspec->name, G_OBJECT_TYPE_NAME (object)); | 
					
						
							|  |  |  |  |       return FALSE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   return TRUE; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:39:33 -05:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_setv: (skip) | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @n_properties: the number of properties | 
					
						
							|  |  |  |  |  * @names: (array length=n_properties): the names of each property to be set | 
					
						
							|  |  |  |  |  * @values: (array length=n_properties): the values of each property to be set | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Sets @n_properties properties for an @object. | 
					
						
							|  |  |  |  |  * Properties to be set will be taken from @values. All properties must be | 
					
						
							|  |  |  |  |  * valid. Warnings will be emitted and undefined behaviour may result if invalid | 
					
						
							|  |  |  |  |  * properties are passed in. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-03-31 11:09:53 +01:00
										 |  |  |  |  * Since: 2.54 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:39:33 -05:00
										 |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_object_setv (GObject       *object, | 
					
						
							|  |  |  |  |                guint          n_properties, | 
					
						
							|  |  |  |  |                const gchar   *names[], | 
					
						
							|  |  |  |  |                const GValue   values[]) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   guint i; | 
					
						
							|  |  |  |  |   GObjectNotifyQueue *nqueue; | 
					
						
							|  |  |  |  |   GParamSpec *pspec; | 
					
						
							|  |  |  |  |   GType obj_type; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (n_properties == 0) | 
					
						
							|  |  |  |  |     return; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_ref (object); | 
					
						
							|  |  |  |  |   obj_type = G_OBJECT_TYPE (object); | 
					
						
							|  |  |  |  |   nqueue = g_object_notify_queue_freeze (object, FALSE); | 
					
						
							|  |  |  |  |   for (i = 0; i < n_properties; i++) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       pspec = g_param_spec_pool_lookup (pspec_pool, names[i], obj_type, TRUE); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       if (!g_object_set_is_valid_property (object, pspec, names[i])) | 
					
						
							|  |  |  |  |         break; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       consider_issuing_property_deprecation_warning (pspec); | 
					
						
							|  |  |  |  |       object_set_property (object, pspec, &values[i], nqueue); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_notify_queue_thaw (object, nqueue); | 
					
						
							|  |  |  |  |   g_object_unref (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_set_valist: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @first_property_name: name of the first property to set | 
					
						
							|  |  |  |  |  * @var_args: value for the first property, followed optionally by more | 
					
						
							|  |  |  |  |  *  name/value pairs, followed by %NULL | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Sets properties on an object. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | g_object_set_valist (GObject	 *object, | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 		     const gchar *first_property_name, | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | 		     va_list	  var_args) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   GObjectNotifyQueue *nqueue; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   const gchar *name; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_object_ref (object); | 
					
						
							| 
									
										
										
										
											2011-11-16 15:42:36 +00:00
										 |  |  |  |   nqueue = g_object_notify_queue_freeze (object, FALSE); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   name = first_property_name; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   while (name) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-09-30 17:19:50 +01:00
										 |  |  |  |       GValue value = G_VALUE_INIT; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |       GParamSpec *pspec; | 
					
						
							|  |  |  |  |       gchar *error = NULL; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |        | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |       pspec = g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 					name, | 
					
						
							|  |  |  |  | 					G_OBJECT_TYPE (object), | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 					TRUE); | 
					
						
							| 
									
										
										
										
											2017-01-26 19:00:16 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       if (!g_object_set_is_valid_property (object, pspec, name)) | 
					
						
							|  |  |  |  |         break; | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-07 11:23:55 +01:00
										 |  |  |  |       G_VALUE_COLLECT_INIT (&value, pspec->value_type, var_args, | 
					
						
							| 
									
										
										
										
											2009-12-02 11:50:02 +01:00
										 |  |  |  | 			    0, &error); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |       if (error) | 
					
						
							|  |  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 	  g_warning ("%s: %s", G_STRFUNC, error); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 	  g_free (error); | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |           g_value_unset (&value); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 	  break; | 
					
						
							|  |  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       consider_issuing_property_deprecation_warning (pspec); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       object_set_property (object, pspec, &value, nqueue); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |       g_value_unset (&value); | 
					
						
							| 
									
										
										
										
											2014-06-27 13:21:03 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |       name = va_arg (var_args, gchar*); | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-19 12:13:22 +00:00
										 |  |  |  |   g_object_notify_queue_thaw (object, nqueue); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_object_unref (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:00:16 -05:00
										 |  |  |  | static inline gboolean | 
					
						
							|  |  |  |  | g_object_get_is_valid_property (GObject          *object, | 
					
						
							|  |  |  |  |                                 GParamSpec       *pspec, | 
					
						
							|  |  |  |  |                                 const char       *property_name) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   if (G_UNLIKELY (pspec == NULL)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_warning ("%s: object class '%s' has no property named '%s'", | 
					
						
							|  |  |  |  |                  G_STRFUNC, G_OBJECT_TYPE_NAME (object), property_name); | 
					
						
							|  |  |  |  |       return FALSE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   if (G_UNLIKELY (!(pspec->flags & G_PARAM_READABLE))) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_warning ("%s: property '%s' of object class '%s' is not readable", | 
					
						
							|  |  |  |  |                  G_STRFUNC, pspec->name, G_OBJECT_TYPE_NAME (object)); | 
					
						
							|  |  |  |  |       return FALSE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   return TRUE; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:39:33 -05:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_getv: | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @n_properties: the number of properties | 
					
						
							|  |  |  |  |  * @names: (array length=n_properties): the names of each property to get | 
					
						
							|  |  |  |  |  * @values: (array length=n_properties): the values of each property to get | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Gets @n_properties properties for an @object. | 
					
						
							|  |  |  |  |  * Obtained properties will be set to @values. All properties must be valid. | 
					
						
							|  |  |  |  |  * Warnings will be emitted and undefined behaviour may result if invalid | 
					
						
							|  |  |  |  |  * properties are passed in. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-03-31 11:09:53 +01:00
										 |  |  |  |  * Since: 2.54 | 
					
						
							| 
									
										
										
										
											2017-01-26 19:39:33 -05:00
										 |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_object_getv (GObject      *object, | 
					
						
							|  |  |  |  |                guint         n_properties, | 
					
						
							|  |  |  |  |                const gchar  *names[], | 
					
						
							|  |  |  |  |                GValue        values[]) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   guint i; | 
					
						
							|  |  |  |  |   GParamSpec *pspec; | 
					
						
							|  |  |  |  |   GType obj_type; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (n_properties == 0) | 
					
						
							|  |  |  |  |     return; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_ref (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   obj_type = G_OBJECT_TYPE (object); | 
					
						
							|  |  |  |  |   for (i = 0; i < n_properties; i++) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       pspec = g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 				        names[i], | 
					
						
							|  |  |  |  | 				        obj_type, | 
					
						
							|  |  |  |  | 				        TRUE); | 
					
						
							|  |  |  |  |       if (!g_object_get_is_valid_property (object, pspec, names[i])) | 
					
						
							|  |  |  |  |         break; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       memset (&values[i], 0, sizeof (GValue)); | 
					
						
							|  |  |  |  |       g_value_init (&values[i], pspec->value_type); | 
					
						
							|  |  |  |  |       object_get_property (object, pspec, &values[i]); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   g_object_unref (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_get_valist: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @first_property_name: name of the first property to get | 
					
						
							|  |  |  |  |  * @var_args: return location for the first property, followed optionally by more | 
					
						
							|  |  |  |  |  *  name/return location pairs, followed by %NULL | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Gets properties of an object. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * In general, a copy is made of the property contents and the caller | 
					
						
							|  |  |  |  |  * is responsible for freeing the memory in the appropriate manner for | 
					
						
							|  |  |  |  |  * the type, for instance by calling g_free() or g_object_unref(). | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * See g_object_get(). | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | g_object_get_valist (GObject	 *object, | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 		     const gchar *first_property_name, | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | 		     va_list	  var_args) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   const gchar *name; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_object_ref (object); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   name = first_property_name; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   while (name) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-09-30 17:19:50 +01:00
										 |  |  |  |       GValue value = G_VALUE_INIT; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |       GParamSpec *pspec; | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |       gchar *error; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |        | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |       pspec = g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 					name, | 
					
						
							|  |  |  |  | 					G_OBJECT_TYPE (object), | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 					TRUE); | 
					
						
							| 
									
										
										
										
											2017-01-26 19:00:16 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       if (!g_object_get_is_valid_property (object, pspec, name)) | 
					
						
							|  |  |  |  |         break; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |        | 
					
						
							| 
									
										
										
										
											2009-12-07 11:23:55 +01:00
										 |  |  |  |       g_value_init (&value, pspec->value_type); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |        | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       object_get_property (object, pspec, &value); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |        | 
					
						
							| 
									
										
										
										
											2001-04-19 21:48:21 +00:00
										 |  |  |  |       G_VALUE_LCOPY (&value, var_args, 0, &error); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |       if (error) | 
					
						
							|  |  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 	  g_warning ("%s: %s", G_STRFUNC, error); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 	  g_free (error); | 
					
						
							| 
									
										
										
										
											2001-03-18 04:44:38 +00:00
										 |  |  |  | 	  g_value_unset (&value); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 	  break; | 
					
						
							|  |  |  |  | 	} | 
					
						
							|  |  |  |  |        | 
					
						
							|  |  |  |  |       g_value_unset (&value); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |        | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |       name = va_arg (var_args, gchar*); | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_object_unref (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_set: (skip) | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @object: (type GObject.Object): a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @first_property_name: name of the first property to set | 
					
						
							|  |  |  |  |  * @...: value for the first property, followed optionally by more | 
					
						
							|  |  |  |  |  *  name/value pairs, followed by %NULL | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Sets properties on an object. | 
					
						
							| 
									
										
										
										
											2013-11-23 16:44:31 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Note that the "notify" signals are queued and only emitted (in | 
					
						
							|  |  |  |  |  * reverse order) after all properties have been set. See | 
					
						
							|  |  |  |  |  * g_object_freeze_notify(). | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2001-09-10 18:32:52 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | g_object_set (gpointer     _object, | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 	      const gchar *first_property_name, | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 	      ...) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   GObject *object = _object; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   va_list var_args; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
										
										
											2001-09-10 18:32:52 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   va_start (var_args, first_property_name); | 
					
						
							|  |  |  |  |   g_object_set_valist (object, first_property_name, var_args); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   va_end (var_args); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_get: (skip) | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @object: (type GObject.Object): a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @first_property_name: name of the first property to get | 
					
						
							|  |  |  |  |  * @...: return location for the first property, followed optionally by more | 
					
						
							|  |  |  |  |  *  name/return location pairs, followed by %NULL | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Gets properties of an object. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * In general, a copy is made of the property contents and the caller | 
					
						
							|  |  |  |  |  * is responsible for freeing the memory in the appropriate manner for | 
					
						
							|  |  |  |  |  * the type, for instance by calling g_free() or g_object_unref(). | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-01-31 21:56:33 -05:00
										 |  |  |  |  * Here is an example of using g_object_get() to get the contents | 
					
						
							|  |  |  |  |  * of three properties: an integer, a string and an object: | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  *  gint intval; | 
					
						
							|  |  |  |  |  *  gchar *strval; | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  *  GObject *objval; | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  *  g_object_get (my_object, | 
					
						
							|  |  |  |  |  *                "int-property", &intval, | 
					
						
							|  |  |  |  |  *                "str-property", &strval, | 
					
						
							|  |  |  |  |  *                "obj-property", &objval, | 
					
						
							|  |  |  |  |  *                NULL); | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-14 21:33:36 -05:00
										 |  |  |  |  *  // Do something with intval, strval, objval
 | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  *  g_free (strval); | 
					
						
							|  |  |  |  |  *  g_object_unref (objval); | 
					
						
							| 
									
										
										
										
											2014-01-31 21:56:33 -05:00
										 |  |  |  |  *  ]| | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | g_object_get (gpointer     _object, | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 	      const gchar *first_property_name, | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 	      ...) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   GObject *object = _object; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   va_list var_args; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   va_start (var_args, first_property_name); | 
					
						
							|  |  |  |  |   g_object_get_valist (object, first_property_name, var_args); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   va_end (var_args); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_set_property: | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @property_name: the name of the property to set | 
					
						
							|  |  |  |  |  * @value: the value | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Sets a property on an object. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | g_object_set_property (GObject	    *object, | 
					
						
							|  |  |  |  | 		       const gchar  *property_name, | 
					
						
							|  |  |  |  | 		       const GValue *value) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2017-01-26 19:39:33 -05:00
										 |  |  |  |   g_object_setv (object, 1, &property_name, value); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_get_property: | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @property_name: the name of the property to get | 
					
						
							|  |  |  |  |  * @value: return location for the property value | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-17 12:34:28 +00:00
										 |  |  |  |  * Gets a property of an object. @value must have been initialized to the | 
					
						
							|  |  |  |  |  * expected type of the property (or a type to which the expected type can be | 
					
						
							|  |  |  |  |  * transformed) using g_value_init(). | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * In general, a copy is made of the property contents and the caller is | 
					
						
							|  |  |  |  |  * responsible for freeing the memory by calling g_value_unset(). | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Note that g_object_get_property() is really intended for language | 
					
						
							|  |  |  |  |  * bindings, g_object_get() is much more convenient for C programming. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | g_object_get_property (GObject	   *object, | 
					
						
							|  |  |  |  | 		       const gchar *property_name, | 
					
						
							|  |  |  |  | 		       GValue	   *value) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   GParamSpec *pspec; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_return_if_fail (property_name != NULL); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_VALUE (value)); | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   g_object_ref (object); | 
					
						
							|  |  |  |  |    | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   pspec = g_param_spec_pool_lookup (pspec_pool, | 
					
						
							|  |  |  |  | 				    property_name, | 
					
						
							|  |  |  |  | 				    G_OBJECT_TYPE (object), | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 				    TRUE); | 
					
						
							| 
									
										
										
										
											2017-01-26 19:00:16 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (g_object_get_is_valid_property (object, pspec, property_name)) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-09-30 17:19:50 +01:00
										 |  |  |  |       GValue *prop_value, tmp_value = G_VALUE_INIT; | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |        | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       /* auto-conversion of the callers value type
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |        */ | 
					
						
							| 
									
										
										
										
											2009-12-07 11:23:55 +01:00
										 |  |  |  |       if (G_VALUE_TYPE (value) == pspec->value_type) | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	{ | 
					
						
							|  |  |  |  | 	  g_value_reset (value); | 
					
						
							|  |  |  |  | 	  prop_value = value; | 
					
						
							|  |  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-12-07 11:23:55 +01:00
										 |  |  |  |       else if (!g_value_type_transformable (pspec->value_type, G_VALUE_TYPE (value))) | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2013-05-20 17:54:48 -03:00
										 |  |  |  | 	  g_warning ("%s: can't retrieve property '%s' of type '%s' as value of type '%s'", | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 		     G_STRFUNC, pspec->name, | 
					
						
							| 
									
										
										
										
											2009-12-07 11:23:55 +01:00
										 |  |  |  | 		     g_type_name (pspec->value_type), | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 		     G_VALUE_TYPE_NAME (value)); | 
					
						
							| 
									
										
										
										
											2001-03-18 04:44:38 +00:00
										 |  |  |  | 	  g_object_unref (object); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	  return; | 
					
						
							|  |  |  |  | 	} | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |       else | 
					
						
							|  |  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2009-12-07 11:23:55 +01:00
										 |  |  |  | 	  g_value_init (&tmp_value, pspec->value_type); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	  prop_value = &tmp_value; | 
					
						
							|  |  |  |  | 	} | 
					
						
							|  |  |  |  |       object_get_property (object, pspec, prop_value); | 
					
						
							|  |  |  |  |       if (prop_value != value) | 
					
						
							|  |  |  |  | 	{ | 
					
						
							|  |  |  |  | 	  g_value_transform (prop_value, value); | 
					
						
							|  |  |  |  | 	  g_value_unset (&tmp_value); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 	} | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   g_object_unref (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_connect: (skip) | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @object: (type GObject.Object): a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @signal_spec: the spec for the first signal | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * @...: #GCallback for the first signal, followed by data for the | 
					
						
							|  |  |  |  |  *       first signal, followed optionally by more signal | 
					
						
							|  |  |  |  |  *       spec/callback/data triples, followed by %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * A convenience function to connect multiple signals at once. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * The signal specs expected by this function have the form | 
					
						
							|  |  |  |  |  * "modifier::signal_name", where modifier can be one of the following: | 
					
						
							| 
									
										
										
										
											2014-02-01 10:19:07 -05:00
										 |  |  |  |  * * - signal: equivalent to g_signal_connect_data (..., NULL, 0) | 
					
						
							|  |  |  |  |  * - object-signal, object_signal: equivalent to g_signal_connect_object (..., 0) | 
					
						
							|  |  |  |  |  * - swapped-signal, swapped_signal: equivalent to g_signal_connect_data (..., NULL, G_CONNECT_SWAPPED) | 
					
						
							|  |  |  |  |  * - swapped_object_signal, swapped-object-signal: equivalent to g_signal_connect_object (..., G_CONNECT_SWAPPED) | 
					
						
							|  |  |  |  |  * - signal_after, signal-after: equivalent to g_signal_connect_data (..., NULL, G_CONNECT_AFTER) | 
					
						
							|  |  |  |  |  * - object_signal_after, object-signal-after: equivalent to g_signal_connect_object (..., G_CONNECT_AFTER) | 
					
						
							|  |  |  |  |  * - swapped_signal_after, swapped-signal-after: equivalent to g_signal_connect_data (..., NULL, G_CONNECT_SWAPPED | G_CONNECT_AFTER) | 
					
						
							|  |  |  |  |  * - swapped_object_signal_after, swapped-object-signal-after: equivalent to g_signal_connect_object (..., G_CONNECT_SWAPPED | G_CONNECT_AFTER) | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  *   menu->toplevel = g_object_connect (g_object_new (GTK_TYPE_WINDOW, | 
					
						
							|  |  |  |  |  * 						   "type", GTK_WINDOW_POPUP, | 
					
						
							|  |  |  |  |  * 						   "child", menu, | 
					
						
							|  |  |  |  |  * 						   NULL), | 
					
						
							|  |  |  |  |  * 				     "signal::event", gtk_menu_window_event, menu, | 
					
						
							|  |  |  |  |  * 				     "signal::size_request", gtk_menu_window_size_request, menu, | 
					
						
							| 
									
										
										
										
											2014-02-01 11:57:13 -05:00
										 |  |  |  |  * 				     "signal::destroy", gtk_widget_destroyed, &menu->toplevel, | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * 				     NULL); | 
					
						
							|  |  |  |  |  * ]| | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * Returns: (transfer none) (type GObject.Object): @object | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | gpointer | 
					
						
							|  |  |  |  | g_object_connect (gpointer     _object, | 
					
						
							|  |  |  |  | 		  const gchar *signal_spec, | 
					
						
							|  |  |  |  | 		  ...) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObject *object = _object; | 
					
						
							|  |  |  |  |   va_list var_args; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (object->ref_count > 0, object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   va_start (var_args, signal_spec); | 
					
						
							|  |  |  |  |   while (signal_spec) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2002-02-21 03:57:33 +00:00
										 |  |  |  |       GCallback callback = va_arg (var_args, GCallback); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       gpointer data = va_arg (var_args, gpointer); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       if (strncmp (signal_spec, "signal::", 8) == 0) | 
					
						
							| 
									
										
										
										
											2011-05-02 11:45:52 -04:00
										 |  |  |  | 	g_signal_connect_data (object, signal_spec + 8, | 
					
						
							|  |  |  |  | 			       callback, data, NULL, | 
					
						
							|  |  |  |  | 			       0); | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |       else if (strncmp (signal_spec, "object_signal::", 15) == 0 || | 
					
						
							|  |  |  |  |                strncmp (signal_spec, "object-signal::", 15) == 0) | 
					
						
							| 
									
										
										
										
											2011-05-02 11:45:52 -04:00
										 |  |  |  | 	g_signal_connect_object (object, signal_spec + 15, | 
					
						
							|  |  |  |  | 				 callback, data, | 
					
						
							|  |  |  |  | 				 0); | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |       else if (strncmp (signal_spec, "swapped_signal::", 16) == 0 || | 
					
						
							|  |  |  |  |                strncmp (signal_spec, "swapped-signal::", 16) == 0) | 
					
						
							| 
									
										
										
										
											2011-05-02 11:45:52 -04:00
										 |  |  |  | 	g_signal_connect_data (object, signal_spec + 16, | 
					
						
							|  |  |  |  | 			       callback, data, NULL, | 
					
						
							|  |  |  |  | 			       G_CONNECT_SWAPPED); | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |       else if (strncmp (signal_spec, "swapped_object_signal::", 23) == 0 || | 
					
						
							|  |  |  |  |                strncmp (signal_spec, "swapped-object-signal::", 23) == 0) | 
					
						
							| 
									
										
										
										
											2011-05-02 11:45:52 -04:00
										 |  |  |  | 	g_signal_connect_object (object, signal_spec + 23, | 
					
						
							|  |  |  |  | 				 callback, data, | 
					
						
							|  |  |  |  | 				 G_CONNECT_SWAPPED); | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |       else if (strncmp (signal_spec, "signal_after::", 14) == 0 || | 
					
						
							|  |  |  |  |                strncmp (signal_spec, "signal-after::", 14) == 0) | 
					
						
							| 
									
										
										
										
											2011-05-02 11:45:52 -04:00
										 |  |  |  | 	g_signal_connect_data (object, signal_spec + 14, | 
					
						
							|  |  |  |  | 			       callback, data, NULL, | 
					
						
							|  |  |  |  | 			       G_CONNECT_AFTER); | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |       else if (strncmp (signal_spec, "object_signal_after::", 21) == 0 || | 
					
						
							|  |  |  |  |                strncmp (signal_spec, "object-signal-after::", 21) == 0) | 
					
						
							| 
									
										
										
										
											2011-05-02 11:45:52 -04:00
										 |  |  |  | 	g_signal_connect_object (object, signal_spec + 21, | 
					
						
							|  |  |  |  | 				 callback, data, | 
					
						
							|  |  |  |  | 				 G_CONNECT_AFTER); | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |       else if (strncmp (signal_spec, "swapped_signal_after::", 22) == 0 || | 
					
						
							|  |  |  |  |                strncmp (signal_spec, "swapped-signal-after::", 22) == 0) | 
					
						
							| 
									
										
										
										
											2011-05-02 11:45:52 -04:00
										 |  |  |  | 	g_signal_connect_data (object, signal_spec + 22, | 
					
						
							|  |  |  |  | 			       callback, data, NULL, | 
					
						
							|  |  |  |  | 			       G_CONNECT_SWAPPED | G_CONNECT_AFTER); | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |       else if (strncmp (signal_spec, "swapped_object_signal_after::", 29) == 0 || | 
					
						
							|  |  |  |  |                strncmp (signal_spec, "swapped-object-signal-after::", 29) == 0) | 
					
						
							| 
									
										
										
										
											2011-05-02 11:45:52 -04:00
										 |  |  |  | 	g_signal_connect_object (object, signal_spec + 29, | 
					
						
							|  |  |  |  | 				 callback, data, | 
					
						
							|  |  |  |  | 				 G_CONNECT_SWAPPED | G_CONNECT_AFTER); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       else | 
					
						
							|  |  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 	  g_warning ("%s: invalid signal spec \"%s\"", G_STRFUNC, signal_spec); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	  break; | 
					
						
							|  |  |  |  | 	} | 
					
						
							|  |  |  |  |       signal_spec = va_arg (var_args, gchar*); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   va_end (var_args); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return object; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_disconnect: (skip) | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @object: (type GObject.Object): a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @signal_spec: the spec for the first signal | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * @...: #GCallback for the first signal, followed by data for the first signal, | 
					
						
							|  |  |  |  |  *  followed optionally by more signal spec/callback/data triples, | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  *  followed by %NULL | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * A convenience function to disconnect multiple signals at once. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * The signal specs expected by this function have the form | 
					
						
							|  |  |  |  |  * "any_signal", which means to disconnect any signal with matching | 
					
						
							|  |  |  |  |  * callback and data, or "any_signal::signal_name", which only | 
					
						
							|  |  |  |  |  * disconnects the signal named "signal_name". | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2001-09-10 18:32:52 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | g_object_disconnect (gpointer     _object, | 
					
						
							|  |  |  |  | 		     const gchar *signal_spec, | 
					
						
							|  |  |  |  | 		     ...) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObject *object = _object; | 
					
						
							|  |  |  |  |   va_list var_args; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-09-10 18:32:52 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (object->ref_count > 0); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   va_start (var_args, signal_spec); | 
					
						
							|  |  |  |  |   while (signal_spec) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2002-02-21 03:57:33 +00:00
										 |  |  |  |       GCallback callback = va_arg (var_args, GCallback); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       gpointer data = va_arg (var_args, gpointer); | 
					
						
							|  |  |  |  |       guint sid = 0, detail = 0, mask = 0; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |       if (strncmp (signal_spec, "any_signal::", 12) == 0 || | 
					
						
							|  |  |  |  |           strncmp (signal_spec, "any-signal::", 12) == 0) | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	{ | 
					
						
							|  |  |  |  | 	  signal_spec += 12; | 
					
						
							|  |  |  |  | 	  mask = G_SIGNAL_MATCH_ID | G_SIGNAL_MATCH_FUNC | G_SIGNAL_MATCH_DATA; | 
					
						
							|  |  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |       else if (strcmp (signal_spec, "any_signal") == 0 || | 
					
						
							|  |  |  |  |                strcmp (signal_spec, "any-signal") == 0) | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	{ | 
					
						
							|  |  |  |  | 	  signal_spec += 10; | 
					
						
							|  |  |  |  | 	  mask = G_SIGNAL_MATCH_FUNC | G_SIGNAL_MATCH_DATA; | 
					
						
							|  |  |  |  | 	} | 
					
						
							|  |  |  |  |       else | 
					
						
							|  |  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 	  g_warning ("%s: invalid signal spec \"%s\"", G_STRFUNC, signal_spec); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | 	  break; | 
					
						
							|  |  |  |  | 	} | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       if ((mask & G_SIGNAL_MATCH_ID) && | 
					
						
							|  |  |  |  | 	  !g_signal_parse_name (signal_spec, G_OBJECT_TYPE (object), &sid, &detail, FALSE)) | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 	g_warning ("%s: invalid signal name \"%s\"", G_STRFUNC, signal_spec); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       else if (!g_signal_handlers_disconnect_matched (object, mask | (detail ? G_SIGNAL_MATCH_DETAIL : 0), | 
					
						
							|  |  |  |  | 						      sid, detail, | 
					
						
							| 
									
										
										
										
											2002-03-13 15:36:04 +00:00
										 |  |  |  | 						      NULL, (gpointer)callback, data)) | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  | 	g_warning ("%s: signal handler %p(%p) is not connected", G_STRFUNC, callback, data); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       signal_spec = va_arg (var_args, gchar*); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   va_end (var_args); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | typedef struct { | 
					
						
							| 
									
										
										
										
											2001-08-18 03:07:48 +00:00
										 |  |  |  |   GObject *object; | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   guint n_weak_refs; | 
					
						
							|  |  |  |  |   struct { | 
					
						
							|  |  |  |  |     GWeakNotify notify; | 
					
						
							|  |  |  |  |     gpointer    data; | 
					
						
							|  |  |  |  |   } weak_refs[1];  /* flexible array */ | 
					
						
							|  |  |  |  | } WeakRefStack; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | weak_refs_notify (gpointer data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   WeakRefStack *wstack = data; | 
					
						
							|  |  |  |  |   guint i; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   for (i = 0; i < wstack->n_weak_refs; i++) | 
					
						
							| 
									
										
										
										
											2001-08-18 03:07:48 +00:00
										 |  |  |  |     wstack->weak_refs[i].notify (wstack->weak_refs[i].data, wstack->object); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   g_free (wstack); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_weak_ref: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: #GObject to reference weakly | 
					
						
							|  |  |  |  |  * @notify: callback to invoke before the object is freed | 
					
						
							|  |  |  |  |  * @data: extra data to pass to notify | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Adds a weak reference callback to an object. Weak references are | 
					
						
							|  |  |  |  |  * used for notification when an object is finalized. They are called | 
					
						
							|  |  |  |  |  * "weak references" because they allow you to safely hold a pointer | 
					
						
							|  |  |  |  |  * to an object without calling g_object_ref() (g_object_ref() adds a | 
					
						
							|  |  |  |  |  * strong reference, that is, forces the object to stay alive). | 
					
						
							| 
									
										
										
										
											2011-12-06 11:37:45 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Note that the weak references created by this method are not | 
					
						
							|  |  |  |  |  * thread-safe: they cannot safely be used in one thread if the | 
					
						
							|  |  |  |  |  * object's last g_object_unref() might happen in another thread. | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * Use #GWeakRef if thread-safety is required. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_weak_ref (GObject    *object, | 
					
						
							|  |  |  |  | 		   GWeakNotify notify, | 
					
						
							|  |  |  |  | 		   gpointer    data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   WeakRefStack *wstack; | 
					
						
							|  |  |  |  |   guint i; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (notify != NULL); | 
					
						
							|  |  |  |  |   g_return_if_fail (object->ref_count >= 1); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_LOCK (weak_refs_mutex); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   wstack = g_datalist_id_remove_no_notify (&object->qdata, quark_weak_refs); | 
					
						
							|  |  |  |  |   if (wstack) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       i = wstack->n_weak_refs++; | 
					
						
							|  |  |  |  |       wstack = g_realloc (wstack, sizeof (*wstack) + sizeof (wstack->weak_refs[0]) * i); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       wstack = g_renew (WeakRefStack, NULL, 1); | 
					
						
							| 
									
										
										
										
											2001-08-18 03:07:48 +00:00
										 |  |  |  |       wstack->object = object; | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |       wstack->n_weak_refs = 1; | 
					
						
							| 
									
										
										
										
											2001-07-02 05:15:29 +00:00
										 |  |  |  |       i = 0; | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  |   wstack->weak_refs[i].notify = notify; | 
					
						
							|  |  |  |  |   wstack->weak_refs[i].data = data; | 
					
						
							|  |  |  |  |   g_datalist_id_set_data_full (&object->qdata, quark_weak_refs, wstack, weak_refs_notify); | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_UNLOCK (weak_refs_mutex); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_weak_unref: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: #GObject to remove a weak reference from | 
					
						
							|  |  |  |  |  * @notify: callback to search for | 
					
						
							|  |  |  |  |  * @data: data to search for | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Removes a weak reference callback to an object. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_weak_unref (GObject    *object, | 
					
						
							|  |  |  |  | 		     GWeakNotify notify, | 
					
						
							|  |  |  |  | 		     gpointer    data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   WeakRefStack *wstack; | 
					
						
							|  |  |  |  |   gboolean found_one = FALSE; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (notify != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_LOCK (weak_refs_mutex); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   wstack = g_datalist_id_get_data (&object->qdata, quark_weak_refs); | 
					
						
							|  |  |  |  |   if (wstack) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       guint i; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       for (i = 0; i < wstack->n_weak_refs; i++) | 
					
						
							|  |  |  |  | 	if (wstack->weak_refs[i].notify == notify && | 
					
						
							|  |  |  |  | 	    wstack->weak_refs[i].data == data) | 
					
						
							|  |  |  |  | 	  { | 
					
						
							|  |  |  |  | 	    found_one = TRUE; | 
					
						
							|  |  |  |  | 	    wstack->n_weak_refs -= 1; | 
					
						
							|  |  |  |  | 	    if (i != wstack->n_weak_refs) | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | 	      wstack->weak_refs[i] = wstack->weak_refs[wstack->n_weak_refs]; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | 	    break; | 
					
						
							|  |  |  |  | 	  } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_UNLOCK (weak_refs_mutex); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   if (!found_one) | 
					
						
							| 
									
										
										
										
											2003-11-27 17:08:06 +00:00
										 |  |  |  |     g_warning ("%s: couldn't find weak ref %p(%p)", G_STRFUNC, notify, data); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_add_weak_pointer: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: The object that should be weak referenced. | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @weak_pointer_location: (inout) (not optional): The memory address | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  *    of a pointer. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Adds a weak reference from weak_pointer to @object to indicate that | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * the pointer located at @weak_pointer_location is only valid during | 
					
						
							|  |  |  |  |  * the lifetime of @object. When the @object is finalized, | 
					
						
							|  |  |  |  |  * @weak_pointer will be set to %NULL. | 
					
						
							| 
									
										
										
										
											2011-12-06 11:37:45 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Note that as with g_object_weak_ref(), the weak references created by | 
					
						
							|  |  |  |  |  * this method are not thread-safe: they cannot safely be used in one | 
					
						
							|  |  |  |  |  * thread if the object's last g_object_unref() might happen in another | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * thread. Use #GWeakRef if thread-safety is required. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2001-08-06 20:55:11 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_add_weak_pointer (GObject  *object,  | 
					
						
							|  |  |  |  |                            gpointer *weak_pointer_location) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (weak_pointer_location != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_weak_ref (object,  | 
					
						
							|  |  |  |  |                      (GWeakNotify) g_nullify_pointer,  | 
					
						
							|  |  |  |  |                      weak_pointer_location); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_remove_weak_pointer: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: The object that is weak referenced. | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @weak_pointer_location: (inout) (not optional): The memory address | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  *    of a pointer. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Removes a weak reference from @object that was previously added | 
					
						
							|  |  |  |  |  * using g_object_add_weak_pointer(). The @weak_pointer_location has | 
					
						
							|  |  |  |  |  * to match the one used with g_object_add_weak_pointer(). | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2001-08-06 20:55:11 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_remove_weak_pointer (GObject  *object,  | 
					
						
							|  |  |  |  |                               gpointer *weak_pointer_location) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (weak_pointer_location != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_weak_unref (object,  | 
					
						
							|  |  |  |  |                        (GWeakNotify) g_nullify_pointer,  | 
					
						
							|  |  |  |  |                        weak_pointer_location); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  | static guint | 
					
						
							|  |  |  |  | object_floating_flag_handler (GObject        *object, | 
					
						
							|  |  |  |  |                               gint            job) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   switch (job) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       gpointer oldvalue; | 
					
						
							|  |  |  |  |     case +1:    /* force floating if possible */ | 
					
						
							|  |  |  |  |       do | 
					
						
							|  |  |  |  |         oldvalue = g_atomic_pointer_get (&object->qdata); | 
					
						
							|  |  |  |  |       while (!g_atomic_pointer_compare_and_exchange ((void**) &object->qdata, oldvalue, | 
					
						
							|  |  |  |  |                                                      (gpointer) ((gsize) oldvalue | OBJECT_FLOATING_FLAG))); | 
					
						
							|  |  |  |  |       return (gsize) oldvalue & OBJECT_FLOATING_FLAG; | 
					
						
							|  |  |  |  |     case -1:    /* sink if possible */ | 
					
						
							|  |  |  |  |       do | 
					
						
							|  |  |  |  |         oldvalue = g_atomic_pointer_get (&object->qdata); | 
					
						
							|  |  |  |  |       while (!g_atomic_pointer_compare_and_exchange ((void**) &object->qdata, oldvalue, | 
					
						
							|  |  |  |  |                                                      (gpointer) ((gsize) oldvalue & ~(gsize) OBJECT_FLOATING_FLAG))); | 
					
						
							|  |  |  |  |       return (gsize) oldvalue & OBJECT_FLOATING_FLAG; | 
					
						
							|  |  |  |  |     default:    /* check floating */ | 
					
						
							|  |  |  |  |       return 0 != ((gsize) g_atomic_pointer_get (&object->qdata) & OBJECT_FLOATING_FLAG); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_is_floating: | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * @object: (type GObject.Object): a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-08 12:26:56 -05:00
										 |  |  |  |  * Checks whether @object has a [floating][floating-ref] reference. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since: 2.10 | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Returns: %TRUE if @object has a floating reference | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2005-11-23 17:54:41 +00:00
										 |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_object_is_floating (gpointer _object) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObject *object = _object; | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), FALSE); | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  |   return floating_flag_handler (object, 0); | 
					
						
							| 
									
										
										
										
											2005-11-23 17:54:41 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_ref_sink: | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * @object: (type GObject.Object): a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Increase the reference count of @object, and possibly remove the | 
					
						
							| 
									
										
										
										
											2014-02-08 12:26:56 -05:00
										 |  |  |  |  * [floating][floating-ref] reference, if @object has a floating reference. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * In other words, if the object is floating, then this call "assumes | 
					
						
							|  |  |  |  |  * ownership" of the floating reference, converting it to a normal | 
					
						
							|  |  |  |  |  * reference by clearing the floating flag while leaving the reference | 
					
						
							|  |  |  |  |  * count unchanged.  If the object is not floating, then this call | 
					
						
							|  |  |  |  |  * adds a new normal reference increasing the reference count by one. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-11-22 15:10:38 -08:00
										 |  |  |  |  * Since GLib 2.56, the type of @object will be propagated to the return type | 
					
						
							|  |  |  |  |  * under the same conditions as for g_object_ref(). | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since: 2.10 | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * Returns: (type GObject.Object) (transfer none): @object | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2005-11-23 17:54:41 +00:00
										 |  |  |  | gpointer | 
					
						
							| 
									
										
										
										
											2017-11-22 15:10:38 -08:00
										 |  |  |  | (g_object_ref_sink) (gpointer _object) | 
					
						
							| 
									
										
										
										
											2005-11-23 17:54:41 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   GObject *object = _object; | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  |   gboolean was_floating; | 
					
						
							| 
									
										
										
										
											2005-11-23 17:54:41 +00:00
										 |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), object); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (object->ref_count >= 1, object); | 
					
						
							|  |  |  |  |   g_object_ref (object); | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  |   was_floating = floating_flag_handler (object, -1); | 
					
						
							|  |  |  |  |   if (was_floating) | 
					
						
							| 
									
										
										
										
											2005-11-23 17:54:41 +00:00
										 |  |  |  |     g_object_unref (object); | 
					
						
							|  |  |  |  |   return object; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_force_floating: | 
					
						
							|  |  |  |  |  * @object: a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-08 12:26:56 -05:00
										 |  |  |  |  * This function is intended for #GObject implementations to re-enforce | 
					
						
							|  |  |  |  |  * a [floating][floating-ref] object reference. Doing this is seldom | 
					
						
							|  |  |  |  |  * required: all #GInitiallyUnowneds are created with a floating reference | 
					
						
							|  |  |  |  |  * which usually just needs to be sunken by calling g_object_ref_sink(). | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since: 2.10 | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2005-11-23 17:54:41 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_force_floating (GObject *object) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (object->ref_count >= 1); | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-02 11:45:52 -04:00
										 |  |  |  |   floating_flag_handler (object, +1); | 
					
						
							| 
									
										
										
										
											2005-11-23 17:54:41 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | typedef struct { | 
					
						
							|  |  |  |  |   GObject *object; | 
					
						
							|  |  |  |  |   guint n_toggle_refs; | 
					
						
							|  |  |  |  |   struct { | 
					
						
							|  |  |  |  |     GToggleNotify notify; | 
					
						
							|  |  |  |  |     gpointer    data; | 
					
						
							|  |  |  |  |   } toggle_refs[1];  /* flexible array */ | 
					
						
							|  |  |  |  | } ToggleRefStack; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | toggle_refs_notify (GObject *object, | 
					
						
							|  |  |  |  | 		    gboolean is_last_ref) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   ToggleRefStack tstack, *tstackptr; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   G_LOCK (toggle_refs_mutex); | 
					
						
							|  |  |  |  |   tstackptr = g_datalist_id_get_data (&object->qdata, quark_toggle_refs); | 
					
						
							|  |  |  |  |   tstack = *tstackptr; | 
					
						
							|  |  |  |  |   G_UNLOCK (toggle_refs_mutex); | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Reentrancy here is not as tricky as it seems, because a toggle reference
 | 
					
						
							|  |  |  |  |    * will only be notified when there is exactly one of them. | 
					
						
							|  |  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   g_assert (tstack.n_toggle_refs == 1); | 
					
						
							|  |  |  |  |   tstack.toggle_refs[0].notify (tstack.toggle_refs[0].data, tstack.object, is_last_ref); | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_add_toggle_ref: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @notify: a function to call when this reference is the | 
					
						
							|  |  |  |  |  *  last reference to the object, or is no longer | 
					
						
							|  |  |  |  |  *  the last reference. | 
					
						
							|  |  |  |  |  * @data: data to pass to @notify | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Increases the reference count of the object by one and sets a | 
					
						
							|  |  |  |  |  * callback to be called when all other references to the object are | 
					
						
							|  |  |  |  |  * dropped, or when this is already the last reference to the object | 
					
						
							|  |  |  |  |  * and another reference is established. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * This functionality is intended for binding @object to a proxy | 
					
						
							|  |  |  |  |  * object managed by another memory manager. This is done with two | 
					
						
							|  |  |  |  |  * paired references: the strong reference added by | 
					
						
							|  |  |  |  |  * g_object_add_toggle_ref() and a reverse reference to the proxy | 
					
						
							|  |  |  |  |  * object which is either a strong reference or weak reference. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * The setup is that when there are no other references to @object, | 
					
						
							|  |  |  |  |  * only a weak reference is held in the reverse direction from @object | 
					
						
							|  |  |  |  |  * to the proxy object, but when there are other references held to | 
					
						
							|  |  |  |  |  * @object, a strong reference is held. The @notify callback is called | 
					
						
							|  |  |  |  |  * when the reference from @object to the proxy object should be | 
					
						
							| 
									
										
										
										
											2014-02-05 22:57:27 -05:00
										 |  |  |  |  * "toggled" from strong to weak (@is_last_ref true) or weak to strong | 
					
						
							|  |  |  |  |  * (@is_last_ref false). | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since a (normal) reference must be held to the object before | 
					
						
							| 
									
										
										
										
											2011-09-05 18:46:59 -04:00
										 |  |  |  |  * calling g_object_add_toggle_ref(), the initial state of the reverse | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * link is always strong. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Multiple toggle references may be added to the same gobject, | 
					
						
							|  |  |  |  |  * however if there are multiple toggle references to an object, none | 
					
						
							|  |  |  |  |  * of them will ever be notified until all but one are removed.  For | 
					
						
							|  |  |  |  |  * this reason, you should only ever use a toggle reference if there | 
					
						
							|  |  |  |  |  * is important state in the proxy object. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since: 2.8 | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_add_toggle_ref (GObject       *object, | 
					
						
							|  |  |  |  | 			 GToggleNotify  notify, | 
					
						
							|  |  |  |  | 			 gpointer       data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   ToggleRefStack *tstack; | 
					
						
							|  |  |  |  |   guint i; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (notify != NULL); | 
					
						
							|  |  |  |  |   g_return_if_fail (object->ref_count >= 1); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_ref (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_LOCK (toggle_refs_mutex); | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  |   tstack = g_datalist_id_remove_no_notify (&object->qdata, quark_toggle_refs); | 
					
						
							|  |  |  |  |   if (tstack) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       i = tstack->n_toggle_refs++; | 
					
						
							|  |  |  |  |       /* allocate i = tstate->n_toggle_refs - 1 positions beyond the 1 declared
 | 
					
						
							|  |  |  |  |        * in tstate->toggle_refs */ | 
					
						
							|  |  |  |  |       tstack = g_realloc (tstack, sizeof (*tstack) + sizeof (tstack->toggle_refs[0]) * i); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       tstack = g_renew (ToggleRefStack, NULL, 1); | 
					
						
							|  |  |  |  |       tstack->object = object; | 
					
						
							|  |  |  |  |       tstack->n_toggle_refs = 1; | 
					
						
							|  |  |  |  |       i = 0; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Set a flag for fast lookup after adding the first toggle reference */ | 
					
						
							|  |  |  |  |   if (tstack->n_toggle_refs == 1) | 
					
						
							| 
									
										
										
										
											2005-07-31 00:05:22 +00:00
										 |  |  |  |     g_datalist_set_flags (&object->qdata, OBJECT_HAS_TOGGLE_REF_FLAG); | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  |    | 
					
						
							|  |  |  |  |   tstack->toggle_refs[i].notify = notify; | 
					
						
							|  |  |  |  |   tstack->toggle_refs[i].data = data; | 
					
						
							|  |  |  |  |   g_datalist_id_set_data_full (&object->qdata, quark_toggle_refs, tstack, | 
					
						
							|  |  |  |  | 			       (GDestroyNotify)g_free); | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_UNLOCK (toggle_refs_mutex); | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_remove_toggle_ref: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: a #GObject | 
					
						
							|  |  |  |  |  * @notify: a function to call when this reference is the | 
					
						
							|  |  |  |  |  *  last reference to the object, or is no longer | 
					
						
							|  |  |  |  |  *  the last reference. | 
					
						
							|  |  |  |  |  * @data: data to pass to @notify | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Removes a reference added with g_object_add_toggle_ref(). The | 
					
						
							|  |  |  |  |  * reference count of the object is decreased by one. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Since: 2.8 | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_remove_toggle_ref (GObject       *object, | 
					
						
							|  |  |  |  | 			    GToggleNotify  notify, | 
					
						
							|  |  |  |  | 			    gpointer       data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   ToggleRefStack *tstack; | 
					
						
							|  |  |  |  |   gboolean found_one = FALSE; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (notify != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_LOCK (toggle_refs_mutex); | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  |   tstack = g_datalist_id_get_data (&object->qdata, quark_toggle_refs); | 
					
						
							|  |  |  |  |   if (tstack) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       guint i; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       for (i = 0; i < tstack->n_toggle_refs; i++) | 
					
						
							|  |  |  |  | 	if (tstack->toggle_refs[i].notify == notify && | 
					
						
							|  |  |  |  | 	    tstack->toggle_refs[i].data == data) | 
					
						
							|  |  |  |  | 	  { | 
					
						
							|  |  |  |  | 	    found_one = TRUE; | 
					
						
							|  |  |  |  | 	    tstack->n_toggle_refs -= 1; | 
					
						
							|  |  |  |  | 	    if (i != tstack->n_toggle_refs) | 
					
						
							|  |  |  |  | 	      tstack->toggle_refs[i] = tstack->toggle_refs[tstack->n_toggle_refs]; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 	    if (tstack->n_toggle_refs == 0) | 
					
						
							| 
									
										
										
										
											2005-07-31 00:05:22 +00:00
										 |  |  |  | 	      g_datalist_unset_flags (&object->qdata, OBJECT_HAS_TOGGLE_REF_FLAG); | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 	    break; | 
					
						
							|  |  |  |  | 	  } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_UNLOCK (toggle_refs_mutex); | 
					
						
							| 
									
										
										
										
											2010-10-22 13:20:54 +02:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (found_one) | 
					
						
							|  |  |  |  |     g_object_unref (object); | 
					
						
							|  |  |  |  |   else | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  |     g_warning ("%s: couldn't find toggle ref %p(%p)", G_STRFUNC, notify, data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_ref: | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * @object: (type GObject.Object): a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Increases the reference count of @object. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-11-22 15:10:38 -08:00
										 |  |  |  |  * Since GLib 2.56, if `GLIB_VERSION_MAX_ALLOWED` is 2.56 or greater, the type | 
					
						
							|  |  |  |  |  * of @object will be propagated to the return type (using the GCC typeof() | 
					
						
							|  |  |  |  |  * extension), so any casting the caller needs to do on the return type must be | 
					
						
							|  |  |  |  |  * explicit. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * Returns: (type GObject.Object) (transfer none): the same @object | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | gpointer | 
					
						
							| 
									
										
										
										
											2017-11-22 15:10:38 -08:00
										 |  |  |  | (g_object_ref) (gpointer _object) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   GObject *object = _object; | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |   gint old_val; | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (object->ref_count > 0, NULL); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
										
										
											2011-05-28 15:59:18 -04:00
										 |  |  |  |   old_val = g_atomic_int_add (&object->ref_count, 1); | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (old_val == 1 && OBJECT_HAS_TOGGLE_REF (object)) | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  |     toggle_refs_notify (object, FALSE); | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   TRACE (GOBJECT_OBJECT_REF(object,G_TYPE_FROM_INSTANCE(object),old_val)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   return object; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_unref: | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * @object: (type GObject.Object): a #GObject | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Decreases the reference count of @object. When its reference count | 
					
						
							|  |  |  |  |  * drops to 0, the object is finalized (i.e. its memory is freed). | 
					
						
							| 
									
										
										
										
											2014-12-19 19:02:15 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the pointer to the #GObject may be reused in future (for example, if it is | 
					
						
							|  |  |  |  |  * an instance variable of another object), it is recommended to clear the | 
					
						
							|  |  |  |  |  * pointer to %NULL rather than retain a dangling pointer to a potentially | 
					
						
							|  |  |  |  |  * invalid #GObject instance. Use g_clear_object() for this. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  | g_object_unref (gpointer _object) | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2000-12-13 00:44:18 +00:00
										 |  |  |  |   GObject *object = _object; | 
					
						
							| 
									
										
										
										
											2005-07-30 19:46:11 +00:00
										 |  |  |  |   gint old_ref; | 
					
						
							|  |  |  |  |    | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (object->ref_count > 0); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
										
										
											2005-07-30 19:46:11 +00:00
										 |  |  |  |   /* here we want to atomically do: if (ref_count>1) { ref_count--; return; } */ | 
					
						
							|  |  |  |  |  retry_atomic_decrement1: | 
					
						
							| 
									
										
										
										
											2009-02-17 16:14:39 +00:00
										 |  |  |  |   old_ref = g_atomic_int_get (&object->ref_count); | 
					
						
							| 
									
										
										
										
											2005-07-30 19:46:11 +00:00
										 |  |  |  |   if (old_ref > 1) | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-10-06 12:27:12 -04:00
										 |  |  |  |       /* valid if last 2 refs are owned by this call to unref and the toggle_ref */ | 
					
						
							|  |  |  |  |       gboolean has_toggle_ref = OBJECT_HAS_TOGGLE_REF (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-26 16:00:33 +00:00
										 |  |  |  |       if (!g_atomic_int_compare_and_exchange ((int *)&object->ref_count, old_ref, old_ref - 1)) | 
					
						
							| 
									
										
										
										
											2005-07-30 19:46:11 +00:00
										 |  |  |  | 	goto retry_atomic_decrement1; | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  |       TRACE (GOBJECT_OBJECT_UNREF(object,G_TYPE_FROM_INSTANCE(object),old_ref)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |       /* if we went from 2->1 we need to notify toggle refs if any */ | 
					
						
							| 
									
										
										
										
											2009-10-06 12:27:12 -04:00
										 |  |  |  |       if (old_ref == 2 && has_toggle_ref) /* The last ref being held in this case is owned by the toggle_ref */ | 
					
						
							| 
									
										
										
										
											2005-05-05 14:57:29 +00:00
										 |  |  |  | 	toggle_refs_notify (object, TRUE); | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   else | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |       GSList **weak_locations; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* The only way that this object can live at this point is if
 | 
					
						
							|  |  |  |  |        * there are outstanding weak references already established | 
					
						
							|  |  |  |  |        * before we got here. | 
					
						
							|  |  |  |  |        * | 
					
						
							|  |  |  |  |        * If there were not already weak references then no more can be | 
					
						
							|  |  |  |  |        * established at this time, because the other thread would have | 
					
						
							|  |  |  |  |        * to hold a strong ref in order to call | 
					
						
							|  |  |  |  |        * g_object_add_weak_pointer() and then we wouldn't be here. | 
					
						
							|  |  |  |  |        */ | 
					
						
							|  |  |  |  |       weak_locations = g_datalist_id_get_data (&object->qdata, quark_weak_locations); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       if (weak_locations != NULL) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           g_rw_lock_writer_lock (&weak_locations_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           /* It is possible that one of the weak references beat us to
 | 
					
						
							|  |  |  |  |            * the lock. Make sure the refcount is still what we expected | 
					
						
							|  |  |  |  |            * it to be. | 
					
						
							|  |  |  |  |            */ | 
					
						
							|  |  |  |  |           old_ref = g_atomic_int_get (&object->ref_count); | 
					
						
							|  |  |  |  |           if (old_ref != 1) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               g_rw_lock_writer_unlock (&weak_locations_lock); | 
					
						
							|  |  |  |  |               goto retry_atomic_decrement1; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           /* We got the lock first, so the object will definitely die
 | 
					
						
							|  |  |  |  |            * now. Clear out all the weak references. | 
					
						
							|  |  |  |  |            */ | 
					
						
							|  |  |  |  |           while (*weak_locations) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               GWeakRef *weak_ref_location = (*weak_locations)->data; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |               weak_ref_location->priv.p = NULL; | 
					
						
							|  |  |  |  |               *weak_locations = g_slist_delete_link (*weak_locations, *weak_locations); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           g_rw_lock_writer_unlock (&weak_locations_lock); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* we are about to remove the last reference */ | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  |       TRACE (GOBJECT_OBJECT_DISPOSE(object,G_TYPE_FROM_INSTANCE(object), 1)); | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |       G_OBJECT_GET_CLASS (object)->dispose (object); | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  |       TRACE (GOBJECT_OBJECT_DISPOSE_END(object,G_TYPE_FROM_INSTANCE(object), 1)); | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-30 19:46:11 +00:00
										 |  |  |  |       /* may have been re-referenced meanwhile */ | 
					
						
							|  |  |  |  |     retry_atomic_decrement2: | 
					
						
							| 
									
										
										
										
											2008-09-26 16:00:33 +00:00
										 |  |  |  |       old_ref = g_atomic_int_get ((int *)&object->ref_count); | 
					
						
							| 
									
										
										
										
											2005-07-30 19:46:11 +00:00
										 |  |  |  |       if (old_ref > 1) | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2009-10-06 12:27:12 -04:00
										 |  |  |  |           /* valid if last 2 refs are owned by this call to unref and the toggle_ref */ | 
					
						
							|  |  |  |  |           gboolean has_toggle_ref = OBJECT_HAS_TOGGLE_REF (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-26 16:00:33 +00:00
										 |  |  |  |           if (!g_atomic_int_compare_and_exchange ((int *)&object->ref_count, old_ref, old_ref - 1)) | 
					
						
							| 
									
										
										
										
											2005-07-30 19:46:11 +00:00
										 |  |  |  | 	    goto retry_atomic_decrement2; | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  | 	  TRACE (GOBJECT_OBJECT_UNREF(object,G_TYPE_FROM_INSTANCE(object),old_ref)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |           /* if we went from 2->1 we need to notify toggle refs if any */ | 
					
						
							| 
									
										
										
										
											2009-10-06 12:27:12 -04:00
										 |  |  |  |           if (old_ref == 2 && has_toggle_ref) /* The last ref being held in this case is owned by the toggle_ref */ | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 	    toggle_refs_notify (object, TRUE); | 
					
						
							| 
									
										
										
										
											2009-10-06 12:27:12 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 	  return; | 
					
						
							|  |  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-30 19:46:11 +00:00
										 |  |  |  |       /* we are still in the process of taking away the last ref */ | 
					
						
							|  |  |  |  |       g_datalist_id_set_data (&object->qdata, quark_closure_array, NULL); | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |       g_signal_handlers_destroy (object); | 
					
						
							|  |  |  |  |       g_datalist_id_set_data (&object->qdata, quark_weak_refs, NULL); | 
					
						
							| 
									
										
										
										
											2005-07-30 19:46:11 +00:00
										 |  |  |  |        | 
					
						
							|  |  |  |  |       /* decrement the last reference */ | 
					
						
							| 
									
										
										
										
											2011-05-28 15:59:18 -04:00
										 |  |  |  |       old_ref = g_atomic_int_add (&object->ref_count, -1); | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       TRACE (GOBJECT_OBJECT_UNREF(object,G_TYPE_FROM_INSTANCE(object),old_ref)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |       /* may have been re-referenced meanwhile */ | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  |       if (G_LIKELY (old_ref == 1)) | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  | 	  TRACE (GOBJECT_OBJECT_FINALIZE(object,G_TYPE_FROM_INSTANCE(object))); | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |           G_OBJECT_GET_CLASS (object)->finalize (object); | 
					
						
							| 
									
										
										
										
											2010-01-01 21:39:52 +01:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 	  TRACE (GOBJECT_OBJECT_FINALIZE_END(object,G_TYPE_FROM_INSTANCE(object))); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-25 22:32:17 +08:00
										 |  |  |  |           GOBJECT_IF_DEBUG (OBJECTS, | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 	    { | 
					
						
							|  |  |  |  | 	      /* catch objects not chaining finalize handlers */ | 
					
						
							|  |  |  |  | 	      G_LOCK (debug_objects); | 
					
						
							| 
									
										
										
										
											2017-10-25 10:53:14 +01:00
										 |  |  |  | 	      g_assert (!g_hash_table_contains (debug_objects_ht, object)); | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  | 	      G_UNLOCK (debug_objects); | 
					
						
							| 
									
										
										
										
											2014-05-25 22:32:17 +08:00
										 |  |  |  | 	    }); | 
					
						
							| 
									
										
											  
											
												Make refcounting threadsafe by using atomic operations. (#166020, Wim
2005-07-15  Matthias Clasen  <mclasen@redhat.com>
	Make refcounting threadsafe by using atomic
	operations.  (#166020, Wim Taymans)
	* gobject.c: Use a recursive lock to protect the
	notify queue.
	(g_object_unref): Get rid of g_object_last_unref and
	do the last unref handling in g_object_unref.
	(g_object_ref, g_object_unref): Use atomic operations.
	* gsignal.c (struct _HandlerMatch): Use a full integer
	for the ref_count field.
	(handler_ref, handler_unref_R): Use atomic operations.
	* gparam.c (g_param_spec_ref, g_param_spec_unref):
	Use atomic operations instead of a lock to make the
	refcounting threadsafe.
	* gclosure.c (g_closure_ref, g_closure_unref): Use atomic
	operations. This is more complicated here, since the
	refcount is stored in a bitfield, so we also have
	to access all other bitfield members atomically.
	* gsignal.c (handlers_find): Read the meta_marshal flag
	of the closure atomically.
	* tests/Makefile.am (SUBDIRS): Add tests/refcount
	* configure.in: Add tests/refcount
	* tests/refcount/properties.c: Test property changes
	from multiple threads.
	* tests/refcount/signals.c: Test signal emission from
	multiple threads.
	* tests/refcount/objects.c: Test refcounting from
	multiple threads.
	* tests/refcount/objects2.c:
	* tests/refcount/properties2.c: Tests to measure the
	overhead of threadsafe refcounting.
	* glib/giochannel.c (g_io_channel_ref, g_io_channel_unref):
	Use atomic operations to make refcounting
	threadsafe.  (#166020, Wim Taymans)
											
										 
											2005-07-15 16:51:10 +00:00
										 |  |  |  |           g_type_free_instance ((GTypeInstance*) object); | 
					
						
							|  |  |  |  | 	} | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-08 16:42:32 -05:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_clear_object: (skip) | 
					
						
							| 
									
										
										
										
											2010-11-08 16:42:32 -05:00
										 |  |  |  |  * @object_ptr: a pointer to a #GObject reference | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Clears a reference to a #GObject. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @object_ptr must not be %NULL. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the reference is %NULL then this function does nothing. | 
					
						
							|  |  |  |  |  * Otherwise, the reference count of the object is decreased and the | 
					
						
							|  |  |  |  |  * pointer is set to %NULL. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * A macro is also included that allows this function to be used without | 
					
						
							|  |  |  |  |  * pointer casts. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.28 | 
					
						
							|  |  |  |  |  **/ | 
					
						
							|  |  |  |  | #undef g_clear_object
 | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_clear_object (volatile GObject **object_ptr) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-23 17:57:56 +02:00
										 |  |  |  |   g_clear_pointer (object_ptr, g_object_unref); | 
					
						
							| 
									
										
										
										
											2010-11-08 16:42:32 -05:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_get_qdata: | 
					
						
							|  |  |  |  |  * @object: The GObject to get a stored user data pointer from | 
					
						
							|  |  |  |  |  * @quark: A #GQuark, naming the user data pointer | 
					
						
							|  |  |  |  |  *  | 
					
						
							|  |  |  |  |  * This function gets back user data pointers stored via | 
					
						
							|  |  |  |  |  * g_object_set_qdata(). | 
					
						
							|  |  |  |  |  *  | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * Returns: (transfer none) (nullable): The user data pointer set, or %NULL | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | gpointer | 
					
						
							|  |  |  |  | g_object_get_qdata (GObject *object, | 
					
						
							|  |  |  |  | 		    GQuark   quark) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   return quark ? g_datalist_id_get_data (&object->qdata, quark) : NULL; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_set_qdata: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: The GObject to set store a user data pointer | 
					
						
							|  |  |  |  |  * @quark: A #GQuark, naming the user data pointer | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * @data: (nullable): An opaque user data pointer | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * This sets an opaque, named pointer on an object. | 
					
						
							|  |  |  |  |  * The name is specified through a #GQuark (retrived e.g. via | 
					
						
							|  |  |  |  |  * g_quark_from_static_string()), and the pointer | 
					
						
							|  |  |  |  |  * can be gotten back from the @object with g_object_get_qdata() | 
					
						
							|  |  |  |  |  * until the @object is finalized. | 
					
						
							|  |  |  |  |  * Setting a previously set user data pointer, overrides (frees) | 
					
						
							|  |  |  |  |  * the old pointer set, using #NULL as pointer essentially | 
					
						
							|  |  |  |  |  * removes the data stored. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_set_qdata (GObject *object, | 
					
						
							|  |  |  |  | 		    GQuark   quark, | 
					
						
							|  |  |  |  | 		    gpointer data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (quark > 0); | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  |   g_datalist_id_set_data (&object->qdata, quark, data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2015-10-14 21:40:34 +03:00
										 |  |  |  |  * g_object_dup_qdata: (skip) | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * @object: the #GObject to store user data on | 
					
						
							|  |  |  |  |  * @quark: a #GQuark, naming the user data pointer | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @dup_func: (nullable): function to dup the value | 
					
						
							|  |  |  |  |  * @user_data: (nullable): passed as user_data to @dup_func | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * This is a variant of g_object_get_qdata() which returns | 
					
						
							|  |  |  |  |  * a 'duplicate' of the value. @dup_func defines the | 
					
						
							|  |  |  |  |  * meaning of 'duplicate' in this context, it could e.g. | 
					
						
							|  |  |  |  |  * take a reference on a ref-counted object. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the @quark is not set on the object then @dup_func | 
					
						
							|  |  |  |  |  * will be called with a %NULL argument. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Note that @dup_func is called while user data of @object | 
					
						
							|  |  |  |  |  * is locked. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This function can be useful to avoid races when multiple | 
					
						
							|  |  |  |  |  * threads are using object data on the same key on the same | 
					
						
							|  |  |  |  |  * object. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Returns: the result of calling @dup_func on the value | 
					
						
							|  |  |  |  |  *     associated with @quark on @object, or %NULL if not set. | 
					
						
							|  |  |  |  |  *     If @dup_func is %NULL, the value is returned | 
					
						
							|  |  |  |  |  *     unmodified. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.34 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | gpointer | 
					
						
							|  |  |  |  | g_object_dup_qdata (GObject        *object, | 
					
						
							|  |  |  |  |                     GQuark          quark, | 
					
						
							|  |  |  |  |                     GDuplicateFunc   dup_func, | 
					
						
							|  |  |  |  |                     gpointer         user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (quark > 0, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return g_datalist_id_dup_data (&object->qdata, quark, dup_func, user_data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2015-10-14 21:40:34 +03:00
										 |  |  |  |  * g_object_replace_qdata: (skip) | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * @object: the #GObject to store user data on | 
					
						
							|  |  |  |  |  * @quark: a #GQuark, naming the user data pointer | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @oldval: (nullable): the old value to compare against | 
					
						
							|  |  |  |  |  * @newval: (nullable): the new value | 
					
						
							|  |  |  |  |  * @destroy: (nullable): a destroy notify for the new value | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * @old_destroy: (out) (optional): destroy notify for the existing value | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Compares the user data for the key @quark on @object with | 
					
						
							|  |  |  |  |  * @oldval, and if they are the same, replaces @oldval with | 
					
						
							|  |  |  |  |  * @newval. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This is like a typical atomic compare-and-exchange | 
					
						
							|  |  |  |  |  * operation, for user data on an object. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the previous value was replaced then ownership of the | 
					
						
							|  |  |  |  |  * old value (@oldval) is passed to the caller, including | 
					
						
							| 
									
										
										
										
											2013-05-29 00:07:26 -04:00
										 |  |  |  |  * the registered destroy notify for it (passed out in @old_destroy). | 
					
						
							| 
									
										
										
										
											2018-01-15 15:35:33 +00:00
										 |  |  |  |  * It’s up to the caller to free this as needed, which may | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * or may not include using @old_destroy as sometimes replacement | 
					
						
							|  |  |  |  |  * should not destroy the object in the normal way. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-07-10 17:09:07 +01:00
										 |  |  |  |  * Returns: %TRUE if the existing value for @quark was replaced | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  *  by @newval, %FALSE otherwise. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.34 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_object_replace_qdata (GObject        *object, | 
					
						
							|  |  |  |  |                         GQuark          quark, | 
					
						
							|  |  |  |  |                         gpointer        oldval, | 
					
						
							|  |  |  |  |                         gpointer        newval, | 
					
						
							|  |  |  |  |                         GDestroyNotify  destroy, | 
					
						
							|  |  |  |  |                         GDestroyNotify *old_destroy) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), FALSE); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (quark > 0, FALSE); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return g_datalist_id_replace_data (&object->qdata, quark, | 
					
						
							|  |  |  |  |                                      oldval, newval, destroy, | 
					
						
							|  |  |  |  |                                      old_destroy); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_set_qdata_full: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: The GObject to set store a user data pointer | 
					
						
							|  |  |  |  |  * @quark: A #GQuark, naming the user data pointer | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * @data: (nullable): An opaque user data pointer | 
					
						
							|  |  |  |  |  * @destroy: (nullable): Function to invoke with @data as argument, when @data | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  *           needs to be freed | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * This function works like g_object_set_qdata(), but in addition, | 
					
						
							|  |  |  |  |  * a void (*destroy) (gpointer) function may be specified which is | 
					
						
							|  |  |  |  |  * called with @data as argument when the @object is finalized, or | 
					
						
							|  |  |  |  |  * the data is being overwritten by a call to g_object_set_qdata() | 
					
						
							|  |  |  |  |  * with the same @quark. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_set_qdata_full (GObject       *object, | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | 			 GQuark		quark, | 
					
						
							|  |  |  |  | 			 gpointer	data, | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | 			 GDestroyNotify destroy) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (quark > 0); | 
					
						
							|  |  |  |  |    | 
					
						
							| 
									
										
										
										
											2001-05-03 10:12:46 +00:00
										 |  |  |  |   g_datalist_id_set_data_full (&object->qdata, quark, data, | 
					
						
							|  |  |  |  | 			       data ? destroy : (GDestroyNotify) NULL); | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_steal_qdata: | 
					
						
							|  |  |  |  |  * @object: The GObject to get a stored user data pointer from | 
					
						
							|  |  |  |  |  * @quark: A #GQuark, naming the user data pointer | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * This function gets back user data pointers stored via | 
					
						
							|  |  |  |  |  * g_object_set_qdata() and removes the @data from object | 
					
						
							| 
									
										
										
										
											2009-02-23 04:30:06 +00:00
										 |  |  |  |  * without invoking its destroy() function (if any was | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * set). | 
					
						
							|  |  |  |  |  * Usually, calling this function is only required to update | 
					
						
							|  |  |  |  |  * user data pointers with a destroy notifier, for example: | 
					
						
							| 
									
										
										
										
											2014-02-01 15:11:49 -05:00
										 |  |  |  |  * |[<!-- language="C" -->  | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * void | 
					
						
							|  |  |  |  |  * object_add_to_user_list (GObject     *object, | 
					
						
							|  |  |  |  |  *                          const gchar *new_string) | 
					
						
							|  |  |  |  |  * { | 
					
						
							|  |  |  |  |  *   // the quark, naming the object data
 | 
					
						
							|  |  |  |  |  *   GQuark quark_string_list = g_quark_from_static_string ("my-string-list"); | 
					
						
							|  |  |  |  |  *   // retrive the old string list
 | 
					
						
							|  |  |  |  |  *   GList *list = g_object_steal_qdata (object, quark_string_list); | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  *   // prepend new string
 | 
					
						
							|  |  |  |  |  *   list = g_list_prepend (list, g_strdup (new_string)); | 
					
						
							|  |  |  |  |  *   // this changed 'list', so we need to set it again
 | 
					
						
							|  |  |  |  |  *   g_object_set_qdata_full (object, quark_string_list, list, free_string_list); | 
					
						
							|  |  |  |  |  * } | 
					
						
							|  |  |  |  |  * static void | 
					
						
							|  |  |  |  |  * free_string_list (gpointer data) | 
					
						
							|  |  |  |  |  * { | 
					
						
							|  |  |  |  |  *   GList *node, *list = data; | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  *   for (node = list; node; node = node->next) | 
					
						
							|  |  |  |  |  *     g_free (node->data); | 
					
						
							|  |  |  |  |  *   g_list_free (list); | 
					
						
							|  |  |  |  |  * } | 
					
						
							|  |  |  |  |  * ]| | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * Using g_object_get_qdata() in the above example, instead of | 
					
						
							|  |  |  |  |  * g_object_steal_qdata() would have left the destroy function set, | 
					
						
							|  |  |  |  |  * and thus the partial string list would have been freed upon | 
					
						
							|  |  |  |  |  * g_object_set_qdata_full(). | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * Returns: (transfer full) (nullable): The user data pointer set, or %NULL | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												add reserved fundamental ids for gtk types (for transition time). added
Fri May  5 01:15:48 2000  Tim Janik  <timj@gtk.org>
	* gtype.h: add reserved fundamental ids for gtk types (for transition
	time). added G_TYPE_FUNDAMENTAL_MAX for gtk.
Mon Apr 17 20:45:50 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.c (g_object_base_class_finalize): oops, don't unset
	n_params prior to destructing them.
Tue Apr 11 04:28:10 2000  Tim Janik  <timj@gtk.org>
	* fixed a couple of bugs in the initial parameter/object
	implementations, after getting beast running on GObject and GValue.
Fri Apr  7 04:27:49 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: completed parameter set/get implementations,
	along with asyncronous parameter changed notification queue.
Sun Apr  2 04:54:36 2000  Tim Janik  <timj@gtk.org>
	* glib-gobject.[hc]: GObject implementation, that is facilities
	for setting/getting quarked data and reference counting.
	* glib-gparamspecs.[hc]: first actuall parameter implementations
	for GLib, so far we have: char, uchar, bool, int, uint, long,
	ulong, enum, flags, float, double, string and object. each of these
	GParamSpecs is a new instantiatable type in its own respect,
	so the .c file derives 13 new types from G_TYPE_PARAM and
	defines over 50 (*2) conversion facilities.
	* glib-gvaluecollector.h: generic varargs handling stubs for
	GParamSpecs, private header file (does get installed for
	inclusion into user code though).
	* glib-gvalue.[hc]: GValue functionality implementation.
	* glib-gparam.[hc]: basis GParamSpec implementation for
	the virtual base type G_TYPE_PARAM.
        * glib-genums.[hc]: enum/flags type implementation, based on
	bseenum.[hc].
	* glib-extra.[hc]: GLib additions, including 1.3 compatibility
	routines and various other functions, from string manipulation
	over list manipulation up to a unix signal GSource.
	* glib-gtype.[hc]: GLib Type System implementation, heavily
	based on BSE's dynamic type system.
											
										 
											2000-05-12 15:22:31 +00:00
										 |  |  |  | gpointer | 
					
						
							|  |  |  |  | g_object_steal_qdata (GObject *object, | 
					
						
							|  |  |  |  | 		      GQuark   quark) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (quark > 0, NULL); | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   return g_datalist_id_remove_no_notify (&object->qdata, quark); | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_get_data: | 
					
						
							|  |  |  |  |  * @object: #GObject containing the associations | 
					
						
							|  |  |  |  |  * @key: name of the key for that association | 
					
						
							|  |  |  |  |  *  | 
					
						
							|  |  |  |  |  * Gets a named field from the objects table of associations (see g_object_set_data()). | 
					
						
							|  |  |  |  |  *  | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * Returns: (transfer none) (nullable): the data if found, | 
					
						
							|  |  |  |  |  *          or %NULL if no such data exists. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2000-11-20 22:24:12 +00:00
										 |  |  |  | gpointer | 
					
						
							|  |  |  |  | g_object_get_data (GObject     *object, | 
					
						
							|  |  |  |  |                    const gchar *key) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (key != NULL, NULL); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-19 21:55:16 +02:00
										 |  |  |  |   return g_datalist_get_data (&object->qdata, key); | 
					
						
							| 
									
										
										
										
											2000-11-20 22:24:12 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_set_data: | 
					
						
							|  |  |  |  |  * @object: #GObject containing the associations. | 
					
						
							|  |  |  |  |  * @key: name of the key | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * @data: (nullable): data to associate with that key | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Each object carries around a table of associations from | 
					
						
							|  |  |  |  |  * strings to pointers.  This function lets you set an association. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * If the object already had an association with that name, | 
					
						
							|  |  |  |  |  * the old association will be destroyed. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2000-11-20 22:24:12 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_set_data (GObject     *object, | 
					
						
							|  |  |  |  |                    const gchar *key, | 
					
						
							|  |  |  |  |                    gpointer     data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (key != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   g_datalist_id_set_data (&object->qdata, g_quark_from_string (key), data); | 
					
						
							| 
									
										
										
										
											2000-11-20 22:24:12 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2015-10-14 21:40:34 +03:00
										 |  |  |  |  * g_object_dup_data: (skip) | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * @object: the #GObject to store user data on | 
					
						
							|  |  |  |  |  * @key: a string, naming the user data pointer | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @dup_func: (nullable): function to dup the value | 
					
						
							|  |  |  |  |  * @user_data: (nullable): passed as user_data to @dup_func | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * This is a variant of g_object_get_data() which returns | 
					
						
							|  |  |  |  |  * a 'duplicate' of the value. @dup_func defines the | 
					
						
							|  |  |  |  |  * meaning of 'duplicate' in this context, it could e.g. | 
					
						
							|  |  |  |  |  * take a reference on a ref-counted object. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the @key is not set on the object then @dup_func | 
					
						
							|  |  |  |  |  * will be called with a %NULL argument. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Note that @dup_func is called while user data of @object | 
					
						
							|  |  |  |  |  * is locked. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This function can be useful to avoid races when multiple | 
					
						
							|  |  |  |  |  * threads are using object data on the same key on the same | 
					
						
							|  |  |  |  |  * object. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Returns: the result of calling @dup_func on the value | 
					
						
							|  |  |  |  |  *     associated with @key on @object, or %NULL if not set. | 
					
						
							|  |  |  |  |  *     If @dup_func is %NULL, the value is returned | 
					
						
							|  |  |  |  |  *     unmodified. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.34 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | gpointer | 
					
						
							|  |  |  |  | g_object_dup_data (GObject        *object, | 
					
						
							|  |  |  |  |                    const gchar    *key, | 
					
						
							|  |  |  |  |                    GDuplicateFunc   dup_func, | 
					
						
							|  |  |  |  |                    gpointer         user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (key != NULL, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return g_datalist_id_dup_data (&object->qdata, | 
					
						
							|  |  |  |  |                                  g_quark_from_string (key), | 
					
						
							|  |  |  |  |                                  dup_func, user_data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2015-10-14 21:40:34 +03:00
										 |  |  |  |  * g_object_replace_data: (skip) | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * @object: the #GObject to store user data on | 
					
						
							|  |  |  |  |  * @key: a string, naming the user data pointer | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @oldval: (nullable): the old value to compare against | 
					
						
							|  |  |  |  |  * @newval: (nullable): the new value | 
					
						
							|  |  |  |  |  * @destroy: (nullable): a destroy notify for the new value | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * @old_destroy: (out) (optional): destroy notify for the existing value | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Compares the user data for the key @key on @object with | 
					
						
							|  |  |  |  |  * @oldval, and if they are the same, replaces @oldval with | 
					
						
							|  |  |  |  |  * @newval. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This is like a typical atomic compare-and-exchange | 
					
						
							|  |  |  |  |  * operation, for user data on an object. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the previous value was replaced then ownership of the | 
					
						
							|  |  |  |  |  * old value (@oldval) is passed to the caller, including | 
					
						
							| 
									
										
										
										
											2013-05-29 00:07:26 -04:00
										 |  |  |  |  * the registered destroy notify for it (passed out in @old_destroy). | 
					
						
							| 
									
										
										
										
											2018-01-15 15:35:33 +00:00
										 |  |  |  |  * It’s up to the caller to free this as needed, which may | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  * or may not include using @old_destroy as sometimes replacement | 
					
						
							|  |  |  |  |  * should not destroy the object in the normal way. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-07-10 17:09:07 +01:00
										 |  |  |  |  * Returns: %TRUE if the existing value for @key was replaced | 
					
						
							| 
									
										
										
										
											2012-08-28 06:45:30 -04:00
										 |  |  |  |  *  by @newval, %FALSE otherwise. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.34 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | gboolean | 
					
						
							|  |  |  |  | g_object_replace_data (GObject        *object, | 
					
						
							|  |  |  |  |                        const gchar    *key, | 
					
						
							|  |  |  |  |                        gpointer        oldval, | 
					
						
							|  |  |  |  |                        gpointer        newval, | 
					
						
							|  |  |  |  |                        GDestroyNotify  destroy, | 
					
						
							|  |  |  |  |                        GDestroyNotify *old_destroy) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), FALSE); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (key != NULL, FALSE); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return g_datalist_id_replace_data (&object->qdata, | 
					
						
							|  |  |  |  |                                      g_quark_from_string (key), | 
					
						
							|  |  |  |  |                                      oldval, newval, destroy, | 
					
						
							|  |  |  |  |                                      old_destroy); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_object_set_data_full: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * @object: #GObject containing the associations | 
					
						
							|  |  |  |  |  * @key: name of the key | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * @data: (nullable): data to associate with that key | 
					
						
							|  |  |  |  |  * @destroy: (nullable): function to call when the association is destroyed | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Like g_object_set_data() except it adds notification | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * for when the association is destroyed, either by setting it | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * to a different value or when the object is destroyed. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Note that the @destroy callback is not called if @data is %NULL. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2000-11-20 22:24:12 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_set_data_full (GObject       *object, | 
					
						
							|  |  |  |  |                         const gchar   *key, | 
					
						
							|  |  |  |  |                         gpointer       data, | 
					
						
							|  |  |  |  |                         GDestroyNotify destroy) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (key != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-05-03 10:12:46 +00:00
										 |  |  |  |   g_datalist_id_set_data_full (&object->qdata, g_quark_from_string (key), data, | 
					
						
							|  |  |  |  | 			       data ? destroy : (GDestroyNotify) NULL); | 
					
						
							| 
									
										
										
										
											2000-11-20 22:24:12 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_steal_data: | 
					
						
							|  |  |  |  |  * @object: #GObject containing the associations | 
					
						
							|  |  |  |  |  * @key: name of the key | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  * Remove a specified datum from the object's data associations, | 
					
						
							|  |  |  |  |  * without invoking the association's destroy handler. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2015-10-14 21:38:48 +03:00
										 |  |  |  |  * Returns: (transfer full) (nullable): the data if found, or %NULL | 
					
						
							|  |  |  |  |  *          if no such data exists. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2000-11-20 22:24:12 +00:00
										 |  |  |  | gpointer | 
					
						
							|  |  |  |  | g_object_steal_data (GObject     *object, | 
					
						
							|  |  |  |  |                      const gchar *key) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   GQuark quark; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2000-11-20 22:24:12 +00:00
										 |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (key != NULL, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   quark = g_quark_try_string (key); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return quark ? g_datalist_id_remove_no_notify (&object->qdata, quark) : NULL; | 
					
						
							| 
									
										
										
										
											2000-11-20 22:24:12 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_value_object_init (GValue *value) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   value->data[0].v_pointer = NULL; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_value_object_free_value (GValue *value) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   if (value->data[0].v_pointer) | 
					
						
							|  |  |  |  |     g_object_unref (value->data[0].v_pointer); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_value_object_copy_value (const GValue *src_value, | 
					
						
							|  |  |  |  | 			   GValue	*dest_value) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   if (src_value->data[0].v_pointer) | 
					
						
							|  |  |  |  |     dest_value->data[0].v_pointer = g_object_ref (src_value->data[0].v_pointer); | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     dest_value->data[0].v_pointer = NULL; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_value_object_transform_value (const GValue *src_value, | 
					
						
							|  |  |  |  | 				GValue       *dest_value) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   if (src_value->data[0].v_pointer && g_type_is_a (G_OBJECT_TYPE (src_value->data[0].v_pointer), G_VALUE_TYPE (dest_value))) | 
					
						
							|  |  |  |  |     dest_value->data[0].v_pointer = g_object_ref (src_value->data[0].v_pointer); | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     dest_value->data[0].v_pointer = NULL; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | static gpointer | 
					
						
							|  |  |  |  | g_value_object_peek_pointer (const GValue *value) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   return value->data[0].v_pointer; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | static gchar* | 
					
						
							|  |  |  |  | g_value_object_collect_value (GValue	  *value, | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  | 			      guint        n_collect_values, | 
					
						
							|  |  |  |  | 			      GTypeCValue *collect_values, | 
					
						
							|  |  |  |  | 			      guint        collect_flags) | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  |   if (collect_values[0].v_pointer) | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  |       GObject *object = collect_values[0].v_pointer; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |        | 
					
						
							|  |  |  |  |       if (object->g_type_instance.g_class == NULL) | 
					
						
							| 
									
										
										
										
											2013-05-20 17:54:48 -03:00
										 |  |  |  | 	return g_strconcat ("invalid unclassed object pointer for value type '", | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | 			    G_VALUE_TYPE_NAME (value), | 
					
						
							|  |  |  |  | 			    "'", | 
					
						
							|  |  |  |  | 			    NULL); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       else if (!g_value_type_compatible (G_OBJECT_TYPE (object), G_VALUE_TYPE (value))) | 
					
						
							| 
									
										
										
										
											2013-05-20 17:54:48 -03:00
										 |  |  |  | 	return g_strconcat ("invalid object type '", | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | 			    G_OBJECT_TYPE_NAME (object), | 
					
						
							| 
									
										
										
										
											2013-05-20 17:54:48 -03:00
										 |  |  |  | 			    "' for value type '", | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | 			    G_VALUE_TYPE_NAME (value), | 
					
						
							|  |  |  |  | 			    "'", | 
					
						
							|  |  |  |  | 			    NULL); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       /* never honour G_VALUE_NOCOPY_CONTENTS for ref-counted types */ | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |       value->data[0].v_pointer = g_object_ref (object); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     value->data[0].v_pointer = NULL; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   return NULL; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static gchar* | 
					
						
							|  |  |  |  | g_value_object_lcopy_value (const GValue *value, | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  | 			    guint        n_collect_values, | 
					
						
							|  |  |  |  | 			    GTypeCValue *collect_values, | 
					
						
							|  |  |  |  | 			    guint        collect_flags) | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  |   GObject **object_p = collect_values[0].v_pointer; | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							|  |  |  |  |   if (!object_p) | 
					
						
							| 
									
										
										
										
											2013-05-20 17:54:48 -03:00
										 |  |  |  |     return g_strdup_printf ("value location for '%s' passed as NULL", G_VALUE_TYPE_NAME (value)); | 
					
						
							| 
									
										
										
										
											2001-02-17 05:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (!value->data[0].v_pointer) | 
					
						
							|  |  |  |  |     *object_p = NULL; | 
					
						
							|  |  |  |  |   else if (collect_flags & G_VALUE_NOCOPY_CONTENTS) | 
					
						
							|  |  |  |  |     *object_p = value->data[0].v_pointer; | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     *object_p = g_object_ref (value->data[0].v_pointer); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							|  |  |  |  |   return NULL; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_value_set_object: | 
					
						
							|  |  |  |  |  * @value: a valid #GValue of %G_TYPE_OBJECT derived type | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @v_object: (type GObject.Object) (nullable): object value to be set | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * Set the contents of a %G_TYPE_OBJECT derived #GValue to @v_object. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * g_value_set_object() increases the reference count of @v_object | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * (the #GValue holds a reference to @v_object).  If you do not wish | 
					
						
							|  |  |  |  |  * to increase the reference count of the object (i.e. you wish to | 
					
						
							|  |  |  |  |  * pass your current reference to the #GValue because you no longer | 
					
						
							|  |  |  |  |  * need it), use g_value_take_object() instead. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * It is important that your #GValue holds a reference to @v_object (either its | 
					
						
							|  |  |  |  |  * own, or one it has taken) to ensure that the object won't be destroyed while | 
					
						
							|  |  |  |  |  * the #GValue still exists). | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | void | 
					
						
							| 
									
										
										
										
											2001-05-22 00:48:06 +00:00
										 |  |  |  | g_value_set_object (GValue   *value, | 
					
						
							| 
									
										
										
										
											2001-05-24 12:52:39 +00:00
										 |  |  |  | 		    gpointer  v_object) | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2003-05-30 18:44:57 +00:00
										 |  |  |  |   GObject *old; | 
					
						
							|  |  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |   g_return_if_fail (G_VALUE_HOLDS_OBJECT (value)); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-05-30 18:44:57 +00:00
										 |  |  |  |   old = value->data[0].v_pointer; | 
					
						
							|  |  |  |  |    | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |   if (v_object) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_return_if_fail (G_IS_OBJECT (v_object)); | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |       g_return_if_fail (g_value_type_compatible (G_OBJECT_TYPE (v_object), G_VALUE_TYPE (value))); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       value->data[0].v_pointer = v_object; | 
					
						
							|  |  |  |  |       g_object_ref (value->data[0].v_pointer); | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2003-05-30 18:44:57 +00:00
										 |  |  |  |   else | 
					
						
							|  |  |  |  |     value->data[0].v_pointer = NULL; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   if (old) | 
					
						
							|  |  |  |  |     g_object_unref (old); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_value_set_object_take_ownership: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * @value: a valid #GValue of %G_TYPE_OBJECT derived type | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @v_object: (nullable): object value to be set | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * This is an internal function introduced mainly for C marshallers. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * Deprecated: 2.4: Use g_value_take_object() instead. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2002-02-19 17:38:45 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_value_set_object_take_ownership (GValue  *value, | 
					
						
							|  |  |  |  | 				   gpointer v_object) | 
					
						
							| 
									
										
										
										
											2003-09-12 20:11:38 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   g_value_take_object (value, v_object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_value_take_object: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * @value: a valid #GValue of %G_TYPE_OBJECT derived type | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @v_object: (nullable): object value to be set | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Sets the contents of a %G_TYPE_OBJECT derived #GValue to @v_object | 
					
						
							|  |  |  |  |  * and takes over the ownership of the callers reference to @v_object; | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * the caller doesn't have to unref it any more (i.e. the reference | 
					
						
							|  |  |  |  |  * count of the object is not increased). | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * If you want the #GValue to hold its own reference to @v_object, use | 
					
						
							|  |  |  |  |  * g_value_set_object() instead. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  * Since: 2.4 | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2003-09-12 20:11:38 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_value_take_object (GValue  *value, | 
					
						
							|  |  |  |  | 		     gpointer v_object) | 
					
						
							| 
									
										
										
										
											2002-02-19 17:38:45 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_VALUE_HOLDS_OBJECT (value)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (value->data[0].v_pointer) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_object_unref (value->data[0].v_pointer); | 
					
						
							|  |  |  |  |       value->data[0].v_pointer = NULL; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (v_object) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_return_if_fail (G_IS_OBJECT (v_object)); | 
					
						
							|  |  |  |  |       g_return_if_fail (g_value_type_compatible (G_OBJECT_TYPE (v_object), G_VALUE_TYPE (value))); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       value->data[0].v_pointer = v_object; /* we take over the reference count */ | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_value_get_object: | 
					
						
							|  |  |  |  |  * @value: a valid #GValue of %G_TYPE_OBJECT derived type | 
					
						
							|  |  |  |  |  *  | 
					
						
							|  |  |  |  |  * Get the contents of a %G_TYPE_OBJECT derived #GValue. | 
					
						
							|  |  |  |  |  *  | 
					
						
							| 
									
										
										
										
											2010-12-19 10:39:36 +01:00
										 |  |  |  |  * Returns: (type GObject.Object) (transfer none): object contents of @value | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  | gpointer | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | g_value_get_object (const GValue *value) | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |   g_return_val_if_fail (G_VALUE_HOLDS_OBJECT (value), NULL); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							|  |  |  |  |   return value->data[0].v_pointer; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_value_dup_object: | 
					
						
							|  |  |  |  |  * @value: a valid #GValue whose type is derived from %G_TYPE_OBJECT | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Get the contents of a %G_TYPE_OBJECT derived #GValue, increasing | 
					
						
							| 
									
										
										
										
											2011-02-15 19:54:53 +01:00
										 |  |  |  |  * its reference count. If the contents of the #GValue are %NULL, then | 
					
						
							|  |  |  |  |  * %NULL will be returned. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * Returns: (type GObject.Object) (transfer full): object content of @value, | 
					
						
							|  |  |  |  |  *          should be unreferenced when no longer needed. | 
					
						
							| 
									
										
										
										
											2008-06-21 22:16:14 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2006-08-23 08:46:21 +00:00
										 |  |  |  | gpointer | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | g_value_dup_object (const GValue *value) | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
											  
											
												changed prototype of g_boxed_type_register_static() to contain an optional
Wed Mar  7 09:36:33 2001  Tim Janik  <timj@gtk.org>
	* gboxed.[hc]: changed prototype of g_boxed_type_register_static()
	to contain an optional init function and a hint at whether the
	boxed structure uses ref counting internally.
	added g_value_set_boxed_take_ownership().
	made G_TYPE_BOXED an abstract value type.
	* genums.[hc]: made G_TYPE_ENUM and G_TYPE_FLAGS abstract value
	types.
	* glib-genmarshal.c: argument type changes, preparation for third-party
	arg specification.
	* gobject.[hc]: cleaned up get/set property code.
	added g_strdup_value_contents() to improve warnings.
	* gparam.[hc]: added g_param_value_convert(), taking over responsibility
	of the old g_value_convert(). added G_PARAM_LAX_VALIDATION flag so
	validation alterations may be valid a part of the property setting
	process.
	* gparamspecs.[hc]: made value comparisons stable (for sort applications).
	added GParamSpecValueArray, a param spec for value arrays and
	GParamSpecClosure. nuked the value exchange functions and
	GParamSpecCCallback.
	* gtype.[hc]: catch unintialized usages of the type system with
	g_return_val_if_uninitialized(). introduced G_TYPE_FLAG_VALUE_ABSTRACT
	to flag types that introduce a value table, but can't be used for
	g_value_init(). cleaned up reserved type ids.
	* gvalue.[hc]: code cleanups and saner checking.
	nuked the value exchange API. implemented value transformations, we
	can't really "convert" values, rather transforms are an anylogy to
	C casts, real conversions need a param spec for validation, which is
	why g_param_value_convert() does real conversions now.
	* gvaluearray.[hc]: new files that implement a GValueArray, a struct
	that can hold inhomogeneous arrays of value (to that extend that it
	also allowes undefined values, i.e. G_VALUE_TYPE(value)==0).
	this is exposed to the type system as a boxed type.
	* gvaluetransform.c: new file implementing most of the former value
	exchange functions as single-sided transformations.
	* gvaluetypes.[hc]: nuked G_TYPE_CCALLBACK, added
	g_value_set_string_take_ownership().
	* *.h: s/G_IS_VALUE_/G_VALUE_HOLDS_/.
	* *.[hc]: many fixes and cleanups.
	* many warning improvements.
Tue Feb 27 18:35:15 2001  Tim Janik  <timj@gtk.org>
	* gobject.c (g_object_get_valist): urg, pass G_VALUE_NOCOPY_CONTENTS
	into G_VALUE_LCOPY(), this needs proper documenting.
	* gparam.c: fixed G_PARAM_USER_MASK.
	* gtype.c (type_data_make_W):
	(type_data_last_unref_Wm): fixed invalid memory freeing.
	* gobject.c (g_object_last_unref): destroy signal handlers associated
	with object, right before finalization.
	* gsignal.c (g_signal_parse_name): catch destroyed nodes or signals
	that don't actually support details.
	* gobject.[hc]: got rid of property trailers. nuked GObject
	properties "data" and the "signal" variants.
	(g_object_connect): new convenience function to do multiple
	signal connections at once.
	(g_object_disconnect): likewise, for disconnections.
	* gparam.[hc] (g_param_spec_pool_lookup): took out trailer support.
	* gvalue.[hc]: marked g_value_fits_pointer() and g_value_peek_pointer()
	as private (the latter got renamed from g_value_get_as_pointer()).
Wed Mar  7 09:32:06 2001  Tim Janik  <timj@gtk.org>
        * glib-object.h: add gvaluearray.h.
        * gstring.[hc]: fixup naming of g_string_sprint*.
        * gtypes.h: fixed GCompareDataFunc naming.
Wed Mar  7 09:33:27 2001  Tim Janik  <timj@gtk.org>
        * gobject/Makefile.am: shuffled rules to avoid excessive
        rebuilds.
        * gobject/gobject-sections.txt: updates.
        * gobject/tmpl/*: bunch of updates, added another patch
        from Eric Lemings <eric.b.lemings@lmco.com>.
											
										 
											2001-03-07 14:46:45 +00:00
										 |  |  |  |   g_return_val_if_fail (G_VALUE_HOLDS_OBJECT (value), NULL); | 
					
						
							| 
									
										
											  
											
												define gstring in terms of gchar*. this typedef reflects the type name of
Fri Jun 23 17:20:26 2000  Tim Janik  <timj@gtk.org>
        * glib.h: define gstring in terms of gchar*. this typedef reflects
        the type name of the primitive G_TYPE_STRING in the gobject module.
Sat Jun 24 23:03:04 2000  Tim Janik  <timj@gtk.org>
        * gtype.[hc]: provide G_TYPE_CHAR, G_TYPE_UCHAR, G_TYPE_BOOLEAN,
        G_TYPE_INT, G_TYPE_UINT, G_TYPE_LONG, G_TYPE_ULONG, G_TYPE_FLOAT,
        G_TYPE_DOUBLE and G_TYPE_STRING fundamental types.
        added a GTypeValueTable* pointer to GTypeInfo structure for types
        to implement GValue handling functions.
        GTypeValueTable contains the following members:
          value_init(): initialize a GValue structure.
          value_free(): free GValue structure contents (optional).
          value_copy(): copy one GValue contents to another GValue structure of
          collect_type: varargs collection type for the first variable argument
          to be collected by collect_value().
          collect_value(): variable arguments collection function (optional).
          lcopy_type: varargs collection type for the first variable argument
          to be location copyied by lcopy_value().
          lcopy_value(): variable arguments location copy function (optional).
        g_type_value_table_peek(): new function to retrive the GTypeValueTable*
        for a type node. ValueTables get inherited from parent types, unless
        overridden through the GTypeInfo structure. internally, GTypeValueTable
        support means an added overhead of one pointer per static or used
        dynamic type node.
        g_type_add_class_cache_func(): provide a cache_func/data pair to be
        called  prior to a type nodes last_unref() function, this can be used
        to prevent premature class destruction. multiple installed cache_func()
        will be chained upon last_unref() untill one of them returns TRUE.
        the cache_func()s have to check the type id passed in to figure whether
        they actually wants to cache the class of this type (since any types are
        routed through the cache_func() chain).
        g_type_remove_class_cache_func(): remove a previously installed
        cache_func/data pair. the cache maintained by this function has to be
        clear when calling g_type_remove_class_cache_func() to avoid leaks.
        g_type_class_unref_uncached(): class unref function for cache_func()
        implementations, unreferences a class omitting the cache chain (and
        therefore unref->cache->unref->... loops).
        * gvaluetypes.[hc]: provide the value setters/getters for the primitive
        fundamental types boolean, char, uchar, int, uint, long, ulong, float,
        double and string.
        * gvalue.[hc]: provide G_TYPE_IS_VALUE() in terms of whether a
        GTypeValueTable is provided for this type.
        removed g_value_init_default(), g_value_validate(), g_value_defaults(),
        g_value_set_default() and g_values_cmp() as these are supplied by the
        GParamSpec API now.
        moved g_values_exchange() into the "implementation details" section,
        since it just provides the underlying functionality for
        g_value_convert().
        * gvaluecollector.h: renamed the varargs value container from
        GParamCValue to GTypeCValue as the value collection methods are
        supplied by the type system now.
        G_PARAM_COLLECT_VALUE() and G_PARAM_LCOPY_VALUE() got renamed to
        G_VALUE_COLLECT() and G_VALUE_LCOPY() and operate without a
        GParamSpec structure now.
        * genums.h: macros cleanups/fixes.
        * genum.c: provide G_TYPE_ENUM and G_TYPE_FLAGS type
        and assorted g_value_{s|g}et_{enum|flags}() implementations.
        * gobject.[hc]:
        provide G_IS_VALUE_OBJECT(), G_TYPE_OBJECT ValueTable methods
        and g_value_{s|g}et_object().
        * gparam.[hc]: reduced class to value_set_default(),
        value_validate() and values_cmp(). also parameters now need to fill
        in a GType value_type; field to indicate the GValue type they
        are handling. provide g_param_value_set_default(),
        g_param_value_defaults(), g_param_value_validate() and
        g_param_values_cmp().
        * gparamspecs.[hc]: got rid of the g_value_* functions and
        the G_IS_VALUE_* macros. adapted param spec implementations
        according to the GParamSpecClass changes.
											
										 
											2000-06-24 22:30:10 +00:00
										 |  |  |  |    | 
					
						
							|  |  |  |  |   return value->data[0].v_pointer ? g_object_ref (value->data[0].v_pointer) : NULL; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-22 09:29:52 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_signal_connect_object: (skip) | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @instance: (type GObject.TypeInstance): the instance to connect to. | 
					
						
							| 
									
										
										
										
											2008-06-22 09:29:52 +00:00
										 |  |  |  |  * @detailed_signal: a string of the form "signal-name::detail". | 
					
						
							|  |  |  |  |  * @c_handler: the #GCallback to connect. | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @gobject: (type GObject.Object) (nullable): the object to pass as data | 
					
						
							|  |  |  |  |  *    to @c_handler. | 
					
						
							| 
									
										
										
										
											2011-09-05 18:46:59 -04:00
										 |  |  |  |  * @connect_flags: a combination of #GConnectFlags. | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * This is similar to g_signal_connect_data(), but uses a closure which | 
					
						
							|  |  |  |  |  * ensures that the @gobject stays alive during the call to @c_handler | 
					
						
							|  |  |  |  |  * by temporarily adding a reference count to @gobject. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2013-03-14 22:56:54 +01:00
										 |  |  |  |  * When the @gobject is destroyed the signal handler will be automatically | 
					
						
							| 
									
										
										
										
											2012-10-08 11:20:07 -04:00
										 |  |  |  |  * disconnected.  Note that this is not currently threadsafe (ie: | 
					
						
							|  |  |  |  |  * emitting a signal while @gobject is being destroyed in another thread | 
					
						
							|  |  |  |  |  * is not safe). | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-22 09:29:52 +00:00
										 |  |  |  |  * Returns: the handler id. | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2002-01-24 06:39:31 +00:00
										 |  |  |  | gulong | 
					
						
							| 
									
										
										
										
											2001-06-28 17:05:12 +00:00
										 |  |  |  | g_signal_connect_object (gpointer      instance, | 
					
						
							|  |  |  |  | 			 const gchar  *detailed_signal, | 
					
						
							|  |  |  |  | 			 GCallback     c_handler, | 
					
						
							|  |  |  |  | 			 gpointer      gobject, | 
					
						
							|  |  |  |  | 			 GConnectFlags connect_flags) | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_TYPE_CHECK_INSTANCE (instance), 0); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (detailed_signal != NULL, 0); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (c_handler != NULL, 0); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (gobject) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       GClosure *closure; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       g_return_val_if_fail (G_IS_OBJECT (gobject), 0); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-28 17:05:12 +00:00
										 |  |  |  |       closure = ((connect_flags & G_CONNECT_SWAPPED) ? g_cclosure_new_object_swap : g_cclosure_new_object) (c_handler, gobject); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-28 17:05:12 +00:00
										 |  |  |  |       return g_signal_connect_closure (instance, detailed_signal, closure, connect_flags & G_CONNECT_AFTER); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							| 
									
										
										
										
											2001-06-28 17:05:12 +00:00
										 |  |  |  |     return g_signal_connect_data (instance, detailed_signal, c_handler, NULL, NULL, connect_flags); | 
					
						
							| 
									
										
											  
											
												fixed dealing with collection/lcopy of NULL values.
Mon Dec 11 04:44:11 2000  Tim Janik  <timj@gtk.org>
	* gboxed.c: fixed dealing with collection/lcopy of NULL values.
	* gclosure.h: removed insane ramblings, added G_CALLBACK() a casting
	convenience macro.
	* Makefile.am: cleanups, marshaller generation rules.
	* gmarshal.[hc]: new files with GRuntime standard marshallers.
	* glib-genmarshal.c: fix log domain, support gruntime standard
	marshallers, suport G_TYPE_PARAM, come with extern "C" and
	#include gmarshal.h.
	* glib-genmarshal.1: reflect glib-genmarshal.c updates.
	* gobject.[hc]: implement object constructor. rework parameter
	changed notification queueing, we support queue freezes now and
	don't dispatch from an idle handler anymore.
	parameter->property rename hassle.
	implemented ::properties_changed and ::notify::* signals for
	property change notification (the later supports property names
	as details). added signal connection and named data properties.
	(g_signal_connect_object): new function to setup while_alive
	connections.
	(g_object_class_install_property): sink properties now, since they
	are initially floating.
	(g_object_steal_data):
	(g_object_set_data_full):
	(g_object_set_data):
	(g_object_get_data): set/get data by using g_datalist_*() functions
	directly.
	(g_object_queue_param_changed): nuked.
	(g_object_freeze_notify): start queueing of property changes (freeze/
	thaw calls stack).
	(g_object_notify): announce changes of a certain property directly.
	(g_object_thaw_notify): process queue of property changes, therefore
	emitting GObject::notify::detail with detail being the changed
	properties names.
	(G_OBJECT_WARN_INVALID_PROPERTY_ID): saner macro variant of former
	G_WARN_INVALID_PARAM_ID().
	* gparam.[hc]: param specs are now initially floating and need to be
	sunken with g_param_spec_sink(), support G_TYPE_PARAM values.
	added G_PARAM_CONSTRUCT and G_PARAM_CONSTRUCT_ONLY parameter flags,
	required by GObjectClass.constructor().
	* gparamspecs.[hc]: added GParamSpecParam, GParamSpecPointer and
	GParamSpecCCallback, param specs for G_TYPE_PARAM, G_TYPE_POINTER
	and G_TYPE_CCALLBACK respectively.
	* gsignal.[hc]: cleanups.
	(signal_id_lookup): after walking the anchestry, try interfaces as well.
	(g_signal_new): new function to create signals from varargs type list.
	(g_signal_connect_closure): closure connection variant that works from
	signal name+detail.
	(g_signal_connect_data): c handler connection variant that works from
	signal name+detail.
	(g_signal_emit_valist): emit signal for an instance with paraneters
	collected from a va_list.
	(g_signal_emit): emit signal, taking parameters from varargs list.
	(g_signal_emit_by_name): same as g_signal_emit, working from
	signal name+detail.
	(signal_emit_R): return whether return_value needs to be altered.
	* gtype.[hc]: set log-domain to GRuntime, i'm slowly getting to all
	the points that need to reflect the upcoming rename.
	melt g_type_conforms_to() functionality into g_type_is_a(), as that
	is what we really want (liskov substitution principle).
	assorted changes to other files due to conforms_to->is_a.
	* gvalue.[hc]: implemented g_value_set_instance() that sets a value
	from an instantiatable type via the value_table's collect_value()
	function (based on an idea from James Henstridge <james@daa.com.au>).
	cleanups/fixes.
	* gvaluetypes.[hc]: implement G_TYPE_CCALLBACK and G_TYPE_PARAM.
											
										 
											2000-12-12 07:32:00 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | typedef struct { | 
					
						
							|  |  |  |  |   GObject  *object; | 
					
						
							|  |  |  |  |   guint     n_closures; | 
					
						
							|  |  |  |  |   GClosure *closures[1]; /* flexible array */ | 
					
						
							|  |  |  |  | } CArray; | 
					
						
							| 
									
										
										
										
											2002-03-03 03:14:43 +00:00
										 |  |  |  | /* don't change this structure without supplying an accessor for
 | 
					
						
							|  |  |  |  |  * watched closures, e.g.: | 
					
						
							|  |  |  |  |  * GSList* g_object_list_watched_closures (GObject *object) | 
					
						
							|  |  |  |  |  * { | 
					
						
							|  |  |  |  |  *   CArray *carray; | 
					
						
							|  |  |  |  |  *   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |  *   carray = g_object_get_data (object, "GObject-closure-array"); | 
					
						
							|  |  |  |  |  *   if (carray) | 
					
						
							|  |  |  |  |  *     { | 
					
						
							|  |  |  |  |  *       GSList *slist = NULL; | 
					
						
							|  |  |  |  |  *       guint i; | 
					
						
							|  |  |  |  |  *       for (i = 0; i < carray->n_closures; i++) | 
					
						
							|  |  |  |  |  *         slist = g_slist_prepend (slist, carray->closures[i]); | 
					
						
							|  |  |  |  |  *       return slist; | 
					
						
							|  |  |  |  |  *     } | 
					
						
							|  |  |  |  |  *   return NULL; | 
					
						
							|  |  |  |  |  * } | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | object_remove_closure (gpointer  data, | 
					
						
							|  |  |  |  | 		       GClosure *closure) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GObject *object = data; | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   CArray *carray; | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |   guint i; | 
					
						
							|  |  |  |  |    | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_LOCK (closure_array_mutex); | 
					
						
							|  |  |  |  |   carray = g_object_get_qdata (object, quark_closure_array); | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |   for (i = 0; i < carray->n_closures; i++) | 
					
						
							|  |  |  |  |     if (carray->closures[i] == closure) | 
					
						
							|  |  |  |  |       { | 
					
						
							|  |  |  |  | 	carray->n_closures--; | 
					
						
							|  |  |  |  | 	if (i < carray->n_closures) | 
					
						
							|  |  |  |  | 	  carray->closures[i] = carray->closures[carray->n_closures]; | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  | 	G_UNLOCK (closure_array_mutex); | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | 	return; | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_UNLOCK (closure_array_mutex); | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |   g_assert_not_reached (); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | destroy_closure_array (gpointer data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   CArray *carray = data; | 
					
						
							|  |  |  |  |   GObject *object = carray->object; | 
					
						
							|  |  |  |  |   guint i, n = carray->n_closures; | 
					
						
							|  |  |  |  |    | 
					
						
							|  |  |  |  |   for (i = 0; i < n; i++) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       GClosure *closure = carray->closures[i]; | 
					
						
							|  |  |  |  |        | 
					
						
							|  |  |  |  |       /* removing object_remove_closure() upfront is probably faster than
 | 
					
						
							|  |  |  |  |        * letting it fiddle with quark_closure_array which is empty anyways | 
					
						
							|  |  |  |  |        */ | 
					
						
							| 
									
										
										
										
											2001-03-18 04:44:38 +00:00
										 |  |  |  |       g_closure_remove_invalidate_notifier (closure, object, object_remove_closure); | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |       g_closure_invalidate (closure); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   g_free (carray); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_object_watch_closure: | 
					
						
							|  |  |  |  |  * @object: GObject restricting lifetime of @closure | 
					
						
							|  |  |  |  |  * @closure: GClosure to watch | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * This function essentially limits the life time of the @closure to | 
					
						
							|  |  |  |  |  * the life time of the object. That is, when the object is finalized, | 
					
						
							|  |  |  |  |  * the @closure is invalidated by calling g_closure_invalidate() on | 
					
						
							|  |  |  |  |  * it, in order to prevent invocations of the closure with a finalized | 
					
						
							|  |  |  |  |  * (nonexisting) object. Also, g_object_ref() and g_object_unref() are | 
					
						
							|  |  |  |  |  * added as marshal guards to the @closure, to ensure that an extra | 
					
						
							|  |  |  |  |  * reference count is held on @object during invocation of the | 
					
						
							|  |  |  |  |  * @closure.  Usually, this function will be called on closures that | 
					
						
							|  |  |  |  |  * use this @object as closure data. | 
					
						
							| 
									
										
										
										
											2008-06-21 20:07:57 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_object_watch_closure (GObject  *object, | 
					
						
							|  |  |  |  | 			GClosure *closure) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   CArray *carray; | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   guint i; | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |    | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  |   g_return_if_fail (closure != NULL); | 
					
						
							|  |  |  |  |   g_return_if_fail (closure->is_invalid == FALSE); | 
					
						
							|  |  |  |  |   g_return_if_fail (closure->in_marshal == FALSE); | 
					
						
							|  |  |  |  |   g_return_if_fail (object->ref_count > 0);	/* this doesn't work on finalizing objects */ | 
					
						
							|  |  |  |  |    | 
					
						
							| 
									
										
										
										
											2001-03-18 04:44:38 +00:00
										 |  |  |  |   g_closure_add_invalidate_notifier (closure, object, object_remove_closure); | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |   g_closure_add_marshal_guards (closure, | 
					
						
							|  |  |  |  | 				object, (GClosureNotify) g_object_ref, | 
					
						
							|  |  |  |  | 				object, (GClosureNotify) g_object_unref); | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_LOCK (closure_array_mutex); | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   carray = g_datalist_id_remove_no_notify (&object->qdata, quark_closure_array); | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |   if (!carray) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       carray = g_renew (CArray, NULL, 1); | 
					
						
							|  |  |  |  |       carray->object = object; | 
					
						
							|  |  |  |  |       carray->n_closures = 1; | 
					
						
							| 
									
										
										
										
											2001-07-02 05:15:29 +00:00
										 |  |  |  |       i = 0; | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |       i = carray->n_closures++; | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  |       carray = g_realloc (carray, sizeof (*carray) + sizeof (carray->closures[0]) * i); | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-07-02 05:02:13 +00:00
										 |  |  |  |   carray->closures[i] = closure; | 
					
						
							|  |  |  |  |   g_datalist_id_set_data_full (&object->qdata, quark_closure_array, carray, destroy_closure_array); | 
					
						
							| 
									
										
										
										
											2010-03-26 16:19:13 +01:00
										 |  |  |  |   G_UNLOCK (closure_array_mutex); | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 12:18:12 +00:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_closure_new_object: | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * @sizeof_closure: the size of the structure to allocate, must be at least | 
					
						
							| 
									
										
										
										
											2014-02-06 08:04:52 -05:00
										 |  |  |  |  *  `sizeof (GClosure)` | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * @object: a #GObject pointer to store in the @data field of the newly | 
					
						
							| 
									
										
										
										
											2008-06-21 12:18:12 +00:00
										 |  |  |  |  *  allocated #GClosure | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * A variant of g_closure_new_simple() which stores @object in the | 
					
						
							|  |  |  |  |  * @data field of the closure and calls g_object_watch_closure() on | 
					
						
							|  |  |  |  |  * @object and the created closure. This function is mainly useful | 
					
						
							|  |  |  |  |  * when implementing new types of closures. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * Returns: (transfer full): a newly allocated #GClosure | 
					
						
							| 
									
										
										
										
											2008-06-21 12:18:12 +00:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | GClosure* | 
					
						
							|  |  |  |  | g_closure_new_object (guint    sizeof_closure, | 
					
						
							|  |  |  |  | 		      GObject *object) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GClosure *closure; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (object->ref_count > 0, NULL);     /* this doesn't work on finalizing objects */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   closure = g_closure_new_simple (sizeof_closure, object); | 
					
						
							|  |  |  |  |   g_object_watch_closure (object, closure); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return closure; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 12:18:12 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:07:08 +01:00
										 |  |  |  |  * g_cclosure_new_object: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 12:18:12 +00:00
										 |  |  |  |  * @callback_func: the function to invoke | 
					
						
							|  |  |  |  |  * @object: a #GObject pointer to pass to @callback_func | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * A variant of g_cclosure_new() which uses @object as @user_data and | 
					
						
							|  |  |  |  |  * calls g_object_watch_closure() on @object and the created | 
					
						
							|  |  |  |  |  * closure. This function is useful when you have a callback closely | 
					
						
							|  |  |  |  |  * associated with a #GObject, and want the callback to no longer run | 
					
						
							|  |  |  |  |  * after the object is is freed. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 12:18:12 +00:00
										 |  |  |  |  * Returns: a new #GCClosure | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | GClosure* | 
					
						
							| 
									
										
										
										
											2000-10-27 22:28:01 +00:00
										 |  |  |  | g_cclosure_new_object (GCallback callback_func, | 
					
						
							| 
									
										
										
										
											2001-09-10 18:32:52 +00:00
										 |  |  |  | 		       GObject  *object) | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   GClosure *closure; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (object->ref_count > 0, NULL);     /* this doesn't work on finalizing objects */ | 
					
						
							|  |  |  |  |   g_return_val_if_fail (callback_func != NULL, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   closure = g_cclosure_new (callback_func, object, NULL); | 
					
						
							|  |  |  |  |   g_object_watch_closure (object, closure); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return closure; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-21 12:18:12 +00:00
										 |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-12-19 22:15:42 +01:00
										 |  |  |  |  * g_cclosure_new_object_swap: (skip) | 
					
						
							| 
									
										
										
										
											2008-06-21 12:18:12 +00:00
										 |  |  |  |  * @callback_func: the function to invoke | 
					
						
							|  |  |  |  |  * @object: a #GObject pointer to pass to @callback_func | 
					
						
							| 
									
										
										
										
											2008-06-22 14:53:09 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * A variant of g_cclosure_new_swap() which uses @object as @user_data | 
					
						
							|  |  |  |  |  * and calls g_object_watch_closure() on @object and the created | 
					
						
							|  |  |  |  |  * closure. This function is useful when you have a callback closely | 
					
						
							|  |  |  |  |  * associated with a #GObject, and want the callback to no longer run | 
					
						
							|  |  |  |  |  * after the object is is freed. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-06-21 12:18:12 +00:00
										 |  |  |  |  * Returns: a new #GCClosure | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | GClosure* | 
					
						
							| 
									
										
										
										
											2000-10-27 22:28:01 +00:00
										 |  |  |  | g_cclosure_new_object_swap (GCallback callback_func, | 
					
						
							| 
									
										
										
										
											2001-09-10 18:32:52 +00:00
										 |  |  |  | 			    GObject  *object) | 
					
						
							| 
									
										
											  
											
												added newly added gobject/ headers.
Tue Oct 24 22:09:14 2000  Tim Janik  <timj@gtk.org>
        * glib-object.h: added newly added gobject/ headers.
        * gmesage.c: print g_message() output to stderr instead of stdout.
Wed Oct 25 20:27:02 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_free_instance): for the moment, freeing object
        structures will fill their memory portion with 0xAA. there's a
        FIXME there, remove this line at a later point.
Tue Oct 24 23:10:26 2000  Tim Janik  <timj@gtk.org>
        * glib-genmarshal.1:
        * glib-genmarshal.c: added publically installed marshaller generator.
        * gtype.h: added G_TYPE_INSTANCE_GET_INTERFACE() to retrive a certain
        interface VTable from instances.
Mon Oct 23 08:28:15 2000  Tim Janik  <timj@gtk.org>
        * gobject.[hc]: new functions for closure maintenance:
        (g_object_watch_closure): maintain validity of the object and
        the closure for objects that are used as data part of a closure.
        (g_cclosure_new_object): convenience function to create C closures
        that have an object as data argument.
        (g_closure_new_object): convenience function to create closures
        that have an object as data argument.
        * gclosure.[hc]: implementation of GClosure mechanism.
        a closure is basically an encapsulation of a callback function
        and its environment. ideally, most places supporting callback
        functions will simply take a GClosure* pointer and thus unify
        callback environments wrg destroy notification etc.
        GClosure provides destroy notifiers for arbitrary data pointers,
        reference counting, invalidation notification (it can be invalidated
        which is merely a deactivate state) and a marshallinbg abstraction.
        GCClosure is also provided in these files, they present a specialized
        GClosure implementation for C language callbacks.
        * genum.c: macro cleanups.
        * gboxed.[hc]: new files, for boxed type abstraction.
        (g_boxed_copy): copy a boxed structure
        (g_boxed_free): free a boxed structure
        (g_value_set_boxed):
        (g_value_get_boxed): standard GValue functions for boxed types
        (g_boxed_type_register_static): convenience function for easy
        introduction of new G_TYPE_BOXED derivatives.
        * gparam.[hc]: introduced g_param_type_register_static(), a short hand
        for creation of new GParamSpec derived types.
        * gtype.[hc]: many fixes, introduced ability to flag individual
        type nodes as ABSTRACT upon registration, added value_peek_pointer()
        to the value table to peek at GValue contents as a pointer for types
        that support this. fixed up GValue checks.
        * gvalue.[hc]: added g_value_fits_pointer() and g_value_get_as_pointer()
        to peek at the value contents as pointer.
        * *.[hc]: adaptions to type macro fixes and changes in the type
        registration API.
        * many const corrections over the place.
Sat Oct 21 02:49:56 2000  Tim Janik  <timj@gtk.org>
        * gtype.c (g_type_conforms_to): this function basically behaves like
        and is_a check, except that it _additionally_ features interfaces
        for instantiatable types. enforce this in the second branch as well
        (`type' conforms_to `type') even if `type' is not an interface type.
Fri Oct 20 15:31:04 2000  Tim Janik  <timj@gtk.org>
        * gvaluetypes.[hc]: added G_TYPE_POINTER implementation from jrb.
        * gtype.[hc]:
        * gobject.c:
        * gvaluetypes.c: added GTypeValueTable.value_peek_pointer and
        suitable implementations of this for G_TYPE_STRING, G_TYPE_OBJECT
        and G_TYPE_POINTER.
Mon Aug 21 04:13:37 2000  Tim Janik  <timj@gtk.org>
        * gbsearcharray.[hc]: long standing needed generic implementation
        of a binary searchable, sorted and dynamically sized array.
											
										 
											2000-10-25 20:36:35 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   GClosure *closure; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_OBJECT (object), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (object->ref_count > 0, NULL);     /* this doesn't work on finalizing objects */ | 
					
						
							|  |  |  |  |   g_return_val_if_fail (callback_func != NULL, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   closure = g_cclosure_new_swap (callback_func, object, NULL); | 
					
						
							|  |  |  |  |   g_object_watch_closure (object, closure); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return closure; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-03-14 06:47:51 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  | gsize | 
					
						
							|  |  |  |  | g_object_compat_control (gsize           what, | 
					
						
							|  |  |  |  |                          gpointer        data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   switch (what) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2006-03-07 16:15:20 +00:00
										 |  |  |  |       gpointer *pp; | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  |     case 1:     /* floating base type */ | 
					
						
							| 
									
										
										
										
											2005-12-22 17:58:21 +00:00
										 |  |  |  |       return G_TYPE_INITIALLY_UNOWNED; | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  |     case 2:     /* FIXME: remove this once GLib/Gtk+ break ABI again */ | 
					
						
							|  |  |  |  |       floating_flag_handler = (guint(*)(GObject*,gint)) data; | 
					
						
							|  |  |  |  |       return 1; | 
					
						
							| 
									
										
										
										
											2006-03-07 16:15:20 +00:00
										 |  |  |  |     case 3:     /* FIXME: remove this once GLib/Gtk+ break ABI again */ | 
					
						
							|  |  |  |  |       pp = data; | 
					
						
							|  |  |  |  |       *pp = floating_flag_handler; | 
					
						
							|  |  |  |  |       return 1; | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  |     default: | 
					
						
							|  |  |  |  |       return 0; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-17 11:54:02 +01:00
										 |  |  |  | G_DEFINE_TYPE (GInitiallyUnowned, g_initially_unowned, G_TYPE_OBJECT) | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							| 
									
										
										
										
											2005-12-22 17:58:21 +00:00
										 |  |  |  | g_initially_unowned_init (GInitiallyUnowned *object) | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   g_object_force_floating (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							| 
									
										
										
										
											2005-12-22 17:58:21 +00:00
										 |  |  |  | g_initially_unowned_class_init (GInitiallyUnownedClass *klass) | 
					
						
							| 
									
										
										
										
											2005-12-22 15:07:03 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * GWeakRef: | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * A structure containing a weak reference to a #GObject.  It can either | 
					
						
							|  |  |  |  |  * be empty (i.e. point to %NULL), or point to an object for as long as | 
					
						
							|  |  |  |  |  * at least one "strong" reference to that object exists. Before the | 
					
						
							|  |  |  |  |  * object's #GObjectClass.dispose method is called, every #GWeakRef | 
					
						
							|  |  |  |  |  * associated with becomes empty (i.e. points to %NULL). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Like #GValue, #GWeakRef can be statically allocated, stack- or | 
					
						
							|  |  |  |  |  * heap-allocated, or embedded in larger structures. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Unlike g_object_weak_ref() and g_object_add_weak_pointer(), this weak | 
					
						
							|  |  |  |  |  * reference is thread-safe: converting a weak pointer to a reference is | 
					
						
							|  |  |  |  |  * atomic with respect to invalidation of weak pointers to destroyed | 
					
						
							|  |  |  |  |  * objects. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the object's #GObjectClass.dispose method results in additional | 
					
						
							| 
									
										
										
										
											2014-02-01 11:57:13 -05:00
										 |  |  |  |  * references to the object being held, any #GWeakRefs taken | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * before it was disposed will continue to point to %NULL.  If | 
					
						
							| 
									
										
										
										
											2014-02-01 11:57:13 -05:00
										 |  |  |  |  * #GWeakRefs are taken after the object is disposed and | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * re-referenced, they will continue to point to it until its refcount | 
					
						
							|  |  |  |  |  * goes back to zero, at which point they too will be invalidated. | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_weak_ref_init: (skip) | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |  * @weak_ref: (inout): uninitialized or empty location for a weak | 
					
						
							|  |  |  |  |  *    reference | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @object: (type GObject.Object) (nullable): a #GObject or %NULL | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Initialise a non-statically-allocated #GWeakRef. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This function also calls g_weak_ref_set() with @object on the | 
					
						
							|  |  |  |  |  * freshly-initialised weak reference. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This function should always be matched with a call to | 
					
						
							|  |  |  |  |  * g_weak_ref_clear().  It is not necessary to use this function for a | 
					
						
							|  |  |  |  |  * #GWeakRef in static storage because it will already be | 
					
						
							|  |  |  |  |  * properly initialised.  Just use g_weak_ref_set() directly. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.32 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  | g_weak_ref_init (GWeakRef *weak_ref, | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |                  gpointer  object) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |   weak_ref->priv.p = NULL; | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |   g_weak_ref_set (weak_ref, object); | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_weak_ref_clear: (skip) | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |  * @weak_ref: (inout): location of a weak reference, which | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  *  may be empty | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Frees resources associated with a non-statically-allocated #GWeakRef. | 
					
						
							|  |  |  |  |  * After this call, the #GWeakRef is left in an undefined state. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * You should only call this on a #GWeakRef that previously had | 
					
						
							|  |  |  |  |  * g_weak_ref_init() called on it. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.32 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  | g_weak_ref_clear (GWeakRef *weak_ref) | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |   g_weak_ref_set (weak_ref, NULL); | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* be unkind */ | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |   weak_ref->priv.p = (void *) 0xccccccccu; | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_weak_ref_get: (skip) | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |  * @weak_ref: (inout): location of a weak reference to a #GObject | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |  * If @weak_ref is not empty, atomically acquire a strong | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * reference to the object it points to, and return that reference. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This function is needed because of the potential race between taking | 
					
						
							|  |  |  |  |  * the pointer value and g_object_ref() on it, if the object was losing | 
					
						
							|  |  |  |  |  * its last reference at the same time in a different thread. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * The caller should release the resulting reference in the usual way, | 
					
						
							|  |  |  |  |  * by using g_object_unref(). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Returns: (transfer full) (type GObject.Object): the object pointed to | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |  *     by @weak_ref, or %NULL if it was empty | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.32 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | gpointer | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  | g_weak_ref_get (GWeakRef *weak_ref) | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   gpointer object_or_null; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |   g_return_val_if_fail (weak_ref!= NULL, NULL); | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_rw_lock_reader_lock (&weak_locations_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |   object_or_null = weak_ref->priv.p; | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (object_or_null != NULL) | 
					
						
							|  |  |  |  |     g_object_ref (object_or_null); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_rw_lock_reader_unlock (&weak_locations_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return object_or_null; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_weak_ref_set: (skip) | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |  * @weak_ref: location for a weak reference | 
					
						
							| 
									
										
										
										
											2013-12-06 12:23:09 +00:00
										 |  |  |  |  * @object: (type GObject.Object) (nullable): a #GObject or %NULL | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |  * Change the object to which @weak_ref points, or set it to | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |  * %NULL. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * You must own a strong reference on @object while calling this | 
					
						
							|  |  |  |  |  * function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.32 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  | g_weak_ref_set (GWeakRef *weak_ref, | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |                 gpointer  object) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GSList **weak_locations; | 
					
						
							|  |  |  |  |   GObject *new_object; | 
					
						
							|  |  |  |  |   GObject *old_object; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |   g_return_if_fail (weak_ref != NULL); | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |   g_return_if_fail (object == NULL || G_IS_OBJECT (object)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   new_object = object; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_rw_lock_writer_lock (&weak_locations_lock); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* We use the extra level of indirection here so that if we have ever
 | 
					
						
							|  |  |  |  |    * had a weak pointer installed at any point in time on this object, | 
					
						
							|  |  |  |  |    * we can see that there is a non-NULL value associated with the | 
					
						
							|  |  |  |  |    * weak-pointer quark and know that this value will not change at any | 
					
						
							|  |  |  |  |    * point in the object's lifetime. | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * Both properties are important for reducing the amount of times we | 
					
						
							|  |  |  |  |    * need to acquire locks and for decreasing the duration of time the | 
					
						
							|  |  |  |  |    * lock is held while avoiding some rather tricky races. | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * Specifically: we can avoid having to do an extra unconditional lock | 
					
						
							|  |  |  |  |    * in g_object_unref() without worrying about some extremely tricky | 
					
						
							|  |  |  |  |    * races. | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |   old_object = weak_ref->priv.p; | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |   if (new_object != old_object) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |       weak_ref->priv.p = new_object; | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* Remove the weak ref from the old object */ | 
					
						
							|  |  |  |  |       if (old_object != NULL) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           weak_locations = g_datalist_id_get_data (&old_object->qdata, quark_weak_locations); | 
					
						
							|  |  |  |  |           /* for it to point to an object, the object must have had it added once */ | 
					
						
							|  |  |  |  |           g_assert (weak_locations != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |           *weak_locations = g_slist_remove (*weak_locations, weak_ref); | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       /* Add the weak ref to the new object */ | 
					
						
							|  |  |  |  |       if (new_object != NULL) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           weak_locations = g_datalist_id_get_data (&new_object->qdata, quark_weak_locations); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           if (weak_locations == NULL) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               weak_locations = g_new0 (GSList *, 1); | 
					
						
							|  |  |  |  |               g_datalist_id_set_data_full (&new_object->qdata, quark_weak_locations, weak_locations, g_free); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-03 10:48:50 -05:00
										 |  |  |  |           *weak_locations = g_slist_prepend (*weak_locations, weak_ref); | 
					
						
							| 
									
										
										
										
											2011-12-06 12:27:07 +00:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_rw_lock_writer_unlock (&weak_locations_lock); | 
					
						
							|  |  |  |  | } |