diff options
author | Christian Persch <chpe@cvs.gnome.org> | 2004-02-19 08:24:50 +0800 |
---|---|---|
committer | Christian Persch <chpe@src.gnome.org> | 2004-02-19 08:24:50 +0800 |
commit | aa8e74d93a2c9fb43da9a5a8259cce7c75b1677f (patch) | |
tree | 58331d8098089f73dc8d8daa91158e8592a11a34 /lib/egg/egg-toolbar-editor.c | |
parent | 01ad74b01b77d67fb5591c2dc960bde63f90fdcd (diff) | |
download | gsoc2013-epiphany-aa8e74d93a2c9fb43da9a5a8259cce7c75b1677f.tar gsoc2013-epiphany-aa8e74d93a2c9fb43da9a5a8259cce7c75b1677f.tar.gz gsoc2013-epiphany-aa8e74d93a2c9fb43da9a5a8259cce7c75b1677f.tar.bz2 gsoc2013-epiphany-aa8e74d93a2c9fb43da9a5a8259cce7c75b1677f.tar.lz gsoc2013-epiphany-aa8e74d93a2c9fb43da9a5a8259cce7c75b1677f.tar.xz gsoc2013-epiphany-aa8e74d93a2c9fb43da9a5a8259cce7c75b1677f.tar.zst gsoc2013-epiphany-aa8e74d93a2c9fb43da9a5a8259cce7c75b1677f.zip |
When removing a toolbar, make its items available again in the toolbar
2004-02-19 Christian Persch <chpe@cvs.gnome.org>
* lib/egg/egg-toolbar-editor.c: (toolbar_removed_cb),
(egg_toolbar_editor_set_model), (egg_toolbar_editor_class_init),
(update_actions_list), (egg_toolbar_editor_load_actions):
* lib/egg/egg-toolbar-editor.h:
When removing a toolbar, make its items available again in the toolbar
editor. Fixes bug #131182.
Diffstat (limited to 'lib/egg/egg-toolbar-editor.c')
-rwxr-xr-x | lib/egg/egg-toolbar-editor.c | 61 |
1 files changed, 44 insertions, 17 deletions
diff --git a/lib/egg/egg-toolbar-editor.c b/lib/egg/egg-toolbar-editor.c index a317ff458..7924e91ef 100755 --- a/lib/egg/egg-toolbar-editor.c +++ b/lib/egg/egg-toolbar-editor.c @@ -44,6 +44,7 @@ static int n_source_drag_types = G_N_ELEMENTS (source_drag_types); static void egg_toolbar_editor_class_init (EggToolbarEditorClass *klass); static void egg_toolbar_editor_init (EggToolbarEditor *t); static void egg_toolbar_editor_finalize (GObject *object); +static void update_actions_list (EggToolbarEditor *editor); static void update_editor_sheet (EggToolbarEditor *editor); enum @@ -161,12 +162,24 @@ egg_toolbar_editor_set_merge (EggToolbarEditor *t, } static void +toolbar_removed_cb (EggToolbarsModel *model, + int position, + EggToolbarEditor *editor) +{ + update_actions_list (editor); + update_editor_sheet (editor); +} + +static void egg_toolbar_editor_set_model (EggToolbarEditor *t, EggToolbarsModel *model) { g_return_if_fail (EGG_IS_TOOLBAR_EDITOR (t)); t->priv->model = g_object_ref (model); + + g_signal_connect_object (model, "toolbar_removed", + G_CALLBACK (toolbar_removed_cb), t, 0); } static void @@ -224,14 +237,16 @@ egg_toolbar_editor_class_init (EggToolbarEditorClass *klass) "MenuMerge", "Menu merge", GTK_TYPE_UI_MANAGER, - G_PARAM_READWRITE)); + G_PARAM_READWRITE | + G_PARAM_CONSTRUCT_ONLY)); g_object_class_install_property (object_class, PROP_TOOLBARS_MODEL, g_param_spec_object ("ToolbarsModel", "ToolbarsModel", "Toolbars Model", EGG_TYPE_TOOLBARS_MODEL, - G_PARAM_READWRITE)); + G_PARAM_READWRITE | + G_PARAM_CONSTRUCT_ONLY)); g_type_class_add_private (object_class, sizeof (EggToolbarEditorPrivate)); } @@ -581,7 +596,7 @@ egg_toolbar_editor_init (EggToolbarEditor *t) setup_editor (t); } -void +static void egg_toolbar_editor_add_action (EggToolbarEditor *editor, const char *action_name) { @@ -638,6 +653,31 @@ model_has_action (EggToolbarsModel *model, GtkAction *action) return FALSE; } +static void +update_actions_list (EggToolbarEditor *editor) +{ + GList *l; + + if (editor->priv->actions_list) + g_list_free (editor->priv->actions_list); + + /* Remove the already used items */ + editor->priv->actions_list = NULL; + + for (l = editor->priv->default_actions_list; l != NULL; l = l->next) + { + GtkAction *action = GTK_ACTION (l->data); + + if (!model_has_action (editor->priv->model, action)) + { + editor->priv->actions_list = g_list_prepend + (editor->priv->actions_list, action); + } + } + + sort_list (editor); +} + void egg_toolbar_editor_load_actions (EggToolbarEditor *editor, const char *xml_file) @@ -662,19 +702,6 @@ egg_toolbar_editor_load_actions (EggToolbarEditor *editor, xmlFreeDoc (doc); - /* Remove the already used items */ - editor->priv->actions_list = g_list_copy (editor->priv->default_actions_list); - for (l = editor->priv->default_actions_list; l != NULL; l = l->next) - { - GtkAction *action = GTK_ACTION (l->data); - - if (model_has_action (editor->priv->model, action)) - { - editor->priv->actions_list = g_list_remove - (editor->priv->actions_list, action); - } - } - sort_list (editor); - + update_actions_list (editor); update_editor_sheet (editor); } |