# HG changeset patch # User Sadrul Habib Chowdhury # Date 1255336023 0 # Node ID 4a917f91bc0590c101888203f5fd246e0989bff2 # Parent ae7348244f56447c80338e3d80f0f77af6874f70# Parent b32f0ca0ed398f95b85df0306e618154dbb3cd05 merge of '3abad7606f4a2dfd1903df796f33924b12509a56' and 'a75276ac556cbbbde137203f6e38e37e3c7c4062' diff -r b32f0ca0ed39 -r 4a917f91bc05 libpurple/protocols/jabber/google.c --- a/libpurple/protocols/jabber/google.c Mon Oct 12 05:18:44 2009 +0000 +++ b/libpurple/protocols/jabber/google.c Mon Oct 12 08:27:03 2009 +0000 @@ -95,14 +95,14 @@ gchar *participant, GoogleSession *session) { GList *candidates = purple_media_get_local_candidates( - session->media, session_id, session->remote_jid); + session->media, session_id, session->remote_jid), *iter; PurpleMediaCandidate *transport; gboolean video = FALSE; if (!strcmp(session_id, "google-video")) video = TRUE; - for (;candidates;candidates = candidates->next) { + for (iter = candidates; iter; iter = iter->next) { JabberIq *iq; gchar *ip, *port, *username, *password; gchar pref[16]; @@ -110,7 +110,7 @@ xmlnode *sess; xmlnode *candidate; guint component_id; - transport = (PurpleMediaCandidate*)(candidates->data); + transport = PURPLE_MEDIA_CANDIDATE(iter->data); component_id = purple_media_candidate_get_component_id( transport); @@ -168,6 +168,7 @@ jabber_iq_send(iq); } + purple_media_candidate_list_free(candidates); } static void diff -r b32f0ca0ed39 -r 4a917f91bc05 libpurple/protocols/jabber/jabber.c --- a/libpurple/protocols/jabber/jabber.c Mon Oct 12 05:18:44 2009 +0000 +++ b/libpurple/protocols/jabber/jabber.c Mon Oct 12 08:27:03 2009 +0000 @@ -1079,39 +1079,19 @@ return; } } else { + const char *ids[] = {"username", "password", "name", "email", "nick", "first", + "last", "address", "city", "state", "zip", "phone", "url", "date", + NULL}; const char *value = purple_request_field_string_get_value(field); - - if(!strcmp(id, "username")) { - y = xmlnode_new_child(query, "username"); - } else if(!strcmp(id, "password")) { - y = xmlnode_new_child(query, "password"); - } else if(!strcmp(id, "name")) { - y = xmlnode_new_child(query, "name"); - } else if(!strcmp(id, "email")) { - y = xmlnode_new_child(query, "email"); - } else if(!strcmp(id, "nick")) { - y = xmlnode_new_child(query, "nick"); - } else if(!strcmp(id, "first")) { - y = xmlnode_new_child(query, "first"); - } else if(!strcmp(id, "last")) { - y = xmlnode_new_child(query, "last"); - } else if(!strcmp(id, "address")) { - y = xmlnode_new_child(query, "address"); - } else if(!strcmp(id, "city")) { - y = xmlnode_new_child(query, "city"); - } else if(!strcmp(id, "state")) { - y = xmlnode_new_child(query, "state"); - } else if(!strcmp(id, "zip")) { - y = xmlnode_new_child(query, "zip"); - } else if(!strcmp(id, "phone")) { - y = xmlnode_new_child(query, "phone"); - } else if(!strcmp(id, "url")) { - y = xmlnode_new_child(query, "url"); - } else if(!strcmp(id, "date")) { - y = xmlnode_new_child(query, "date"); - } else { + int i; + for (i = 0; ids[i]; i++) { + if (!strcmp(id, ids[i])) + break; + } + + if (!ids[i]) continue; - } + y = xmlnode_new_child(query, ids[i]); xmlnode_insert_data(y, value, -1); if(cbdata->js->registration && !strcmp(id, "username")) { g_free(cbdata->js->user->node); diff -r b32f0ca0ed39 -r 4a917f91bc05 libpurple/protocols/msn/nexus.c --- a/libpurple/protocols/msn/nexus.c Mon Oct 12 05:18:44 2009 +0000 +++ b/libpurple/protocols/msn/nexus.c Mon Oct 12 08:27:03 2009 +0000 @@ -508,6 +508,7 @@ } g_free(ud); + g_free(key); } void diff -r b32f0ca0ed39 -r 4a917f91bc05 libpurple/protocols/msn/servconn.c --- a/libpurple/protocols/msn/servconn.c Mon Oct 12 05:18:44 2009 +0000 +++ b/libpurple/protocols/msn/servconn.c Mon Oct 12 08:27:03 2009 +0000 @@ -299,8 +299,8 @@ static gboolean servconn_idle_timeout_cb(MsnServConn *servconn) { + servconn->timeout_handle = 0; msn_servconn_disconnect(servconn); - servconn->timeout_handle = 0; /* XXX: servconn may not be valid anymore */ return FALSE; }