|  |  |  | Glade User Interface Designer Reference Manual |  | 
|---|---|---|---|---|
#define GPC_OBJECT_DELIMITER #define GPC_PROPERTY_NAMELEN GladePropertyClass; GladePropertyClass* glade_property_class_new (gpointer handle); GladePropertyClass* glade_property_class_new_from_spec (gpointer handle, GParamSpec *spec); GladePropertyClass* glade_property_class_clone (GladePropertyClass *property_class); void glade_property_class_free (GladePropertyClass *property_class); gboolean glade_property_class_is_visible (GladePropertyClass *property_class); gboolean glade_property_class_is_object (GladePropertyClass *property_class); GValue* glade_property_class_make_gvalue_from_string (GladePropertyClass *property_class, const gchar *string, GladeProject *project); gchar* glade_property_class_make_string_from_gvalue (GladePropertyClass *property_class, const GValue *value); GValue* glade_property_class_make_gvalue_from_vl (GladePropertyClass *property_class, va_list vl); void glade_property_class_set_vl_from_gvalue (GladePropertyClass *klass, GValue *value, va_list vl); GValue* glade_property_class_make_gvalue (GladePropertyClass *klass, ...); void glade_property_class_get_from_gvalue (GladePropertyClass *klass, GValue *value, ...); gboolean glade_property_class_update_from_node (GladeXmlNode *node, GModule *module, GType object_type, GladePropertyClass **property_class, const gchar *domain); const gchar* glade_property_class_get_displayable_value (GladePropertyClass *klass, gint value); GtkAdjustment* glade_property_class_make_adjustment (GladePropertyClass *property_class); gboolean glade_property_class_match (GladePropertyClass *klass, GladePropertyClass *comp); gboolean glade_property_class_void_value (GladePropertyClass *klass, GValue *value);
GladePropertyClass is a structure based on a GParamSpec and parameters from the Glade catalog files and describes how properties are to be handled in Glade; it also provides an interface to convert GValue to strings and va_lists etc (back and forth).
#define GPC_PROPERTY_NAMELEN 512 /* Enough space for a property name I think */
typedef struct {
	gpointer    handle; /* The GladeWidgetAdaptor that this property class
			     * was created for.
			     */
	gpointer    origin_handle; /* The GladeWidgetAdaptor that this property class
				    * was introduced in.
				    */
	gint        version_since_major; /* Version in which this property was
					  * introduced
					  */
	gint        version_since_minor; 
	GParamSpec *pspec; /* The Parameter Specification for this property.
			    */
	gchar *id;       /* The id of the property. Like "label" or "xpad"
			  * this is a non-translatable string
			  */
	gchar *name;     /* The name of the property. Like "Label" or "X Pad"
			  * this is a translatable string
			  */
	gchar *tooltip; /* The default tooltip for the property editor rows.
			 */
	gboolean virt; /* Whether this is a virtual property with its pspec supplied
			* via the catalog (or hard code-paths); or FALSE if its a real
			* GObject introspected property
			*/
	GValue *def;      /* The default value for this property (this will exist
			   * as a copy of orig_def if not specified by the catalog)
			   */
	GValue *orig_def; /* The real default value obtained through introspection.
			   * (used to decide whether we should write to the
			   * glade file or not, or to restore the loaded property
			   * correctly); all property classes have and orig_def.
			   */
	GList *parameters; /* list of GladeParameter objects. This list
			    * provides with an extra set of key-value
			    * pairs to specify aspects of this property.
			    *
			    * This is unused by glade and only maintained
			    * to be of possible use in plugin code.
			    */
	GArray *displayable_values; /* If this property's value is an enumeration/flags and 
				     * there is some value name overridden in a catalog
				     * then it will point to a GEnumValue array with the
				     * modified names, otherwise NULL.
				     */
	gboolean query; /* Whether we should explicitly ask the user about this property
			 * when instantiating a widget with this property (through a popup
			 * dialog).
			 */
	gboolean optional; /* Some properties are optional by nature like
			    * default width. It can be set or not set. A
			    * default property has a check box in the
			    * left that enables/disables the input
			    */
	gboolean optional_default; /* For optional values, what the default is */
	gboolean construct_only; /* Whether this property is G_PARAM_CONSTRUCT_ONLY or not */
	
	gboolean common;  /* Common properties go in the common tab */
	gboolean atk;     /* Atk properties go in the atk tab */
	gboolean packing; /* Packing properties go in the packing tab */
	
	gboolean translatable; /* The property should be translatable, which
				* means that it needs extra parameters in the
				* UI.
				*/
	gint  visible_lines; /* When this pspec calls for a text editor, how many
			      * lines should be visible in the editor.
			      */
	/* These three are the master switches for the glade-file output,
	 * property editor availability & live object updates in the glade environment.
	 */
	gboolean save;      /* Whether we should save to the glade file or not
			     * (mostly just for virtual internal glade properties,
			     * also used for properties with generic pspecs that
			     * are saved in custom ways by the plugin)
			     */
	gboolean save_always; /* Used to make a special case exception and always
			       * save this property regardless of what the default
			       * value is (used for some special cases like properties
			       * that are assigned initial values in composite widgets
			       * or derived widget code).
			       */
	gboolean visible;   /* Whether or not to show this property in the editor
			     */
	gboolean ignore;    /* When true, we will not sync the object when the property
			     * changes, or load values from the object.
			     */
	gboolean is_modified; /* If true, this property_class has been "modified" from the
			       * the standard property by a xml file. */
	gboolean resource;  /* Some property types; such as some file specifying
			     * string properties or GDK_TYPE_PIXBUF properties; are
			     * resource files and are treated specialy (a filechooser
			     * popup is used and the resource is copied to the project
			     * directory).
			     */
	gboolean themed_icon; /* Some GParamSpecString properties reffer to icon names
			       * in the icon theme... these need to be specified in the
			       * property class definition if proper editing tools are to
			       * be used.
			       */
	
	gboolean transfer_on_paste; /* If this is a packing prop, 
				     * wether we should transfer it on paste.
				     */
	
	gdouble weight;	/* This will determine the position of this property in 
			 * the editor.
			 */
} GladePropertyClass;
GladePropertyClass* glade_property_class_new (gpointer handle);
| handle: | A generic pointer (i.e. a GladeWidgetClass) | 
| Returns : | a new GladePropertyClass | 
GladePropertyClass* glade_property_class_new_from_spec (gpointer handle, GParamSpec *spec);
| handle: | A generic pointer (i.e. a GladeWidgetClass) | 
| spec: | A GParamSpec | 
| Returns : | a newly created GladePropertyClass based on specorNULLif its unsupported. | 
GladePropertyClass* glade_property_class_clone (GladePropertyClass *property_class);
| property_class: | a GladePropertyClass | 
| Returns : | a new GladePropertyClass cloned from property_class | 
void glade_property_class_free (GladePropertyClass *property_class);
Frees klass and its associated memory.
| property_class: | a GladePropertyClass | 
gboolean glade_property_class_is_visible (GladePropertyClass *property_class);
| property_class: | A GladePropertyClass | 
| Returns : | whether or not to show this property in the editor | 
gboolean glade_property_class_is_object (GladePropertyClass *property_class);
| property_class: | A GladePropertyClass | 
| Returns : | whether or not this is an object property that refers to another object in this project. | 
GValue*             glade_property_class_make_gvalue_from_string
                                                        (GladePropertyClass *property_class,
                                                         const gchar *string,
                                                         GladeProject *project);
