From 1bf37776c3ef6d0b11109123d2a0916309a386c4 Mon Sep 17 00:00:00 2001 From: "Alex R.M. Turner" Date: Sun, 28 Oct 2007 15:51:14 +0000 Subject: [PATCH] Truncate the string to max_char_per_title before adding bold tags and fix 2007-10-27 Alex R.M. Turner * src/tabpopup.c (tab_entry_new): Truncate the string to max_char_per_title before adding bold tags and fix general flow of function. svn path=/trunk/; revision=3363 --- ChangeLog | 6 ++++++ src/tabpopup.c | 31 +++++++++++++++++-------------- 2 files changed, 23 insertions(+), 14 deletions(-) diff --git a/ChangeLog b/ChangeLog index 9b4b1c9f8..fd7538711 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2007-10-27 Alex R.M. Turner + + * src/tabpopup.c (tab_entry_new): Truncate the string to + max_char_per_title before adding bold tags and fix general flow of + function. + 2007-10-16 Thomas Thurman * src/window.c (window_would_be_covered): new function. diff --git a/src/tabpopup.c b/src/tabpopup.c index af24764a9..e17c2a63c 100644 --- a/src/tabpopup.c +++ b/src/tabpopup.c @@ -156,31 +156,34 @@ tab_entry_new (const MetaTabEntry *entry, te->title = NULL; if (entry->title) { + gchar *str; gchar *tmp; + gchar *formatter = "%s"; + + str = meta_g_utf8_strndup (entry->title, max_chars_per_title); + if (entry->hidden) { - tmp = g_markup_printf_escaped ("[%s]", entry->title); + formatter = "[%s]"; } - else - { - tmp = g_markup_printf_escaped ("%s", entry->title); - } - + + tmp = g_markup_printf_escaped (formatter, str); + g_free (str); + str = tmp; + if (entry->demands_attention) { /* Escape the whole line of text then markup the text and * copy it back into the original buffer. */ - gchar *markup, *escaped; - escaped = g_markup_escape_text (tmp, -1); - markup = g_strdup_printf ("%s", escaped); - g_free (escaped); - g_free (tmp); - tmp = markup; + tmp = g_strdup_printf ("%s", str); + g_free (str); + str = tmp; } - te->title = meta_g_utf8_strndup (tmp, max_chars_per_title); - g_free (tmp); + te->title=g_strdup(str); + + g_free (str); } te->widget = NULL; te->icon = entry->icon;