Mercurial > pidgin
changeset 3349:000546860da7
[gaim-migrate @ 3368]
Group rename synchronized on server roster.
committer: Tailor Script <tailor@pidgin.im>
author | Jim Seymour <jseymour> |
---|---|
date | Sun, 07 Jul 2002 14:34:41 +0000 (2002-07-07) |
parents | dd34e0b40fed |
children | 66e2846bacbb |
files | src/protocols/jabber/jabber.c |
diffstat | 1 files changed, 67 insertions(+), 17 deletions(-) [+] |
line wrap: on
line diff
--- a/src/protocols/jabber/jabber.c Sun Jul 07 14:31:57 2002 +0000 +++ b/src/protocols/jabber/jabber.c Sun Jul 07 14:34:41 2002 +0000 @@ -2276,14 +2276,19 @@ /* * Add/update buddy's roster entry on server + * + * If "alias" or "group" are NULL, gets them from Gaim's current buddylist values + * for the buddy. */ -static void jabber_roster_update(struct gaim_connection *gc, char *name) +static void jabber_roster_update(struct gaim_connection *gc, char *name, char *alias, char *group) { xmlnode x, y; char *realwho; gjconn gjc; struct buddy *buddy = NULL; struct group *buddy_group = NULL; + char *my_alias = NULL; + char *my_group = NULL; if(gc && gc->proto_data && ((struct jabber_data *)gc->proto_data)->gjc && name) { gaim_jid gjid; @@ -2304,26 +2309,42 @@ y = xmlnode_insert_tag(xmlnode_get_tag(x, "query"), "item"); xmlnode_put_attrib(y, "jid", realwho); - - /* If we can find the buddy, there's an alias for him, it's not 0-length + /* + * See if there's an explict (new?) alias for the buddy or we can pull + * one out of current Gaim buddylist data for him. + */ + if(alias && alias[0] != '\0') { + my_alias = alias; + } else if((buddy = find_buddy(gc, realwho)) != NULL) { + my_alias = buddy->show; + } + + /* If there's an alias for the buddy, it's not 0-length * and it doesn't match his JID, add the "name" attribute. */ - if((buddy = find_buddy(gc, realwho)) != NULL && - buddy->show != NULL && buddy->show[0] != '\0' && strcmp(realwho, buddy->show)) + if(my_alias != NULL && my_alias[0] != '\0' && strcmp(realwho, my_alias)) { - char *utf8 = str_to_utf8(buddy->show); + char *utf8 = str_to_utf8(my_alias); xmlnode_put_attrib(y, "name", utf8); g_free(utf8); } /* - * Find out what group the buddy's in and send that along - * with the roster item. + * See if there's an explict (new?) group for the buddy or pull + * one out of current Gaim buddylist data for him. */ - if((buddy_group = find_group_by_buddy(gc, realwho)) != NULL) { - xmlnode z; - z = xmlnode_insert_tag(y, "group"); - xmlnode_insert_cdata(z, buddy_group->name, -1); + if(group && group[0] != '\0') { + my_group = group; + } else if((buddy_group = find_group_by_buddy(gc, realwho)) != NULL) { + my_group = buddy_group->name; + } + + /* + * Send what group the buddy's in along with the roster item. + */ + if(my_group != NULL && my_group[0] != '\0') { + xmlnode z = xmlnode_insert_tag(y, "group"); + xmlnode_insert_cdata(z, my_group, -1); } gjab_send(((struct jabber_data *)gc->proto_data)->gjc, x); @@ -2334,13 +2355,41 @@ } /* + * Add/update buddy's alias on server + * + * This is just a roster update using existing, local buddylist data + */ +static void jabber_alias_buddy(struct gaim_connection *gc, char *name) +{ + jabber_roster_update(gc, name, NULL, NULL); +} + +/* * Change buddy's group on server roster */ static void jabber_group_change(struct gaim_connection *gc, char *name, char *old_group, char *new_group) { - if(strcmp(old_group, new_group)) { - jabber_roster_update(gc, name); - } + if(old_group && new_group && strcmp(old_group, new_group)) + jabber_roster_update(gc, name, NULL, new_group); +} + +/* + * Group rename + * + * Jabber doesn't have "groups," per se. "Group" is simply a JID attribute. + * So we iterate through the list of buddies that are in the group and change + * the group attribute for each of them. + */ +static void jabber_rename_group(struct gaim_connection *gc, + char *old_group, + char *new_group, + GList *members) +{ + if(old_group && new_group && strcmp(old_group, new_group)) + while(members) { + jabber_group_change(gc, (char *)(members->data), old_group, new_group); + members = members->next; + } } static void jabber_add_buddy(struct gaim_connection *gc, char *name) @@ -2381,7 +2430,7 @@ gjab_send(((struct jabber_data *)gc->proto_data)->gjc, x); xmlnode_free(x); - jabber_roster_update(gc, realwho); + jabber_roster_update(gc, realwho, NULL, NULL); g_free(realwho); } @@ -3965,10 +4014,11 @@ ret->keepalive = jabber_keepalive; ret->normalize = jabber_normalize; ret->register_user = jabber_register_user; - ret->alias_buddy = jabber_roster_update; + ret->alias_buddy = jabber_alias_buddy; ret->group_buddy = jabber_group_change; ret->send_typing = jabber_send_typing; ret->convo_closed = jabber_convo_closed; + ret->rename_group = jabber_rename_group; my_protocol = ret; }