diff options
-rw-r--r-- | camel/ChangeLog | 9 | ||||
-rw-r--r-- | camel/providers/local/camel-mbox-summary.c | 23 |
2 files changed, 30 insertions, 2 deletions
diff --git a/camel/ChangeLog b/camel/ChangeLog index 1932b03d14..84adfa5ec4 100644 --- a/camel/ChangeLog +++ b/camel/ChangeLog @@ -1,3 +1,10 @@ +2004-03-02 Jeffrey Stedfast <fejj@ximian.com> + + * providers/local/camel-mbox-summary.c + (mbox_summary_encode_x_evolution): Overrides the parent method. We + don't want to encode user flags/tags or the size of the header + will change and force a complete rewrite of the mbox file. + 2004-02-25 Jeffrey Stedfast <fejj@ximian.com> * camel-filter-driver.c (camel_filter_driver_filter_folder): Free @@ -9,7 +16,7 @@ corruption if using Heimdal's implementation of Kerberos5. Yay Heimdal. -2004-02-25 <rodo@ximian.com> +2004-02-25 Radek Doulik <rodo@ximian.com> * camel-folder.c (get_unread_message_count): do not avoid junk mails in unread count diff --git a/camel/providers/local/camel-mbox-summary.c b/camel/providers/local/camel-mbox-summary.c index ac87fd2476..c34df06114 100644 --- a/camel/providers/local/camel-mbox-summary.c +++ b/camel/providers/local/camel-mbox-summary.c @@ -35,6 +35,7 @@ #include <errno.h> #include <string.h> #include <stdlib.h> +#include <ctype.h> #include "camel-mbox-summary.h" #include "camel/camel-file-utils.h" @@ -55,6 +56,8 @@ static CamelMessageInfo * message_info_load (CamelFolderSummary *, FILE *); static int message_info_save (CamelFolderSummary *, FILE *, CamelMessageInfo *); /*static void message_info_free (CamelFolderSummary *, CamelMessageInfo *);*/ +static char *mbox_summary_encode_x_evolution (CamelLocalSummary *cls, const CamelMessageInfo *mi); + static int mbox_summary_check(CamelLocalSummary *cls, CamelFolderChangeInfo *changeinfo, CamelException *ex); static int mbox_summary_sync(CamelLocalSummary *cls, gboolean expunge, CamelFolderChangeInfo *changeinfo, CamelException *ex); #ifdef STATUS_PINE @@ -113,7 +116,8 @@ camel_mbox_summary_class_init(CamelMboxSummaryClass *klass) sklass->message_info_load = message_info_load; sklass->message_info_save = message_info_save; /*sklass->message_info_free = message_info_free;*/ - + + lklass->encode_x_evolution = mbox_summary_encode_x_evolution; lklass->check = mbox_summary_check; lklass->sync = mbox_summary_sync; #ifdef STATUS_PINE @@ -164,6 +168,23 @@ void camel_mbox_summary_xstatus(CamelMboxSummary *mbs, int state) mbs->xstatus = state; } +static char * +mbox_summary_encode_x_evolution (CamelLocalSummary *cls, const CamelMessageInfo *mi) +{ + const char *p, *uidstr; + guint32 uid; + + p = uidstr = camel_message_info_uid (mi); + while (*p && isdigit (*p)) + p++; + + if (*p == 0 && sscanf (uidstr, "%u", &uid) == 1) { + return g_strdup_printf ("%08x-%04x", uid, mi->flags & 0xffff); + } else { + return g_strdup_printf ("%s-%04x", uidstr, mi->flags & 0xffff); + } +} + static int summary_header_load(CamelFolderSummary *s, FILE *in) { |