<MACRO>
<NAME>G_TYPE_IS_ENUM</NAME>
#define G_TYPE_IS_ENUM(type)	       (G_TYPE_FUNDAMENTAL (type) == G_TYPE_ENUM)
</MACRO>
<MACRO>
<NAME>G_ENUM_CLASS</NAME>
#define G_ENUM_CLASS(class)	       (G_TYPE_CHECK_CLASS_CAST ((class), G_TYPE_ENUM, GEnumClass))
</MACRO>
<MACRO>
<NAME>G_IS_ENUM_CLASS</NAME>
#define G_IS_ENUM_CLASS(class)	       (G_TYPE_CHECK_CLASS_TYPE ((class), G_TYPE_ENUM))
</MACRO>
<MACRO>
<NAME>G_ENUM_CLASS_TYPE</NAME>
#define G_ENUM_CLASS_TYPE(class)       (G_TYPE_FROM_CLASS (class))
</MACRO>
<MACRO>
<NAME>G_ENUM_CLASS_TYPE_NAME</NAME>
#define G_ENUM_CLASS_TYPE_NAME(class)  (g_type_name (G_ENUM_TYPE (class)))
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_FLAGS</NAME>
#define G_TYPE_IS_FLAGS(type)	       (G_TYPE_FUNDAMENTAL (type) == G_TYPE_FLAGS)
</MACRO>
<MACRO>
<NAME>G_FLAGS_CLASS</NAME>
#define G_FLAGS_CLASS(class)	       (G_TYPE_CHECK_CLASS_CAST ((class), G_TYPE_FLAGS, GFlagsClass))
</MACRO>
<MACRO>
<NAME>G_IS_FLAGS_CLASS</NAME>
#define G_IS_FLAGS_CLASS(class)        (G_TYPE_CHECK_CLASS_TYPE ((class), G_TYPE_FLAGS))
</MACRO>
<MACRO>
<NAME>G_FLAGS_CLASS_TYPE</NAME>
#define G_FLAGS_CLASS_TYPE(class)      (G_TYPE_FROM_CLASS (class))
</MACRO>
<MACRO>
<NAME>G_FLAGS_CLASS_TYPE_NAME</NAME>
#define G_FLAGS_CLASS_TYPE_NAME(class) (g_type_name (G_FLAGS_TYPE (class)))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_ENUM</NAME>
#define G_IS_VALUE_ENUM(value)         (G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_ENUM))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_FLAGS</NAME>
#define G_IS_VALUE_FLAGS(value)        (G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_FLAGS))
</MACRO>
<STRUCT>
<NAME>GEnumClass</NAME>
</STRUCT>
<STRUCT>
<NAME>GFlagsClass</NAME>
</STRUCT>
<STRUCT>
<NAME>GEnumValue</NAME>
</STRUCT>
<STRUCT>
<NAME>GFlagsValue</NAME>
</STRUCT>
<STRUCT>
<NAME>GEnumValue</NAME>
struct GEnumValue
{
  gint	 value;
  gchar *value_name;
  gchar *value_nick;
};
</STRUCT>
<STRUCT>
<NAME>GFlagsValue</NAME>
struct GFlagsValue
{
  guint	 value;
  gchar *value_name;
  gchar *value_nick;
};
</STRUCT>
<FUNCTION>
<NAME>g_enum_get_value</NAME>
<RETURNS>GEnumValue *</RETURNS>
GEnumClass	*enum_class,gint		 value
</FUNCTION>
<FUNCTION>
<NAME>g_enum_get_value_by_name</NAME>
<RETURNS>GEnumValue *</RETURNS>
GEnumClass	*enum_class,const gchar	*name
</FUNCTION>
<FUNCTION>
<NAME>g_enum_get_value_by_nick</NAME>
<RETURNS>GEnumValue *</RETURNS>
GEnumClass	*enum_class,const gchar	*nick
</FUNCTION>
<FUNCTION>
<NAME>g_flags_get_first_value</NAME>
<RETURNS>GFlagsValue *</RETURNS>
GFlagsClass	*flags_class,guint		 value
</FUNCTION>
<FUNCTION>
<NAME>g_flags_get_value_by_name</NAME>
<RETURNS>GFlagsValue *</RETURNS>
GFlagsClass	*flags_class,const gchar	*name
</FUNCTION>
<FUNCTION>
<NAME>g_flags_get_value_by_nick</NAME>
<RETURNS>GFlagsValue *</RETURNS>
GFlagsClass	*flags_class,const gchar	*nick
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_enum</NAME>
<RETURNS>void  </RETURNS>
GValue         *value,gint            v_enum
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_enum</NAME>
<RETURNS>gint  </RETURNS>
const GValue   *value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_flags</NAME>
<RETURNS>void  </RETURNS>
GValue         *value,guint           v_flags
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_flags</NAME>
<RETURNS>guint  </RETURNS>
const GValue   *value
</FUNCTION>
<FUNCTION>
<NAME>g_enum_register_static</NAME>
<RETURNS>GType 	</RETURNS>
const gchar	      *name,const GEnumValue  *const_static_values
</FUNCTION>
<FUNCTION>
<NAME>g_flags_register_static</NAME>
<RETURNS>GType 	</RETURNS>
const gchar	      *name,const GFlagsValue *const_static_values
</FUNCTION>
<FUNCTION>
<NAME>g_enum_complete_type_info</NAME>
<RETURNS>void 	</RETURNS>
GType	       g_enum_type,GTypeInfo	      *info,const GEnumValue  *const_values
</FUNCTION>
<FUNCTION>
<NAME>g_flags_complete_type_info</NAME>
<RETURNS>void 	</RETURNS>
GType	       g_flags_type,GTypeInfo	      *info,const GFlagsValue *const_values
</FUNCTION>
<UNION>
<NAME>GTypeCValue</NAME>
union GTypeCValue
{
  gint     v_int;
  glong    v_long;
  gdouble  v_double;
  gpointer v_pointer;
};
</UNION>
<MACRO>
<NAME>G_VALUE_COLLECT</NAME>
#define G_VALUE_COLLECT(value, var_args, __error)					\
G_STMT_START {										\
  GValue *_value = (value);								\
  GTypeValueTable *_vtable = g_type_value_table_peek (G_VALUE_TYPE (_value));		\
  gchar *_error_msg = NULL;								\
  guint _collect_type = _vtable->collect_type;						\
  guint _nth_value = 0;									\
                                                                                        \
  g_value_reset (_value);								\
  while (_collect_type && !_error_msg)							\
    {											\
      GTypeCValue _cvalue;								\
                                                                                        \
      memset (&_cvalue, 0, sizeof (_cvalue));						\
      switch (_collect_type)								\
	{										\
	case G_VALUE_COLLECT_INT:							\
	  _cvalue.v_int = va_arg ((var_args), gint);					\
	  break;									\
	case G_VALUE_COLLECT_LONG:							\
	  _cvalue.v_long = va_arg ((var_args), glong);					\
	  break;									\
	case G_VALUE_COLLECT_DOUBLE:							\
	  _cvalue.v_double = va_arg ((var_args), gdouble);				\
	  break;									\
	case G_VALUE_COLLECT_POINTER:							\
	  _cvalue.v_pointer = va_arg ((var_args), gpointer);				\
	  break;									\
	default:									\
	  _error_msg  = g_strdup_printf ("%s: invalid collect type (%d) used for %s",	\
					 G_STRLOC,					\
					 _collect_type,					\
					 "G_VALUE_COLLECT()");				\
	  continue;									\
	}										\
      _error_msg = _vtable->collect_value (_value,					\
					   _nth_value++,				\
					   &_collect_type,				\
					   &_cvalue);					\
    }											\
  *(__error) = _error_msg;								\
} G_STMT_END
</MACRO>
<MACRO>
<NAME>G_VALUE_LCOPY</NAME>
#define G_VALUE_LCOPY(value, var_args, __error)						\
G_STMT_START {										\
  GValue *_value = (value);								\
  GTypeValueTable *_vtable = g_type_value_table_peek (G_VALUE_TYPE (_value));		\
  gchar *_error_msg = NULL;								\
  guint _lcopy_type = _vtable->lcopy_type;						\
  guint _nth_value = 0;									\
                                                                                        \
  while (_lcopy_type && !_error_msg)							\
    {											\
      GTypeCValue _cvalue;								\
                                                                                        \
      memset (&_cvalue, 0, sizeof (_cvalue));						\
      switch (_lcopy_type)								\
	{										\
	case G_VALUE_COLLECT_INT:							\
	  _cvalue.v_int = va_arg ((var_args), gint);					\
	  break;									\
	case G_VALUE_COLLECT_LONG:							\
	  _cvalue.v_long = va_arg ((var_args), glong);					\
	  break;									\
	case G_VALUE_COLLECT_DOUBLE:							\
	  _cvalue.v_double = va_arg ((var_args), gdouble);				\
	  break;									\
	case G_VALUE_COLLECT_POINTER:							\
	  _cvalue.v_pointer = va_arg ((var_args), gpointer);				\
	  break;									\
	default:									\
	  _error_msg  = g_strdup_printf ("%s: invalid collect type (%d) used for %s",	\
					 G_STRLOC,					\
					 _lcopy_type,					\
					 "G_VALUE_LCOPY()");				\
	  continue;									\
	}										\
      _error_msg = _vtable->lcopy_value (_value,					\
					 _nth_value++,					\
					 &_lcopy_type,					\
					 &_cvalue);					\
    }											\
  *(__error) = _error_msg;								\
} G_STMT_END
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_OBJECT</NAME>
#define G_TYPE_IS_OBJECT(type)	   (G_TYPE_FUNDAMENTAL (type) == G_TYPE_OBJECT)
</MACRO>
<MACRO>
<NAME>G_OBJECT</NAME>
#define G_OBJECT(object)	   (G_TYPE_CHECK_INSTANCE_CAST ((object), G_TYPE_OBJECT, GObject))
</MACRO>
<MACRO>
<NAME>G_OBJECT_CLASS</NAME>
#define G_OBJECT_CLASS(class)	   (G_TYPE_CHECK_CLASS_CAST ((class), G_TYPE_OBJECT, GObjectClass))
</MACRO>
<MACRO>
<NAME>G_IS_OBJECT</NAME>
#define G_IS_OBJECT(object)	   (G_TYPE_CHECK_INSTANCE_TYPE ((object), G_TYPE_OBJECT))
</MACRO>
<MACRO>
<NAME>G_IS_OBJECT_CLASS</NAME>
#define G_IS_OBJECT_CLASS(class)   (G_TYPE_CHECK_CLASS_TYPE ((class), G_TYPE_OBJECT))
</MACRO>
<MACRO>
<NAME>G_OBJECT_GET_CLASS</NAME>
#define G_OBJECT_GET_CLASS(object) (G_TYPE_INSTANCE_GET_CLASS ((object), G_TYPE_OBJECT, GObjectClass))
</MACRO>
<MACRO>
<NAME>G_OBJECT_TYPE</NAME>
#define G_OBJECT_TYPE(object)	   (G_TYPE_FROM_INSTANCE (object))
</MACRO>
<MACRO>
<NAME>G_OBJECT_TYPE_NAME</NAME>
#define G_OBJECT_TYPE_NAME(object) (g_type_name (G_OBJECT_TYPE (object)))
</MACRO>
<MACRO>
<NAME>G_OBJECT_CLASS_TYPE</NAME>
#define G_OBJECT_CLASS_TYPE(class) (G_TYPE_FROM_CLASS (class))
</MACRO>
<MACRO>
<NAME>G_OBJECT_CLASS_NAME</NAME>
#define G_OBJECT_CLASS_NAME(class) (g_type_name (G_OBJECT_CLASS_TYPE (class)))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_OBJECT</NAME>
#define G_IS_VALUE_OBJECT(value)   (G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_OBJECT))
</MACRO>
<MACRO>
<NAME>G_NOTIFY_PRIORITY</NAME>
#define	G_NOTIFY_PRIORITY	   (G_PRIORITY_HIGH_IDLE + 20)
</MACRO>
<STRUCT>
<NAME>GObject</NAME>
</STRUCT>
<STRUCT>
<NAME>GObjectClass</NAME>
</STRUCT>
<STRUCT>
<NAME>GObjectConstructParam</NAME>
</STRUCT>
<USER_FUNCTION>
<NAME>GObjectGetParamFunc</NAME>
<RETURNS>void </RETURNS>
GObject      *object,
					 guint	       param_id,
					 GValue	      *value,
					 GParamSpec   *pspec,
					 const gchar  *trailer
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GObjectSetParamFunc</NAME>
<RETURNS>void </RETURNS>
GObject      *object,
					 guint	       param_id,
					 const GValue *value,
					 GParamSpec   *pspec,
					 const gchar  *trailer
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GObjectFinalizeFunc</NAME>
<RETURNS>void </RETURNS>
GObject      *object
</USER_FUNCTION>
<STRUCT>
<NAME>GObject</NAME>
struct GObject
{
  GTypeInstance g_type_instance;
  
