qulogic/pidgin

31e8c7c92e2f
Make sure all of the license headers for IRCv3 are GPLv2

Testing Done:
Ran `licensecheck` from debian in the following way.

```
$ licensecheck *.[ch] | cut -d: -f 2 | sort | uniq -c
27 GNU General Public License v2.0 or later
```

Reviewed at https://reviews.imfreedom.org/r/2913/
/*
* Purple - Internet Messaging Library
* Copyright (C) Pidgin Developers <devel@pidgin.im>
*
* Purple is the legal property of its developers, whose names are too numerous
* to list here. Please refer to the COPYRIGHT file distributed with this
* source distribution.
*
* 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, see <https://www.gnu.org/licenses/>.
*/
#include "purpleprotocolcontacts.h"
/******************************************************************************
* GInterface Implementation
*****************************************************************************/
G_DEFINE_INTERFACE(PurpleProtocolContacts, purple_protocol_contacts,
PURPLE_TYPE_PROTOCOL)
static void
purple_protocol_contacts_default_init(G_GNUC_UNUSED PurpleProtocolContactsInterface *iface)
{
}
/******************************************************************************
* Public API
*****************************************************************************/
void
purple_protocol_contacts_search_async(PurpleProtocolContacts *protocol_contacts,
PurpleAccount *account,
const char *text,
GCancellable *cancellable,
GAsyncReadyCallback callback,
gpointer data)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts));
g_return_if_fail(PURPLE_IS_ACCOUNT(account));
g_return_if_fail(!purple_strempty(text));
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->search_async != NULL) {
iface->search_async(protocol_contacts, account, text, cancellable,
callback, data);
} else {
g_warning("%s does not implement search_async",
G_OBJECT_TYPE_NAME(protocol_contacts));
}
}
GListModel *
purple_protocol_contacts_search_finish(PurpleProtocolContacts *protocol_contacts,
GAsyncResult *result,
GError **error)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_val_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts), NULL);
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->search_finish != NULL) {
GListModel *ret = NULL;
ret = iface->search_finish(protocol_contacts, result, error);
if(G_IS_LIST_MODEL(ret)) {
GType type = G_TYPE_INVALID;
type = g_list_model_get_item_type(G_LIST_MODEL(ret));
if(g_type_is_a(type, PURPLE_TYPE_CONTACT_INFO)) {
return ret;
}
/* The GListModel we got back doesn't have an item type that is
* PurpleContactInfo or a subclass of it.
*/
g_clear_object(&ret);
g_set_error(error, PURPLE_PROTOCOL_CONTACTS_DOMAIN, 0,
"%s returned a list of type %s which is not "
"PurpleContactInfo or a subclass of",
G_OBJECT_TYPE_NAME(protocol_contacts),
g_type_name(type));
}
} else {
g_warning("%s does not implement search_finish",
G_OBJECT_TYPE_NAME(protocol_contacts));
}
return NULL;
}
void
purple_protocol_contacts_get_profile_async(PurpleProtocolContacts *protocol_contacts,
PurpleContactInfo *info,
GCancellable *cancellable,
GAsyncReadyCallback callback,
gpointer data)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts));
g_return_if_fail(PURPLE_IS_CONTACT_INFO(info));
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->get_profile_async != NULL) {
iface->get_profile_async(protocol_contacts, info, cancellable,
callback, data);
} else {
g_warning("%s does not implement get_profile_async",
G_OBJECT_TYPE_NAME(protocol_contacts));
}
}
char *
purple_protocol_contacts_get_profile_finish(PurpleProtocolContacts *protocol_contacts,
GAsyncResult *result,
GError **error)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_val_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts), NULL);
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->get_profile_finish != NULL) {
return iface->get_profile_finish(protocol_contacts, result, error);
} else {
g_warning("%s does not implement get_profile_finish",
G_OBJECT_TYPE_NAME(protocol_contacts));
}
return NULL;
}
GActionGroup *
purple_protocol_contacts_get_actions(PurpleProtocolContacts *protocol_contacts,
PurpleContactInfo *info)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_val_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts), NULL);
g_return_val_if_fail(PURPLE_IS_CONTACT_INFO(info), NULL);
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->get_actions != NULL) {
return iface->get_actions(protocol_contacts, info);
}
return NULL;
}
GMenuModel *
purple_protocol_contacts_get_menu(PurpleProtocolContacts *protocol_contacts,
PurpleContactInfo *info)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_val_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts), NULL);
g_return_val_if_fail(PURPLE_IS_CONTACT_INFO(info), NULL);
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->get_menu != NULL) {
return iface->get_menu(protocol_contacts, info);
}
return NULL;
}