|  |  |  | Exo Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Signals | ||||
| ExoToolbarsModelExoToolbarsModel — The toolbars backend used by ExoToolbarsView | 
#include <exo/exo.h>
                    ExoToolbarsModel;
enum                ExoToolbarsModelFlags;
#define             EXO_TOOLBARS_ITEM_TYPE
ExoToolbarsModel *  exo_toolbars_model_new              (void);
void                exo_toolbars_model_set_actions      (ExoToolbarsModel *model,
                                                         gchar **actions,
                                                         guint n_actions);
gchar **            exo_toolbars_model_get_actions      (ExoToolbarsModel *model);
gboolean            exo_toolbars_model_load_from_file   (ExoToolbarsModel *model,
                                                         const gchar *filename,
                                                         GError **error);
gboolean            exo_toolbars_model_save_to_file     (ExoToolbarsModel *model,
                                                         const gchar *filename,
                                                         GError **error);
ExoToolbarsModelFlags  exo_toolbars_model_get_flags     (ExoToolbarsModel *model,
                                                         gint toolbar_position);
void                exo_toolbars_model_set_flags        (ExoToolbarsModel *model,
                                                         ExoToolbarsModelFlags flags,
                                                         gint toolbar_position);
GtkToolbarStyle     exo_toolbars_model_get_style        (ExoToolbarsModel *model,
                                                         gint toolbar_position);
void                exo_toolbars_model_set_style        (ExoToolbarsModel *model,
                                                         GtkToolbarStyle style,
                                                         gint toolbar_position);
void                exo_toolbars_model_unset_style      (ExoToolbarsModel *model,
                                                         gint toolbar_position);
gchar *             exo_toolbars_model_get_item_type    (ExoToolbarsModel *model,
                                                         GdkAtom dnd_type);
gchar *             exo_toolbars_model_get_item_id      (ExoToolbarsModel *model,
                                                         const gchar *type,
                                                         const gchar *name);
gchar *             exo_toolbars_model_get_item_data    (ExoToolbarsModel *model,
                                                         const gchar *type,
                                                         const gchar *id);
gboolean            exo_toolbars_model_add_item         (ExoToolbarsModel *model,
                                                         gint toolbar_position,
                                                         gint item_position,
                                                         const gchar *id,
                                                         const gchar *type);
void                exo_toolbars_model_add_separator    (ExoToolbarsModel *model,
                                                         gint toolbar_position,
                                                         gint item_position);
gint                exo_toolbars_model_add_toolbar      (ExoToolbarsModel *model,
                                                         gint toolbar_position,
                                                         const gchar *name);
void                exo_toolbars_model_move_item        (ExoToolbarsModel *model,
                                                         gint toolbar_position,
                                                         gint item_position,
                                                         gint new_toolbar_position,
                                                         gint new_item_position);
void                exo_toolbars_model_remove_item      (ExoToolbarsModel *model,
                                                         gint toolbar_position,
                                                         gint item_position);
void                exo_toolbars_model_remove_toolbar   (ExoToolbarsModel *model,
                                                         gint toolbar_position);
gint                exo_toolbars_model_n_items          (ExoToolbarsModel *model,
                                                         gint toolbar_position);
void                exo_toolbars_model_item_nth         (ExoToolbarsModel *model,
                                                         gint toolbar_position,
                                                         gint item_position,
                                                         gboolean *is_separator,
                                                         const gchar **id,
                                                         const gchar **type);
gint                exo_toolbars_model_n_toolbars       (ExoToolbarsModel *model);
const gchar *       exo_toolbars_model_toolbar_nth      (ExoToolbarsModel *model,
                                                         gint toolbar_position);