  /*< private >*/
  guint		ref_count;
  GData	       *qdata;
};
</STRUCT>
<STRUCT>
<NAME>GObjectConstructParam</NAME>
struct GObjectConstructParam
{
  GParamSpec *pspec;
  GValue     *value;
  gchar      *trailer;
};
</STRUCT>
<FUNCTION>
<NAME>g_object_class_install_param</NAME>
<RETURNS>void 	</RETURNS>
GObjectClass   *oclass,guint	    param_id,GParamSpec	   *pspec
</FUNCTION>
<FUNCTION>
<NAME>g_object_class_find_param_spec</NAME>
<RETURNS>GParamSpec *</RETURNS>
GObjectClass   *oclass,const gchar	   *param_name
</FUNCTION>
<FUNCTION>
<NAME>g_object_new</NAME>
<RETURNS>gpointer  </RETURNS>
GType	    object_type,const gchar	   *first_param_name,...
</FUNCTION>
<FUNCTION>
<NAME>g_object_new_valist</NAME>
<RETURNS>gpointer  </RETURNS>
GType	    object_type,const gchar	   *first_param_name,va_list	    var_args
</FUNCTION>
<FUNCTION>
<NAME>g_object_set</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,const gchar	   *first_param_name,...
</FUNCTION>
<FUNCTION>
<NAME>g_object_get</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,const gchar	   *first_param_name,...
</FUNCTION>
<FUNCTION>
<NAME>g_object_set_valist</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,const gchar	   *first_param_name,va_list	    var_args
</FUNCTION>
<FUNCTION>
<NAME>g_object_get_valist</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,const gchar	   *first_param_name,va_list	    var_args
</FUNCTION>
<FUNCTION>
<NAME>g_object_set_param</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,const gchar    *param_name,const GValue   *value
</FUNCTION>
<FUNCTION>
<NAME>g_object_get_param</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,const gchar    *param_name,GValue	   *value
</FUNCTION>
<FUNCTION>
<NAME>g_object_queue_param_changed</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,const gchar	   *param_name
</FUNCTION>
<FUNCTION>
<NAME>g_object_ref</NAME>
<RETURNS>GObject *</RETURNS>
GObject	   *object
</FUNCTION>
<FUNCTION>
<NAME>g_object_unref</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object
</FUNCTION>
<FUNCTION>
<NAME>g_object_get_qdata</NAME>
<RETURNS>gpointer  </RETURNS>
GObject	   *object,GQuark	    quark
</FUNCTION>
<FUNCTION>
<NAME>g_object_set_qdata</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,GQuark	    quark,gpointer	    data
</FUNCTION>
<FUNCTION>
<NAME>g_object_set_qdata_full</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,GQuark	    quark,gpointer	    data,GDestroyNotify  destroy
</FUNCTION>
<FUNCTION>
<NAME>g_object_steal_qdata</NAME>
<RETURNS>gpointer  </RETURNS>
GObject	   *object,GQuark	    quark
</FUNCTION>
<FUNCTION>
<NAME>g_object_watch_closure</NAME>
<RETURNS>void 	</RETURNS>
GObject	   *object,GClosure	   *closure
</FUNCTION>
<FUNCTION>
<NAME>g_cclosure_new_object</NAME>
<RETURNS>GClosure *</RETURNS>
GCallback	    callback_func,gpointer        object
</FUNCTION>
<FUNCTION>
<NAME>g_cclosure_new_object_swap</NAME>
<RETURNS>GClosure *</RETURNS>
GCallback	    callback_func,gpointer        object
</FUNCTION>
<FUNCTION>
<NAME>g_closure_new_object</NAME>
<RETURNS>GClosure *</RETURNS>
guint           sizeof_closure,GObject	   *object
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_object</NAME>
<RETURNS>void  </RETURNS>
GValue         *value,GObject        *v_object
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_object</NAME>
<RETURNS>GObject *</RETURNS>
const GValue   *value
</FUNCTION>
<FUNCTION>
<NAME>g_value_dup_object</NAME>
<RETURNS>GObject *</RETURNS>
const GValue   *value
</FUNCTION>
<MACRO>
<NAME>G_WARN_INVALID_PARAM_ID</NAME>
#define G_WARN_INVALID_PARAM_ID(object, param_id, pspec) \
G_STMT_START { \
  GObject *_object = (GObject*) (object); \
  GParamSpec *_pspec = (GParamSpec*) (pspec); \
  guint _param_id = (param_id); \
  g_warning ("%s: invalid parameter id %u for \"%s\" of type `%s' in `%s'", \
	     G_STRLOC, \
	     _param_id, \
	     _pspec->name, \
	     g_type_name (G_PARAM_SPEC_TYPE (_pspec)), \
	     BSE_OBJECT_TYPE_NAME (_object)); \
} G_STMT_END
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_PARAM</NAME>
#define G_TYPE_IS_PARAM(type)		(G_TYPE_FUNDAMENTAL (type) == G_TYPE_PARAM)
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_TYPE</NAME>
#define G_PARAM_SPEC_TYPE(pspec)	(G_TYPE_FROM_INSTANCE (pspec))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_TYPE_NAME</NAME>
#define G_PARAM_SPEC_TYPE_NAME(pspec)	(g_type_name (G_PARAM_SPEC_TYPE (pspec)))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC</NAME>
#define G_PARAM_SPEC(pspec)		(G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM, GParamSpec))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC</NAME>
#define G_IS_PARAM_SPEC(pspec)		(G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_GET_CLASS</NAME>
#define G_PARAM_SPEC_GET_CLASS(pspec)	(G_TYPE_INSTANCE_GET_CLASS ((pspec), G_TYPE_PARAM, GParamSpecClass))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_VALUE</NAME>
#define	G_IS_PARAM_VALUE(pspec, value)	(g_type_is_a (G_VALUE_TYPE (value), G_PARAM_SPEC_VALUE_TYPE (pspec))) /* FIXME */
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_VALUE_TYPE</NAME>
#define	G_PARAM_SPEC_VALUE_TYPE(pspec)	(G_PARAM_SPEC_GET_CLASS (pspec)->value_type)
</MACRO>
<ENUM>
<NAME>GParamFlags</NAME>
typedef enum
{
  G_PARAM_READABLE            = 1 << 0,
  G_PARAM_WRITABLE            = 1 << 1,
  G_PARAM_MASK                = 0x000f,
  /* bits in the range 0xfff0 are reserved for 3rd party usage */
  G_PARAM_USER_MASK           = 0xfff0
} GParamFlags;
</ENUM>
<STRUCT>
<NAME>GParamSpecClass</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpec</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpec</NAME>
struct GParamSpec
{
  GTypeInstance  g_instance;

  gchar         *name;
  gchar         *nick;
  gchar         *blurb;
  GParamFlags    flags;

