aboutsummaryrefslogtreecommitdiffstats
path: root/camel/providers/imap/camel-imap-utils.c
diff options
context:
space:
mode:
authorDan Winship <danw@src.gnome.org>2001-05-01 02:13:45 +0800
committerDan Winship <danw@src.gnome.org>2001-05-01 02:13:45 +0800
commit8ad89adf8ca7d1208473a8028036d270b6ad0b30 (patch)
tree3d7718059c99a55bac407e49852bb38c9b26eb5a /camel/providers/imap/camel-imap-utils.c
parent155fcd81538ef9aa63e6e6d4b585d5dd528b4e47 (diff)
downloadgsoc2013-evolution-8ad89adf8ca7d1208473a8028036d270b6ad0b30.tar.gz
gsoc2013-evolution-8ad89adf8ca7d1208473a8028036d270b6ad0b30.tar.zst
gsoc2013-evolution-8ad89adf8ca7d1208473a8028036d270b6ad0b30.zip
New-and-improved version of get_uid_set() from camel-imap-folder.c. Looks
* providers/imap/camel-imap-utils.c (imap_uid_array_to_set): New-and-improved version of get_uid_set() from camel-imap-folder.c. Looks at the summary as it goes so that if you ask for messages 5, 6, 8, and 9, and there is no message 7, then you get "5:9" instead of "5:6,8:9" * providers/imap/camel-imap-folder.c (imap_copy_messages_to): Use imap_uid_array_to_set() rather than get_uid_set(). (get_uid_set): Gone svn path=/trunk/; revision=9632
Diffstat (limited to 'camel/providers/imap/camel-imap-utils.c')
-rw-r--r--camel/providers/imap/camel-imap-utils.c74
1 files changed, 74 insertions, 0 deletions
diff --git a/camel/providers/imap/camel-imap-utils.c b/camel/providers/imap/camel-imap-utils.c
index acbfe46b23..22f3c95b50 100644
--- a/camel/providers/imap/camel-imap-utils.c
+++ b/camel/providers/imap/camel-imap-utils.c
@@ -566,3 +566,77 @@ imap_quote_string (const char *str)
return quoted;
}
+
+
+static inline unsigned long
+get_summary_uid_numeric (CamelFolderSummary *summary, int index)
+{
+ CamelMessageInfo *info;
+ unsigned long uid;
+
+ info = camel_folder_summary_index (summary, index);
+ uid = strtoul (camel_message_info_uid (info), NULL, 10);
+ camel_folder_summary_info_free (summary, info);
+ return uid;
+}
+
+/**
+ * imap_uid_array_to_set:
+ * @summary: summary for the folder the UIDs come from
+ * @uids: a (sorted) array of UIDs
+ *
+ * Return value: an IMAP "set" covering the listed UIDs, which the
+ * caller must free with g_free().
+ **/
+char *
+imap_uid_array_to_set (CamelFolderSummary *summary, GPtrArray *uids)
+{
+ int ui, si, scount;
+ unsigned long last_uid, next_summary_uid, this_uid;
+ gboolean range = FALSE;
+ GString *gset;
+ char *set;
+
+ gset = g_string_new (uids->pdata[0]);
+ last_uid = strtoul (uids->pdata[0], NULL, 10);
+ scount = camel_folder_summary_count (summary);
+
+ for (ui = 1, si = 0; ui < uids->len; ui++) {
+ /* Find the next UID in the summary */
+ for (; si < scount; si++) {
+ next_summary_uid = get_summary_uid_numeric (summary, si);
+ if (next_summary_uid == last_uid)
+ break;
+ }
+ if (++si < scount)
+ next_summary_uid = get_summary_uid_numeric (summary, si);
+ else
+ next_summary_uid = (guint32) -1;
+
+ /* Now get the next UID from @uids */
+ this_uid = strtoul (uids->pdata[ui], NULL, 10);
+ if (this_uid == next_summary_uid) {
+ range = TRUE;
+ if (++si < scount)
+ next_summary_uid = get_summary_uid_numeric (summary, si);
+ else
+ next_summary_uid = (guint32) -1;
+ } else {
+ if (range) {
+ g_string_sprintfa (gset, ":%lu", last_uid);
+ range = FALSE;
+ }
+ g_string_sprintfa (gset, ",%lu", this_uid);
+ }
+
+ last_uid = this_uid;
+ }
+
+ if (range)
+ g_string_sprintfa (gset, ":%lu", last_uid);
+
+ set = gset->str;
+ g_string_free (gset, FALSE);
+
+ return set;
+}