Mercurial > pidgin
view libpurple/protocols/bonjour/buddy.h @ 24389:2b62300d2c19
Use libtool to build static archives when --with-static-prpls is passed
to configure. Does anyone know why we weren't using libtool before? We
were building old-fashioned .a files. But libtool archives (.la) can
contain either static or shared libraries.
I found it a lot easier to get static prpl compilation working after
making this change (that is to say, it worked). Without this I got this
error, which is probably fixable, but consistently using libtool seems
like it makes things easier:
*** Warning: Linking the shared library libpurple.la against the
*** static library ../libpurple/protocols/msn/libmsn.a is not portable!
/usr/bin/ld: ../libpurple/protocols/msn/libmsn.a(libmsn_a-msn.o): relocation R_X86_64_32 against `a local symbol' can not be used when making a shared object; recompile with -fPIC
../libpurple/protocols/msn/libmsn.a: could not read symbols: Bad value
collect2: ld returned 1 exit status
author | Mark Doliner <mark@kingant.net> |
---|---|
date | Wed, 12 Nov 2008 11:30:51 +0000 |
parents | d50194ab3016 |
children |
line wrap: on
line source
/* * 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 Library 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. */ #ifndef _BONJOUR_BUDDY #define _BONJOUR_BUDDY #include <glib.h> #include "account.h" #include "jabber.h" typedef struct _BonjourBuddy { PurpleAccount *account; gchar *name; GSList *ips; gint port_p2pj; gchar *first; gchar *phsh; gchar *status; gchar *email; gchar *last; gchar *jid; gchar *AIM; gchar *vc; gchar *msg; gchar *ext; gchar *nick; gchar *node; gchar *ver; BonjourJabberConversation *conversation; gpointer mdns_impl_data; } BonjourBuddy; static const char *const buddy_TXT_records[] = { "1st", "email", "ext", "jid", "last", "msg", "nick", "node", "phsh", /* "port.p2pj", Deprecated - MUST ignore */ "status", /* "txtvers", Deprecated - hardcoded to 1 */ "vc", "ver", "AIM", /* non standard */ NULL }; /** * Creates a new buddy. */ BonjourBuddy *bonjour_buddy_new(const gchar *name, PurpleAccount *account); /** * Clear any existing values from the buddy. * This is called before updating so that we can notice removals */ void clear_bonjour_buddy_values(BonjourBuddy *buddy); /** * Sets a value in the BonjourBuddy struct, destroying the old value */ void set_bonjour_buddy_value(BonjourBuddy *buddy, const char *record_key, const char *value, guint32 len); /** * Check if all the compulsory buddy data is present. */ gboolean bonjour_buddy_check(BonjourBuddy *buddy); /** * If the buddy doesn't previously exists, it is created. Else, its data is changed (???) * purple_buddy is optional; it saves an additional lookup if we already have it */ void bonjour_buddy_add_to_purple(BonjourBuddy *bonjour_buddy, PurpleBuddy *purple_buddy); /** * The buddy has signed off Bonjour. * If the buddy is being saved, mark as offline, otherwise delete */ void bonjour_buddy_signed_off(PurpleBuddy *purple_buddy); /** * We got the buddy icon data; deal with it */ void bonjour_buddy_got_buddy_icon(BonjourBuddy *buddy, gconstpointer data, gsize len); /** * Deletes a buddy from memory. */ void bonjour_buddy_delete(BonjourBuddy *buddy); #endif