  /*< private >*/
  GType		 owner_type;
  GData		*qdata;
  guint          ref_count;
};
</STRUCT>
<FUNCTION>
<NAME>g_param_spec_ref</NAME>
<RETURNS>GParamSpec *</RETURNS>
GParamSpec    *pspec
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_unref</NAME>
<RETURNS>void 	</RETURNS>
GParamSpec    *pspec
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_get_qdata</NAME>
<RETURNS>gpointer  </RETURNS>
GParamSpec    *pspec,GQuark         quark
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_set_qdata</NAME>
<RETURNS>void  </RETURNS>
GParamSpec    *pspec,GQuark         quark,gpointer       data
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_set_qdata_full</NAME>
<RETURNS>void  </RETURNS>
GParamSpec    *pspec,GQuark         quark,gpointer       data,GDestroyNotify destroy
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_steal_qdata</NAME>
<RETURNS>gpointer  </RETURNS>
GParamSpec    *pspec,GQuark         quark
</FUNCTION>
<FUNCTION>
<NAME>g_param_value_set_default</NAME>
<RETURNS>void 	</RETURNS>
GParamSpec    *pspec,GValue	       *value
</FUNCTION>
<FUNCTION>
<NAME>g_param_value_defaults</NAME>
<RETURNS>gboolean 	</RETURNS>
GParamSpec    *pspec,GValue	       *value
</FUNCTION>
<FUNCTION>
<NAME>g_param_value_validate</NAME>
<RETURNS>gboolean 	</RETURNS>
GParamSpec    *pspec,GValue	       *value
</FUNCTION>
<FUNCTION>
<NAME>g_param_values_cmp</NAME>
<RETURNS>gint 	</RETURNS>
GParamSpec    *pspec,const GValue  *value1,const GValue  *value2
</FUNCTION>
<STRUCT>
<NAME>GParamSpecTypeInfo</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecTypeInfo</NAME>
struct GParamSpecTypeInfo
{
  /* type system portion */
  guint16         instance_size;                               /* obligatory */
  guint16         n_preallocs;                                 /* optional */
  void		(*instance_init)	(GParamSpec   *pspec); /* optional */

  /* class portion */
  GType           value_type;				       /* obligatory */
  void          (*finalize)             (GParamSpec   *pspec); /* optional */
  void          (*value_set_default)    (GParamSpec   *pspec,  /* recommended */
					 GValue       *value);
  gboolean      (*value_validate)       (GParamSpec   *pspec,  /* optional */
					 GValue       *value);
  gint          (*values_cmp)           (GParamSpec   *pspec,  /* recommended */
					 const GValue *value1,
					 const GValue *value2);
};
</STRUCT>
<FUNCTION>
<NAME>g_param_type_register_static</NAME>
<RETURNS>GType 	</RETURNS>
const gchar		  *name,const GParamSpecTypeInfo *pspec_info
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_internal</NAME>
<RETURNS>gpointer 	</RETURNS>
GType	        param_type,const gchar   *name,const gchar   *nick,const gchar   *blurb,GParamFlags    flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_hash_table_new</NAME>
<RETURNS>GHashTable *</RETURNS>
void
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_hash_table_insert</NAME>
<RETURNS>void 	</RETURNS>
GHashTable    *hash_table,GParamSpec    *pspec,GType		owner_type
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_hash_table_remove</NAME>
<RETURNS>void 	</RETURNS>
GHashTable    *hash_table,GParamSpec    *pspec
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_hash_table_lookup</NAME>
<RETURNS>GParamSpec *</RETURNS>
GHashTable    *hash_table,const gchar   *param_name,GType		owner_type,gboolean       try_ancestors,const gchar  **trailer
</FUNCTION>
<MACRO>
<NAME>G_IS_PARAM_SPEC_CHAR</NAME>
#define G_IS_PARAM_SPEC_CHAR(pspec)     (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_CHAR))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_CHAR</NAME>
#define G_PARAM_SPEC_CHAR(pspec)        (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_CHAR, GParamSpecChar))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_UCHAR</NAME>
#define G_IS_PARAM_SPEC_UCHAR(pspec)    (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_UCHAR))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_UCHAR</NAME>
#define G_PARAM_SPEC_UCHAR(pspec)       (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_UCHAR, GParamSpecUChar))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_BOOLEAN</NAME>
#define G_IS_PARAM_SPEC_BOOLEAN(pspec)  (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_BOOLEAN))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_BOOLEAN</NAME>
#define G_PARAM_SPEC_BOOLEAN(pspec)     (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_BOOLEAN, GParamSpecBoolean))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_INT</NAME>
#define G_IS_PARAM_SPEC_INT(pspec)      (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_INT))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_INT</NAME>
#define G_PARAM_SPEC_INT(pspec)         (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_INT, GParamSpecInt))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_UINT</NAME>
#define G_IS_PARAM_SPEC_UINT(pspec)     (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_UINT))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_UINT</NAME>
#define G_PARAM_SPEC_UINT(pspec)        (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_UINT, GParamSpecUInt))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_LONG</NAME>
#define G_IS_PARAM_SPEC_LONG(pspec)     (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_LONG))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_LONG</NAME>
#define G_PARAM_SPEC_LONG(pspec)        (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_LONG, GParamSpecLong))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_ULONG</NAME>
#define G_IS_PARAM_SPEC_ULONG(pspec)    (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_ULONG))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_ULONG</NAME>
#define G_PARAM_SPEC_ULONG(pspec)       (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_ULONG, GParamSpecULong))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_ENUM</NAME>
#define G_IS_PARAM_SPEC_ENUM(pspec)     (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_ENUM))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_ENUM</NAME>
#define G_PARAM_SPEC_ENUM(pspec)        (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_ENUM, GParamSpecEnum))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_FLAGS</NAME>
#define G_IS_PARAM_SPEC_FLAGS(pspec)    (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_FLAGS))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_FLAGS</NAME>
#define G_PARAM_SPEC_FLAGS(pspec)       (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_FLAGS, GParamSpecFlags))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_FLOAT</NAME>
#define G_IS_PARAM_SPEC_FLOAT(pspec)    (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_FLOAT))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_FLOAT</NAME>
#define G_PARAM_SPEC_FLOAT(pspec)       (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_FLOAT, GParamSpecFloat))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_DOUBLE</NAME>
#define G_IS_PARAM_SPEC_DOUBLE(pspec)   (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_DOUBLE))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_DOUBLE</NAME>
#define G_PARAM_SPEC_DOUBLE(pspec)      (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_DOUBLE, GParamSpecDouble))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_STRING</NAME>
#define G_IS_PARAM_SPEC_STRING(pspec)   (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_STRING))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_STRING</NAME>
#define G_PARAM_SPEC_STRING(pspec)      (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_STRING, GParamSpecString))
</MACRO>
<MACRO>
<NAME>G_IS_PARAM_SPEC_OBJECT</NAME>
#define G_IS_PARAM_SPEC_OBJECT(pspec)   (G_TYPE_CHECK_INSTANCE_TYPE ((pspec), G_TYPE_PARAM_OBJECT))
</MACRO>
<MACRO>
<NAME>G_PARAM_SPEC_OBJECT</NAME>
#define G_PARAM_SPEC_OBJECT(pspec)      (G_TYPE_CHECK_INSTANCE_CAST ((pspec), G_TYPE_PARAM_OBJECT, GParamSpecObject))
</MACRO>
<STRUCT>
<NAME>GParamSpecChar</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecUChar</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecBoolean</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecInt</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecUInt</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecLong</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecULong</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecEnum</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecFlags</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecFloat</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecDouble</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecString</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecObject</NAME>
</STRUCT>
<STRUCT>
<NAME>GParamSpecChar</NAME>
struct GParamSpecChar
{
  GParamSpec    parent_instance;
  
  gint8         minimum;
  gint8         maximum;
  gint8         default_value;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecUChar</NAME>
struct GParamSpecUChar
{
  GParamSpec    parent_instance;
  
  guint8        minimum;
  guint8        maximum;
  guint8        default_value;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecBoolean</NAME>
struct GParamSpecBoolean
{
  GParamSpec    parent_instance;
  
  gboolean      default_value;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecInt</NAME>
struct GParamSpecInt
{
  GParamSpec    parent_instance;
  
  gint          minimum;
  gint          maximum;
  gint          default_value;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecUInt</NAME>
struct GParamSpecUInt
{
  GParamSpec    parent_instance;
  
  guint         minimum;
  guint         maximum;
  guint         default_value;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecLong</NAME>
struct GParamSpecLong
{
  GParamSpec    parent_instance;
  
  glong         minimum;
  glong         maximum;
  glong         default_value;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecULong</NAME>
struct GParamSpecULong
{
  GParamSpec    parent_instance;
  
  gulong        minimum;
  gulong        maximum;
  gulong        default_value;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecEnum</NAME>
struct GParamSpecEnum
{
  GParamSpec    parent_instance;
  
  GEnumClass   *enum_class;
  glong         default_value;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecFlags</NAME>
struct GParamSpecFlags
{
  GParamSpec    parent_instance;
  
  GFlagsClass  *flags_class;
  gulong        default_value;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecFloat</NAME>
struct GParamSpecFloat
{
  GParamSpec    parent_instance;
  
  gfloat        minimum;
  gfloat        maximum;
  gfloat        default_value;
  gfloat        epsilon;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecDouble</NAME>
struct GParamSpecDouble
{
  GParamSpec    parent_instance;
  
  gdouble       minimum;
  gdouble       maximum;
  gdouble       default_value;
  gdouble       epsilon;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecString</NAME>
struct GParamSpecString
{
  GParamSpec    parent_instance;
  
  gchar        *default_value;
  gchar        *cset_first;
  gchar        *cset_nth;
  gchar         substitutor;
  guint         null_fold_if_empty : 1;
  guint         ensure_non_null : 1;
};
</STRUCT>
<STRUCT>
<NAME>GParamSpecObject</NAME>
struct GParamSpecObject
{
  GParamSpec    parent_instance;
  
