aboutsummaryrefslogtreecommitdiffstats
path: root/mail
diff options
context:
space:
mode:
authorMatthew Barnes <mbarnes@redhat.com>2011-08-18 07:06:27 +0800
committerRodrigo Moya <rodrigo@gnome-db.org>2011-09-14 20:08:51 +0800
commit87e18345094a649f2d6940d1ebd12b79454d7a94 (patch)
treea2b55edf296d74e7b3b43aa0d87600fc6992fe5f /mail
parentee3863cc54fb76f4f7e24c70b5598a136d987799 (diff)
downloadgsoc2013-evolution-87e18345094a649f2d6940d1ebd12b79454d7a94.tar
gsoc2013-evolution-87e18345094a649f2d6940d1ebd12b79454d7a94.tar.gz
gsoc2013-evolution-87e18345094a649f2d6940d1ebd12b79454d7a94.tar.bz2
gsoc2013-evolution-87e18345094a649f2d6940d1ebd12b79454d7a94.tar.lz
gsoc2013-evolution-87e18345094a649f2d6940d1ebd12b79454d7a94.tar.xz
gsoc2013-evolution-87e18345094a649f2d6940d1ebd12b79454d7a94.tar.zst
gsoc2013-evolution-87e18345094a649f2d6940d1ebd12b79454d7a94.zip
Bug 656718 - Runtime warning in folder_tree_get_folder_info_cb()
If we've just set up an NNTP account and haven't subscribed to any folders yet, the folder_info tree may legitimately be NULL. Don't treat it as an error.
Diffstat (limited to 'mail')
-rw-r--r--mail/em-folder-tree.c29
1 files changed, 16 insertions, 13 deletions
diff --git a/mail/em-folder-tree.c b/mail/em-folder-tree.c
index eb7b3e4215..18320eccf7 100644
--- a/mail/em-folder-tree.c
+++ b/mail/em-folder-tree.c
@@ -293,13 +293,9 @@ folder_tree_get_folder_info_cb (CamelStore *store,
return;
}
- if (!folder_info) {
- g_warn_if_fail (folder_info != NULL);
- async_context_free (context);
- return;
- }
-
- g_return_if_fail (folder_info != NULL);
+ /* If we've just set up an NNTP account, for example, and haven't
+ * subscribed to any folders yet, folder_info may legitimately be
+ * NULL at this point. We handle that case below. Proceed. */
/* Check if the store has been removed. */
si = em_folder_tree_model_lookup_store_info (
@@ -336,17 +332,24 @@ folder_tree_get_folder_info_cb (CamelStore *store,
}
iter = titer;
+ child_info = folder_info;
/* FIXME Camel's IMAP code is totally on crack here: the
* folder_info we got back should be for the folder
* we're expanding, and folder_info->child should be
* what we want to fill our tree with... *sigh* */
- if (g_strcmp0 (folder_info->full_name, context->full_name) == 0) {
- child_info = folder_info->child;
- if (child_info == NULL)
- child_info = folder_info->next;
- } else
- child_info = folder_info;
+ if (folder_info != NULL) {
+ gboolean names_match;
+
+ names_match = (g_strcmp0 (
+ folder_info->full_name,
+ context->full_name) == 0);
+ if (names_match) {
+ child_info = folder_info->child;
+ if (child_info == NULL)
+ child_info = folder_info->next;
+ }
+ }
/* The folder being expanded has no children after all. Remove
* the "Loading..." placeholder row and collapse the parent. */