| GTK+ Reference Manual | |||
|---|---|---|---|
| <<< Previous Page | Home | Up | Next Page >>> | 
GtkType is unique integer identifying the type. The guts of the information about the type is held in a private struct named GtkTypeNode.
| typedef enum	/*< skip >*/
{
  GTK_TYPE_INVALID	= G_TYPE_INVALID,
  GTK_TYPE_NONE		= G_TYPE_NONE,
  GTK_TYPE_ENUM		= G_TYPE_ENUM,
  GTK_TYPE_FLAGS	= G_TYPE_FLAGS,
  /* GtkArg types */
  GTK_TYPE_CHAR		= G_TYPE_CHAR,
  GTK_TYPE_UCHAR	= G_TYPE_UCHAR,
  GTK_TYPE_BOOL		= G_TYPE_BOOLEAN,
  GTK_TYPE_INT		= G_TYPE_INT,
  GTK_TYPE_UINT		= G_TYPE_UINT,
  GTK_TYPE_LONG		= G_TYPE_LONG,
  GTK_TYPE_ULONG	= G_TYPE_ULONG,
  GTK_TYPE_FLOAT	= G_TYPE_FLOAT,
  GTK_TYPE_DOUBLE	= G_TYPE_DOUBLE,
  GTK_TYPE_STRING	= G_TYPE_STRING,
  GTK_TYPE_BOXED	= G_TYPE_BOXED,
  GTK_TYPE_POINTER	= G_TYPE_POINTER
} GtkFundamentalType; | 
GtkFundamentalType is an enumerated type which lists all the possible fundamental types (e.g. char, uchar, int, long, float, etc).
| #define GTK_TYPE_FUNDAMENTAL_LAST | 
The highest-numbered structured or flat enumerated type value.
| #define GTK_TYPE_FUNDAMENTAL_MAX | 
The highest maximum fundamental enumerated type value.
| #define GTK_CHECK_CAST | 
Cast the object in tobj into cast. If GTK_NO_CHECK_CASTS is defined, just cast it. Otherwise, check to see if we can cast tobj into a cast.
| #define GTK_CHECK_CLASS_CAST | 
Cast the object in tobj into cast. If GTK_NO_CHECK_CASTS is defined, just cast it. Otherwise, check to see if we can cast tobj into a cast.
| void (*GtkCallbackMarshal) (GtkObject *object, gpointer data, guint n_args, GtkArg *args); | 
Define a function pointer.
| void (*GtkArgGetFunc) (GtkObject *object, GtkArg *arg, guint arg_id); | 
Define a function pointer. Deprecated.
| void (*GtkArgSetFunc) (GtkObject *object, GtkArg *arg, guint arg_id); | 
Define a function pointer. Deprecated.
| typedef GTypeInstance GtkTypeObject; | 
A GtkTypeObject defines the minimum structure requirements for type instances. Type instances returned from gtk_type_new() and initialized through a GtkObjectInitFunc need to directly inherit from this structure or at least copy its fields one by one.
| struct GtkArg
{
  GtkType type;
  gchar *name;
  
  /* this union only defines the required storage types for
   * the possibile values, thus there is no gint enum_data field,
   * because that would just be a mere alias for gint int_data.
   * use the GTK_VALUE_*() and GTK_RETLOC_*() macros to access
   * the discrete memebers.
   */
  union {
    /* flat values */
    gchar char_data;
    guchar uchar_data;
    gboolean bool_data;
    gint int_data;
    guint uint_data;
    glong long_data;
    gulong ulong_data;
    gfloat float_data;
    gdouble double_data;
    gchar *string_data;
    GtkObject *object_data;
    gpointer pointer_data;
    
    /* structured values */
    struct {
      GtkSignalFunc f;
      gpointer d;
    } signal_data;
  } d;
}; | 
This is a structure that we use to pass in typed values (and names).
| #define GTK_VALUE_CHAR(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_CHAR
| #define GTK_VALUE_UCHAR(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_UCHAR
| #define GTK_VALUE_BOOL(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_BOOL
| #define GTK_VALUE_INT(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_INT
| #define GTK_VALUE_UINT(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_UINT
| #define GTK_VALUE_LONG(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_LONG
| #define GTK_VALUE_ULONG(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_ULONG
| #define GTK_VALUE_FLOAT(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_FLOAT
| #define GTK_VALUE_DOUBLE(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_DOUBLE
| #define GTK_VALUE_STRING(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_STRING
| #define GTK_VALUE_ENUM(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_ENUM
| #define GTK_VALUE_FLAGS(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_FLAGS
| #define GTK_VALUE_BOXED(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_BOXED
| #define GTK_VALUE_POINTER(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_POINTER
| #define GTK_VALUE_OBJECT(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_OBJECT
| #define GTK_VALUE_SIGNAL(a) | 
Use to get the value of a GtkArg whose GtkType is GTK_TYPE_SIGNAL
| #define GTK_RETLOC_CHAR(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_CHAR
| #define GTK_RETLOC_UCHAR(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_UCHAR
| #define GTK_RETLOC_BOOL(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_BOOL
| #define GTK_RETLOC_INT(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_INT
| #define GTK_RETLOC_UINT(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_UINT
| #define GTK_RETLOC_LONG(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_LONG
| #define GTK_RETLOC_ULONG(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_ULONG
| #define GTK_RETLOC_FLOAT(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_FLOAT
| #define GTK_RETLOC_DOUBLE(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_DOUBLE
| #define GTK_RETLOC_STRING(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_STRING
| #define GTK_RETLOC_ENUM(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_ENUM
| #define GTK_RETLOC_FLAGS(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_FLAGS
| #define GTK_RETLOC_BOXED(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_BOXED
| #define GTK_RETLOC_POINTER(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_POINTER
| #define GTK_RETLOC_OBJECT(a) | 
If the GtkArg contains a pointer to the value, this macro will be a pointer to a GTK_TYPE_OBJECT
| struct GtkTypeInfo
{
  gchar			*type_name;
  guint			 object_size;
  guint			 class_size;
  GtkClassInitFunc	 class_init_func;
  GtkObjectInitFunc	 object_init_func;
  gpointer		 reserved_1;
  gpointer		 reserved_2;
  GtkClassInitFunc	 base_class_init_func;
}; | 
Holds information about the type. gtk_type_name returns the name. object_size is somehow set to the number of bytes that an instance of the object will occupy. class_init_func holds the type's initialization function. object_init_func holds the initialization function for an instance of the object. reserved_1 is used for GtkEnumValue to hold the enumerated values.
| typedef GTypeClass GtkTypeClass; | 
The base structure for a Gtk Type. Every type inherits this as a base structure.
| typedef GEnumValue GtkEnumValue; | 
A structure which contains a single enum value, and its name, and it's nickname.
| void gtk_type_init (GTypeDebugFlags debug_flags); | 
Initialize the data structures associated with gtk types.
| GtkType gtk_type_unique (GtkType parent_type, const GtkTypeInfo *gtkinfo); | 
Create a new, unique type.
| GtkType gtk_type_from_name (const gchar *name); | 
Get the internal representation of a type given its name.
| gpointer gtk_type_class (GtkType type); | 
Return a gpointer pointing to the class of type or NULL if there was any trouble identifying type. Initialize the class if necessary.
| gpointer gtk_type_new (GtkType type); | 
Create a new object of a given type, and return a gpointer to it. Returns NULL if you give it an invalid type. It allocates the object out of the type's memory chunk if there is a memory chunk. The object has all the proper initializers called.
| gboolean gtk_type_is_a (GtkType type, GtkType is_a_type); | 
Look in the type hierarchy to see if type has is_a_type among its ancestors. Do so with a simple lookup, not a loop.
| GtkEnumValue* gtk_type_enum_get_values (GtkType enum_type); | 
If enum_type has values, then return a pointer to all of them.
| GtkFlagValue* gtk_type_flags_get_values (GtkType flags_type); | 
If flags_type has values, then return a pointer to all of them.
| GtkEnumValue* gtk_type_enum_find_value (GtkType enum_type, const gchar *value_name); | 
Return a pointer to one of enum_type's GtkEnumValues's whose name (or nickname) matches value_name.
| GtkFlagValue* gtk_type_flags_find_value (GtkType flags_type, const gchar *value_name); | 
Return a pointer to one of flag_type's GtkFlagValue's whose name (or nickname) matches value_name.