  GType         object_type;
};
</STRUCT>
<FUNCTION>
<NAME>g_param_spec_char</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,gint8           minimum,gint8           maximum,gint8           default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_uchar</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,guint8          minimum,guint8          maximum,guint8          default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_boolean</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,gboolean        default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_int</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,gint            minimum,gint            maximum,gint            default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_uint</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,guint           minimum,guint           maximum,guint           default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_long</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,glong           minimum,glong           maximum,glong           default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_ulong</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,gulong          minimum,gulong          maximum,gulong          default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_enum</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,GType           enum_type,gint            default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_flags</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,GType           flags_type,guint           default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_float</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,gfloat          minimum,gfloat          maximum,gfloat          default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_double</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,gdouble         minimum,gdouble         maximum,gdouble         default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_string</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,const gchar    *default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_string_c</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,const gchar    *default_value,GParamFlags     flags
</FUNCTION>
<FUNCTION>
<NAME>g_param_spec_object</NAME>
<RETURNS>GParamSpec *</RETURNS>
const gchar    *name,const gchar    *nick,const gchar    *blurb,GType           object_type,GParamFlags     flags
</FUNCTION>
<VARIABLE>
<NAME>g_log_domain_gobject</NAME>
extern const char *g_log_domain_gobject;
</VARIABLE>
<MACRO>
<NAME>G_TYPE_FUNDAMENTAL</NAME>
#define G_TYPE_FUNDAMENTAL(type)                ((type) & 0xff)
</MACRO>
<MACRO>
<NAME>G_TYPE_FUNDAMENTAL_MAX</NAME>
#define	G_TYPE_FUNDAMENTAL_MAX			(0xff)
</MACRO>
<MACRO>
<NAME>G_TYPE_DERIVE_ID</NAME>
#define G_TYPE_DERIVE_ID(ptype, branch_seqno)   (G_TYPE_FUNDAMENTAL (ptype) | ((branch_seqno) << 8))
</MACRO>
<MACRO>
<NAME>G_TYPE_BRANCH_SEQNO</NAME>
#define G_TYPE_BRANCH_SEQNO(type)               ((type) >> 8)
</MACRO>
<MACRO>
<NAME>G_TYPE_FUNDAMENTAL_LAST</NAME>
#define G_TYPE_FUNDAMENTAL_LAST                 ((GType) g_type_fundamental_last ())
</MACRO>
<ENUM>
<NAME>GTypeFundamentals</NAME>
typedef enum    /*< skip >*/
{
  /* standard types, introduced by g_type_init() */
  G_TYPE_INVALID,
  G_TYPE_NONE,
  G_TYPE_INTERFACE,

  /* GLib type ids */
  G_TYPE_CHAR,
  G_TYPE_UCHAR,
  G_TYPE_BOOLEAN,
  G_TYPE_INT,
  G_TYPE_UINT,
  G_TYPE_LONG,
  G_TYPE_ULONG,
  G_TYPE_ENUM,
  G_TYPE_FLAGS,
  G_TYPE_FLOAT,
  G_TYPE_DOUBLE,
  G_TYPE_STRING,
  G_TYPE_PARAM,
  G_TYPE_BOXED,
  G_TYPE_POINTER,
  G_TYPE_OBJECT,

  /* the following reserved ids should vanish soon */
  G_TYPE_GTK_SIGNAL,

  /* reserved fundamental type ids,
   * mail gtk-devel-list@redhat.com for reservations
   */
  G_TYPE_BSE_PROCEDURE,
  G_TYPE_BSE_TIME,
  G_TYPE_BSE_NOTE,
  G_TYPE_BSE_DOTS,
  G_TYPE_GLE_GOBJECT,

  G_TYPE_LAST_RESERVED_FUNDAMENTAL,

  /* derived type ids */
  /* FIXME: G_TYPE_PARAM_INTERFACE */
  G_TYPE_PARAM_CHAR             = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 1),
  G_TYPE_PARAM_UCHAR            = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 2),
  G_TYPE_PARAM_BOOLEAN          = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 3),
  G_TYPE_PARAM_INT              = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 4),
  G_TYPE_PARAM_UINT             = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 5),
  G_TYPE_PARAM_LONG             = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 6),
  G_TYPE_PARAM_ULONG            = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 7),
  G_TYPE_PARAM_ENUM             = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 8),
  G_TYPE_PARAM_FLAGS            = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 9),
  G_TYPE_PARAM_FLOAT            = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 10),
  G_TYPE_PARAM_DOUBLE           = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 11),
  G_TYPE_PARAM_STRING           = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 12),
  /* FIXME: G_TYPE_PARAM_PARAM */
  G_TYPE_PARAM_OBJECT           = G_TYPE_DERIVE_ID (G_TYPE_PARAM, 13)
} GTypeFundamentals;
</ENUM>
<MACRO>
<NAME>G_TYPE_IS_FUNDAMENTAL</NAME>
#define G_TYPE_IS_FUNDAMENTAL(type)             (G_TYPE_BRANCH_SEQNO (type) == 0)
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_INTERFACE</NAME>
#define G_TYPE_IS_INTERFACE(type)               (G_TYPE_FUNDAMENTAL (type) == G_TYPE_INTERFACE)
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_CLASSED</NAME>
#define G_TYPE_IS_CLASSED(type)                 (g_type_check_flags ((type), G_TYPE_FLAG_CLASSED))
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_INSTANTIATABLE</NAME>
#define G_TYPE_IS_INSTANTIATABLE(type)          (g_type_check_flags ((type), G_TYPE_FLAG_INSTANTIATABLE))
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_DERIVABLE</NAME>
#define G_TYPE_IS_DERIVABLE(type)               (g_type_check_flags ((type), G_TYPE_FLAG_DERIVABLE))
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_DEEP_DERIVABLE</NAME>
#define G_TYPE_IS_DEEP_DERIVABLE(type)          (g_type_check_flags ((type), G_TYPE_FLAG_DEEP_DERIVABLE))
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_ABSTRACT</NAME>
#define G_TYPE_IS_ABSTRACT(type)                (g_type_check_flags ((type), G_TYPE_FLAG_ABSTRACT))
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_PARAM</NAME>
#define G_TYPE_IS_PARAM(type)                   (G_TYPE_FUNDAMENTAL (type) == G_TYPE_PARAM)
</MACRO>
<MACRO>
<NAME>G_TYPE_IS_VALUE_TYPE</NAME>
#define G_TYPE_IS_VALUE_TYPE(type)              (g_type_value_table_peek (type) != NULL)
</MACRO>
<TYPEDEF>
<NAME>GType</NAME>
typedef guint32                         GType;
</TYPEDEF>
<STRUCT>
<NAME>GValue</NAME>
</STRUCT>
<STRUCT>
<NAME>GTypePlugin</NAME>
</STRUCT>
<STRUCT>
<NAME>GTypeClass</NAME>
</STRUCT>
<STRUCT>
<NAME>GTypeInterface</NAME>
</STRUCT>
<STRUCT>
<NAME>GTypeInstance</NAME>
</STRUCT>
<STRUCT>
<NAME>GTypeInfo</NAME>
</STRUCT>
<STRUCT>
<NAME>GTypeFundamentalInfo</NAME>
</STRUCT>
<STRUCT>
<NAME>GInterfaceInfo</NAME>
</STRUCT>
<STRUCT>
<NAME>GTypeValueTable</NAME>
</STRUCT>
<STRUCT>
<NAME>GTypeInstance</NAME>
struct GTypeInstance
{
  /*< private >*/
  GTypeClass *g_class;
};
</STRUCT>
<STRUCT>
<NAME>GTypeInterface</NAME>
struct GTypeInterface
{
  /*< private >*/
  GType g_type;         /* iface type */
  GType g_instance_type;
};
</STRUCT>
<MACRO>
<NAME>G_TYPE_CHECK_INSTANCE</NAME>
#define G_TYPE_CHECK_INSTANCE(instance)				(_G_TYPE_CHI ((GTypeInstance*) (instance)))
</MACRO>
<MACRO>
<NAME>G_TYPE_CHECK_INSTANCE_CAST</NAME>
#define G_TYPE_CHECK_INSTANCE_CAST(instance, g_type, c_type)    (_G_TYPE_CIC ((instance), (g_type), c_type))
</MACRO>
<MACRO>
<NAME>G_TYPE_CHECK_INSTANCE_TYPE</NAME>
#define G_TYPE_CHECK_INSTANCE_TYPE(instance, g_type)            (_G_TYPE_CIT ((instance), (g_type)))
</MACRO>
<MACRO>
<NAME>G_TYPE_INSTANCE_GET_CLASS</NAME>
#define G_TYPE_INSTANCE_GET_CLASS(instance, g_type, c_type)     (_G_TYPE_IGC ((instance), (g_type), c_type))
</MACRO>
<MACRO>
<NAME>G_TYPE_INSTANCE_GET_INTERFACE</NAME>
#define G_TYPE_INSTANCE_GET_INTERFACE(instance, g_type, c_type) (_G_TYPE_IGI ((instance), (g_type), c_type))
</MACRO>
<MACRO>
<NAME>G_TYPE_CHECK_CLASS_CAST</NAME>
#define G_TYPE_CHECK_CLASS_CAST(g_class, g_type, c_type)        (_G_TYPE_CCC ((g_class), (g_type), c_type))
</MACRO>
<MACRO>
<NAME>G_TYPE_CHECK_CLASS_TYPE</NAME>
#define G_TYPE_CHECK_CLASS_TYPE(g_class, g_type)                (_G_TYPE_CCT ((g_class), (g_type)))
</MACRO>
<MACRO>
<NAME>G_TYPE_CHECK_VALUE</NAME>
#define G_TYPE_CHECK_VALUE(value)				(_G_TYPE_CHV ((value)))
</MACRO>
<MACRO>
<NAME>G_TYPE_CHECK_VALUE_TYPE</NAME>
#define G_TYPE_CHECK_VALUE_TYPE(value, g_type)			(_G_TYPE_CVT ((value), (g_type)))
</MACRO>
<MACRO>
<NAME>G_TYPE_FROM_INSTANCE</NAME>
#define G_TYPE_FROM_INSTANCE(instance)                          (G_TYPE_FROM_CLASS (((GTypeInstance*) (instance))->g_class))
</MACRO>
<MACRO>
<NAME>G_TYPE_FROM_CLASS</NAME>
#define G_TYPE_FROM_CLASS(g_class)                              (((GTypeClass*) (g_class))->g_type)
</MACRO>
<MACRO>
<NAME>G_TYPE_FROM_INTERFACE</NAME>
#define G_TYPE_FROM_INTERFACE(g_iface)                          (((GTypeInterface*) (g_iface))->g_type)
</MACRO>
<FUNCTION>
<NAME>g_type_init</NAME>
<RETURNS>void  </RETURNS>
void
</FUNCTION>
<FUNCTION>
<NAME>g_type_name</NAME>
<RETURNS>gchar *</RETURNS>
GType                   type
</FUNCTION>
<FUNCTION>
<NAME>g_type_qname</NAME>
<RETURNS>GQuark  </RETURNS>
GType                   type
</FUNCTION>
<FUNCTION>
<NAME>g_type_from_name</NAME>
<RETURNS>GType  </RETURNS>
const gchar            *name
</FUNCTION>
<FUNCTION>
<NAME>g_type_parent</NAME>
<RETURNS>GType  </RETURNS>
GType                   type
</FUNCTION>
<FUNCTION>
<NAME>g_type_next_base</NAME>
<RETURNS>GType  </RETURNS>
GType                   type,GType                   base_type
</FUNCTION>
<FUNCTION>
<NAME>g_type_is_a</NAME>
<RETURNS>gboolean  </RETURNS>
GType                   type,GType                   is_a_type
</FUNCTION>
<FUNCTION>
<NAME>g_type_conforms_to</NAME>
<RETURNS>gboolean  </RETURNS>
GType                   type,GType                   iface_type
</FUNCTION>
<FUNCTION>
<NAME>g_type_fundamental_branch_last</NAME>
<RETURNS>guint  </RETURNS>
GType                   type
</FUNCTION>
<FUNCTION>
<NAME>g_type_class_ref</NAME>
<RETURNS>gpointer  </RETURNS>
GType                   type
</FUNCTION>
<FUNCTION>
<NAME>g_type_class_peek</NAME>
<RETURNS>gpointer  </RETURNS>
GType                   type
</FUNCTION>
<FUNCTION>
<NAME>g_type_class_unref</NAME>
<RETURNS>void  </RETURNS>
gpointer                g_class
</FUNCTION>
<FUNCTION>
<NAME>g_type_class_peek_parent</NAME>
<RETURNS>gpointer  </RETURNS>
gpointer                g_class
</FUNCTION>
<FUNCTION>
<NAME>g_type_interface_peek</NAME>
<RETURNS>gpointer  </RETURNS>
gpointer                instance_class,GType                   iface_type
</FUNCTION>
<FUNCTION>
<NAME>g_type_children</NAME>
<RETURNS>GType *</RETURNS>
GType                   type,guint                  *n_children
</FUNCTION>
<FUNCTION>
<NAME>g_type_interfaces</NAME>
<RETURNS>GType *</RETURNS>
GType                   type,guint                  *n_interfaces
</FUNCTION>
<FUNCTION>
<NAME>g_type_set_qdata</NAME>
<RETURNS>void  </RETURNS>
GType                   type,GQuark                  quark,gpointer                data
</FUNCTION>
<FUNCTION>
<NAME>g_type_get_qdata</NAME>
<RETURNS>gpointer  </RETURNS>
GType                   type,GQuark                  quark
</FUNCTION>
<USER_FUNCTION>
<NAME>GBaseInitFunc</NAME>
<RETURNS>void </RETURNS>
gpointer         g_class
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GBaseFinalizeFunc</NAME>
<RETURNS>void </RETURNS>
gpointer         g_class
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GClassInitFunc</NAME>
<RETURNS>void </RETURNS>
gpointer         g_class,
					      gpointer         class_data
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GClassFinalizeFunc</NAME>
<RETURNS>void </RETURNS>
gpointer         g_class,
					      gpointer         class_data
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GInstanceInitFunc</NAME>
<RETURNS>void </RETURNS>
GTypeInstance   *instance,
					      gpointer         g_class
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GInterfaceInitFunc</NAME>
<RETURNS>void </RETURNS>
gpointer         g_iface,
					      gpointer         iface_data
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GInterfaceFinalizeFunc</NAME>
<RETURNS>void </RETURNS>
gpointer         g_iface,
					      gpointer         iface_data
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GTypeClassCacheFunc</NAME>
<RETURNS>gboolean </RETURNS>
gpointer	       cache_data,
					      GTypeClass      *g_class
