aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog16
-rw-r--r--mail/mail-folder-cache.c18
-rw-r--r--mail/mail-local.c16
3 files changed, 41 insertions, 9 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index c1b83e0ddd..c4f6f4a882 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,18 @@
+2001-09-27 <NotZed@Ximian.com>
+
+ * mail-folder-cache.c (real_note_folder): No such event finalized!
+ Its finalize.
+ (mail_note_store): "
+
+ Fixed dan's comment a bit, info != NULL for folder_created, info==
+ NULL for changed.
+
+2001-09-26 <NotZed@Ximian.com>
+
+ * mail-local.c (mlf_set_message_flags): Proxy the
+ set_message_flags call too. Doesn't fix the 'local folder counts
+ dont update' problem, but its more correct.
+
2001-09-27 Jeffrey Stedfast <fejj@ximian.com>
* mail-session.c (mail_session_remember_password): Perform a
@@ -65,6 +80,7 @@
oaf_active_server_register returns OAF_REG_ALREADY_ACTIVE.
>>>>>>> 1.1748
+>>>>>>> 1.1752
2001-09-26 Jeffrey Stedfast <fejj@ximian.com>
* mail-config.c (config_read): Oops, translate the fake account
diff --git a/mail/mail-folder-cache.c b/mail/mail-folder-cache.c
index f6db9e6024..9ccf138a75 100644
--- a/mail/mail-folder-cache.c
+++ b/mail/mail-folder-cache.c
@@ -84,13 +84,13 @@ static GHashTable *stores;
* folders it checks, but it can also return -1 for a folder, meaning
* it didn't check, and so you should stick with your previous answer.
*
- * update_1folder is called from three places: with info == NULL when
- * the folder is created, with info == NULL when a changed event is
- * emitted, or with info != NULL when doing a get_folder_info. So if
- * info is NULL, camel_folder_unread_message_count is correct, and
- * if it's not NULL and its unread_message_count isn't -1, then it's
- * correct.
- */
+ * update_1folder is called from three places: with info != NULL when
+ * the folder is created (or get_folder_info), with info == NULL when
+ * a folder changed event is emitted.
+ *
+ * So if info is NULL, camel_folder_unread_message_count is correct,
+ * and if it's not NULL and its unread_message_count isn't -1, then
+ * it's correct. */
static void
update_1folder(struct _folder_info *mfi, CamelFolderInfo *info)
@@ -227,7 +227,7 @@ real_note_folder(CamelFolder *folder, void *event_data, void *data)
camel_object_hook_event((CamelObject *)folder, "folder_changed", folder_changed, mfi);
camel_object_hook_event((CamelObject *)folder, "message_changed", folder_changed, mfi);
- camel_object_hook_event((CamelObject *)folder, "finalized", folder_finalised, mfi);
+ camel_object_hook_event((CamelObject *)folder, "finalize", folder_finalised, mfi);
camel_object_unref((CamelObject *)folder);
}
@@ -375,7 +375,7 @@ mail_note_store(CamelStore *store, EvolutionStorage *storage, GNOME_Evolution_St
camel_object_hook_event((CamelObject *)store, "folder_created", store_folder_created, NULL);
camel_object_hook_event((CamelObject *)store, "folder_deleted", store_folder_deleted, NULL);
- camel_object_hook_event((CamelObject *)store, "finalized", store_finalised, NULL);
+ camel_object_hook_event((CamelObject *)store, "finalize", store_finalised, NULL);
}
UNLOCK(info_lock);
diff --git a/mail/mail-local.c b/mail/mail-local.c
index 710a016d91..e0e2c8792c 100644
--- a/mail/mail-local.c
+++ b/mail/mail-local.c
@@ -338,6 +338,21 @@ mlf_search_free(CamelFolder *folder, GPtrArray *result)
}
static void
+mlf_set_message_flags(CamelFolder *folder, const char *uid, guint32 flags, guint32 set)
+{
+ MailLocalFolder *mlf = MAIL_LOCAL_FOLDER(folder);
+ CamelFolder *f;
+
+ LOCAL_FOLDER_LOCK(mlf);
+ f = mlf->real_folder;
+ camel_object_ref((CamelObject *)f);
+ LOCAL_FOLDER_UNLOCK(mlf);
+
+ camel_folder_set_message_flags(mlf->real_folder, uid, flags, set);
+ camel_object_unref((CamelObject *)f);
+}
+
+static void
mlf_set_message_user_flag(CamelFolder *folder, const char *uid, const char *name, gboolean value)
{
MailLocalFolder *mlf = MAIL_LOCAL_FOLDER(folder);
@@ -461,6 +476,7 @@ mlf_class_init (CamelObjectClass *camel_object_class)
camel_folder_class->search_free = mlf_search_free;
camel_folder_class->search_by_expression = mlf_search_by_expression;
+ camel_folder_class->set_message_flags = mlf_set_message_flags;
camel_folder_class->set_message_user_flag = mlf_set_message_user_flag;
camel_folder_class->set_message_user_tag = mlf_set_message_user_tag;
}