diff options
Diffstat (limited to 'src/fe-common/core')
-rw-r--r-- | src/fe-common/core/formats.c | 39 |
1 files changed, 35 insertions, 4 deletions
diff --git a/src/fe-common/core/formats.c b/src/fe-common/core/formats.c index 22ed82be..235bc60c 100644 --- a/src/fe-common/core/formats.c +++ b/src/fe-common/core/formats.c @@ -297,14 +297,44 @@ void format_create_dest_tag(TEXT_DEST_REC *dest, void *server, window_find_closest(server, target, level); } +static gboolean term_is_utf8 (void) +{ + const char *charset; + + charset = settings_get_str("term_type"); + if (*charset) + return ! g_strcasecmp(charset, "utf-8"); + + return g_get_charset(&charset); +} + +static int advance (char const **str, gboolean utf8) +{ + if (utf8) { + gunichar c; + + c = g_utf8_get_char(*str); + *str = g_utf8_next_char(*str); + + return g_unichar_iswide(c) ? 2 : 1; + } else { + *str += 1; + + return 1; + } +} + /* Return length of text part in string (ie. without % codes) */ int format_get_length(const char *str) { GString *tmp; int len; + gboolean utf8; g_return_val_if_fail(str != NULL, 0); + utf8 = term_is_utf8() && g_utf8_validate(str, -1, NULL); + tmp = g_string_new(NULL); len = 0; while (*str != '\0') { @@ -321,8 +351,7 @@ int format_get_length(const char *str) len++; } - len++; - str++; + len += advance(&str, utf8); } g_string_free(tmp, TRUE); @@ -336,10 +365,13 @@ int format_real_length(const char *str, int len) { GString *tmp; const char *start; + gboolean utf8; g_return_val_if_fail(str != NULL, 0); g_return_val_if_fail(len >= 0, 0); + utf8 = term_is_utf8() && g_utf8_validate(str, -1, NULL); + start = str; tmp = g_string_new(NULL); while (*str != '\0' && len > 0) { @@ -358,8 +390,7 @@ int format_real_length(const char *str, int len) } } - len--; - str++; + len -= advance(&str, utf8); } g_string_free(tmp, TRUE); |