# HG changeset patch # User Yoshiki Yazawa # Date 1181567280 0 # Node ID 2dca564c246592767cd254597c5e9939b899a6bc # Parent abc46fd562bd25987486f4dbbb14411662126abf# Parent fb0b82b40f985ac5982977f46c113a66d9f2bf06 merge of '3a630a4fd8d8b4dc763804428205cac11bbfe2ad' and '822d7136334636074d3efb9862c7300265d44e0c' diff -r fb0b82b40f98 -r 2dca564c2465 libpurple/protocols/irc/parse.c --- a/libpurple/protocols/irc/parse.c Mon Jun 11 05:49:32 2007 +0000 +++ b/libpurple/protocols/irc/parse.c Mon Jun 11 13:08:00 2007 +0000 @@ -242,6 +242,8 @@ gboolean iskana = FALSE; char *pos = NULL; gboolean irc_use_sosi, irc_use_8bit; + char *strtmp; + size_t strtmp_len; enclist = purple_account_get_string(irc->account, "encoding", IRC_DEFAULT_CHARSET); encodings = g_strsplit(enclist, ",", 2); @@ -254,11 +256,13 @@ return g_strdup(string); } - utf8 = g_convert(string, strlen(string), encodings[0], "UTF-8", NULL, NULL, &err); + strtmp = (char *)sanitize_utf((unsigned char *)string, strlen(string), &strtmp_len); + utf8 = g_convert(strtmp, strlen(strtmp), encodings[0], "UTF-8", NULL, NULL, &err); + if (err) { purple_debug(PURPLE_DEBUG_ERROR, "irc", "Send conversion error: %s\n", err->message); purple_debug(PURPLE_DEBUG_ERROR, "irc", "Sending as UTF-8 instead of %s\n", encodings[0]); - utf8 = g_strdup(string); + utf8 = g_strdup(strtmp); g_error_free(err); } @@ -321,6 +325,7 @@ } g_strfreev(encodings); + g_free(strtmp); return utf8; } @@ -334,6 +339,8 @@ gboolean retry; gsize in_len, out_len; int conv_len; + char *strtmp; + size_t strtmp_len; enclist = purple_account_get_string(irc->account, "encoding", IRC_DEFAULT_CHARSET); encodings = g_strsplit(enclist, ",", -1); @@ -464,8 +471,10 @@ if(utf8){ - g_strfreev(encodings); - return utf8; + strtmp = (char *)botch_utf((unsigned char *)utf8, strlen(utf8), &strtmp_len); + g_strfreev(encodings); + g_free(utf8); + return strtmp; } } g_strfreev(encodings);