X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fmodest-text-utils.c;h=db00b31447a5bec21178302879162fd0f7375503;hp=88f48e8163ef503a8b5e4b7733384d8fddc11cfd;hb=a31e3b7e2d3779420c9e0b62fc0ffba214137f0e;hpb=b5e55da755b60754159661b5d1587a443f07e355 diff --git a/src/modest-text-utils.c b/src/modest-text-utils.c index 88f48e8..db00b31 100644 --- a/src/modest-text-utils.c +++ b/src/modest-text-utils.c @@ -163,6 +163,8 @@ static gchar* modest_text_utils_quote_html (const gchar *text, GList *attachments, int limit); static gchar* get_email_from_address (const gchar *address); +static void remove_extra_spaces (gchar *string); + /* ******************************************************************* */ @@ -607,29 +609,49 @@ modest_text_utils_get_addresses_indexes (const gchar *addresses, GSList **start_ GString *str; gchar *start, *cur; + if (!addresses) + return; + + if (strlen (addresses) == 0) + return; + str = g_string_new (""); start = (gchar*) addresses; cur = (gchar*) addresses; for (cur = start; *cur != '\0'; cur = g_utf8_next_char (cur)) { if (*cur == ',' || *cur == ';') { - if (!g_utf8_strchr (start, (cur - start + 1), g_utf8_get_char ("@"))) + gint *start_index, *end_index; + gchar *next_char = g_utf8_next_char (cur); + + if (!g_utf8_strchr (start, (cur - start + 1), g_utf8_get_char ("@")) && + next_char && *next_char != '\n') continue; - { - gint *start_index, *end_index; - start_index = g_new0 (gint, 1); - end_index = g_new0 (gint, 1); - *start_index = g_utf8_pointer_to_offset (addresses, start); - *end_index = g_utf8_pointer_to_offset (addresses, cur);; - *start_indexes = g_slist_prepend (*start_indexes, start_index); - *end_indexes = g_slist_prepend (*end_indexes, end_index); - start = g_utf8_next_char (cur); - } + + start_index = g_new0 (gint, 1); + end_index = g_new0 (gint, 1); + *start_index = g_utf8_pointer_to_offset (addresses, start); + *end_index = g_utf8_pointer_to_offset (addresses, cur);; + *start_indexes = g_slist_prepend (*start_indexes, start_index); + *end_indexes = g_slist_prepend (*end_indexes, end_index); + start = g_utf8_next_char (cur); } } - *start_indexes = g_slist_reverse (*start_indexes); - *end_indexes = g_slist_reverse (*end_indexes); + if (start != cur) { + gint *start_index, *end_index; + start_index = g_new0 (gint, 1); + end_index = g_new0 (gint, 1); + *start_index = g_utf8_pointer_to_offset (addresses, start); + *end_index = g_utf8_pointer_to_offset (addresses, cur);; + *start_indexes = g_slist_prepend (*start_indexes, start_index); + *end_indexes = g_slist_prepend (*end_indexes, end_index); + } + + if (*start_indexes) + *start_indexes = g_slist_reverse (*start_indexes); + if (*end_indexes) + *end_indexes = g_slist_reverse (*end_indexes); } @@ -674,12 +696,56 @@ modest_text_utils_split_addresses_list (const gchar *addresses) addr = g_strndup (my_addrs, end - my_addrs); g_strchomp (addr); + remove_extra_spaces (addr); + head = g_slist_append (NULL, addr); head->next = modest_text_utils_split_addresses_list (end); /* recurse */ return head; } +gchar * +modest_text_utils_join_addresses (const gchar *from, + const gchar *to, + const gchar *cc, + const gchar *bcc) +{ + GString *buffer; + gboolean add_separator = FALSE; + + buffer = g_string_new (""); + + if (from && strlen (from)) { + buffer = g_string_append (buffer, from); + add_separator = TRUE; + } + if (to && strlen (to)) { + if (add_separator) + buffer = g_string_append (buffer, "; "); + else + add_separator = TRUE; + + buffer = g_string_append (buffer, to); + } + if (cc && strlen (cc)) { + if (add_separator) + buffer = g_string_append (buffer, "; "); + else + add_separator = TRUE; + + buffer = g_string_append (buffer, cc); + } + if (bcc && strlen (bcc)) { + if (add_separator) + buffer = g_string_append (buffer, "; "); + else + add_separator = TRUE; + + buffer = g_string_append (buffer, bcc); + } + + return g_string_free (buffer, FALSE); +} void modest_text_utils_address_range_at_position (const gchar *recipients_list, @@ -1692,7 +1758,7 @@ modest_text_utils_validate_recipient (const gchar *recipient, const gchar **inva } } if (last_quote) - current = last_quote; + current = g_utf8_next_char (last_quote); } else { has_error = TRUE; for (current = stripped ; *current != '\0'; current = g_utf8_next_char (current)) { @@ -1916,6 +1982,20 @@ remove_quotes (gchar **quotes) } } +static void +remove_extra_spaces (gchar *string) +{ + gchar *start; + + start = string; + while (start && start[0] != '\0') { + if ((start[0] == ' ') && (start[1] == ' ')) { + g_strchug (start+1); + } + start++; + } +} + gchar * modest_text_utils_escape_mnemonics (const gchar *text) { @@ -2027,7 +2107,7 @@ gchar * modest_text_utils_get_secure_header (const gchar *value, const gchar *header) { - const gint max_len = 128; + const gint max_len = 16384; gchar *new_value = NULL; gchar *needle = g_strrstr (value, header); @@ -2097,7 +2177,7 @@ quote_name_part (GString **str, gchar **cur, gchar **start) if (blank && (blank != *start)) { if (is_quoted (*start, blank - 1)) { *str = g_string_append_len (*str, *start, str_len); - *str = g_string_append (*str, "; "); + *str = g_string_append (*str, ";"); *start = g_utf8_next_char (*cur); } else { *str = g_string_append_c (*str, '"'); @@ -2108,12 +2188,12 @@ quote_name_part (GString **str, gchar **cur, gchar **start) *str = g_string_append_len (*str, blank, (g_utf8_pointer_to_offset (*start, *cur) - g_utf8_pointer_to_offset (*start, blank))); - *str = g_string_append (*str, "; "); + *str = g_string_append (*str, ";"); *start = g_utf8_next_char (*cur); } } else { *str = g_string_append_len (*str, *start, str_len); - *str = g_string_append (*str, "; "); + *str = g_string_append (*str, ";"); *start = g_utf8_next_char (*cur); } }