From 3e2188235f0cde226477d268aa4928ebb83af831 Mon Sep 17 00:00:00 2001 From: Jeffrey Stedfast Date: Mon, 10 Jul 2000 07:30:59 +0000 Subject: Implemented. 2000-07-10 Jeffrey Stedfast * 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 --- camel/providers/mbox/camel-mbox-folder.c | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) (limited to 'camel/providers/mbox') diff --git a/camel/providers/mbox/camel-mbox-folder.c b/camel/providers/mbox/camel-mbox-folder.c index ca313ec045..e8c3f7c795 100644 --- a/camel/providers/mbox/camel-mbox-folder.c +++ b/camel/providers/mbox/camel-mbox-folder.c @@ -4,6 +4,7 @@ /* * Authors: Bertrand Guiheneuf * Michael Zucchi + * Jeffrey Stedfast * * Copyright (C) 1999, 2000 Helix Code Inc. * @@ -63,6 +64,7 @@ static void mbox_init (CamelFolder *folder, CamelStore *parent_store, static void mbox_sync (CamelFolder *folder, gboolean expunge, CamelException *ex); static gint mbox_get_message_count (CamelFolder *folder, CamelException *ex); +static gint mbox_get_unread_message_count (CamelFolder *folder, CamelException *ex); static void mbox_append_message (CamelFolder *folder, CamelMimeMessage *message, CamelException *ex); static GPtrArray *mbox_get_uids (CamelFolder *folder, CamelException *ex); static GPtrArray *mbox_get_subfolder_names (CamelFolder *folder, CamelException *ex); @@ -100,6 +102,7 @@ camel_mbox_folder_class_init (CamelMboxFolderClass *camel_mbox_folder_class) camel_folder_class->init = mbox_init; camel_folder_class->sync = mbox_sync; camel_folder_class->get_message_count = mbox_get_message_count; + camel_folder_class->get_unread_message_count = mbox_get_unread_message_count; camel_folder_class->append_message = mbox_append_message; camel_folder_class->get_uids = mbox_get_uids; camel_folder_class->get_subfolder_names = mbox_get_subfolder_names; @@ -269,6 +272,31 @@ mbox_get_message_count (CamelFolder *folder, CamelException *ex) return camel_folder_summary_count (CAMEL_FOLDER_SUMMARY (mbox_folder->summary)); } +static gint +mbox_get_unread_message_count (CamelFolder *folder, CamelException *ex) +{ + CamelMboxFolder *mbox_folder = CAMEL_MBOX_FOLDER (folder); + CamelMessageInfo *info; + GPtrArray *infolist; + gint i, max, count = 0; + + g_return_val_if_fail (folder != NULL, -1); + + max = camel_folder_summary_count (CAMEL_FOLDER_SUMMARY (mbox_folder->summary)); + if (max == -1) + return -1; + + infolist = mbox_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++; + } + + return count; +} + /* FIXME: this may need some tweaking for performance? */ static void mbox_append_message (CamelFolder *folder, CamelMimeMessage *message, CamelException *ex) -- cgit v1.2.3