</USER_FUNCTION>
<ENUM>
<NAME>GTypeFundamentalFlags</NAME>
typedef enum    /*< skip >*/
{
  G_TYPE_FLAG_CLASSED           = (1 << 0),
  G_TYPE_FLAG_INSTANTIATABLE    = (1 << 1),
  G_TYPE_FLAG_DERIVABLE         = (1 << 2),
  G_TYPE_FLAG_DEEP_DERIVABLE    = (1 << 3)
} GTypeFundamentalFlags;
</ENUM>
<ENUM>
<NAME>GTypeFlags</NAME>
typedef enum    /*< skip >*/
{
  G_TYPE_FLAG_ABSTRACT          = (1 << 4)
} GTypeFlags;
</ENUM>
<STRUCT>
<NAME>GTypeInfo</NAME>
struct GTypeInfo
{
  /* interface types, classed types, instantiated types */
  guint16                class_size;

  GBaseInitFunc          base_init;
  GBaseFinalizeFunc      base_finalize;

  /* classed types, instantiated types */
  GClassInitFunc         class_init;
  GClassFinalizeFunc     class_finalize;
  gconstpointer          class_data;

  /* instantiated types */
  guint16                instance_size;
  guint16                n_preallocs;
  GInstanceInitFunc      instance_init;

  /* value handling */
  const GTypeValueTable	*value_table;
};
</STRUCT>
<STRUCT>
<NAME>GTypeFundamentalInfo</NAME>
struct GTypeFundamentalInfo
{
  GTypeFundamentalFlags  type_flags;
};
</STRUCT>
<STRUCT>
<NAME>GInterfaceInfo</NAME>
struct GInterfaceInfo
{
  GInterfaceInitFunc     interface_init;
  GInterfaceFinalizeFunc interface_finalize;
  gpointer               interface_data;
};
</STRUCT>
<STRUCT>
<NAME>GTypeValueTable</NAME>
struct GTypeValueTable
{
  void     (*value_init)         (GValue       *value);
  void     (*value_free)         (GValue       *value);
  void     (*value_copy)         (const GValue *src_value,
				  GValue       *dest_value);
  /* varargs functionality (optional) */
  gpointer (*value_peek_pointer) (const GValue *value);
  guint      collect_type;
  gchar*   (*collect_value)      (GValue       *value,
				  guint         nth_value,
				  GType        *collect_type,
				  GTypeCValue  *collect_value);
  guint      lcopy_type;
  gchar*   (*lcopy_value)        (const GValue *value,
				  guint         nth_value,
				  GType        *collect_type,
				  GTypeCValue  *collect_value);
};
</STRUCT>
<FUNCTION>
<NAME>g_type_register_static</NAME>
<RETURNS>GType  </RETURNS>
GType                       parent_type,const gchar                *type_name,const GTypeInfo            *info,GTypeFlags			flags
</FUNCTION>
<FUNCTION>
<NAME>g_type_register_dynamic</NAME>
<RETURNS>GType  </RETURNS>
GType                       parent_type,const gchar                *type_name,GTypePlugin                *plugin,GTypeFlags			flags
</FUNCTION>
<FUNCTION>
<NAME>g_type_register_fundamental</NAME>
<RETURNS>GType  </RETURNS>
GType                       type_id,const gchar                *type_name,const GTypeInfo            *info,const GTypeFundamentalInfo *finfo,GTypeFlags			flags
</FUNCTION>
<FUNCTION>
<NAME>g_type_add_interface_static</NAME>
<RETURNS>void  </RETURNS>
GType                       instance_type,GType                       interface_type,const GInterfaceInfo       *info
</FUNCTION>
<FUNCTION>
<NAME>g_type_add_interface_dynamic</NAME>
<RETURNS>void  </RETURNS>
GType                       instance_type,GType                       interface_type,GTypePlugin                *plugin
</FUNCTION>
<FUNCTION>
<NAME>g_type_get_plugin</NAME>
<RETURNS>GTypePlugin *</RETURNS>
GType		     type
</FUNCTION>
<FUNCTION>
<NAME>g_type_interface_get_plugin</NAME>
<RETURNS>GTypePlugin *</RETURNS>
GType		     instance_type,GType               implementation_type
</FUNCTION>
<FUNCTION>
<NAME>g_type_fundamental_last</NAME>
<RETURNS>GType 	</RETURNS>
void
</FUNCTION>
<FUNCTION>
<NAME>g_type_check_flags</NAME>
<RETURNS>gboolean  </RETURNS>
GType               type,guint               flags
</FUNCTION>
<FUNCTION>
<NAME>g_type_create_instance</NAME>
<RETURNS>GTypeInstance *</RETURNS>
GType               type
</FUNCTION>
<FUNCTION>
<NAME>g_type_free_instance</NAME>
<RETURNS>void  </RETURNS>
GTypeInstance      *instance
</FUNCTION>
<FUNCTION>
<NAME>g_type_add_class_cache_func</NAME>
<RETURNS>void 	</RETURNS>
gpointer	     cache_data,GTypeClassCacheFunc cache_func
</FUNCTION>
<FUNCTION>
<NAME>g_type_remove_class_cache_func</NAME>
<RETURNS>void 	</RETURNS>
gpointer	     cache_data,GTypeClassCacheFunc cache_func
</FUNCTION>
<FUNCTION>
<NAME>g_type_class_unref_uncached</NAME>
<RETURNS>void  </RETURNS>
gpointer            g_class
</FUNCTION>
<FUNCTION>
<NAME>g_type_check_class_cast</NAME>
<RETURNS>GTypeClass *</RETURNS>
GTypeClass         *g_class,GType               is_a_type
</FUNCTION>
<FUNCTION>
<NAME>g_type_class_is_a</NAME>
<RETURNS>gboolean  </RETURNS>
GTypeClass         *g_class,GType               is_a_type
</FUNCTION>
<FUNCTION>
<NAME>g_type_check_instance_cast</NAME>
<RETURNS>GTypeInstance *</RETURNS>
GTypeInstance      *instance,GType               iface_type
</FUNCTION>
<FUNCTION>
<NAME>g_type_instance_conforms_to</NAME>
<RETURNS>gboolean  </RETURNS>
GTypeInstance      *instance,GType               iface_type
</FUNCTION>
<FUNCTION>
<NAME>g_type_check_value</NAME>
<RETURNS>gboolean 	</RETURNS>
GValue		    *value
</FUNCTION>
<FUNCTION>
<NAME>g_type_value_conforms_to</NAME>
<RETURNS>gboolean 	</RETURNS>
GValue		    *value,GType		     type
</FUNCTION>
<FUNCTION>
<NAME>g_type_check_instance</NAME>
<RETURNS>gboolean 	</RETURNS>
GTypeInstance      *instance
</FUNCTION>
<FUNCTION>
<NAME>g_type_value_table_peek</NAME>
<RETURNS>GTypeValueTable *</RETURNS>
GType		     type
</FUNCTION>
<MACRO>
<NAME>G_TYPE_IS_VALUE</NAME>
#define	G_TYPE_IS_VALUE(type)		(g_type_value_table_peek (type) != NULL)
</MACRO>
<MACRO>
<NAME>G_IS_VALUE</NAME>
#define	G_IS_VALUE(value)		(G_TYPE_CHECK_VALUE (value))
</MACRO>
<MACRO>
<NAME>G_VALUE_HOLDS</NAME>
#define	G_VALUE_HOLDS(value, g_type)	(G_TYPE_CHECK_VALUE_TYPE ((value), (g_type)))
</MACRO>
<MACRO>
<NAME>G_VALUE_TYPE</NAME>
#define	G_VALUE_TYPE(value)		(((GValue*) (value))->g_type)
</MACRO>
<MACRO>
<NAME>G_VALUE_TYPE_NAME</NAME>
#define	G_VALUE_TYPE_NAME(value)	(g_type_name (G_VALUE_TYPE (value)))
</MACRO>
<USER_FUNCTION>
<NAME>GValueExchange</NAME>
<RETURNS>void </RETURNS>
GValue	*value1,
				GValue	*value2
