aboutsummaryrefslogtreecommitdiffstats
path: root/camel/providers
diff options
context:
space:
mode:
Diffstat (limited to 'camel/providers')
-rw-r--r--camel/providers/imap/camel-imap-folder.c21
-rw-r--r--camel/providers/imap/camel-imap-store.c2
2 files changed, 14 insertions, 9 deletions
diff --git a/camel/providers/imap/camel-imap-folder.c b/camel/providers/imap/camel-imap-folder.c
index fcb6cba5a2..16533dbc1c 100644
--- a/camel/providers/imap/camel-imap-folder.c
+++ b/camel/providers/imap/camel-imap-folder.c
@@ -286,11 +286,9 @@ imap_refresh_info (CamelFolder *folder, CamelException *ex)
}
}
- /* Theoretically, the UIDs could get arbitrarily reordered,
- * but that won't normally happen. We assume that if we find a
- * UID in the summary that doesn't correspond to the UID in
- * the folder, that it means the message was deleted on the
- * server, so we remove it from the summary.
+ /* If we find a UID in the summary that doesn't correspond to
+ * the UID in the folder, that it means the message was
+ * deleted on the server, so we remove it from the summary.
*/
summary_len = camel_folder_summary_count (imap_folder->summary);
for (i = 0; i < summary_len && i < imap_folder->exists; i++) {
@@ -314,13 +312,20 @@ imap_refresh_info (CamelFolder *folder, CamelException *ex)
g_free (new[i].uid);
}
+ /* Remove any leftover cached summary messages. */
+ while (summary_len > i + 1) {
+ camel_folder_summary_remove_index (imap_folder->summary,
+ --summary_len);
+ }
+
+ /* Add any new folder messages. */
if (i < imap_folder->exists) {
/* Fetch full summary for the remaining messages. */
imap_update_summary (folder, i + 1, imap_folder->exists, ex);
- }
- for (; i < imap_folder->exists; i++)
- g_free (new[i].uid);
+ while (i < imap_folder->exists)
+ g_free (new[i++].uid);
+ }
g_free (new);
}
diff --git a/camel/providers/imap/camel-imap-store.c b/camel/providers/imap/camel-imap-store.c
index 6ad48107b1..ae4c13c150 100644
--- a/camel/providers/imap/camel-imap-store.c
+++ b/camel/providers/imap/camel-imap-store.c
@@ -448,7 +448,7 @@ get_folder (CamelStore *store, const char *folder_name, gboolean create, CamelEx
summary_file = g_strdup_printf ("%s/%s/#summary",
imap_store->storage_path,
- folder_path);
+ folder_name);
p = strrchr (summary_file, '/');
*p = '\0';
if (e_mkdir_hier (summary_file, S_IRWXU) == 0) {