"get-item-data" : Run First "get-item-id" : Run First "get-item-type" : Run First "item-added" : Run Last "item-removed" : Run Last "toolbar-added" : Run Last "toolbar-changed" : Run Last "toolbar-removed" : Run Last
The ExoToolbarsModel class includes the basic functionality to manage editable toolbars.
typedef struct _ExoToolbarsModel ExoToolbarsModel;
The ExoToolbarsModel struct contains only private fields and should not be directly accessed.
typedef enum
{
  EXO_TOOLBARS_MODEL_NOT_REMOVABLE      = 1 << 0,
  EXO_TOOLBARS_MODEL_ACCEPT_ITEMS_ONLY  = 1 << 1,
  EXO_TOOLBARS_MODEL_OVERRIDE_STYLE     = 1 << 2,
} ExoToolbarsModelFlags;
| Not possible to remove items from the model. | |
| Only accept new item, dragging items around is disabled. | |
| If set, the ExoToolbarsModel
                                        accepts a custom GtkToolbarStyle. See exo_toolbars_model_set_style(). | 
#define EXO_TOOLBARS_ITEM_TYPE
The string used for drag-and-drop in the toolbars editor/model.
ExoToolbarsModel *  exo_toolbars_model_new              (void);
Creates a new ExoToolbarsModel with a reference count of one.
You need to call exo_toolbars_model_set_actions() first, after
you created an ExoToolbarsModel to set the list of actions,
that should be available from the toolbars.
| Returns : | A newly created ExoToolbarsModel. | 
void exo_toolbars_model_set_actions (ExoToolbarsModel *model,gchar **actions,guint n_actions);
Specifies the list of valid actions for model. model will only
manage actions that are specified in this list. This function
should be called right after you created model.
| 
 | An ExoToolbarsModel. | 
| 
 | A string array with action names. | 
| 
 | The number of strings in actions. | 
gchar **            exo_toolbars_model_get_actions      (ExoToolbarsModel *model);
Returns the list of valid actions for model.
| 
 | An ExoToolbarsModel. | 
| Returns : | The list of valid actions for model. | 
gboolean exo_toolbars_model_load_from_file (ExoToolbarsModel *model,const gchar *filename,GError **error);
Parses a file containing a toolbars UI definition and merges it with
the current contents of model.
| 
 | An ExoToolbarsModel. | 
| 
 | The name of the file to parse. | 
| 
 | Return location for an error or NULL. | 
| Returns : | TRUEif the data was successfully loaded from the file
         specified byfilename, elseFALSE. | 
gboolean exo_toolbars_model_save_to_file (ExoToolbarsModel *model,const gchar *filename,GError **error);
Stores the UI definition of the contents of model to the file
specified by filename.
| 
 | An ExoToolbarsModel. | 
| 
 | The name of the file to save to. | 
| 
 | The return location for an error or NULL. | 
| Returns : | TRUEif saving was successfully, elseFALSEis returned. | 
ExoToolbarsModelFlags exo_toolbars_model_get_flags (ExoToolbarsModel *model,gint toolbar_position);
Returns the ExoToolbarsModelFlags associated with the
toolbar at toolbar_position.
| 
 | An ExoToolbarsModel. | 
| 
 | The index of a toolbar in model. | 
| Returns : | The ExoToolbarsModelFlags associated with toolbar_position. | 
void exo_toolbars_model_set_flags (ExoToolbarsModel *model,ExoToolbarsModelFlags flags,gint toolbar_position);
Changes the ExoToolbarsModelFlags associated with the
toolbar at toolbar_position to the value of flags.
| 
 | An ExoToolbarsModel. | 
| 
 | The new flags for toolbar_position. | 
| 
 | The index of a toolbar in model. | 
GtkToolbarStyle exo_toolbars_model_get_style (ExoToolbarsModel *model,gint toolbar_position);
Returns the overridden GtkToolbarStyle for the toolbar
at toolbar_position. Should only be used if
EXO_TOOLBARS_MODEL_OVERRIDE_STYLE is set for the
toolbar.
| 
 | An ExoToolbarsModel. | 
| 
 | The index of a toolbar in model. | 
| Returns : | The GtkToolbarStyle associated with toolbar_position. | 
void exo_toolbars_model_set_style (ExoToolbarsModel *model,GtkToolbarStyle style,gint toolbar_position);
Sets the style to use for a particular toolbar in model. You can
undo the effect of this function by calling
exo_toolbars_model_unset_style().
| 
 | An ExoToolbarsModel. | 