</USER_FUNCTION>
<STRUCT>
<NAME>GValue</NAME>
struct GValue
{
  /*< private >*/
  GType		g_type;

  /* public for GTypeValueTable methods */
  union {
    gint	v_int;
    guint	v_uint;
    glong	v_long;
    gulong	v_ulong;
    gfloat	v_float;
    gdouble	v_double;
    gpointer	v_pointer;
  } data[4];
};
</STRUCT>
<FUNCTION>
<NAME>g_value_init</NAME>
<RETURNS>void  </RETURNS>
GValue       *value,GType         g_type
</FUNCTION>
<FUNCTION>
<NAME>g_value_copy</NAME>
<RETURNS>void  </RETURNS>
const GValue *src_value,GValue       *dest_value
</FUNCTION>
<FUNCTION>
<NAME>g_value_convert</NAME>
<RETURNS>gboolean 	</RETURNS>
const GValue *src_value,GValue       *dest_value
</FUNCTION>
<FUNCTION>
<NAME>g_value_reset</NAME>
<RETURNS>void  </RETURNS>
GValue       *value
</FUNCTION>
<FUNCTION>
<NAME>g_value_unset</NAME>
<RETURNS>void  </RETURNS>
GValue       *value
</FUNCTION>
<FUNCTION>
<NAME>g_value_fits_pointer</NAME>
<RETURNS>gboolean 	</RETURNS>
const GValue *value
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_as_pointer</NAME>
<RETURNS>gpointer 	</RETURNS>
const GValue *value
</FUNCTION>
<FUNCTION>
<NAME>g_values_exchange</NAME>
<RETURNS>gboolean  </RETURNS>
GValue       *value1,GValue       *value2
</FUNCTION>
<FUNCTION>
<NAME>g_value_types_exchangable</NAME>
<RETURNS>gboolean  </RETURNS>
GType         value_type1,GType         value_type2
</FUNCTION>
<FUNCTION>
<NAME>g_value_register_exchange_func</NAME>
<RETURNS>void  </RETURNS>
GType         value_type1,GType         value_type2,GValueExchange func
</FUNCTION>
<MACRO>
<NAME>G_VALUE_STATIC_TAG</NAME>
#define G_VALUE_STATIC_TAG		(1 << 27)
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_CHAR</NAME>
#define G_IS_VALUE_CHAR(value)		(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_CHAR))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_UCHAR</NAME>
#define G_IS_VALUE_UCHAR(value)		(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_UCHAR))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_BOOLEAN</NAME>
#define G_IS_VALUE_BOOLEAN(value)	(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_BOOLEAN))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_INT</NAME>
#define G_IS_VALUE_INT(value)		(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_INT))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_UINT</NAME>
#define G_IS_VALUE_UINT(value)		(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_UINT))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_LONG</NAME>
#define G_IS_VALUE_LONG(value)		(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_LONG))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_ULONG</NAME>
#define G_IS_VALUE_ULONG(value)		(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_ULONG))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_FLOAT</NAME>
#define G_IS_VALUE_FLOAT(value)		(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_FLOAT))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_DOUBLE</NAME>
#define G_IS_VALUE_DOUBLE(value)	(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_DOUBLE))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_STRING</NAME>
#define G_IS_VALUE_STRING(value)	(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_STRING))
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_POINTER</NAME>
#define G_IS_VALUE_POINTER(value)	(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_POINTER))
</MACRO>
<FUNCTION>
<NAME>g_value_set_char</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,gint8		 v_char
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_char</NAME>
<RETURNS>gint8 	</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_uchar</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,guint8		 v_uchar
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_uchar</NAME>
<RETURNS>guint8 	</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_boolean</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,gboolean	 v_boolean
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_boolean</NAME>
<RETURNS>gboolean 	</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_int</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,gint		 v_int
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_int</NAME>
<RETURNS>gint 	</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_uint</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,guint		 v_uint
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_uint</NAME>
<RETURNS>guint 	</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_long</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,glong		 v_long
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_long</NAME>
<RETURNS>glong 	</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_ulong</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,gulong		 v_ulong
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_ulong</NAME>
<RETURNS>gulong 	</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_float</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,gfloat		 v_float
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_float</NAME>
<RETURNS>gfloat 	</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_double</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,gdouble	 v_double
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_double</NAME>
<RETURNS>gdouble 	</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_string</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,const gchar	*v_string
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_static_string</NAME>
<RETURNS>void 	</RETURNS>
GValue		*value,const gchar	*v_string
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_string</NAME>
<RETURNS>gchar *</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_dup_string</NAME>
<RETURNS>gchar *</RETURNS>
const GValue	*value
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_pointer</NAME>
<RETURNS>void  </RETURNS>
GValue         *value,gpointer        v_pointer
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_pointer</NAME>
<RETURNS>gpointer  </RETURNS>
const GValue   *value
</FUNCTION>
<MACRO>
<NAME>G_TYPE_IS_BOXED</NAME>
#define G_TYPE_IS_BOXED(type)	(G_TYPE_FUNDAMENTAL (type) == G_TYPE_BOXED)
</MACRO>
<MACRO>
<NAME>G_IS_VALUE_BOXED</NAME>
#define G_IS_VALUE_BOXED(value)	(G_TYPE_CHECK_VALUE_TYPE ((value), G_TYPE_BOXED))
</MACRO>
<STRUCT>
<NAME>GBoxed</NAME>
</STRUCT>
<USER_FUNCTION>
<NAME>GBoxedCopyFunc</NAME>
<RETURNS>gpointer </RETURNS>
gpointer	 boxed
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GBoxedFreeFunc</NAME>
<RETURNS>void </RETURNS>
gpointer	 boxed
</USER_FUNCTION>
<FUNCTION>
<NAME>g_boxed_copy</NAME>
<RETURNS>GBoxed *</RETURNS>
GType		 boxed_type,gconstpointer	 src_boxed
</FUNCTION>
<FUNCTION>
<NAME>g_boxed_free</NAME>
<RETURNS>void 	</RETURNS>
GType		 boxed_type,gpointer	 boxed
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_boxed</NAME>
<RETURNS>void  </RETURNS>
GValue         *value,gconstpointer   boxed
</FUNCTION>
<FUNCTION>
<NAME>g_value_set_static_boxed</NAME>
<RETURNS>void  </RETURNS>
GValue         *value,gconstpointer   boxed
</FUNCTION>
<FUNCTION>
<NAME>g_value_get_boxed</NAME>
<RETURNS>gpointer 	</RETURNS>
const GValue   *value
</FUNCTION>
<FUNCTION>
<NAME>g_value_dup_boxed</NAME>
<RETURNS>gpointer 	</RETURNS>
GValue         *value
</FUNCTION>
<FUNCTION>
<NAME>g_boxed_type_register_static</NAME>
<RETURNS>GType 	</RETURNS>
const gchar   *name,GBoxedCopyFunc	boxed_copy,GBoxedFreeFunc	boxed_free
</FUNCTION>
<MACRO>
<NAME>G_CLOSURE_NEEDS_MARSHAL</NAME>
#define	G_CLOSURE_NEEDS_MARSHAL(closure) (((GClosure*) (closure))->marshal == NULL)
</MACRO>
<MACRO>
<NAME>G_CCLOSURE_SWAP_DATA</NAME>
#define	G_CCLOSURE_SWAP_DATA(cclosure)	 (((GClosure*) (closure))->derivative_flag)
</MACRO>
<STRUCT>
<NAME>GClosure</NAME>
</STRUCT>
<STRUCT>
<NAME>GClosureNotifyData</NAME>
</STRUCT>
<TYPEDEF>
<NAME>GCallback</NAME>
typedef	gpointer GCallback;
</TYPEDEF>
<USER_FUNCTION>
<NAME>GClosureNotify</NAME>
<RETURNS>void </RETURNS>
gpointer	 data,
					 GClosure	*closure
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GClosureMarshal</NAME>
<RETURNS>void </RETURNS>
GClosure	*closure,
					 GValue         *return_value,
					 guint           n_param_values,
					 const GValue   *param_values,
					 gpointer        invocation_hint,
					 gpointer	 marshal_data
