Mercurial > pidgin
view libpurple/protocols/novell/nmconference.c @ 30604:bc0bccdbc28f
jabber: Handle a corner case better by throwing an error instead of stalling
This happens if the server *has* a TXT record for _xmppconnect.$domain,
but has no useful content there. Fixes #12744, #a14367.
author | Paul Aurich <paul@darkrain42.org> |
---|---|
date | Thu, 14 Oct 2010 03:12:01 +0000 |
parents | 44b4e8bd759b |
children |
line wrap: on
line source
/* * nmconference.c * * Copyright (c) 2004 Novell, Inc. All Rights Reserved. * * 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; version 2 of the License. * * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA * */ #include <string.h> #include "nmconference.h" static int conf_count = 0; struct _NMConference { /* The conference identifier */ char *guid; /* The list of participants for the conference */ GSList *participants; /* Flags for the conference */ guint32 flags; /* User defined data */ gpointer data; /* Reference count for this object */ int ref_count; }; /******************************************************************************* * Conference API -- see header file for comments ******************************************************************************/ NMConference * nm_create_conference(const char *guid) { NMConference *conf = g_new0(NMConference, 1); if (guid) { conf->guid = g_strdup(guid); } else { conf->guid = g_strdup(BLANK_GUID); } conf->ref_count = 1; purple_debug(PURPLE_DEBUG_INFO, "novell", "Creating a conference %p, total=%d\n", conf, conf_count++); return conf; } void nm_release_conference(NMConference * conference) { GSList *node; g_return_if_fail(conference != NULL); purple_debug(PURPLE_DEBUG_INFO, "novell", "In release conference %p, refs=%d\n", conference, conference->ref_count); if (--conference->ref_count == 0) { purple_debug(PURPLE_DEBUG_INFO, "novell", "Releasing conference %p, total=%d\n", conference, --conf_count); if (conference->guid) g_free(conference->guid); if (conference->participants) { for (node = conference->participants; node; node = node->next) { if (node->data) { NMUserRecord *user_record = node->data; nm_release_user_record(user_record); node->data = NULL; } } g_slist_free(conference->participants); } g_free(conference); } } gboolean nm_conference_is_instantiated(NMConference * conference) { if (conference == NULL) return FALSE; return (strncmp(conference->guid, BLANK_GUID, CONF_GUID_END) != 0); } int nm_conference_get_participant_count(NMConference * conference) { if (conference == NULL) return 0; return g_slist_length(conference->participants); } NMUserRecord * nm_conference_get_participant(NMConference * conference, int index) { if (conference == NULL) return NULL; return (NMUserRecord *) g_slist_nth_data(conference->participants, index); } void nm_conference_add_participant(NMConference * conference, NMUserRecord * user_record) { if (conference == NULL || user_record == NULL) { return; } nm_user_record_add_ref(user_record); conference->participants = g_slist_append(conference->participants, user_record); } void nm_conference_remove_participant(NMConference * conference, const char *dn) { GSList *node, *element = NULL; if (conference == NULL || dn == NULL) { return; } for (node = conference->participants; node; node = node->next) { NMUserRecord *user_record = node->data; if (user_record) { if (nm_utf8_str_equal(dn, nm_user_record_get_dn(user_record))) { element = node; break; } } } if (element) { nm_release_user_record((NMUserRecord *) element->data); element->data = NULL; conference->participants = g_slist_remove_link(conference->participants, element); g_slist_free_1(element); } } void nm_conference_add_ref(NMConference * conference) { if (conference) conference->ref_count++; } void nm_conference_set_flags(NMConference * conference, guint32 flags) { if (conference) { conference->flags = flags; } } void nm_conference_set_guid(NMConference * conference, const char *guid) { if (conference) { /* Release memory for old guid */ if (conference->guid) { g_free(conference->guid); } /* Set the new guid */ if (guid) conference->guid = g_strdup(guid); else conference->guid = g_strdup(BLANK_GUID); } } void nm_conference_set_data(NMConference * conference, gpointer data) { if (conference == NULL) return; conference->data = data; } gpointer nm_conference_get_data(NMConference * conference) { if (conference == NULL) return NULL; return conference->data; } const char * nm_conference_get_guid(NMConference * conference) { if (conference == NULL) return NULL; return conference->guid; }