From: Carlos Garcia Campos Date: Mon, 5 Feb 2007 17:57:23 +0000 (+0000) Subject: Make sure g_markup_escape_text receives a valid utf-8 string. Fixes bug X-Git-Tag: EVINCE_0_7_2~25 X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=commitdiff_plain;h=a887618b58630a604adfdfb24d253a88ea08fc2c;p=evince.git Make sure g_markup_escape_text receives a valid utf-8 string. Fixes bug 2007-02-05 Carlos Garcia Campos * backend/djvu/djvu-links.c: (str_to_utf8), (build_tree): Make sure g_markup_escape_text receives a valid utf-8 string. Fixes bug #373715. svn path=/trunk/; revision=2296 --- diff --git a/ChangeLog b/ChangeLog index b8b7c5b8..b0e1dfff 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2007-02-05 Carlos Garcia Campos + + * backend/djvu/djvu-links.c: (str_to_utf8), (build_tree): + + Make sure g_markup_escape_text receives a valid utf-8 string. Fixes + bug #373715. + 2007-02-05 Carlos Garcia Campos * backend/ps/ps.c: (psscan): diff --git a/backend/djvu/djvu-links.c b/backend/djvu/djvu-links.c index 1fc394ad..bdc24be8 100644 --- a/backend/djvu/djvu-links.c +++ b/backend/djvu/djvu-links.c @@ -108,6 +108,39 @@ get_djvu_link_action (const DjvuDocument *djvu_document, const gchar *link_name, return ev_action; } +static gchar * +str_to_utf8 (const gchar *text) +{ + static const gchar *encodings_to_try[2]; + static gint n_encodings_to_try = 0; + gchar *utf8_text = NULL; + gint i; + + if (n_encodings_to_try == 0) { + const gchar *charset; + gboolean charset_is_utf8; + + charset_is_utf8 = g_get_charset (&charset); + if (!charset_is_utf8) { + encodings_to_try[n_encodings_to_try++] = charset; + } + + if (g_ascii_strcasecmp (charset, "ISO-8859-1") != 0) { + encodings_to_try[n_encodings_to_try++] = "ISO-8859-1"; + } + } + + for (i = 0; i < n_encodings_to_try; i++) { + utf8_text = g_convert (text, -1, "UTF-8", + encodings_to_try[i], + NULL, NULL, NULL); + if (utf8_text) + break; + } + + return utf8_text; +} + /** * Builds the index GtkTreeModel from DjVu s-expr * @@ -141,7 +174,16 @@ build_tree (const DjvuDocument *djvu_document, if (!string_from_miniexp (miniexp_car (iter), &title)) goto unknown_entry; if (!string_from_miniexp (miniexp_cadr (iter), &link_dest)) goto unknown_entry; - title_markup = g_markup_escape_text (title, -1); + if (!g_utf8_validate (title, -1, NULL)) { + gchar *utf8_title; + + utf8_title = str_to_utf8 (title); + title_markup = g_markup_escape_text (utf8_title, -1); + g_free (utf8_title); + } else { + title_markup = g_markup_escape_text (title, -1); + } + ev_action = get_djvu_link_action (djvu_document, link_dest, -1); if (g_str_has_suffix (link_dest, ".djvu")) {