# HG changeset patch # User Christian Hammond # Date 1053405520 0 # Node ID c8c290021b7be3c4f5065ca75c611ea10c75df2a # Parent 40e976d420284586047a8040cbf3244cf5df7337 [gaim-migrate @ 5845] Okay, now it's fixed. Everybody gets an MsnUser. Yay! committer: Tailor Script diff -r 40e976d42028 -r c8c290021b7b src/protocols/msn/notification.c --- a/src/protocols/msn/notification.c Tue May 20 04:14:17 2003 +0000 +++ b/src/protocols/msn/notification.c Tue May 20 04:38:40 2003 +0000 @@ -37,6 +37,64 @@ G_MODULE_IMPORT GSList *connections; /************************************************************************** + * Utility functions + **************************************************************************/ +static gboolean +__add_buddy(MsnServConn *servconn, MsnUser *user) +{ + MsnSession *session = servconn->session; + struct gaim_connection *gc = session->account->gc; + struct buddy *b; + + b = gaim_find_buddy(gc->account, msn_user_get_passport(user)); + + if (b == NULL) { + struct group *g = NULL; + const char *group_name = NULL; + int group_id; + + group_id = msn_user_get_group_id(user); + + if (group_id > -1) { + group_name = g_hash_table_lookup(session->group_names, + &group_id); + } + + if (group_name == NULL) { + gaim_debug(GAIM_DEBUG_WARNING, "msn", + "Group ID %d for user %s was not defined.\n", + group_id, msn_user_get_passport(user)); + } + else if ((g = gaim_find_group(group_name)) == NULL) { + gaim_debug(GAIM_DEBUG_ERROR, "msn", + "Group '%s' appears in server-side " + "buddy list, but not here!", + group_name); + } + + if (g == NULL) { + if ((g = gaim_find_group(_("Buddies"))) == NULL) { + g = gaim_group_new(_("Buddies")); + gaim_blist_add_group(g, NULL); + } + } + + b = gaim_buddy_new(gc->account, + msn_user_get_passport(user), NULL); + + gaim_blist_add_buddy(b, g, NULL); + } + + b->proto_data = user; + + serv_got_alias(gc, (char *)msn_user_get_passport(user), + (char *)msn_user_get_name(user)); + + return TRUE; +} + + +/************************************************************************** * Callbacks **************************************************************************/ static void @@ -344,6 +402,7 @@ size_t param_count) { MsnSession *session = servconn->session; + MsnUser *user; struct gaim_connection *gc = session->account->gc; MsnPermitAdd *pa; GSList *sl; @@ -356,7 +415,14 @@ friend = msn_url_decode(params[4]); - if (g_ascii_strcasecmp(list, "RL")) + if (!g_ascii_strcasecmp(list, "FL")) { + user = msn_user_new(session, passport, friend); + + __add_buddy(servconn, user); + + return TRUE; + } + else if (g_ascii_strcasecmp(list, "RL")) return TRUE; for (sl = gc->account->permit; sl != NULL; sl = sl->next) { @@ -364,9 +430,11 @@ return TRUE; } - pa = g_new0(MsnPermitAdd, 1); - pa->user = msn_user_new(session, passport, friend); - pa->gc = gc; + user = msn_user_new(session, passport, friend); + + pa = g_new0(MsnPermitAdd, 1); + pa->user = user; + pa->gc = gc; g_snprintf(msg, sizeof(msg), _("The user %s (%s) wants to add %s to his or her buddy list."), @@ -684,54 +752,11 @@ while (session->lists.forward != NULL) { MsnUser *user = session->lists.forward->data; - struct buddy *b; - - b = gaim_find_buddy(gc->account, msn_user_get_passport(user)); session->lists.forward = g_slist_remove(session->lists.forward, user); - if (b == NULL) { - struct group *g = NULL; - const char *group_name = NULL; - int group_id; - - group_id = msn_user_get_group_id(user); - - if (group_id > -1) { - group_name = g_hash_table_lookup(session->group_names, - &group_id); - } - - if (group_name == NULL) { - gaim_debug(GAIM_DEBUG_WARNING, "msn", - "Group ID %d for user %s was not defined.\n", - group_id, passport); - } - else if ((g = gaim_find_group(group_name)) == NULL) { - gaim_debug(GAIM_DEBUG_ERROR, "msn", - "Group '%s' appears in server-side " - "buddy list, but not here!", - group_name); - } - - if (g == NULL) { - if ((g = gaim_find_group(_("Buddies"))) == NULL) { - g = gaim_group_new(_("Buddies")); - gaim_blist_add_group(g, NULL); - } - } - - b = gaim_buddy_new(gc->account, - msn_user_get_passport(user), NULL); - - gaim_blist_add_buddy(b, g, NULL); - } - - b->proto_data = user; - - serv_got_alias(gc, (char *)msn_user_get_passport(user), - (char *)msn_user_get_name(user)); + __add_buddy(servconn, user); } session->syncing_lists = FALSE;