aboutsummaryrefslogtreecommitdiffstats
path: root/mail
diff options
context:
space:
mode:
Diffstat (limited to 'mail')
-rw-r--r--mail/ChangeLog16
-rw-r--r--mail/em-folder-view.c33
-rw-r--r--mail/em-popup.c4
-rw-r--r--mail/em-utils.c31
-rw-r--r--mail/em-utils.h3
-rw-r--r--mail/mail-folder-cache.c1
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 "&amp;" 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, "&amp;", 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, "&amp;", 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, "&amp;", 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, "&amp;", 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 &amp; 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);
}
}
}