diff options
author | Milan Crha <mcrha@redhat.com> | 2012-12-11 16:39:23 +0800 |
---|---|---|
committer | Milan Crha <mcrha@redhat.com> | 2012-12-11 16:39:23 +0800 |
commit | a1e4aae6834243cbf9bc8899e2985fdceba063a5 (patch) | |
tree | b33c8e96273f97060c91db908c64d66f3edd50ae | |
parent | 11cf01088945080550102b693793ec3709174d4a (diff) | |
download | gsoc2013-evolution-a1e4aae6834243cbf9bc8899e2985fdceba063a5.tar.gz gsoc2013-evolution-a1e4aae6834243cbf9bc8899e2985fdceba063a5.tar.zst gsoc2013-evolution-a1e4aae6834243cbf9bc8899e2985fdceba063a5.zip |
Do not restore certificate manager columns when all are hidden
If all columns are hidden, then header of a GtkTreeView is also hidden,
thus there is no way to show columns again, which results in empty
Certificate Preferences view.
-rw-r--r-- | smime/gui/certificate-manager.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/smime/gui/certificate-manager.c b/smime/gui/certificate-manager.c index acddc8a974..3d823e6f8f 100644 --- a/smime/gui/certificate-manager.c +++ b/smime/gui/certificate-manager.c @@ -254,13 +254,19 @@ load_treeview_state (GtkTreeView *treeview) list = g_key_file_get_integer_list (keyfile, tree_name, "columns", &length, NULL); if (list) { + gboolean all_hidden = TRUE; + if (length != (gtk_tree_model_get_n_columns (model) - 1)) { g_debug ("%s: Unexpected number of columns in config file", G_STRFUNC); g_free (list); goto exit; } - for (i = 0; i < length; i++) { + for (i = 0; all_hidden && i < length; i++) { + all_hidden = list[i] == 0; + } + + for (i = 0; !all_hidden && i < length; i++) { GtkTreeViewColumn *column = gtk_tree_view_get_column (treeview, i); if (list[i]) { gtk_tree_view_column_set_sizing (column, GTK_TREE_VIEW_COLUMN_FIXED); |