| 
 | A GtkToolbarStyle. | 
| 
 | The index of a toolbar in model. | 
void exo_toolbars_model_unset_style (ExoToolbarsModel *model,gint toolbar_position);
Undoes the effect of exo_toolbars_model_unset_style() and resets
the style of the specified toolbar to the system default.
| 
 | An ExoToolbarsModel. | 
| 
 | The index of a toolbar in model. | 
gchar * exo_toolbars_model_get_item_type (ExoToolbarsModel *model,GdkAtom dnd_type);
FIXME.
| 
 | An ExoToolbarsModel. | 
| 
 | FIXME. | 
| Returns : | FIXME. | 
gchar * exo_toolbars_model_get_item_id (ExoToolbarsModel *model,const gchar *type,const gchar *name);
FIXME.
| 
 | An ExoToolbarsModel. | 
| 
 | FIXME. | 
| 
 | FIXME. | 
| Returns : | FIXME. | 
gchar * exo_toolbars_model_get_item_data (ExoToolbarsModel *model,const gchar *type,const gchar *id);
FIXME.
| 
 | An ExoToolbarsModel. | 
| 
 | FIXME. | 
| 
 | FIXME. | 
| Returns : | FIXME. | 
gboolean exo_toolbars_model_add_item (ExoToolbarsModel *model,gint toolbar_position,gint item_position,const gchar *id,const gchar *type);
Adds a new toolbar item with the specified type and id to model,
where id has to be a valid action name for model, that was previously
set with exo_toolbars_model_set_actions().
| 
 | An ExoToolbarsModel. | 
| 
 | The index of toolbar in model. | 
| 
 | The position in the specified toolbar or -1. | 
| 
 | The identifier of the new item. | 
| 
 | The type of the new item. | 
| Returns : | TRUEif the item was added successfully, elseFALSE. | 
void exo_toolbars_model_add_separator (ExoToolbarsModel *model,gint toolbar_position,gint item_position);
Adds a new separator item to the specified toolbar in model. If
you specify -1 for item_position, the separator will be appended
to the toolbar, else it will be inserted at the specified item_position.
| 
 | An ExoToolbarsModel. | 
| 
 | The index of a toolbar in model. | 
| 
 | The position in the specified toolbar or -1. | 
gint exo_toolbars_model_add_toolbar (ExoToolbarsModel *model,gint toolbar_position,const gchar *name);
Adds a new toolbar to model. If you specify -1 for toolbar_position,
the toolbar will be appended to model; else the toolbar will be
inserted at the specified position. Emits the ::toolbar-added
signal.
| 
 | An ExoToolbarsModel. | 
| 
 | Where to insert the new toolbar in modelor -1 to append the toolbar. | 
| 
 | The name of the new toolbar. | 
| Returns : | The real position of the new toolbar in model. | 
void exo_toolbars_model_move_item (ExoToolbarsModel *model,gint toolbar_position,gint item_position,gint new_toolbar_position,gint new_item_position);
Moves an item to another position. The move operation is done by first removing the specified item and afterwards readding the item at the new position. Therefore, this functions emits the ::item-removed and ::item-added signals.
| 
 | An ExoToolbarsModel. | 
| 
 | Old toolbar index. | 
| 
 | Old item index. | 
| 
 | New toolbar index. | 
| 
 | New item index. | 
void exo_toolbars_model_remove_item (ExoToolbarsModel *model,gint toolbar_position,gint item_position);
Removes the toolbar item at item_position from the toolbar
toolbar_position in model and emits the ::item-removed
signal.
| 
 | An ExoToolbarsModel. | 
| 
 | A toolbar index. | 
| 
 | The index of the item to remove. | 
void exo_toolbars_model_remove_toolbar (ExoToolbarsModel *model,gint toolbar_position);
Removes the specified toolbar from model and emits
the ::toolbar-removed signal.
| 
 | A ExoToolbarsModel. | 
| 
 | The index of a toolbar in model. | 