</USER_FUNCTION>
<STRUCT>
<NAME>GCClosure</NAME>
</STRUCT>
<STRUCT>
<NAME>GClosureNotifyData</NAME>
struct GClosureNotifyData
{
  gpointer       data;
  GClosureNotify notify;
};
</STRUCT>
<STRUCT>
<NAME>GClosure</NAME>
struct GClosure
{
  /*< private >*/	guint	 ref_count : 15;
  /*< private >*/	guint	 meta_marshal : 1;
  /*< private >*/	guint	 n_guards : 1;
  /*< private >*/	guint	 n_fnotifiers : 2;	/* finalization notifiers */
  /*< private >*/	guint	 n_inotifiers : 8;	/* invalidation notifiers */
  /*< private >*/	guint	 in_inotify : 1;
  /*< private >*/	guint	 floating : 1;
  /*< protected >*/	guint	 derivative_flag : 1;
  /*< puplic >*/	guint	 in_marshal : 1;
  /*< public >*/	guint	 is_invalid : 1;

  /*< private >*/	void   (*marshal)  (GClosure       *closure,
					    GValue /*out*/ *return_value,
					    guint           n_param_values,
					    const GValue   *param_values,
					    gpointer        invocation_hint,
					    gpointer	    marshal_data);
  /*< protected >*/	gpointer data;

  /*< private >*/	GClosureNotifyData *notifiers;

  /* invariants/constrains:
   * - ->marshal and ->data are _invalid_ as soon as ->is_invalid==TRUE
   * - invocation of all inotifiers occours prior to fnotifiers
   * - order of inotifiers is random
   *   inotifiers may _not_ free/invalidate parameter values (e.g. ->data)
   * - order of fnotifiers is random
   * - notifiers may only be removed before or during their invocation
   * - reference counting may only happen prior to fnotify invocation
   *   (in that sense, fnotifiers are really finalization handlers)
   */
};
</STRUCT>
<STRUCT>
<NAME>GCClosure</NAME>
struct GCClosure
{
  GClosure	closure;
  gpointer	callback;
};
</STRUCT>
<FUNCTION>
<NAME>g_cclosure_new</NAME>
<RETURNS>GClosure *</RETURNS>
GCallback	callback_func,gpointer	user_data,GClosureNotify destroy_data
</FUNCTION>
<FUNCTION>
<NAME>g_cclosure_new_swap</NAME>
<RETURNS>GClosure *</RETURNS>
GCallback	callback_func,gpointer	user_data,GClosureNotify destroy_data
</FUNCTION>
<FUNCTION>
<NAME>g_signal_type_closure_new</NAME>
<RETURNS>GClosure *</RETURNS>
GType          itype,guint          struct_offset
</FUNCTION>
<FUNCTION>
<NAME>g_closure_ref</NAME>
<RETURNS>GClosure *</RETURNS>
GClosure	*closure
</FUNCTION>
<FUNCTION>
<NAME>g_closure_unref</NAME>
<RETURNS>void 	</RETURNS>
GClosure	*closure
</FUNCTION>
<FUNCTION>
<NAME>g_closure_new_simple</NAME>
<RETURNS>GClosure *</RETURNS>
guint		 sizeof_closure,gpointer	 data
</FUNCTION>
<FUNCTION>
<NAME>g_closure_add_fnotify</NAME>
<RETURNS>void 	</RETURNS>
GClosure       *closure,gpointer	 notify_data,GClosureNotify	 notify_func
</FUNCTION>
<FUNCTION>
<NAME>g_closure_remove_fnotify</NAME>
<RETURNS>void 	</RETURNS>
GClosure       *closure,gpointer	 notify_data,GClosureNotify	 notify_func
</FUNCTION>
<FUNCTION>
<NAME>g_closure_add_inotify</NAME>
<RETURNS>void 	</RETURNS>
GClosure       *closure,gpointer	 notify_data,GClosureNotify	 notify_func
</FUNCTION>
<FUNCTION>
<NAME>g_closure_remove_inotify</NAME>
<RETURNS>void 	</RETURNS>
GClosure       *closure,gpointer	 notify_data,GClosureNotify	 notify_func
</FUNCTION>
<FUNCTION>
<NAME>g_closure_add_marshal_guards</NAME>
<RETURNS>void 	</RETURNS>
GClosure	*closure,gpointer        pre_marshal_data,GClosureNotify	 pre_marshal_notify,gpointer        post_marshal_data,GClosureNotify	 post_marshal_notify
</FUNCTION>
<FUNCTION>
<NAME>g_closure_set_marshal</NAME>
<RETURNS>void 	</RETURNS>
GClosure	*closure,GClosureMarshal marshal
</FUNCTION>
<FUNCTION>
<NAME>g_closure_set_meta_marshal</NAME>
<RETURNS>void 	</RETURNS>
GClosure       *closure,gpointer	 marshal_data,GClosureMarshal meta_marshal
</FUNCTION>
<FUNCTION>
<NAME>g_closure_invalidate</NAME>
<RETURNS>void 	</RETURNS>
GClosure	*closure
</FUNCTION>
<FUNCTION>
<NAME>g_closure_invoke</NAME>
<RETURNS>void 	</RETURNS>
GClosure 	*closure,GValue		*return_value,guint		 n_param_values,const GValue	*param_values,gpointer	 invocation_hint
</FUNCTION>
<STRUCT>
<NAME>GSignalQuery</NAME>
</STRUCT>
<STRUCT>
<NAME>GSignalInvocationHint</NAME>
</STRUCT>
<TYPEDEF>
<NAME>GSignalCMarshaller</NAME>
typedef GClosureMarshal			 GSignalCMarshaller;
</TYPEDEF>
<USER_FUNCTION>
<NAME>GSignalEmissionHook</NAME>
<RETURNS>gboolean </RETURNS>
GSignalInvocationHint *ihint,
					 guint			n_param_values,
					 const GValue	       *param_values
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GSignalAccumulator</NAME>
<RETURNS>gboolean </RETURNS>
GSignalInvocationHint *ihint,
					 GValue		       *return_accu,
					 const GValue	       *return_value
