Mercurial > pidgin
changeset 8185:3a229ad2fab0
[gaim-migrate @ 8906]
take 1 of UberUglyHack
committer: Tailor Script <tailor@pidgin.im>
author | Nathan Walp <nwalp@pidgin.im> |
---|---|
date | Fri, 30 Jan 2004 21:56:31 +0000 (2004-01-30) |
parents | f05d0a317f45 |
children | 8efff3aa4e39 |
files | src/protocols/jabber/buddy.c src/protocols/jabber/presence.c src/protocols/jabber/presence.h src/protocols/jabber/roster.c |
diffstat | 4 files changed, 47 insertions(+), 18 deletions(-) [+] |
line wrap: on
line diff
--- a/src/protocols/jabber/buddy.c Thu Jan 29 17:39:32 2004 +0000 +++ b/src/protocols/jabber/buddy.c Fri Jan 30 21:56:31 2004 +0000 @@ -912,7 +912,9 @@ */ - if(js->protocol_version == JABBER_PROTO_0_9) { + /* XXX: fix the NOT ME below */ + + if(js->protocol_version == JABBER_PROTO_0_9 /* && NOT ME */) { pbm = g_new0(struct proto_buddy_menu, 1); if(jb->invisible & JABBER_INVIS_BUDDY) { pbm->label = _("Un-hide From"); @@ -925,7 +927,7 @@ m = g_list_append(m, pbm); } - if(jb->subscription & JABBER_SUB_FROM) { + if(jb->subscription & JABBER_SUB_FROM /* && NOT ME */) { pbm = g_new0(struct proto_buddy_menu, 1); pbm->label = _("Cancel Presence Notification"); pbm->callback = jabber_buddy_cancel_presence_notification; @@ -939,7 +941,7 @@ pbm->callback = jabber_buddy_rerequest_auth; pbm->gc = gc; m = g_list_append(m, pbm); - } else { + } else /* if(NOT ME) */{ pbm = g_new0(struct proto_buddy_menu, 1); pbm->label = _("Unsubscribe"); pbm->callback = jabber_buddy_unsubscribe;
--- a/src/protocols/jabber/presence.c Thu Jan 29 17:39:32 2004 +0000 +++ b/src/protocols/jabber/presence.c Fri Jan 30 21:56:31 2004 +0000 @@ -45,6 +45,35 @@ jabber_send(chat->js, presence); } +static int show_to_state(const char *show) { + if(!show) + return 0; + else if(!strcmp(show, "away") || !strcmp(show, _("Away"))) + return JABBER_STATE_AWAY; + else if(!strcmp(show, "chat") || !strcmp(show, _("Chatty"))) + return JABBER_STATE_CHAT; + else if(!strcmp(show, "xa") || !strcmp(show, _("Extended Away"))) + return JABBER_STATE_XA; + else if(!strcmp(show, "dnd") || !strcmp(show, _("Do Not Disturb"))) + return JABBER_STATE_DND; + return 0; +} + +void jabber_presence_fake_to_self(JabberStream *js, const char *show, const char *status) { + char *my_base_jid = g_strdup_printf("%s@%s", js->user->node, js->user->domain); + if(gaim_find_buddy(js->gc->account, my_base_jid)) { + JabberBuddy *jb; + JabberBuddyResource *jbr; + if((jb = jabber_buddy_find(js, my_base_jid, TRUE))) { + jabber_buddy_track_resource(jb, js->user->resource, 0, + show_to_state(show), (status && *status) ? status : NULL); + if((jbr = jabber_buddy_find_resource(jb, NULL))) + serv_got_update(js->gc, my_base_jid, 1, 0, 0, 0, jbr->state); + } + } + g_free(my_base_jid); +} + void jabber_presence_send(GaimConnection *gc, const char *state, const char *msg) @@ -64,10 +93,12 @@ g_free(gc->away); gc->away = stripped; - presence = jabber_presence_create(state, msg); + presence = jabber_presence_create(state, stripped); jabber_send(js, presence); g_hash_table_foreach(js->chats, chats_send_presence_foreach, presence); xmlnode_free(presence); + + jabber_presence_fake_to_self(js, state, stripped); } xmlnode *jabber_presence_create(const char *state, const char *msg) @@ -199,17 +230,7 @@ } else { if((y = xmlnode_get_child(packet, "show"))) { char *show = xmlnode_get_data(y); - if(!show) { - state = 0; - } else if(!strcasecmp(show, "away")) { - state = JABBER_STATE_AWAY; - } else if(!strcasecmp(show, "chat")) { - state = JABBER_STATE_CHAT; - } else if(!strcasecmp(show, "xa")) { - state = JABBER_STATE_XA; - } else if(!strcasecmp(show, "dnd")) { - state = JABBER_STATE_DND; - } + state = show_to_state(show); g_free(show); } else { state = 0;
--- a/src/protocols/jabber/presence.h Thu Jan 29 17:39:32 2004 +0000 +++ b/src/protocols/jabber/presence.h Fri Jan 30 21:56:31 2004 +0000 @@ -37,5 +37,6 @@ void jabber_presence_parse(JabberStream *js, xmlnode *packet); void jabber_presence_subscription_set(JabberStream *js, const char *who, const char *type); +void jabber_presence_fake_to_self(JabberStream *js, const char *show, const char *status); #endif /* _GAIM_JABBER_PRESENCE_H_ */
--- a/src/protocols/jabber/roster.c Thu Jan 29 17:39:32 2004 +0000 +++ b/src/protocols/jabber/roster.c Fri Jan 30 21:56:31 2004 +0000 @@ -176,9 +176,6 @@ jb->subscription &= ~JABBER_SUB_PENDING; if(jb->subscription == JABBER_SUB_NONE) { - jb = jabber_buddy_find(js, jid, FALSE); - if(jb) - jb->subscription = JABBER_SUB_NONE; remove_gaim_buddies(js, jid); } else { GSList *groups = NULL; @@ -191,6 +188,14 @@ groups = g_slist_append(groups, group_name); } add_gaim_buddies_in_groups(js, jid, name, groups); + + if(jb->subscription == JABBER_SUB_BOTH) { + char *my_bare_jid = g_strdup_printf("%s@%s", js->user->node, js->user->domain); + if(!strcmp(jid, my_bare_jid)) { + jabber_presence_fake_to_self(js, js->gc->away_state, js->gc->away); + } + g_free(my_bare_jid); + } } }