diff options
Diffstat (limited to 'mail')
-rw-r--r-- | mail/ChangeLog | 16 | ||||
-rw-r--r-- | mail/em-folder-view.c | 33 | ||||
-rw-r--r-- | mail/em-popup.c | 4 | ||||
-rw-r--r-- | mail/em-utils.c | 31 | ||||
-rw-r--r-- | mail/em-utils.h | 3 | ||||
-rw-r--r-- | mail/mail-folder-cache.c | 1 |
6 files changed, 55 insertions, 33 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index 915369221f..ea7e85313f 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,3 +1,19 @@ +2009-01-13 Felix Riemann <friemann@svn.gnome.org> + + ** Fix for bug #563867 + + * em-folder-view.c (emp_uri_popup_link_copy): + * em-popup.c (emp_uri_popup_link_open): + * em-utils.c (em_utils_url_unescape_amp): + * em-utils.h: + Unescape "&" when passing the link to browsers. + +2009-01-12 Srinivasa Ragavan <sragavan@novell.com> + + ** Fix for bug #566653 + + * mail-folder-cache.c: (folder_changed): Fix a leaked info + 2009-01-11 Matthew Barnes <mbarnes@redhat.com> * em-config.c: diff --git a/mail/em-folder-view.c b/mail/em-folder-view.c index 6cf21f3a94..30309df598 100644 --- a/mail/em-folder-view.c +++ b/mail/em-folder-view.c @@ -1675,37 +1675,6 @@ emfv_popup_menu (GtkWidget *widget) // } //} -static gchar * -url_unescape_amp (const gchar *url) -{ - gchar *buff; - int i, j, amps; - - if (!url) - return NULL; - - amps = 0; - for (i = 0; url [i]; i++) { - if (url [i] == '&' && strncmp (url + i, "&", 5) == 0) - amps++; - } - - buff = g_strdup (url); - - if (!amps) - return buff; - - for (i = 0, j = 0; url [i]; i++, j++) { - buff [j] = url [i]; - - if (url [i] == '&' && strncmp (url + i, "&", 5) == 0) - i += 4; - } - buff [j] = 0; - - return buff; -} - static void emp_uri_popup_link_copy(EPopup *ep, EPopupItem *pitem, void *data) { @@ -1713,7 +1682,7 @@ emp_uri_popup_link_copy(EPopup *ep, EPopupItem *pitem, void *data) struct _EMFolderViewPrivate *p = emfv->priv; g_free(p->selection_uri); - p->selection_uri = url_unescape_amp(pitem->user_data); + p->selection_uri = em_utils_url_unescape_amp(pitem->user_data); gtk_selection_owner_set(p->invisible, GDK_SELECTION_PRIMARY, gtk_get_current_event_time()); gtk_selection_owner_set(p->invisible, GDK_SELECTION_CLIPBOARD, gtk_get_current_event_time()); diff --git a/mail/em-popup.c b/mail/em-popup.c index 18d4875a8d..38f3b1426b 100644 --- a/mail/em-popup.c +++ b/mail/em-popup.c @@ -585,9 +585,11 @@ static void emp_uri_popup_link_open(EPopup *ep, EPopupItem *item, void *data) { EMPopupTargetURI *t = (EMPopupTargetURI *)ep->target; + gchar *unescaped_uri = em_utils_url_unescape_amp (t->uri); /* FIXME Pass a parent window. */ - e_show_uri (NULL, t->uri); + e_show_uri (NULL, unescaped_uri); + g_free (unescaped_uri); } static void diff --git a/mail/em-utils.c b/mail/em-utils.c index e31bab0d22..8dbadea15b 100644 --- a/mail/em-utils.c +++ b/mail/em-utils.c @@ -2473,3 +2473,34 @@ em_utils_show_info_silent (GtkWidget *widget) widget, "response", G_CALLBACK (gtk_widget_destroy), NULL); } + +gchar * +em_utils_url_unescape_amp (const gchar *url) +{ + gchar *buff; + int i, j, amps; + + if (!url) + return NULL; + + amps = 0; + for (i = 0; url [i]; i++) { + if (url [i] == '&' && strncmp (url + i, "&", 5) == 0) + amps++; + } + + buff = g_strdup (url); + + if (!amps) + return buff; + + for (i = 0, j = 0; url [i]; i++, j++) { + buff [j] = url [i]; + + if (url [i] == '&' && strncmp (url + i, "&", 5) == 0) + i += 4; + } + buff [j] = 0; + + return buff; +} diff --git a/mail/em-utils.h b/mail/em-utils.h index 56dd4c6713..adc22d23b6 100644 --- a/mail/em-utils.h +++ b/mail/em-utils.h @@ -109,6 +109,9 @@ const char *em_utils_snoop_type(CamelMimePart *part); /* clears flag 'get_password_canceled' at every known accounts, so if needed, get_password will show dialog */ void em_utils_clear_get_password_canceled_accounts_flag (void); +/* Unescapes & back to a real & in URIs */ +gchar *em_utils_url_unescape_amp (const gchar *url); + G_END_DECLS #endif /* __EM_UTILS_H__ */ diff --git a/mail/mail-folder-cache.c b/mail/mail-folder-cache.c index f46b22850c..06335a515b 100644 --- a/mail/mail-folder-cache.c +++ b/mail/mail-folder-cache.c @@ -462,6 +462,7 @@ folder_changed (CamelObject *o, gpointer event_data, gpointer user_data) ((flags & CAMEL_MESSAGE_DELETED) == 0) && (camel_message_info_date_received (info) > last_newmail)) new++; + camel_message_info_free (info); } } } |