</USER_FUNCTION>
<ENUM>
<NAME>GSignalFlags</NAME>
typedef enum
{
  G_SIGNAL_RUN_FIRST	= 1 << 0,
  G_SIGNAL_RUN_LAST	= 1 << 1,
  G_SIGNAL_RUN_CLEANUP	= 1 << 2,
  G_SIGNAL_NO_RECURSE	= 1 << 3,
  G_SIGNAL_DETAILED	= 1 << 4,
  G_SIGNAL_ACTION	= 1 << 5,
  G_SIGNAL_NO_HOOKS	= 1 << 6
#define G_SIGNAL_FLAGS_MASK  0x7f
} GSignalFlags;
</ENUM>
<ENUM>
<NAME>GSignalMatchType</NAME>
typedef enum
{
  G_SIGNAL_MATCH_ID	   = 1 << 0,
  G_SIGNAL_MATCH_DETAIL	   = 1 << 1,
  G_SIGNAL_MATCH_CLOSURE   = 1 << 2,
  G_SIGNAL_MATCH_FUNC	   = 1 << 3,
  G_SIGNAL_MATCH_DATA	   = 1 << 4,
  G_SIGNAL_MATCH_UNBLOCKED = 1 << 5
#define G_SIGNAL_MATCH_MASK  0x3f
} GSignalMatchType;
</ENUM>
<STRUCT>
<NAME>GSignalInvocationHint</NAME>
struct GSignalInvocationHint
{
  guint		signal_id;
  GQuark	detail;
  GSignalFlags	run_type;
};
</STRUCT>
<STRUCT>
<NAME>GSignalQuery</NAME>
struct GSignalQuery
{
  guint		signal_id;
  const gchar  *signal_name;
  GType		itype;
  GSignalFlags	signal_flags;
  GType		return_type;
  guint		n_params;
  const GType  *param_types;
};
</STRUCT>
<FUNCTION>
<NAME>g_signal_newv</NAME>
<RETURNS>guint 	</RETURNS>
const gchar	 *signal_name,GType		  itype,GSignalFlags	   signal_flags,GClosure		 *class_closure,GSignalAccumulator accumulator,GSignalCMarshaller c_marshaller,GType		  return_type,guint		  n_params,GType		 *param_types
</FUNCTION>
<FUNCTION>
<NAME>g_signal_emitv</NAME>
<RETURNS>void 	</RETURNS>
const GValue	 *instance_and_params,guint		  signal_id,GQuark		  detail,GValue		 *return_value
</FUNCTION>
<FUNCTION>
<NAME>g_signal_lookup</NAME>
<RETURNS>guint 	</RETURNS>
const gchar	 *name,GType		  itype
</FUNCTION>
<FUNCTION>
<NAME>g_signal_name</NAME>
<RETURNS>gchar *</RETURNS>
guint		  signal_id
</FUNCTION>
<FUNCTION>
<NAME>g_signal_query</NAME>
<RETURNS>void 	</RETURNS>
guint		  signal_id,GSignalQuery	 *query
</FUNCTION>
<FUNCTION>
<NAME>g_signal_list_ids</NAME>
<RETURNS>guint *</RETURNS>
GType		  itype,guint		 *n_ids
</FUNCTION>
<FUNCTION>
<NAME>g_signal_stop_emission</NAME>
<RETURNS>void 	</RETURNS>
gpointer		  instance,guint		  signal_id,GQuark		  detail
</FUNCTION>
<FUNCTION>
<NAME>g_signal_add_emission_hook_full</NAME>
<RETURNS>guint 	</RETURNS>
guint		  signal_id,GClosure		 *closure
</FUNCTION>
<FUNCTION>
<NAME>g_signal_remove_emission_hook</NAME>
<RETURNS>void 	</RETURNS>
guint		  signal_id,guint		  hook_id
</FUNCTION>
<FUNCTION>
<NAME>g_signal_has_handler_pending</NAME>
<RETURNS>gboolean  </RETURNS>
gpointer		  instance,guint		  signal_id,GQuark		  detail,gboolean		  may_be_blocked
</FUNCTION>
<FUNCTION>
<NAME>g_signal_connect_closure_by_id</NAME>
<RETURNS>guint 	</RETURNS>
gpointer		  instance,guint		  signal_id,GQuark		  detail,GClosure		 *closure,gboolean		  after
</FUNCTION>
<FUNCTION>
<NAME>g_signal_handler_block</NAME>
<RETURNS>void 	</RETURNS>
gpointer		  instance,guint		  handler_id
</FUNCTION>
<FUNCTION>
<NAME>g_signal_handler_unblock</NAME>
<RETURNS>void 	</RETURNS>
gpointer		  instance,guint		  handler_id
</FUNCTION>
<FUNCTION>
<NAME>g_signal_handler_disconnect</NAME>
<RETURNS>void 	</RETURNS>
gpointer		  instance,guint		  handler_id
</FUNCTION>
<FUNCTION>
<NAME>g_signal_handler_find</NAME>
<RETURNS>guint 	</RETURNS>
gpointer		  instance,GSignalMatchType	  mask,guint		  signal_id,GQuark		  detail,GClosure		 *closure,gpointer		  func,gpointer		  data
</FUNCTION>
<FUNCTION>
<NAME>g_signal_handlers_block_matched</NAME>
<RETURNS>guint 	</RETURNS>
gpointer		  instance,GSignalMatchType	  mask,guint		  signal_id,GQuark		  detail,GClosure		 *closure,gpointer		  func,gpointer		  data
</FUNCTION>
<FUNCTION>
<NAME>g_signal_handlers_unblock_matched</NAME>
<RETURNS>guint 	</RETURNS>
gpointer		  instance,GSignalMatchType	  mask,guint		  signal_id,GQuark		  detail,GClosure		 *closure,gpointer		  func,gpointer		  data
</FUNCTION>
<FUNCTION>
<NAME>g_signal_handlers_disconnect_matched</NAME>
<RETURNS>guint 	</RETURNS>
gpointer		  instance,GSignalMatchType	  mask,guint		  signal_id,GQuark		  detail,GClosure		 *closure,gpointer		  func,gpointer		  data
</FUNCTION>
<FUNCTION>
<NAME>g_signal_parse_name</NAME>
<RETURNS>gboolean  </RETURNS>
const gchar	 *detailed_signal,GType		  itype,guint		 *signal_id_p,GQuark		 *detail_p,gboolean		  force_detail_quark
</FUNCTION>
<FUNCTION>
<NAME>g_signal_handlers_destroy</NAME>
<RETURNS>void 	</RETURNS>
gpointer		  instance
</FUNCTION>
<MACRO>
<NAME>G_TYPE_TYPE_PLUGIN</NAME>
#define G_TYPE_TYPE_PLUGIN		(g_type_plugin_get_type ())
</MACRO>
<MACRO>
<NAME>G_TYPE_PLUGIN</NAME>
#define G_TYPE_PLUGIN(inst)		(G_TYPE_CHECK_INSTANCE_CAST ((inst), G_TYPE_TYPE_PLUGIN, GTypePlugin))
</MACRO>
<MACRO>
<NAME>G_TYPE_PLUGIN_CLASS</NAME>
#define G_TYPE_PLUGIN_CLASS(vtable)	(G_TYPE_CHECK_CLASS_CAST ((vtable), G_TYPE_TYPE_PLUGIN, GTypePluginClass))
</MACRO>
<MACRO>
<NAME>G_IS_TYPE_PLUGIN</NAME>
#define G_IS_TYPE_PLUGIN(inst)		(G_TYPE_CHECK_INSTANCE_TYPE ((inst), G_TYPE_TYPE_PLUGIN))
</MACRO>
<MACRO>
<NAME>G_IS_TYPE_PLUGIN_CLASS</NAME>
#define G_IS_TYPE_PLUGIN_CLASS(vtable)	(G_TYPE_CHECK_CLASS_TYPE ((vtable), G_TYPE_TYPE_PLUGIN))
</MACRO>
<MACRO>
<NAME>G_TYPE_PLUGIN_GET_CLASS</NAME>
#define G_TYPE_PLUGIN_GET_CLASS(inst)	(G_TYPE_INSTANCE_GET_INTERFACE ((inst), G_TYPE_TYPE_PLUGIN, GTypePluginClass))
</MACRO>
<STRUCT>
<NAME>GTypePluginClass</NAME>
</STRUCT>
<USER_FUNCTION>
<NAME>GTypePluginUse</NAME>
<RETURNS>void </RETURNS>
GTypePlugin     *plugin
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GTypePluginUnuse</NAME>
<RETURNS>void </RETURNS>
GTypePlugin     *plugin
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GTypePluginCompleteTypeInfo</NAME>
<RETURNS>void </RETURNS>
GTypePlugin     *plugin,
						   GType            g_type,
						   GTypeInfo       *info,
						   GTypeValueTable *value_table
</USER_FUNCTION>
<USER_FUNCTION>
<NAME>GTypePluginCompleteInterfaceInfo</NAME>
<RETURNS>void </RETURNS>
GTypePlugin     *plugin,
						   GType            interface_type,
						   GType            instance_type,
						   GInterfaceInfo  *info
</USER_FUNCTION>
<FUNCTION>
<NAME>g_type_plugin_get_type</NAME>
<RETURNS>GType 	</RETURNS>
void
</FUNCTION>
<FUNCTION>
<NAME>g_type_plugin_use</NAME>
<RETURNS>void 	</RETURNS>
GTypePlugin	 *plugin
</FUNCTION>
<FUNCTION>
<NAME>g_type_plugin_unuse</NAME>
<RETURNS>void 	</RETURNS>
GTypePlugin	 *plugin
</FUNCTION>
<FUNCTION>
<NAME>g_type_plugin_complete_type_info</NAME>
<RETURNS>void 	</RETURNS>
GTypePlugin     *plugin,GType            g_type,GTypeInfo       *info,GTypeValueTable *value_table
</FUNCTION>
<FUNCTION>
<NAME>g_type_plugin_complete_interface_info</NAME>
<RETURNS>void 	</RETURNS>
GTypePlugin     *plugin,GType            interface_type,GType            instance_type,GInterfaceInfo  *info
</FUNCTION>
<STRUCT>
<NAME>GTypeModule</NAME>
</STRUCT>
<STRUCT>
<NAME>GTypeModuleClass</NAME>
</STRUCT>
<MACRO>
<NAME>G_TYPE_TYPE_MODULE</NAME>
#define G_TYPE_TYPE_MODULE              (g_type_module_get_type ())
</MACRO>
<MACRO>
<NAME>G_TYPE_MODULE</NAME>
#define G_TYPE_MODULE(module)           (G_TYPE_CHECK_INSTANCE_CAST ((module), G_TYPE_TYPE_MODULE, GTypeModule))
</MACRO>
<MACRO>
<NAME>G_TYPE_MODULE_CLASS</NAME>
#define G_TYPE_MODULE_CLASS(class)      (G_TYPE_CHECK_CLASS_CAST ((class), G_TYPE_TYPE_MODULE, GTypeModuleClass))
</MACRO>
<MACRO>
<NAME>G_IS_TYPE_MODULE</NAME>
#define G_IS_TYPE_MODULE(module)        (G_TYPE_CHECK_INSTANCE_TYPE ((module), G_TYPE_TYPE_MODULE))
</MACRO>
<MACRO>
<NAME>G_IS_TYPE_MODULE_CLASS</NAME>
#define G_IS_TYPE_MODULE_CLASS(class)   (G_TYPE_CHECK_CLASS_TYPE ((class), G_TYPE_TYPE_MODULE))
</MACRO>
<MACRO>
<NAME>G_TYPE_MODULE_GET_CLASS</NAME>
#define G_TYPE_MODULE_GET_CLASS(module) (G_TYPE_INSTANCE_GET_CLASS ((module), G_TYPE_TYPE_MODULE, GTypeModuleClass))
</MACRO>
<STRUCT>
<NAME>GTypeModule</NAME>
struct GTypeModule 
{
  GObject parent_instance;

  guint use_count;
  GSList *type_infos;
  GSList *interface_infos;
  gchar *name;
};
</STRUCT>
<FUNCTION>
<NAME>g_type_module_get_type</NAME>
<RETURNS>GType  </RETURNS>
void
</FUNCTION>
<FUNCTION>
<NAME>g_type_module_use</NAME>
<RETURNS>gboolean  </RETURNS>
GTypeModule     *module
</FUNCTION>
<FUNCTION>
<NAME>g_type_module_unuse</NAME>
<RETURNS>void  </RETURNS>
GTypeModule     *module
</FUNCTION>
<FUNCTION>
<NAME>g_type_module_set_name</NAME>
<RETURNS>void  </RETURNS>
GTypeModule     *module,const gchar     *name
</FUNCTION>
<FUNCTION>
<NAME>g_type_module_register_type</NAME>
<RETURNS>GType  </RETURNS>
GTypeModule     *module,GType            parent_type,const gchar     *type_name,const GTypeInfo *type_info,GTypeFlags       flags
</FUNCTION>
<FUNCTION>
<NAME>g_type_module_add_interface</NAME>
<RETURNS>void  </RETURNS>
GTypeModule     *module,GType            instance_type,GType            interface_type,GInterfaceInfo  *interface_info
</FUNCTION>
