From 0c927779b5b37ba01bb710b86e21c55f35e7ad94 Mon Sep 17 00:00:00 2001 From: Vitaly Minko Date: Tue, 2 Nov 2010 10:08:15 +0100 Subject: Escape URL itself along with the title (#616339) --- libempathy-gtk/empathy-string-parser.c | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) (limited to 'libempathy-gtk') diff --git a/libempathy-gtk/empathy-string-parser.c b/libempathy-gtk/empathy-string-parser.c index 3bb6a82be..5f5df5209 100644 --- a/libempathy-gtk/empathy-string-parser.c +++ b/libempathy-gtk/empathy-string-parser.c @@ -161,20 +161,24 @@ empathy_string_replace_link (const gchar *text, { GString *string = user_data; gchar *real_url; - gchar *escaped; + gchar *title; + gchar *markup; real_url = empathy_make_absolute_url_len (text, len); - /* The thing we are making a link of may contain - * characters which need escaping */ - escaped = g_markup_escape_text (text, len); + /* Need to copy manually, because g_markup_printf_escaped does not work + * with string precision pitfalls. */ + title = g_strndup (text, len); /* Append the link inside tag */ - g_string_append_printf (string, "%s", - real_url, escaped); + markup = g_markup_printf_escaped ("%s", + real_url, title); + + g_string_append (string, markup); g_free (real_url); - g_free (escaped); + g_free (title); + g_free (markup); } void -- cgit v1.2.3