|  |  |  | Glade User Interface Designer Reference Manual |  | 
|---|---|---|---|---|
struct GladeProject; enum GladeProjectFormat; GladeProject* glade_project_new (void); GladeProjectFormat glade_project_get_format (GladeProject *project); void glade_project_set_format (GladeProject *project, GladeProjectFormat format); gboolean glade_project_load_from_file (GladeProject *project, const gchar *path); GladeProject* glade_project_load (const gchar *path); gboolean glade_project_save (GladeProject *project, const gchar *path, GError **error); const gchar* glade_project_get_path (GladeProject *project); gchar* glade_project_get_name (GladeProject *project); void glade_project_undo (GladeProject *project); void glade_project_redo (GladeProject *project); GladeCommand* glade_project_next_undo_item (GladeProject *project); GladeCommand* glade_project_next_redo_item (GladeProject *project); void glade_project_push_undo (GladeProject *project, GladeCommand *cmd); GtkWidget* glade_project_undo_items (GladeProject *project); GtkWidget* glade_project_redo_items (GladeProject *project); void glade_project_reset_path (GladeProject *project); gboolean glade_project_get_readonly (GladeProject *project); const GList* glade_project_get_objects (GladeProject *project); void glade_project_add_object (GladeProject *project, GladeProject *old_project, GObject *object); void glade_project_remove_object (GladeProject *project, GObject *object); gboolean glade_project_has_object (GladeProject *project, GObject *object); GladeWidget* glade_project_get_widget_by_name (GladeProject *project, const char *name); char* glade_project_new_widget_name (GladeProject *project, const char *base_name); void glade_project_widget_name_changed (GladeProject *project, GladeWidget *widget, const char *old_name); gboolean glade_project_is_selected (GladeProject *project, GObject *object); void glade_project_selection_set (GladeProject *project, GObject *object, gboolean emit_signal); void glade_project_selection_add (GladeProject *project, GObject *object, gboolean emit_signal); void glade_project_selection_remove (GladeProject *project, GObject *object, gboolean emit_signal); void glade_project_selection_clear (GladeProject *project, gboolean emit_signal); void glade_project_selection_changed (GladeProject *project); GList* glade_project_selection_get (GladeProject *project); gboolean glade_project_get_has_selection (GladeProject *project); void glade_project_set_accel_group (GladeProject *project, GtkAccelGroup *accel_group); void glade_project_set_resource (GladeProject *project, GladeProperty *property, const gchar *resource); GList* glade_project_list_resources (GladeProject *project); gchar* glade_project_resource_fullpath (GladeProject *project, const gchar *resource); gboolean glade_project_is_loading (GladeProject *project); time_t glade_project_get_file_mtime (GladeProject *project); guint glade_project_get_instance_count (GladeProject *project); void glade_project_set_instance_count (GladeProject *project, guint instance_count); gboolean glade_project_get_modified (GladeProject *project);
"has-selection" gboolean : Read "modified" gboolean : Read "path" gchararray : Read "read-only" gboolean : Read
"add-widget" : Run Last "changed" : Run First "close" : Run Last "parse-finished" : Run First "remove-widget" : Run Last "resource-added" : Run Last "resource-removed" : Run Last "selection-changed" : Run Last "widget-name-changed" : Run Last
This object owns all project objects and is responsable for loading and saving the glade document, you can monitor the project state via this object and its signals.
typedef enum
{
	GLADE_PROJECT_FORMAT_LIBGLADE,
	GLADE_PROJECT_FORMAT_GTKBUILDER
} GladeProjectFormat;
GladeProject* glade_project_new (void);
Creates a new GladeProject.
| Returns : | a new GladeProject | 
void glade_project_set_format (GladeProject *project, GladeProjectFormat format);
gboolean glade_project_load_from_file (GladeProject *project, const gchar *path);
GladeProject* glade_project_load (const gchar *path);
Opens a project at the given path.
| path: | |
| Returns : | a new GladeProject for the opened project on success, NULLon 
         failure | 
