Mercurial > pidgin
view libgaim/buddyicon.h @ 14357:4e14503b9bac
[gaim-migrate @ 17063]
Fix an assertion that fails for me about half the time
when I try to sign onto MSN.
Here's a backtrace, in case someone wants to look at this
more in depth:
#4 0x00002aaab203d857 in msn_object_new_from_string (str=0x2aaaac4f0860 "0")
at object.c:79
obj = (MsnObject *) 0x7fff2bc6efe0
tag = 0x2aaaac4f0861 ""
c = 0x100000001 <Address 0x100000001 out of bounds>
__PRETTY_FUNCTION__ = "msn_object_new_from_string"
#5 0x00002aaab203bf37 in nln_cmd (cmdproc=0xd84f30, cmd=0xcb1e10)
at notification.c:687
session = (MsnSession *) 0xd72e70
account = (GaimAccount *) 0x63c020
gc = (GaimConnection *) 0xd5d9b0
user = (MsnUser *) 0xcb1d90
msnobj = (MsnObject *) 0x2aaaacc127d9
clientid = 32767
state = 0xc97820 "NLN"
passport = 0xd65310 "lbdash@yahoo.com"
friendly = 0x2aaaac4f0860 "0"
#6 0x00002aaab202ff18 in msn_cmdproc_process_cmd (cmdproc=0xd84f30,
cmd=0xcb1e10) at cmdproc.c:313
cb = 0x2aaab203be63 <nln_cmd>
trans = (MsnTransaction *) 0x0
#7 0x00002aaab202ffbe in msn_cmdproc_process_cmd_text (cmdproc=0xd84f30,
command=0xe082b0 "NLN NLN lbdash@yahoo.com lbdash@yahoo.com 1073741856 0")
at cmdproc.c:335
No locals.
#8 0x00002aaab2032c06 in read_cb (data=0xd4e600, source=7,
cond=GAIM_INPUT_READ) at httpconn.c:380
httpconn = (MsnHttpConn *) 0xd4e600
servconn = (MsnServConn *) 0xd65360
session = (MsnSession *) 0xd72e70
buf = "HTTP/1.1 200 OK\r\nDate: Sun, 27 Aug 2006 21:29:58 GMT\r\nServer:
Microsoft-IIS/6.0\r\nX-Powered-By: ASP.N ET\r\nX-MSN-Messenger:
SessionID=26246177.8760; GW-IP=207.46.7.4\r\nContent-Length: 56\r\nContent-type:
ap"...
cur = 0xe082b0 "NLN NLN lbdash@yahoo.com lbdash@yahoo.com 1073741856 0"
end = 0xe082e8 ""
old_rx_buf = 0xe082b0 "NLN NLN lbdash@yahoo.com lbdash@yahoo.com
1073741856 0"
len = 285
cur_len = 56
result_msg = 0xe082b0 "NLN NLN lbdash@yahoo.com lbdash@yahoo.com
1073741856 0"
result_len = 56
error = 0
committer: Tailor Script <tailor@pidgin.im>
author | Mark Doliner <mark@kingant.net> |
---|---|
date | Sun, 27 Aug 2006 21:36:52 +0000 |
parents | 60b1bc8dbf37 |
children | 97ae8709d6dc |
line wrap: on
line source
/** * @file buddyicon.h Buddy Icon API * @ingroup core * * gaim * * Gaim 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, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef _GAIM_BUDDYICON_H_ #define _GAIM_BUDDYICON_H_ typedef struct _GaimBuddyIcon GaimBuddyIcon; #include "account.h" #include "blist.h" #include "prpl.h" struct _GaimBuddyIcon { GaimAccount *account; /**< The account the user is on. */ char *username; /**< The username the icon belongs to. */ void *data; /**< The buddy icon data. */ size_t len; /**< The length of the buddy icon data. */ int ref_count; /**< The buddy icon reference count. */ }; #ifdef __cplusplus extern "C" { #endif /**************************************************************************/ /** @name Buddy Icon API */ /**************************************************************************/ /*@{*/ /** * Creates a new buddy icon structure. * * @param account The account the user is on. * @param username The username the icon belongs to. * @param icon_data The buddy icon data. * @param icon_len The buddy icon length. * * @return The buddy icon structure. */ GaimBuddyIcon *gaim_buddy_icon_new(GaimAccount *account, const char *username, void *icon_data, size_t icon_len); /** * Destroys a buddy icon structure. * * If the buddy icon's reference count is greater than 1, this will * just decrease the reference count and return. * * @param icon The buddy icon structure to destroy. */ void gaim_buddy_icon_destroy(GaimBuddyIcon *icon); /** * Increments the reference count on a buddy icon. * * @param icon The buddy icon. * * @return @a icon. */ GaimBuddyIcon *gaim_buddy_icon_ref(GaimBuddyIcon *icon); /** * Decrements the reference count on a buddy icon. * * If the reference count reaches 0, the icon will be destroyed. * * @param icon The buddy icon. * * @return @a icon, or @c NULL if the reference count reached 0. */ GaimBuddyIcon *gaim_buddy_icon_unref(GaimBuddyIcon *icon); /** * Updates every instance of this icon. * * @param icon The buddy icon. */ void gaim_buddy_icon_update(GaimBuddyIcon *icon); /** * Caches a buddy icon associated with a specific buddy to disk. * * @param icon The buddy icon. * @param buddy The buddy that this icon belongs to. */ void gaim_buddy_icon_cache(GaimBuddyIcon *icon, GaimBuddy *buddy); /** * Removes cached buddy icon for a specific buddy. * * @param buddy The buddy for which to remove the cached icon. */ void gaim_buddy_icon_uncache(GaimBuddy *buddy); /** * Sets the buddy icon's account. * * @param icon The buddy icon. * @param account The account. */ void gaim_buddy_icon_set_account(GaimBuddyIcon *icon, GaimAccount *account); /** * Sets the buddy icon's username. * * @param icon The buddy icon. * @param username The username. */ void gaim_buddy_icon_set_username(GaimBuddyIcon *icon, const char *username); /** * Sets the buddy icon's icon data. * * @param icon The buddy icon. * @param data The buddy icon data. * @param len The length of the icon data. */ void gaim_buddy_icon_set_data(GaimBuddyIcon *icon, void *data, size_t len); /** * Returns the buddy icon's account. * * @param icon The buddy icon. * * @return The account. */ GaimAccount *gaim_buddy_icon_get_account(const GaimBuddyIcon *icon); /** * Returns the buddy icon's username. * * @param icon The buddy icon. * * @return The username. */ const char *gaim_buddy_icon_get_username(const GaimBuddyIcon *icon); /** * Returns the buddy icon's data. * * @param icon The buddy icon. * @param len The returned icon length. * * @return The icon data. */ const guchar *gaim_buddy_icon_get_data(const GaimBuddyIcon *icon, size_t *len); /** * Returns an extension corresponding to the buddy icon's file type. * * @param icon The buddy icon. * * @return The icon's extension. */ const char *gaim_buddy_icon_get_type(const GaimBuddyIcon *icon); /*@}*/ /**************************************************************************/ /** @name Buddy Icon Subsystem API */ /**************************************************************************/ /*@{*/ /** * Sets a buddy icon for a user. * * @param account The account the user is on. * @param username The username of the user. * @param icon_data The icon data. * @param icon_len The length of the icon data. */ void gaim_buddy_icons_set_for_user(GaimAccount *account, const char *username, void *icon_data, size_t icon_len); /** * Returns the buddy icon information for a user. * * @param account The account the user is on. * @param username The username of the user. * * @return The icon data if found, or @c NULL if not found. */ GaimBuddyIcon *gaim_buddy_icons_find(GaimAccount *account, const char *username); /** * Sets whether or not buddy icon caching is enabled. * * @param caching TRUE of buddy icon caching should be enabled, or * FALSE otherwise. */ void gaim_buddy_icons_set_caching(gboolean caching); /** * Returns whether or not buddy icon caching should be enabled. * * The default is TRUE, unless otherwise specified by * gaim_buddy_icons_set_caching(). * * @return TRUE if buddy icon caching is enabled, or FALSE otherwise. */ gboolean gaim_buddy_icons_is_caching(void); /** * Sets the directory used to store buddy icon cache files. * * @param cache_dir The directory to store buddy icon cache files to. */ void gaim_buddy_icons_set_cache_dir(const char *cache_dir); /** * Returns the directory used to store buddy icon cache files. * * The default directory is GAIMDIR/icons, unless otherwise specified * by gaim_buddy_icons_set_cache_dir(). * * @return The directory to store buddy icon cache files to. */ const char *gaim_buddy_icons_get_cache_dir(void); /** * Takes a buddy icon and returns a full path. * * If @a icon is a full path to an existing file, a copy of * @a icon is returned. Otherwise, a newly allocated string * consiting of gaim_buddy_icons_get_cache_dir() + @a icon is * returned. * * @return The full path for an icon. */ char *gaim_buddy_icons_get_full_path(const char *icon); /** * Returns the buddy icon subsystem handle. * * @return The subsystem handle. */ void *gaim_buddy_icons_get_handle(void); /** * Initializes the buddy icon subsystem. */ void gaim_buddy_icons_init(void); /** * Uninitializes the buddy icon subsystem. */ void gaim_buddy_icons_uninit(void); /*@}*/ /**************************************************************************/ /** @name Buddy Icon Helper API */ /**************************************************************************/ /*@{*/ /** * Gets display size for a buddy icon */ void gaim_buddy_icon_get_scale_size(GaimBuddyIconSpec *spec, int *width, int *height); /*@}*/ #ifdef __cplusplus } #endif #endif /* _GAIM_BUDDYICON_H_ */