Mercurial > pidgin.yaz
view libgaim/protocols/gg/confer.c @ 15298:f08b43af6791
[gaim-migrate @ 18088]
We've seen a crash in which a NULL circbuffer was passed to gaim_circ_buffer_append() from flap_connection_send_byte_stream().
(flap_connection_send_byte_stream() was somehow called after flap_connection_close() - perhaps a result of the rate limiting queuing code?)
In any case, circbuffer should use g_return_if_fail() and g_return_val_if_fail() to throw warnings in this condition rather than crashing on a NULL pointer access. Added such checks at the top of the relevant functions.
committer: Tailor Script <tailor@pidgin.im>
author | Evan Schoenberg <evan.s@dreskin.net> |
---|---|
date | Mon, 08 Jan 2007 15:01:06 +0000 |
parents | 60b1bc8dbf37 |
children |
line wrap: on
line source
/** * @file confer.c * * gaim * * Copyright (C) 2005 Bartosz Oler <bartosz@bzimage.us> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include <libgadu.h> #include "gg.h" #include "gg-utils.h" #include "confer.h" /* GaimConversation *ggp_confer_find_by_name(GaimConnection *gc, const gchar *name) {{{ */ GaimConversation *ggp_confer_find_by_name(GaimConnection *gc, const gchar *name) { g_return_val_if_fail(gc != NULL, NULL); g_return_val_if_fail(name != NULL, NULL); return gaim_find_conversation_with_account(GAIM_CONV_TYPE_CHAT, name, gaim_connection_get_account(gc)); } /* }}} */ /* void ggp_confer_participants_add_uin(GaimConnection *gc, const gchar *chat_name, const uin_t uin) {{{ */ void ggp_confer_participants_add_uin(GaimConnection *gc, const gchar *chat_name, const uin_t uin) { GaimConversation *conv; GGPInfo *info = gc->proto_data; GGPChat *chat; GList *l; gchar *str_uin; for (l = info->chats; l != NULL; l = l->next) { chat = l->data; if (g_utf8_collate(chat->name, chat_name) != 0) continue; if (g_list_find(chat->participants, GINT_TO_POINTER(uin)) == NULL) { chat->participants = g_list_append( chat->participants, GINT_TO_POINTER(uin)); str_uin = g_strdup_printf("%lu", (unsigned long int)uin); conv = ggp_confer_find_by_name(gc, chat_name); gaim_conv_chat_add_user(GAIM_CONV_CHAT(conv), str_uin, NULL, GAIM_CBFLAGS_NONE, TRUE); g_free(str_uin); } break; } } /* }}} */ /* void ggp_confer_participants_add(GaimConnection *gc, const gchar *chat_name, const uin_t *recipients, int count) {{{ */ void ggp_confer_participants_add(GaimConnection *gc, const gchar *chat_name, const uin_t *recipients, int count) { GGPInfo *info = gc->proto_data; GList *l; gchar *str_uin; for (l = info->chats; l != NULL; l = l->next) { GGPChat *chat = l->data; int i; if (g_utf8_collate(chat->name, chat_name) != 0) continue; for (i = 0; i < count; i++) { GaimConversation *conv; if (g_list_find(chat->participants, GINT_TO_POINTER(recipients[i])) != NULL) { continue; } chat->participants = g_list_append(chat->participants, GINT_TO_POINTER(recipients[i])); str_uin = g_strdup_printf("%lu", (unsigned long int)recipients[i]); conv = ggp_confer_find_by_name(gc, chat_name); gaim_conv_chat_add_user(GAIM_CONV_CHAT(conv), str_uin, NULL, GAIM_CBFLAGS_NONE, TRUE); g_free(str_uin); } break; } } /* }}} */ /* const char *ggp_confer_find_by_participants(GaimConnection *gc, const uin_t *recipients, int count) {{{ */ const char *ggp_confer_find_by_participants(GaimConnection *gc, const uin_t *recipients, int count) { GGPInfo *info = gc->proto_data; GGPChat *chat = NULL; GList *l; int matches; g_return_val_if_fail(info->chats != NULL, NULL); for (l = info->chats; l != NULL; l = l->next) { GList *m; chat = l->data; matches = 0; for (m = chat->participants; m != NULL; m = m->next) { uin_t uin = GPOINTER_TO_INT(m->data); int i; for (i = 0; i < count; i++) if (uin == recipients[i]) matches++; } if (matches == count) break; chat = NULL; } if (chat == NULL) return NULL; else return chat->name; } /* }}} */ /* const char *ggp_confer_add_new(GaimConnection *gc, const char *name) {{{ */ const char *ggp_confer_add_new(GaimConnection *gc, const char *name) { GGPInfo *info = gc->proto_data; GGPChat *chat; chat = g_new0(GGPChat, 1); if (name == NULL) chat->name = g_strdup_printf("conf#%d", info->chats_count++); else chat->name = g_strdup(name); chat->participants = NULL; info->chats = g_list_append(info->chats, chat); return chat->name; } /* }}} */ /* vim: set ts=8 sts=0 sw=8 noet: */