Mercurial > pidgin
changeset 1083:12478dd1e9d7
[gaim-migrate @ 1093]
yeah
committer: Tailor Script <tailor@pidgin.im>
author | Eric Warmenhoven <eric@warmenhoven.org> |
---|---|
date | Sat, 11 Nov 2000 06:57:57 +0000 (2000-11-11) |
parents | 13df4e342cff |
children | fb49b3f93726 |
files | src/buddy.c src/prpl.h |
diffstat | 2 files changed, 18 insertions(+), 12 deletions(-) [+] |
line wrap: on
line diff
--- a/src/buddy.c Fri Nov 10 23:26:57 2000 +0000 +++ b/src/buddy.c Sat Nov 11 06:57:57 2000 +0000 @@ -270,13 +270,13 @@ m = g->members; while (m) { b = (struct buddy_show *)m->data; - if (g_slist_length(b->connlist) == 1 && b->connlist->data == gc) { + if ((g_slist_length(b->connlist) == 1) && (b->connlist->data == gc)) { if (b->log_timer > 0) gtk_timeout_remove(b->log_timer); b->connlist = g_slist_remove(b->connlist, gc); gtk_container_remove(GTK_CONTAINER(g->tree), b->item); - g->members = g_slist_remove(g->members, b); - if (g->members == NULL) { + m = g->members = g_slist_remove(g->members, b); + if ((g->members == NULL) && (display_options & OPT_DISP_NO_MT_GRP)) { shows = g_slist_remove(shows, g); gtk_container_remove(GTK_CONTAINER(buddies), g->item); g_free(g->name); @@ -284,12 +284,13 @@ m = NULL; remove_group = TRUE; } else - m = g->members; + update_num_group(g); g_free(b->name); g_free(b->show); g_free(b); } else if (g_slist_find(b->connlist, gc)) { - b->connlist = g_slist_remove(b->connlist, gc); + if (g_slist_find(b->connlist, gc)) + b->connlist = g_slist_remove(b->connlist, gc); m = g_slist_next(m); } else m = g_slist_next(m); @@ -491,7 +492,6 @@ if (bs) { if (g_slist_find(bs->connlist, gc)) { bs->connlist = g_slist_remove(bs->connlist, gc); - update_num_group(gs); if (!g_slist_length(bs->connlist)) { gs->members = g_slist_remove(gs->members, bs); if (bs->log_timer > 0) @@ -500,13 +500,16 @@ g_free(bs->show); g_free(bs->name); g_free(bs); - if (!g_slist_length(gs->members)) { + if (!g_slist_length(gs->members) && + (display_options & OPT_DISP_NO_MT_GRP)) { shows = g_slist_remove(shows, gs); gtk_container_remove(GTK_CONTAINER(buddies), gs->item); g_free(gs->name); g_free(gs); - } - } + } else + update_num_group(gs); + } else + update_num_group(gs); } } } @@ -549,7 +552,8 @@ while(delg->members) { delb = (struct buddy *)delg->members->data; - remove_buddy(gc, delg, delb); + remove_buddy(gc, delg, delb); /* this should take care of removing + the group_show if necessary */ serv_remove_buddy(gc, delb->name); } @@ -1529,12 +1533,13 @@ struct group_show *g = find_gs_by_bs(b); g->members = g_slist_remove(g->members, b); gtk_container_remove(GTK_CONTAINER(g->tree), b->item); - if (g->members == NULL && (display_options & OPT_DISP_NO_MT_GRP)) { + if ((g->members == NULL) && (display_options & OPT_DISP_NO_MT_GRP)) { shows = g_slist_remove(shows, g); gtk_container_remove(GTK_CONTAINER(buddies), g->item); g_free(g->name); g_free(g); - } + } else + update_num_group(g); g_free(b->name); g_free(b->show); g_free(b);