gboolean glade_project_save (GladeProject *project, const gchar *path, GError **error);
Saves project to the given path.
| project: | a GladeProject | 
| path: | location to save glade file | 
| error: | an error from the G_FILE_ERROR domain. | 
| Returns : | TRUEon success,FALSEon failure | 
void glade_project_undo (GladeProject *project);
Redoes a GladeCommand in this project.
| project: | a GladeProject | 
GladeCommand* glade_project_next_undo_item (GladeProject *project);
Gets the next undo item on project's command stack.
| project: | a GladeProject | 
| Returns : | the GladeCommand | 
GladeCommand* glade_project_next_redo_item (GladeProject *project);
Gets the next redo item on project's command stack.
| project: | a GladeProject | 
| Returns : | the GladeCommand | 
void glade_project_push_undo (GladeProject *project, GladeCommand *cmd);
Pushes a newly created GladeCommand onto projects stack.
| project: | a GladeProject | 
| cmd: | the GladeCommand | 
GtkWidget* glade_project_undo_items (GladeProject *project);
Creates a menu of the undo items in the project stack
| project: | A GladeProject | 
| Returns : | A newly created menu | 
GtkWidget* glade_project_redo_items (GladeProject *project);
Creates a menu of the undo items in the project stack
| project: | A GladeProject | 
| Returns : | A newly created menu | 
gboolean glade_project_get_readonly (GladeProject *project);
Gets whether the project is read only or not
| project: | a GladeProject | 
| Returns : | TRUE if project is read only | 
void glade_project_add_object (GladeProject *project, GladeProject *old_project, GObject *object);
Adds an object to the project.
| project: | the GladeProject the widget is added to | 
| old_project: | the GladeProject the widget was previously in
              (or NULLfor the clipboard) | 
| object: | the GObject to add | 
void glade_project_remove_object (GladeProject *project, GObject *object);
Removes object from project.
Note that when removing the GObject from the project we don't change ->project in the associated GladeWidget; this way UNDO can work.
| project: | a GladeProject | 
| object: | the GObject to remove | 
gboolean glade_project_has_object (GladeProject *project, GObject *object);
| project: | the GladeProject the widget is added to | 
| object: | the GObject to search | 
| Returns : | whether this object is in this project. | 
GladeWidget* glade_project_get_widget_by_name (GladeProject *project, const char *name);
Searches through project looking for a GladeWidget named name.
| project: | a GladeProject | 
| name: | The user visible name of the widget we are looking for | 
| Returns : | a pointer to the widget, NULLif the widget does not exist | 
char* glade_project_new_widget_name (GladeProject *project, const char *base_name);
Creates a new name for a widget that doesn't collide with any of the names 
already in project. This name will start with base_name.
| project: | a GladeProject | 
| base_name: | base name of the widget to create | 
| Returns : | a string containing the new name, NULLif there is not enough 
         memory for this string | 