gint exo_toolbars_model_n_items (ExoToolbarsModel *model,gint toolbar_position);
Returns the number of items in the specified toolbar.
| 
 | An ExoToolbarsModel. | 
| 
 | The index of a toolbar in model. | 
| Returns : | The number of items in the specified toolbar. | 
void exo_toolbars_model_item_nth (ExoToolbarsModel *model,gint toolbar_position,gint item_position,gboolean *is_separator,const gchar **id,const gchar **type);
Queries the properites of the toolbar item at item_position in toolbar
toolbar_position.
| 
 | An ExoToolbarsModel. | 
| 
 | The index of a toolbar in model. | 
| 
 | The index of an item in the specified toolbar. | 
| 
 | Return location for the separator setting or NULL. | 
| 
 | Return location for the item id or NULL. | 
| 
 | Return location for the item type or NULL. | 
gint                exo_toolbars_model_n_toolbars       (ExoToolbarsModel *model);
Returns the number of toolbars currently
managed by model.
| 
 | An ExoToolbarsModel. | 
| Returns : | The number of toolbars in model. | 
const gchar * exo_toolbars_model_toolbar_nth (ExoToolbarsModel *model,gint toolbar_position);
Returns the name of the toolbar at toolbar_position in
model.
| 
 | An ExoToolbarsModel. | 
| 
 | The index of a toolbar in model. | 
| Returns : | The name of the toolbar at toolbar_positioninmodel. | 
"get-item-data" signalgchar* user_function (ExoToolbarsModel *arg0, gchar *arg1, gchar *arg2, gpointer user_data) : Run First
| 
 | user data set when the signal handler was connected. | 
"get-item-id" signalgchar* user_function (ExoToolbarsModel *arg0, gchar *arg1, gchar *arg2, gpointer user_data) : Run First
| 
 | user data set when the signal handler was connected. | 
"get-item-type" signalgchar* user_function (ExoToolbarsModel *arg0, gpointer arg1, gpointer user_data) : Run First
| 
 | user data set when the signal handler was connected. | 
"item-added" signalvoid user_function (ExoToolbarsModel *model, gint toolbar_position, gint item_position, gpointer user_data) : Run Last
This signal is emitted whenever a new item is added to a toolbar
managed by model.
| 
 | The ExoToolbarsModel to which an item was added. | 
| 
 | The index of the toolbar in modelto which the item
                     was added. | 
| 
 | The index of the new item in the specified toolbar. | 
| 
 | user data set when the signal handler was connected. | 
"item-removed" signalvoid user_function (ExoToolbarsModel *model, gint toolbar_position, gint item_position, gpointer user_data) : Run Last
This signal is emitted whenever an item is removed from a toolbar
managed by model.
| 
 | The ExoToolbarsModel from which an item was removed. | 
| 
 | The index of the toolbar in modelfrom which
                     the item was removed. | 
| 
 | The index of the item in the specified toolbar. | 
| 
 | user data set when the signal handler was connected. | 
"toolbar-added" signalvoid user_function (ExoToolbarsModel *model, gint toolbar_position, gpointer user_data) : Run Last
This signal is emitted whenever a new toolbar is added to model.
| 
 | The ExoToolbarsModel to which a new toolbar was added. | 
| 
 | The index of the new toolbar in model. | 
| 
 | user data set when the signal handler was connected. | 
"toolbar-changed" signalvoid user_function (ExoToolbarsModel *model, gint toolbar_position, gpointer user_data) : Run Last
This signal is emitted whenever the flags or the style of a toolbar
change, which is managed by model. All views connected to model
should then update their internal state of the specified toolbar.
| 
 | The ExoToolbarsModel that manages the changed toolbar. | 
| 
 | The index of the changed toolbar in model. | 
| 
 | user data set when the signal handler was connected. | 
"toolbar-removed" signalvoid user_function (ExoToolbarsModel *model, gint toolbar_position, gpointer user_data) : Run Last
This signal is emitted whenever a toolbar is removed from model.
| 
 | The ExoToolbarsModel | 
| 
 | The index of the toolbar in modelthat was
                     removed. | 
| 
 | user data set when the signal handler was connected. |