diff options
author | JP Rosevear <jpr@ximian.com> | 2004-01-24 05:36:53 +0000 |
---|---|---|
committer | JP Rosevear <jpr@src.gnome.org> | 2004-01-24 05:36:53 +0000 |
commit | 4fb59bd0298eac1e8f0d98c53a81858ba8b9bbd1 (patch) | |
tree | 3b93e4bc50538042658c22057d0afcef9d92f405 | |
parent | 84a4fe92ec256a62ede06b0b21236956337aaf56 (diff) | |
download | evolution-data-server-EVOLUTION_1_5_3.tar.gz |
if the source is primary, don't allow it to be un-selectedEVOLUTION_1_5_3
2004-01-24 JP Rosevear <jpr@ximian.com>
* e-source-selector.c (cell_toggled_callback): if the source is
primary, don't allow it to be un-selected
-rw-r--r-- | libedataserverui/e-source-selector.c | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/libedataserverui/e-source-selector.c b/libedataserverui/e-source-selector.c index f64c192bd..f26ce4030 100644 --- a/libedataserverui/e-source-selector.c +++ b/libedataserverui/e-source-selector.c @@ -475,17 +475,20 @@ cell_toggled_callback (GtkCellRendererToggle *renderer, gtk_tree_path_free (path); } else { source = E_SOURCE (data); - if (source_is_selected (selector, source)) - unselect_source (selector, source); - else - select_source (selector, source); - - selector->priv->toggled_last = TRUE; - - gtk_tree_model_row_changed (model, path, &iter); - g_signal_emit (selector, signals[SELECTION_CHANGED], 0); - - gtk_tree_path_free (path); + + if (e_source_selector_peek_primary_selection (selector) != source) { + if (source_is_selected (selector, source)) + unselect_source (selector, source); + else + select_source (selector, source); + + selector->priv->toggled_last = TRUE; + + gtk_tree_model_row_changed (model, path, &iter); + g_signal_emit (selector, signals[SELECTION_CHANGED], 0); + + gtk_tree_path_free (path); + } } g_object_unref (data); |