aboutsummaryrefslogtreecommitdiffstats
path: root/mail/em-folder-tree-model.c
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@ximian.com>2004-05-08 04:36:18 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2004-05-08 04:36:18 +0800
commita02934f6a81406fa9509025e94199e9e78ea59a8 (patch)
tree936bd1e9a56db46f0358956f6166913b10799050 /mail/em-folder-tree-model.c
parent6b70641a976fd56ca4df9b49e620da0fd1b3e2df (diff)
downloadgsoc2013-evolution-a02934f6a81406fa9509025e94199e9e78ea59a8.tar
gsoc2013-evolution-a02934f6a81406fa9509025e94199e9e78ea59a8.tar.gz
gsoc2013-evolution-a02934f6a81406fa9509025e94199e9e78ea59a8.tar.bz2
gsoc2013-evolution-a02934f6a81406fa9509025e94199e9e78ea59a8.tar.lz
gsoc2013-evolution-a02934f6a81406fa9509025e94199e9e78ea59a8.tar.xz
gsoc2013-evolution-a02934f6a81406fa9509025e94199e9e78ea59a8.tar.zst
gsoc2013-evolution-a02934f6a81406fa9509025e94199e9e78ea59a8.zip
Fix for bug #57152.
2004-05-07 Jeffrey Stedfast <fejj@ximian.com> Fix for bug #57152. * em-folder-tree.c (emft_get_folder_info__got): If we queried for a recursive folder-info listing, then pass fully_loaded as TRUE to set_folder_info(). (emft_get_folder_info__got): If we find that a folder doesn't have children, set the expanded state to FALSE. * em-folder-tree-model.c (em_folder_tree_model_set_folder_info): Now takes a "fully_loaded" argument to hint to set_folder_info whether or not folder-info's without child nodes can possibly have children (eg. if fully_loaded is set and fi->child is NULL, then 'load' will be FALSE no matter what fi->flags contains). svn path=/trunk/; revision=25826
Diffstat (limited to 'mail/em-folder-tree-model.c')
-rw-r--r--mail/em-folder-tree-model.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/mail/em-folder-tree-model.c b/mail/em-folder-tree-model.c
index 8c81be9735..571ac3042b 100644
--- a/mail/em-folder-tree-model.c
+++ b/mail/em-folder-tree-model.c
@@ -411,17 +411,18 @@ account_removed (EAccountList *accounts, EAccount *account, gpointer user_data)
void
em_folder_tree_model_set_folder_info (EMFolderTreeModel *model, GtkTreeIter *iter,
struct _EMFolderTreeModelStoreInfo *si,
- CamelFolderInfo *fi)
+ CamelFolderInfo *fi, int fully_loaded)
{
GtkTreeRowReference *uri_row, *path_row;
unsigned int unread;
GtkTreePath *path;
GtkTreeIter sub;
- gboolean load;
+ gboolean load = FALSE;
struct _CamelFolder *folder;
gboolean emitted = FALSE;
- load = fi->child == NULL && !(fi->flags & (CAMEL_FOLDER_NOCHILDREN | CAMEL_FOLDER_NOINFERIORS));
+ if (!fully_loaded)
+ load = fi->child == NULL && !(fi->flags & (CAMEL_FOLDER_NOCHILDREN | CAMEL_FOLDER_NOINFERIORS));
path = gtk_tree_model_get_path ((GtkTreeModel *) model, iter);
uri_row = gtk_tree_row_reference_new ((GtkTreeModel *) model, path);
@@ -493,7 +494,7 @@ em_folder_tree_model_set_folder_info (EMFolderTreeModel *model, GtkTreeIter *ite
emitted = TRUE;
}
- em_folder_tree_model_set_folder_info (model, &sub, si, fi);
+ em_folder_tree_model_set_folder_info (model, &sub, si, fi, fully_loaded);
fi = fi->next;
} while (fi);
}
@@ -558,7 +559,7 @@ folder_subscribed (CamelStore *store, CamelFolderInfo *fi, EMFolderTreeModel *mo
/* append a new node */
gtk_tree_store_append ((GtkTreeStore *) model, &iter, &parent);
- em_folder_tree_model_set_folder_info (model, &iter, si, fi);
+ em_folder_tree_model_set_folder_info (model, &iter, si, fi, TRUE);
g_signal_emit (model, signals[FOLDER_ADDED], 0, fi->path, fi->uri);
@@ -701,7 +702,7 @@ folder_renamed (CamelStore *store, CamelRenameInfo *info, EMFolderTreeModel *mod
}
gtk_tree_store_append ((GtkTreeStore *) model, &iter, &root);
- em_folder_tree_model_set_folder_info (model, &iter, si, info->new);
+ em_folder_tree_model_set_folder_info (model, &iter, si, info->new, TRUE);
done: