aboutsummaryrefslogtreecommitdiffstats
path: root/camel/providers/imap
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@helixcode.com>2000-07-10 15:30:59 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2000-07-10 15:30:59 +0800
commit3e2188235f0cde226477d268aa4928ebb83af831 (patch)
tree5daf1b2bc32a1b4d766c089692fa4f9a80a38292 /camel/providers/imap
parentcccc6d3b5b40488dfdf8354ce78b8ad65b50e74a (diff)
downloadgsoc2013-evolution-3e2188235f0cde226477d268aa4928ebb83af831.tar
gsoc2013-evolution-3e2188235f0cde226477d268aa4928ebb83af831.tar.gz
gsoc2013-evolution-3e2188235f0cde226477d268aa4928ebb83af831.tar.bz2
gsoc2013-evolution-3e2188235f0cde226477d268aa4928ebb83af831.tar.lz
gsoc2013-evolution-3e2188235f0cde226477d268aa4928ebb83af831.tar.xz
gsoc2013-evolution-3e2188235f0cde226477d268aa4928ebb83af831.tar.zst
gsoc2013-evolution-3e2188235f0cde226477d268aa4928ebb83af831.zip
Implemented.
2000-07-10 Jeffrey Stedfast <fejj@helixcode.com> * providers/mbox/camel-mbox-folder.c (mbox_get_unread_message_count): * providers/vee/camel-vee-folder.c (vee_get_unread_message_count): * providers/imap/camel-imap-folder.c (imap_get_unread_message_count): Implemented. * camel-folder.c (camel_folder_get_unread_message_count): New convenience function to allow the mailer to query the number of unread messages in a folder (for displaying message stats in a folder tree?). svn path=/trunk/; revision=4028
Diffstat (limited to 'camel/providers/imap')
-rw-r--r--camel/providers/imap/camel-imap-folder.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/camel/providers/imap/camel-imap-folder.c b/camel/providers/imap/camel-imap-folder.c
index d92f260870..53c77e2f1e 100644
--- a/camel/providers/imap/camel-imap-folder.c
+++ b/camel/providers/imap/camel-imap-folder.c
@@ -63,6 +63,7 @@ static void imap_init (CamelFolder *folder, CamelStore *parent_store,
static void imap_sync (CamelFolder *folder, gboolean expunge, CamelException *ex);
static gint imap_get_message_count (CamelFolder *folder, CamelException *ex);
+static gint imap_get_unread_message_count (CamelFolder *folder, CamelException *ex);
static void imap_append_message (CamelFolder *folder, CamelMimeMessage *message, CamelException *ex);
static void imap_copy_message_to (CamelFolder *source, const char *uid, CamelFolder *destination, CamelException *ex);
static void imap_move_message_to (CamelFolder *source, const char *uid, CamelFolder *destination, CamelException *ex);
@@ -111,6 +112,7 @@ camel_imap_folder_class_init (CamelImapFolderClass *camel_imap_folder_class)
camel_folder_class->get_subfolder_names = imap_get_subfolder_names;
camel_folder_class->get_message_count = imap_get_message_count;
+ camel_folder_class->get_unread_message_count = imap_get_unread_message_count;
camel_folder_class->get_message = imap_get_message;
camel_folder_class->append_message = imap_append_message;
camel_folder_class->delete_message = imap_delete_message;
@@ -446,6 +448,33 @@ imap_get_message_count (CamelFolder *folder, CamelException *ex)
return imap_folder->count;
}
+static gint
+imap_get_unread_message_count (CamelFolder *folder, CamelException *ex)
+{
+ CamelImapFolder *imap_folder = CAMEL_IMAP_FOLDER (folder);
+ CamelMessageInfo *info;
+ GPtrArray *infolist;
+ gint i, count = 0;
+
+ g_return_val_if_fail (folder != NULL, -1);
+
+ /* If we don't have a message count, return */
+ if (imap_folder->count == -1)
+ return -1;
+
+ infolist = imap_get_summary (folder, ex);
+
+ for (i = 0; i < infolist->len; i++) {
+ info = (CamelMessageInfo *) g_ptr_array_index (infolist, i);
+ if (!(info->flags & CAMEL_MESSAGE_SEEN))
+ count++;
+ }
+
+ imap_free_summary (folder, infolist);
+
+ return count;
+}
+
static void
imap_append_message (CamelFolder *folder, CamelMimeMessage *message, CamelException *ex)
{