READ_CACHE_DATA(msginfo->subject, fp);
READ_CACHE_DATA(msginfo->msgid, fp);
READ_CACHE_DATA(msginfo->inreplyto, fp);
+ READ_CACHE_DATA(msginfo->references, fp);
MSG_SET_FLAGS(msginfo->flags, default_flags);
debug_print(_("\tMarking the messages..."));
markdir = folder_item_get_path(item);
+ if (!is_dir_exist(markdir))
+ make_dir_hier(markdir);
+
mark_table = procmsg_read_mark_file(markdir);
g_free(markdir);
return last;
}
+void procmsg_msg_list_free(GSList *mlist)
+{
+ GSList *cur;
+ MsgInfo *msginfo;
+
+ for (cur = mlist; cur != NULL; cur = cur->next) {
+ msginfo = (MsgInfo *)cur->data;
+ procmsg_msginfo_free(msginfo);
+ }
+ g_slist_free(mlist);
+}
+
void procmsg_write_cache(MsgInfo *msginfo, FILE *fp)
{
MsgFlags flags = msginfo->flags & MSG_CACHED_FLAG_MASK;
WRITE_CACHE_DATA(msginfo->subject, fp);
WRITE_CACHE_DATA(msginfo->msgid, fp);
WRITE_CACHE_DATA(msginfo->inreplyto, fp);
+ WRITE_CACHE_DATA(msginfo->references, fp);
}
void procmsg_write_flags(MsgInfo *msginfo, FILE *fp)
MsgFlags flags = GPOINTER_TO_UINT(value);
struct MarkSum *marksum = data;
- if (MSG_IS_NEW(flags)) (*marksum->new)++;
- if (MSG_IS_UNREAD(flags)) (*marksum->unread)++;
+ if (MSG_IS_NEW(flags) && !MSG_IS_IGNORE_THREAD(flags)) (*marksum->new)++;
+ if (MSG_IS_UNREAD(flags) && !MSG_IS_IGNORE_THREAD(flags)) (*marksum->unread)++;
(*marksum->total)++;
}
file = g_strdup(msginfo->plaintext_file);
else {
path = folder_item_get_path(msginfo->folder);
+
file = g_strconcat(path, G_DIR_SEPARATOR_S,
itos(msginfo->msgnum), NULL);
g_free(path);
MEMBDUP(xface);
MEMBDUP(dispositionnotificationto);
MEMBDUP(returnreceiptto);
+ MEMBDUP(references);
MEMBCOPY(score);
MEMBCOPY(threadscore);
{
if (msginfo == NULL) return;
+ g_free(msginfo->fromspace);
+ g_free(msginfo->references);
g_free(msginfo->returnreceiptto);
g_free(msginfo->dispositionnotificationto);
g_free(msginfo->xface);