diff options
author | Dan Winship <danw@src.gnome.org> | 2000-04-10 22:27:22 +0800 |
---|---|---|
committer | Dan Winship <danw@src.gnome.org> | 2000-04-10 22:27:22 +0800 |
commit | 7d8c98fb7d35db162f6e355a07e4b5ed3c2e1de7 (patch) | |
tree | 9d8eafbf60cdcfb39e5e817b0d045375cf3abe03 /camel | |
parent | 325ed84013a410201fbb3b2e3e41395e40a42f1b (diff) | |
download | gsoc2013-evolution-7d8c98fb7d35db162f6e355a07e4b5ed3c2e1de7.tar gsoc2013-evolution-7d8c98fb7d35db162f6e355a07e4b5ed3c2e1de7.tar.gz gsoc2013-evolution-7d8c98fb7d35db162f6e355a07e4b5ed3c2e1de7.tar.bz2 gsoc2013-evolution-7d8c98fb7d35db162f6e355a07e4b5ed3c2e1de7.tar.lz gsoc2013-evolution-7d8c98fb7d35db162f6e355a07e4b5ed3c2e1de7.tar.xz gsoc2013-evolution-7d8c98fb7d35db162f6e355a07e4b5ed3c2e1de7.tar.zst gsoc2013-evolution-7d8c98fb7d35db162f6e355a07e4b5ed3c2e1de7.zip |
implement get_message_by_number for the mail fetch code.
* providers/mbox/camel-mbox-folder.c (_get_message_by_number):
implement get_message_by_number for the mail fetch code.
svn path=/trunk/; revision=2358
Diffstat (limited to 'camel')
-rw-r--r-- | camel/ChangeLog | 5 | ||||
-rw-r--r-- | camel/providers/mbox/camel-mbox-folder.c | 26 |
2 files changed, 29 insertions, 2 deletions
diff --git a/camel/ChangeLog b/camel/ChangeLog index 50cb012b93..922c67fe25 100644 --- a/camel/ChangeLog +++ b/camel/ChangeLog @@ -1,3 +1,8 @@ +2000-04-10 Dan Winship <danw@helixcode.com> + + * providers/mbox/camel-mbox-folder.c (_get_message_by_number): + implement get_message_by_number for the mail fetch code. + 2000-04-09 Jeffrey Stedfast <fejj@stampede.org> * providers/smtp/camel-smtp-transport.c: reformatted to fit diff --git a/camel/providers/mbox/camel-mbox-folder.c b/camel/providers/mbox/camel-mbox-folder.c index 8e1fe00402..685e2824e2 100644 --- a/camel/providers/mbox/camel-mbox-folder.c +++ b/camel/providers/mbox/camel-mbox-folder.c @@ -70,7 +70,7 @@ static gboolean _create(CamelFolder *folder, CamelException *ex); static gboolean _delete (CamelFolder *folder, gboolean recurse, CamelException *ex); static gboolean _delete_messages (CamelFolder *folder, CamelException *ex); static GList *_list_subfolders (CamelFolder *folder, CamelException *ex); -/* static CamelMimeMessage *_get_message_by_number (CamelFolder *folder, gint number, CamelException *ex);*/ +static CamelMimeMessage *_get_message_by_number (CamelFolder *folder, gint number, CamelException *ex); static gint _get_message_count (CamelFolder *folder, CamelException *ex); static void _append_message (CamelFolder *folder, CamelMimeMessage *message, CamelException *ex); static GList *_get_uid_list (CamelFolder *folder, CamelException *ex); @@ -103,7 +103,7 @@ camel_mbox_folder_class_init (CamelMboxFolderClass *camel_mbox_folder_class) camel_folder_class->delete = _delete; camel_folder_class->delete_messages = _delete_messages; camel_folder_class->list_subfolders = _list_subfolders; - /* camel_folder_class->get_message_by_number = _get_message_by_number; */ + camel_folder_class->get_message_by_number = _get_message_by_number; camel_folder_class->get_message_count = _get_message_count; camel_folder_class->append_message = _append_message; camel_folder_class->get_uid_list = _get_uid_list; @@ -998,8 +998,30 @@ _get_uid_list (CamelFolder *folder, CamelException *ex) +static CamelMimeMessage * +_get_message_by_number (CamelFolder *folder, gint number, CamelException *ex) +{ + GArray *message_info_array; + CamelMboxSummaryInformation *message_info; + char uidbuf[20]; + message_info_array = + CAMEL_MBOX_SUMMARY (folder->summary)->message_info; + if (number > message_info_array->len) { + camel_exception_setv (ex, CAMEL_EXCEPTION_FOLDER_INVALID, + "No such message %d in folder `%s'.", + number, folder->name); + return NULL; + } + + message_info = + (CamelMboxSummaryInformation *)(message_info_array->data) + + (number - 1); + sprintf (uidbuf, "%lu", message_info->uid); + + return _get_message_by_uid (folder, uidbuf, ex); +} static CamelMimeMessage * |