| property_class: | A GladePropertyClass | 
| string: | a string representation of this property | 
| project: | the glade project that the associated property belongs to. | 
| Returns : | A GValue created based on the property_classandstringcriteria. | 
gchar*              glade_property_class_make_string_from_gvalue
                                                        (GladePropertyClass *property_class,
                                                         const GValue *value);
| property_class: | A GladePropertyClass | 
| value: | A GValue | 
| Returns : | A newly allocated string representation of value | 
GValue*             glade_property_class_make_gvalue_from_vl
                                                        (GladePropertyClass *property_class,
                                                         va_list vl);
| property_class: | A GladePropertyClass | 
| vl: | a va_list holding one argument of the correct type
     specified by property_class | 
| Returns : | A GValue created based on the property_classand avlarg of the correct type. | 
void                glade_property_class_set_vl_from_gvalue
                                                        (GladePropertyClass *klass,
                                                         GValue *value,
                                                         va_list vl);
Sets vl from value based on klass criteria.
| klass: | A GladePropertyClass | 
| value: | A GValue to set | 
| vl: | a va_list holding one argument of the correct type
     specified by klass | 
GValue* glade_property_class_make_gvalue (GladePropertyClass *klass, ...);
| klass: | A GladePropertyClass | 
| ...: | an argument of the correct type specified by property_class | 
| Returns : | A GValue created based on the property_classand the provided argument. | 
void                glade_property_class_get_from_gvalue
                                                        (GladePropertyClass *klass,
                                                         GValue *value,
                                                         ...);
Assignes the provided return location to value
| klass: | A GladePropertyClass | 
| value: | A GValue to set | 
| ...: | a return location of the correct type | 
gboolean            glade_property_class_update_from_node
                                                        (GladeXmlNode *node,
                                                         GModule *module,
                                                         GType object_type,
                                                         GladePropertyClass **property_class,
                                                         const gchar *domain);
Updates the property_class with the contents of the node in the xml
file. Only the values found in the xml file are overridden.
| node: | the property node | 
| module: | a GModule to lookup symbols from the plugin | 
| object_type: | the GType of the owning object | 
| property_class: | a pointer to the property class | 
| domain: | the domain to translate catalog strings from | 
| Returns : | TRUEon success.property_classis set to NULL if the property
         has Disabled="TRUE". | 
const gchar*        glade_property_class_get_displayable_value
                                                        (GladePropertyClass *klass,
                                                         gint value);
Search a displayable values for value in this property class.
| klass: | the property class to search in | 
| value: | the value to search | 
| Returns : | a (gchar *) if a diplayable value was found, otherwise NULL. | 
GtkAdjustment*      glade_property_class_make_adjustment
                                                        (GladePropertyClass *property_class);
Creates and appropriate GtkAdjustment for use in the editor
| property_class: | a pointer to the property class | 
| Returns : | An appropriate GtkAdjustment for use in the Property editor | 
gboolean glade_property_class_match (GladePropertyClass *klass, GladePropertyClass *comp);
| klass: | a GladePropertyClass | 
| comp: | a GladePropertyClass | 
| Returns : | whether klassandcompare a match or not
         (properties in seperate decendant heirarchies that
          have the same name are not matches). | 
gboolean glade_property_class_void_value (GladePropertyClass *klass, GValue *value);
| klass: | a GladePropertyClass | 
| Returns : | Whether valuefor thisklassis voided; a voided value
         can be aNULLvalue for boxed or object type param specs. |