void glade_project_widget_name_changed (GladeProject *project, GladeWidget *widget, const char *old_name);
TODO: write me
| project: | a GladeProject | 
| widget: | a GladeWidget | 
| old_name: | 
gboolean glade_project_is_selected (GladeProject *project, GObject *object);
| project: | a GladeProject | 
| object: | a GObject | 
| Returns : | whether objectis inprojectselection | 
void glade_project_selection_set (GladeProject *project, GObject *object, gboolean emit_signal);
Set the selection in project to object
If emit_signal is TRUE, calls glade_project_selection_changed().
| project: | a GladeProject | 
| object: | a GObject in project | 
| emit_signal: | whether or not to emit a signal indicating a selection change | 
void glade_project_selection_add (GladeProject *project, GObject *object, gboolean emit_signal);
Adds object to the selection chain of project
If emit_signal is TRUE, calls glade_project_selection_changed().
| project: | a GladeProject | 
| object: | a GObject in project | 
| emit_signal: | whether or not to emit a signal indicating a selection change | 
void glade_project_selection_remove (GladeProject *project, GObject *object, gboolean emit_signal);
Removes object from the selection chain of project
If emit_signal is TRUE, calls glade_project_selection_changed().
| project: | a GladeProject | 
| object: | a GObject in project | 
| emit_signal: | whether or not to emit a signal indicating a selection change | 
void glade_project_selection_clear (GladeProject *project, gboolean emit_signal);
Clears project's selection chain
If emit_signal is TRUE, calls glade_project_selection_changed().
| project: | a GladeProject | 
| emit_signal: | whether or not to emit a signal indication a selection change | 
void glade_project_selection_changed (GladeProject *project);
Causes project to emit a "selection_changed" signal.
| project: | a GladeProject | 
GList* glade_project_selection_get (GladeProject *project);
| project: | a GladeProject | 
| Returns : | a GList containing the GtkWidget items currently selected in project | 
gboolean glade_project_get_has_selection (GladeProject *project);
| project: | a GladeProject | 
| Returns : | whether projectcurrently has a selection | 
void glade_project_set_accel_group (GladeProject *project, GtkAccelGroup *accel_group);
Set accel_group to every top level widget in project.
| project: | A GladeProject | 
| accel_group: | The GtkAccelGroup | 
void glade_project_set_resource (GladeProject *project, GladeProperty *property, const gchar *resource);
Adds/Modifies/Removes a resource from a project; any project resources will be copied when using "Save As...", when moving widgets across projects and will be copied into the project's directory when selected.
| project: | A GladeProject | 
| property: | The GladeProperty this resource is required by | 
| resource: | The resource file basename to be found in the same directory as the glade file. | 
GList* glade_project_list_resources (GladeProject *project);
| project: | A GladeProject | 
| Returns : | A newly allocated GList of file basenames of resources in this project, note that the strings are not allocated and are unsafe to use once the projects state changes. The returned list should be freed with g_list_free. | 
gchar* glade_project_resource_fullpath (GladeProject *project, const gchar *resource);
| project: | The GladeProject. | 
| resource: | The resource basename | 
| Returns : | A newly allocated string holding the full path the the project resource. | 
gboolean glade_project_is_loading (GladeProject *project);
| project: | A GladeProject | 
| Returns : | Whether the project is being loaded or not | 
void glade_project_set_instance_count (GladeProject *project, guint instance_count);
gboolean glade_project_get_modified (GladeProject *project);
Get's whether the project has been modified since it was last saved.
| project: | a GladeProject | 
| Returns : | TRUE if the project has been modified since it was last saved | 
"has-selection" property"has-selection" gboolean : Read
Whether project has a selection.
Default value: FALSE
"modified" property"modified" gboolean : Read
Whether project has been modified since it was last saved.
Default value: FALSE
"path" property"path" gchararray : Read
The filesystem path of the project.
Default value: NULL
"add-widget" signalvoid user_function (GladeProject *gladeproject, GladeWidget *arg1, gpointer user_data) : Run Last
Emitted when a widget is added to a project.
| gladeproject: | the GladeProject which received the signal. | 
| arg1: | the GladeWidget that was added to gladeproject. | 
| user_data: | user data set when the signal handler was connected. | 
"changed" signalvoid user_function (GladeProject *gladeproject, GladeCommand *arg1, gboolean arg2, gpointer user_data) : Run First
Emitted when a gladeproject's state changes via a GladeCommand.
| gladeproject: | the GladeProject which received the signal. | 
| arg1: | the GladeCommand that was executed | 
| arg2: | whether the command was executed or undone. | 
| user_data: | user data set when the signal handler was connected. | 
"close" signalvoid user_function (GladeProject *gladeproject, gpointer user_data) : Run Last
Emitted when a project is closing (a good time to clean up any associated resources).
| gladeproject: | the GladeProject which received the signal. | 
| user_data: | user data set when the signal handler was connected. | 
"parse-finished" signalvoid user_function (GladeProject *gladeproject, gpointer user_data) : Run First
Emitted when gladeproject parsing has finished.
| gladeproject: | the GladeProject which received the signal. | 
| user_data: | user data set when the signal handler was connected. | 
"remove-widget" signalvoid user_function (GladeProject *gladeproject, GladeWidget *arg1, gpointer user_data) : Run Last
Emitted when a widget is removed from a project.
| gladeproject: | the GladeProject which received the signal. | 
| arg1: | the GladeWidget that was removed from gladeproject. | 
| user_data: | user data set when the signal handler was connected. | 
"resource-added" signalvoid user_function (GladeProject *gladeproject, gchar *arg1, gpointer user_data) : Run Last
Emitted when a resource file required by a GladeProperty is
added to gladeproject
| gladeproject: | the GladeProject which received the signal. | 
| arg1: | the file's basename (in the project path). | 
| user_data: | user data set when the signal handler was connected. | 
"resource-removed" signalvoid user_function (GladeProject *gladeproject, gchar *arg1, gpointer user_data) : Run Last
Emitted when a resource file is removed from gladeproject
| gladeproject: | the GladeProject which received the signal. | 
| arg1: | the file's basename | 
| user_data: | user data set when the signal handler was connected. | 
"selection-changed" signalvoid user_function (GladeProject *gladeproject, gpointer user_data) : Run Last
Emitted when gladeproject selection list changes.
| gladeproject: | the GladeProject which received the signal. | 
| user_data: | user data set when the signal handler was connected. | 
"widget-name-changed" signalvoid user_function (GladeProject *gladeproject, GladeWidget *arg1, gpointer user_data) : Run Last
Emitted when gwidget's name changes.
| gladeproject: | the GladeProject which received the signal. | 
| arg1: | the GladeWidget who's name changed. | 
| user_data: | user data set when the signal handler was connected. |