Mercurial > pidgin
diff src/list.c @ 4458:a46c57f2d58b
[gaim-migrate @ 4733]
(20:45:09) Trogdor: http://web.ics.purdue.edu/~eblanton/gaim/gaim-cvs-oscar-ssi-conv.diff
(20:45:12) Trogdor: commit please
(20:45:22) LSchiere: commit log?
(20:45:48) Trogdor: Adds best-effort charset conversion to Oscar SSI aliases and group names.
(20:45:55) Trogdor: oh
(20:46:19) Trogdor: Also adds a gaim global function gaim_try_conv_to_utf8 () for attempting several logical encodings on a given string.
(20:46:43) Trogdor: (which replaces the aptly named whatever_to_utf8)
committer: Tailor Script <tailor@pidgin.im>
author | Luke Schierer <lschiere@pidgin.im> |
---|---|
date | Wed, 29 Jan 2003 01:46:44 +0000 |
parents | fd83159169db |
children | 3196d9044a45 |
line wrap: on
line diff
--- a/src/list.c Wed Jan 29 01:20:20 2003 +0000 +++ b/src/list.c Wed Jan 29 01:46:44 2003 +0000 @@ -41,11 +41,6 @@ #define PATHSIZE 1024 -/* This guy does its best to convert a string to UTF-8 from an unknown - * encoding by checking the locale and trying some sane defaults ... - * if everything fails it returns NULL. */ -static char *whatever_to_utf8(const char *str); - void remove_buddy(struct buddy *rem_b) { if(rem_b->user->gc) { @@ -263,7 +258,7 @@ break; if (*c == 'g') { char *utf8 = NULL; - utf8 = whatever_to_utf8(c + 2); + utf8 = gaim_try_conv_to_utf8(c + 2); if (utf8 == NULL) { g_strlcpy(current, _("Invalid Groupname"), sizeof(current)); } else { @@ -282,7 +277,7 @@ g_strlcpy(nm, c + 2, sizeof(nm)); if (a) { - utf8 = whatever_to_utf8(a); + utf8 = gaim_try_conv_to_utf8(a); if (utf8 == NULL) { debug_printf ("Failed to convert alias for '%s' to UTF-8\n", nm); } @@ -1210,29 +1205,3 @@ return NULL; return g_strdup(g_hash_table_lookup(b->settings, key)); } - -static char *whatever_to_utf8(const char *str) -{ - int converted; - char *utf8; - - if (g_utf8_validate(str, -1, NULL)) { - return g_strdup(str); - } - - utf8 = g_locale_to_utf8(str, -1, &converted, NULL, NULL); - if (utf8 && converted == strlen (str)) { - return(utf8); - } else if (utf8) { - g_free(utf8); - } - - utf8 = g_convert(str, -1, "UTF-8", "ISO-8859-15", &converted, NULL, NULL); - if (utf8 && converted == strlen (str)) { - return(utf8); - } else if (utf8) { - g_free(utf8); - } - - return(NULL); -}