#include "statusbar.h"
#include "gtkutils.h"
#include "timing.h"
+#include "compose.h"
/* Dependecies to be removed ?! */
#include "prefs_common.h"
(GNode *node, GHashTable *pptable);
static gboolean persist_prefs_free (gpointer key, gpointer val, gpointer data);
void folder_item_read_cache (FolderItem *item);
-void folder_item_free_cache (FolderItem *item);
gint folder_item_scan_full (FolderItem *item, gboolean filtering);
static void folder_item_update_with_msg (FolderItem *item, FolderItemUpdateFlags update_flags,
MsgInfo *msg);
folder->trash = NULL;
}
+static void reset_parent_type(FolderItem *item, gpointer data) {
+ item->parent_stype = -1;
+}
+
+void folder_item_change_type(FolderItem *item, SpecialFolderItemType newtype)
+{
+ Folder *folder = NULL;
+ FolderUpdateData hookdata;
+
+ folder = item->folder;
+ /* unset previous root of newtype */
+ switch(newtype) {
+ case F_INBOX:
+ folder_item_change_type(folder->inbox, F_NORMAL);
+ folder->inbox = item;
+ break;
+ case F_OUTBOX:
+ folder_item_change_type(folder->outbox, F_NORMAL);
+ folder->outbox = item;
+ break;
+ case F_QUEUE:
+ folder_item_change_type(folder->queue, F_NORMAL);
+ folder->queue = item;
+ break;
+ case F_DRAFT:
+ folder_item_change_type(folder->draft, F_NORMAL);
+ folder->draft = item;
+ break;
+ case F_TRASH:
+ folder_item_change_type(folder->trash, F_NORMAL);
+ folder->trash = item;
+ break;
+ case F_NORMAL:
+ default:
+ break;
+ }
+ /* set new type for current folder and sons */
+ item->stype = newtype;
+ folder_func_to_all_folders(reset_parent_type, NULL);
+
+ hookdata.folder = folder;
+ hookdata.update_flags = FOLDER_TREE_CHANGED;
+ hookdata.item = NULL;
+ hooks_invoke(FOLDER_UPDATE_HOOKLIST, &hookdata);
+}
+
void folder_destroy(Folder *folder)
{
g_return_if_fail(folder != NULL);
}
if (item->cache)
- folder_item_free_cache(item);
+ folder_item_free_cache(item, TRUE);
if (item->prefs)
folder_item_prefs_free(item->prefs);
g_free(item->name);
{
GHashTable *pptable;
FolderUpdateData hookdata;
-
+ Folder *old_folder = folder;
+
if (!folder->klass->scan_tree)
return;
pptable = folder_persist_prefs_new(folder);
if (rebuild)
- folder_tree_destroy(folder);
+ folder_remove(folder);
- folder->klass->scan_tree(folder);
+ if (folder->klass->scan_tree(folder) < 0) {
+ if (rebuild)
+ folder_add(old_folder);
+ return;
+ } else if (rebuild)
+ folder_add(folder);
hookdata.folder = folder;
hookdata.update_flags = FOLDER_TREE_CHANGED;
continue;
if (folder->inbox == NULL)
continue;
+ if (folder->klass->type == F_UNKNOWN)
+ continue;
return folder->inbox;
}
(item->stype == F_INBOX) &&
(item->folder->account != NULL) &&
(item->folder->account->filter_on_recv) &&
- procmsg_msginfo_filter(msginfo))
+ procmsg_msginfo_filter(msginfo, item->folder->account))
to_filter = g_slist_prepend(to_filter, msginfo);
else {
exists_list = g_slist_prepend(exists_list, msginfo);
g_hash_table_destroy(subject_table);
}
+ if (item->new_msgs != newcnt || item->unread_msgs != unreadcnt
+ || item->total_msgs != totalcnt || item->marked_msgs != markedcnt
+ || item->unreadmarked_msgs != unreadmarkedcnt) {
+ update_flags |= F_ITEM_UPDATE_CONTENT;
+ }
+
item->new_msgs = newcnt;
item->unread_msgs = unreadcnt;
item->total_msgs = totalcnt;
difftime = (gint) (time(NULL) - msgcache_get_last_access_time(item->cache));
expiretime = prefs_common.cache_min_keep_time * 60;
debug_print("Cache unused time: %d (Expire time: %d)\n", difftime, expiretime);
+
if (difftime > expiretime && !item->opened && !item->processing_pending) {
*folder_item_list = g_slist_insert_sorted(*folder_item_list, item, folder_cache_time_compare_func);
}
}
-void folder_item_free_cache(FolderItem *item)
+gboolean folder_item_free_cache(FolderItem *item, gboolean force)
{
- g_return_if_fail(item != NULL);
+ g_return_val_if_fail(item != NULL, TRUE);
if (item->cache == NULL)
- return;
+ return TRUE;
- if (item->opened > 0)
- return;
+ if (item->opened > 0 && !force)
+ return FALSE;
folder_item_write_cache(item);
msgcache_destroy(item->cache);
item->cache = NULL;
+ return TRUE;
}
void folder_clean_cache_memory_force(void)
listitem = folder_item_list;
while((listitem != NULL) && (memusage > (prefs_common.cache_max_mem_usage * 1024))) {
FolderItem *item = (FolderItem *)(listitem->data);
+ gint cache_size = 0;
if (item == protected_item) {
listitem = listitem->next;
continue;
}
debug_print("Freeing cache memory for %s\n", item->path ? item->path : item->name);
- memusage -= msgcache_get_memory_usage(item->cache);
- folder_item_free_cache(item);
+ cache_size = msgcache_get_memory_usage(item->cache);
+ if (folder_item_free_cache(item, FALSE))
+ memusage -= cache_size;
+
listitem = listitem->next;
}
g_slist_free(folder_item_list);
}
}
+ if (FOLDER_TYPE(item->folder) == F_MH)
+ item->mtime = time(NULL);
+
g_free(cache_file);
g_free(mark_file);
}
if (!mimeinfo->subtype
|| strcmp(mimeinfo->subtype, "pgp-signature"))
procmsg_msginfo_set_flags(msginfo, 0, MSG_HAS_ATTACHMENT);
- }
+ } else if (mimeinfo->disposition == DISPOSITIONTYPE_INLINE &&
+ strcmp(mimeinfo->subtype, "pgp-signature") &&
+ (procmime_mimeinfo_get_parameter(mimeinfo, "name") != NULL ||
+ procmime_mimeinfo_get_parameter(mimeinfo, "filename") != NULL)) {
+ procmsg_msginfo_set_flags(msginfo, 0, MSG_HAS_ATTACHMENT);
+ }
/* don't descend below top level message for signed and encrypted info */
if (mimeinfo->type == MIMETYPE_MESSAGE)
procmsg_msginfo_set_flags(msginfo, 0, MSG_SCANNED);
}
}
+ procmsg_msginfo_free(msginfo);
}
return msgfile;
procmsg_msginfo_set_flags(msginfo, 0, MSG_SCANNED);
}
}
+ procmsg_msginfo_free(msginfo);
}
return msgfile;
{
FolderItem *tmp = folder_item_parent(dest);
gchar * src_identifier, * dst_identifier;
- gchar * phys_srcpath, * phys_dstpath;
+ gchar * phys_srcpath, * phys_dstpath, *tmppath;
while (tmp) {
if (tmp == src) {
}
phys_srcpath = folder_item_get_path(src);
- phys_dstpath = g_strconcat(folder_item_get_path(dest),
+ tmppath = folder_item_get_path(dest);
+ phys_dstpath = g_strconcat(tmppath,
G_DIR_SEPARATOR_S,
g_path_get_basename(phys_srcpath),
NULL);
+ g_free(tmppath);
if (folder_item_parent(src) == dest || src == dest) {
g_free(src_identifier);
GRelation *relation;
GSList *not_moved = NULL;
gint total = 0, curmsg = 0;
+ MsgInfo *msginfo = NULL;
g_return_val_if_fail(dest != NULL, -1);
g_return_val_if_fail(msglist != NULL, -1);
if (dest->no_select)
return -1;
+ msginfo = (MsgInfo *)msglist->data;
+
+ if (!msginfo)
+ return -1;
+
+ if (!MSG_IS_QUEUED(msginfo->flags) &&
+ MSG_IS_DRAFT(msginfo->flags) &&
+ folder_has_parent_of_type(dest, F_QUEUE)) {
+ GSList *cur = msglist;
+ gboolean queue_err = FALSE;
+ for (; cur; cur = cur->next) {
+ Compose *compose = NULL;
+ FolderItem *queue = dest;
+ int val = 0;
+
+ msginfo = (MsgInfo *)cur->data;
+ compose = compose_reedit(msginfo, TRUE);
+ if (compose == NULL) {
+ queue_err = TRUE;
+ continue;
+ }
+ val = compose_queue(compose, NULL, &queue, NULL,
+ FALSE);
+ if (val < 0) {
+ queue_err = TRUE;
+ } else if (remove_source) {
+ folder_item_remove_msg(msginfo->folder, msginfo->msgnum);
+ }
+ if (val == 0)
+ compose_close(compose);
+ }
+ return queue_err ? -1:0;
+ }
+
relation = g_relation_new(2);
g_relation_index(relation, 0, g_direct_hash, g_direct_equal);
g_relation_index(relation, 1, g_direct_hash, g_direct_equal);
result = folder->klass->remove_all_msg(folder, item);
if (result == 0) {
- folder_item_free_cache(item);
+ folder_item_free_cache(item, TRUE);
item->cache = msgcache_new();
}
} else {
xmlnode = xml_node_new(tag, NULL);
node = g_node_new(xmlnode);
+
+ g_return_val_if_fail (folder->node != NULL, NULL);
+
if (folder->node->children) {
GNode *cur;
statusbar_progress_all(curmsg++,total, 10);
/* apply pre global rules */
- filter_message_by_msginfo(pre_global_processing, msginfo);
+ filter_message_by_msginfo(pre_global_processing, msginfo, NULL);
/* apply rules of the folder */
- filter_message_by_msginfo(processing_list, msginfo);
+ filter_message_by_msginfo(processing_list, msginfo, NULL);
/* apply post global rules */
- filter_message_by_msginfo(post_global_processing, msginfo);
+ filter_message_by_msginfo(post_global_processing, msginfo, NULL);
}
if (pre_global_processing || processing_list