aboutsummaryrefslogtreecommitdiffstats
path: root/camel/camel-folder.c
diff options
context:
space:
mode:
authorNot Zed <NotZed@Ximian.com>2001-02-20 04:59:54 +0800
committerMichael Zucci <zucchi@src.gnome.org>2001-02-20 04:59:54 +0800
commit10fba20de92e3cb8c7346452e804c9fa11ffd343 (patch)
tree054b635fb681a699fad24d2820fe9c455384f24f /camel/camel-folder.c
parent55f2ad59245f4bf9405639a22ef108375c9167e6 (diff)
downloadgsoc2013-evolution-10fba20de92e3cb8c7346452e804c9fa11ffd343.tar.gz
gsoc2013-evolution-10fba20de92e3cb8c7346452e804c9fa11ffd343.tar.zst
gsoc2013-evolution-10fba20de92e3cb8c7346452e804c9fa11ffd343.zip
Added flags argument. (message_changed): Add support for the auto-update
2001-02-19 Not Zed <NotZed@Ximian.com> * providers/vee/camel-vee-folder.c (camel_vee_folder_new): Added flags argument. (message_changed): Add support for the auto-update flag, in which case we auto-match the content as it changes. (camel_vee_folder_init): Remoive "DYNAMIC" optionality (camel_vee_folder_finalise): " (vee_expunge): As we expunge folders, re-sync their content by rerunning the query. * providers/vee/camel-vee-store.c (vee_get_folder): Pass flags to folder new. 2001-02-18 Not Zed <NotZed@Ximian.com> * providers/vee/Makefile.am (noinst_HEADERS): Added camel-vee-private.h. * providers/vee/camel-vee-private.h: New file to add locking stuff for vee folders. * providers/vee/camel-vee-folder.c (camel_vee_folder_new): Add locking around unmatched setup. (camel_vee_folder_init): Setup lock. (camel_vee_folder_finalise): Free locks. (folder_changed): Add locking. (unmatched_finalise): " (message_changed): " (vee_folder_build): " 2001-02-17 Not Zed <NotZed@Ximian.com> * providers/vee/camel-vee-folder.c (vee_folder_add): Check uid doesn't exist before adding it. 2001-02-16 Not Zed <NotZed@Ximian.com> * providers/vee/camel-vee-folder.c (camel_vee_folder_new): Create a new virtual virtual folder UNMATCHED, to store all messages that dont match other vfolders. (unmatched_folder_changed): When a vfolder issues a changed event, use its info to update the unmatched folder info. (unmatched_finalise): When a vfolder is finalised, remove any uids it has as if we had a removed event for it. svn path=/trunk/; revision=8276
Diffstat (limited to 'camel/camel-folder.c')
-rw-r--r--camel/camel-folder.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/camel/camel-folder.c b/camel/camel-folder.c
index e9d72d879d..674094ce42 100644
--- a/camel/camel-folder.c
+++ b/camel/camel-folder.c
@@ -1163,6 +1163,7 @@ freeze (CamelFolder *folder)
folder->priv->frozen++;
+ printf("freeze(%p) = %d\n", folder, folder->priv->frozen);
CAMEL_FOLDER_UNLOCK(folder, change_lock);
}
@@ -1192,6 +1193,9 @@ thaw (CamelFolder * folder)
CAMEL_FOLDER_LOCK(folder, change_lock);
folder->priv->frozen--;
+
+ printf("thaw(%p) = %d\n", folder, folder->priv->frozen);
+
if (folder->priv->frozen == 0) {
/* If we have more or less messages, do a folder changed, otherwise just
do a message changed for each one.
@@ -1235,6 +1239,8 @@ folder_changed (CamelObject *obj, gpointer event_data)
CamelFolderChangeInfo *changed = event_data;
gboolean ret = TRUE;
+ printf("folder_changed(%p, %p), frozen=%d\n", obj, event_data, folder->priv->frozen);
+
if (folder->priv->frozen) {
CAMEL_FOLDER_LOCK(folder, change_lock);
@@ -1257,6 +1263,8 @@ message_changed (CamelObject *obj, /*const char *uid*/gpointer event_data)
CamelFolder *folder = CAMEL_FOLDER (obj);
gboolean ret = TRUE;
+ printf("message_changed(%p, %p), frozen=%d\n", folder, event_data, folder->priv->frozen);
+
if (folder->priv->frozen) {
CAMEL_FOLDER_LOCK(folder, change_lock);