diff options
author | Christopher James Lahey <clahey@ximian.com> | 2002-05-14 15:04:49 +0800 |
---|---|---|
committer | Chris Lahey <clahey@src.gnome.org> | 2002-05-14 15:04:49 +0800 |
commit | eec3b5a2f3d0d4ca1211c0f3ddec19e707cfbf22 (patch) | |
tree | d9169ec9c6f6aadc7678c78c7d449f1e667c168d /widgets/menus | |
parent | e17f52c2110226f97b9d63d212a3e6be203f92ad (diff) | |
download | gsoc2013-evolution-eec3b5a2f3d0d4ca1211c0f3ddec19e707cfbf22.tar.gz gsoc2013-evolution-eec3b5a2f3d0d4ca1211c0f3ddec19e707cfbf22.tar.zst gsoc2013-evolution-eec3b5a2f3d0d4ca1211c0f3ddec19e707cfbf22.zip |
Made it so that if the current_id doesn't match any of the given ids, it
2002-05-14 Christopher James Lahey <clahey@ximian.com>
* menus/gal-view-menus.c (build_menus): Made it so that if the
current_id doesn't match any of the given ids, it treats it the
same as a NULL id.
(gal_view_menus_apply): Added a check for gvm->priv == NULL here.
(gal_view_menus_apply, collection_changed, instance_changed):
Removed calls to set_radio after build_stuff, since the last thing
build_stuff does is calls set_radio.
svn path=/trunk/; revision=16781
Diffstat (limited to 'widgets/menus')
-rw-r--r-- | widgets/menus/gal-view-menus.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/widgets/menus/gal-view-menus.c b/widgets/menus/gal-view-menus.c index 312f492a7f..6c796dd6ee 100644 --- a/widgets/menus/gal-view-menus.c +++ b/widgets/menus/gal-view-menus.c @@ -252,6 +252,7 @@ build_menus(GalViewMenus *menus) GalViewInstance *instance = menus->priv->instance; GalViewCollection *collection = instance->collection; char *id; + gboolean found = FALSE; root = bonobo_ui_node_new("Root"); menu = bonobo_ui_node_new_child(root, "menu"); @@ -269,6 +270,7 @@ build_menus(GalViewMenus *menus) id = gal_view_instance_get_current_view_id (instance); + length = gal_view_collection_get_count(collection); menus->priv->listenerClosures = e_list_new (closure_copy, closure_free, menus); @@ -300,6 +302,10 @@ build_menus(GalViewMenus *menus) closure->id = item->id; closure->ref_count = 1; + if (!found && id && !strcmp (item->id, id)) { + found = TRUE; + } + gtk_object_ref (GTK_OBJECT(closure->instance)); bonobo_ui_component_add_listener (menus->priv->component, item->id, toggled_cb, closure); @@ -308,7 +314,7 @@ build_menus(GalViewMenus *menus) closure_free (closure, menus); } - if (id == NULL) { + if (!found) { menuitem = bonobo_ui_node_new_child(submenu, "separator"); bonobo_ui_node_set_attr(menuitem, "name", "GalView:first_sep"); @@ -417,6 +423,9 @@ gal_view_menus_apply (GalViewMenus *gvm, BonoboUIComponent *component, CORBA_Environment *opt_ev) { + if (gvm->priv == NULL) + return; + if (component != gvm->priv->component) { if (component) bonobo_object_ref (BONOBO_OBJECT (component)); @@ -428,7 +437,6 @@ gal_view_menus_apply (GalViewMenus *gvm, gvm->priv->component = component; build_stuff (gvm, opt_ev); - set_radio (gvm, opt_ev); } void @@ -450,7 +458,6 @@ collection_changed (GalViewCollection *collection, CORBA_exception_init (&ev); build_stuff(gvm, &ev); - set_radio (gvm, &ev); CORBA_exception_free (&ev); } @@ -462,7 +469,6 @@ instance_changed (GalViewInstance *instance, CORBA_exception_init (&ev); build_stuff(gvm, &ev); - set_radio (gvm, &ev); CORBA_exception_free (&ev); } |