aboutsummaryrefslogtreecommitdiffstats
path: root/mail/message-list.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/message-list.c')
-rw-r--r--mail/message-list.c191
1 files changed, 38 insertions, 153 deletions
diff --git a/mail/message-list.c b/mail/message-list.c
index 46c69ea556..59ce592f7e 100644
--- a/mail/message-list.c
+++ b/mail/message-list.c
@@ -108,196 +108,81 @@ static struct {
{ NULL, NULL }
};
-typedef struct {
- char *name;
- char *address;
-} InternetAddress;
-
-
-static InternetAddress *
-internet_address_new_from_string (const gchar *string)
+static gint
+address_compare (gconstpointer address1, gconstpointer address2)
{
- /* We have 3 possibilities...
- 1. "Jeffrey Stedfast" <fejj@helixcode.com>
- 2. fejj@helixcode.com
- 3. <fejj@helixcode.com> (Jeffrey Stedfast)
-
- notzed: actually we dont, this isn't spruce, the addresses have already been parsed by camel.
- FIXME: This code wont handle multiple addresses.
- */
-
- InternetAddress *ia;
- gchar *name = NULL, *address = NULL;
- const gchar *ptr;
- const gchar *padding;
- gboolean in_quotes = FALSE;
- gboolean name_first = FALSE;
-
- g_return_val_if_fail (string != NULL, NULL);
- g_return_val_if_fail (*string != '\0', NULL);
+ CamelInternetAddress *ia1, *ia2;
+ const char *name1, *name2;
+ const char *addr1, *addr2;
+ gint retval = 0;
- padding = NULL;
+ ia1 = camel_internet_address_new ();
+ ia2 = camel_internet_address_new ();
- ptr = string;
- while (isspace (*ptr))
- ptr++;
+ camel_address_decode (CAMEL_ADDRESS (ia1), (const char *) address1);
+ camel_address_decode (CAMEL_ADDRESS (ia2), (const char *) address2);
- /* look for padding between parts... */
- for (; *ptr; ptr++) {
- if (*ptr == '"') {
- in_quotes = !in_quotes;
- name_first = TRUE;
- } else if (!in_quotes && isspace (*ptr)) {
- padding = ptr;
- break;
- }
+ if (!camel_internet_address_get (ia1, 0, &name1, &addr1)) {
+ camel_object_unref (CAMEL_OBJECT (ia1));
+ camel_object_unref (CAMEL_OBJECT (ia2));
+ return 1;
}
- if (padding) {
- padding--;
- /* we have a type-one or a type-three address */
- if (name_first) {
- name = g_strndup (string, (gint) (padding - string));
- g_strstrip (name);
-
- /* strip off the quotes */
- if (*name) {
- *(name + strlen (name) - 1) = '\0';
- memmove (name, name + 1, strlen (name) - 1);
- } else {
- g_free (name);
- name = NULL;
- }
-
- address = strchr (padding, '<');
- if (address) {
- address++;
- for (ptr = address; *ptr && *ptr != '>'; ptr++);
-
- address = g_strndup (address, (gint) (ptr - address));
- }
- } else {
- address = g_strndup (string, (gint) (padding - string));
- g_strstrip (address);
-
- /* strip off the braces */
- if (*address) {
- *(address + strlen (address) - 1) = '\0';
- memmove (address, address + 1, strlen (address) - 1);
- } else {
- g_free (address);
- address = NULL;
- }
-
- name = strchr (padding, '(');
- if (name) {
- name++;
- in_quotes = FALSE;
- ptr = name;
-
- while (*ptr) {
- if (*ptr == '"')
- in_quotes = !in_quotes;
- else if (!in_quotes && *ptr == ')')
- break;
- }
-
- name = g_strndup (name, (gint) (ptr - name));
- }
- }
- } else {
- /* we have a type-two address */
- address = g_strdup (string);
- }
-
- if (!address) {
- /* the address is the most important part! */
- g_free (name);
- return NULL;
+ if (!camel_internet_address_get (ia2, 0, &name2, &addr2)) {
+ camel_object_unref (CAMEL_OBJECT (ia1));
+ camel_object_unref (CAMEL_OBJECT (ia2));
+ return -1;
}
- ia = g_new (InternetAddress, 1);
- ia->name = name;
- ia->address = address;
-
- return ia;
-}
-
-static void
-internet_address_destroy (InternetAddress *ia)
-{
- g_return_if_fail (ia != NULL);
-
- g_free (ia->name);
- g_free (ia->address);
- g_free (ia);
-}
-
-static gint
-address_compare (gconstpointer address1, gconstpointer address2)
-{
- InternetAddress *ia1, *ia2;
- gint retval = 0;
-
- ia1 = internet_address_new_from_string ((const char *) address1);
- ia2 = internet_address_new_from_string ((const char *) address2);
-
- g_return_val_if_fail (ia1 != NULL, -1);
- g_return_val_if_fail (ia2 != NULL, 1);
-
- if (!ia1->name && !ia2->name) {
+ if (!name1 && !name2) {
/* if neither has a name we should compare addresses */
- retval = g_strcasecmp (ia1->address, ia2->address);
+ retval = g_strcasecmp (addr1, addr2);
} else {
- if (!ia1->name)
+ if (!name1)
retval = -1;
- else if (!ia2->name)
+ else if (!name2)
retval = 1;
else {
- ENameWestern *name1, *name2;
+ ENameWestern *wname1, *wname2;
- name1 = e_name_western_parse (ia1->name);
- name2 = e_name_western_parse (ia2->name);
+ wname1 = e_name_western_parse (name1);
+ wname2 = e_name_western_parse (name2);
- if (!name1->last && !name2->last) {
+ if (!wname1->last && !wname2->last) {
/* neither has a last name */
-
- retval = g_strcasecmp (ia1->name, ia2->name);
+ retval = g_strcasecmp (name1, name2);
} else {
/* compare last names */
-
- if (!name1->last)
+ if (!wname1->last)
retval = -1;
- else if (!name2->last)
+ else if (!wname2->last)
retval = 1;
else {
- retval = g_strcasecmp (name1->last, name2->last);
+ retval = g_strcasecmp (wname1->last, wname2->last);
if (!retval) {
/* last names are identical - compare first names */
-
- if (!name1->first)
+ if (!wname1->first)
retval = -1;
- else if (!name2->first)
+ else if (!wname2->first)
retval = 1;
else {
- retval = g_strcasecmp (name1->first, name2->first);
+ retval = g_strcasecmp (wname1->first, wname2->first);
if (!retval) {
/* first names are identical - compare addresses */
-
- retval = g_strcasecmp (ia1->address, ia2->address);
+ retval = g_strcasecmp (addr1, addr2);
}
}
}
}
}
- e_name_western_free (name1);
- e_name_western_free (name2);
+ e_name_western_free (wname1);
+ e_name_western_free (wname2);
}
}
- internet_address_destroy (ia1);
- internet_address_destroy (ia2);
+ camel_object_unref (CAMEL_OBJECT (ia1));
+ camel_object_unref (CAMEL_OBJECT (ia2));
return retval;
}