# HG changeset patch # User Jeffrey Connelly # Date 1186808543 0 # Node ID daedc964734171b44b688b606dc41f80e459eb31 # Parent cd90423c0a88d26b11f393fe1c06578a08b87520 Convert password to lowercase using g_utf8_strdown(), better because g_strdown() in glib is deprecated (documentation says it is "totally broken") and now you might be able to use Unicode passwords (if MySpace allows it). diff -r cd90423c0a88 -r daedc9647341 libpurple/protocols/myspace/myspace.c --- a/libpurple/protocols/myspace/myspace.c Sat Aug 11 04:54:13 2007 +0000 +++ b/libpurple/protocols/myspace/myspace.c Sat Aug 11 05:02:23 2007 +0000 @@ -47,7 +47,7 @@ * Multiple emoticon symbols in Pidgin can map to one name. List the * canonical form, as inserted by the "Smile!" dialog, first. For example, * :) comes before :-), because although both are recognized as 'happy', - * the first is inserted by the smiley button. + * the first is inserted by the smiley button. * * Note that symbols are case-sensitive in Pidgin -- :-X is not :-x. */ @@ -361,6 +361,7 @@ menu = zap_menu = NULL; + /* TODO: move to / command, or better yet new API */ for (i = 0; i < sizeof(zap_names) / sizeof(zap_names[0]); ++i) { act = purple_menu_action_new(zap_names[i], PURPLE_CALLBACK(msim_send_zap), GUINT_TO_POINTER(i), NULL); @@ -633,7 +634,7 @@ guchar hash_pw[HASH_SIZE]; guchar key[HASH_SIZE]; - gchar *password_utf16le, *password_ascii_lc; + gchar *password_utf16le, *password_utf8_lc; guchar *data; guchar *data_out; size_t data_len, data_out_len; @@ -651,15 +652,14 @@ /* Convert password to lowercase (required for passwords containing * uppercase characters). MySpace passwords are lowercase, * see ticket #2066. */ - password_ascii_lc = g_strdup(password); - g_strdown(password_ascii_lc); + password_utf8_lc = g_utf8_strdown(password, -1); /* Convert ASCII password to UTF16 little endian */ purple_debug_info("msim", "converting password to UTF-16LE\n"); conv_error = NULL; - password_utf16le = g_convert(password_ascii_lc, -1, "UTF-16LE", "UTF-8", + password_utf16le = g_convert(password_utf8_lc, -1, "UTF-16LE", "UTF-8", &conv_bytes_read, &conv_bytes_written, &conv_error); - g_free(password_ascii_lc); + g_free(password_utf8_lc); g_return_val_if_fail(conv_bytes_read == strlen(password), NULL);