Mercurial > pidgin.yaz
view libgaim/imgstore.c @ 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 | 2a4a8b24de92 |
line wrap: on
line source
/** * @file imgstore.h IM Image Store 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 * */ #include <glib.h> #include <debug.h> #include <imgstore.h> static GSList *imgstore = NULL; static int nextid = 0; /** * Stored image * * Represents a single IM image awaiting display and/or transmission. * Now that this type is basicly private too, these two structs could * probably be combined. */ struct _GaimStoredImage { char *data; /**< The image data. */ size_t size; /**< The image data's size. */ char *filename; /**< The filename (for the UI) */ }; typedef struct { int id; int refcount; GaimStoredImage *img; } GaimStoredImagePriv; /* private functions */ static GaimStoredImagePriv *gaim_imgstore_get_priv(int id) { GSList *tmp = imgstore; GaimStoredImagePriv *priv = NULL; g_return_val_if_fail(id > 0, NULL); while (tmp && !priv) { GaimStoredImagePriv *tmp_priv = tmp->data; if (tmp_priv->id == id) priv = tmp_priv; tmp = tmp->next; } if (!priv) gaim_debug(GAIM_DEBUG_ERROR, "imgstore", "failed to find image id %d\n", id); return priv; } static void gaim_imgstore_free_priv(GaimStoredImagePriv *priv) { GaimStoredImage *img = NULL; g_return_if_fail(priv != NULL); img = priv->img; if (img) { g_free(img->data); g_free(img->filename); g_free(img); } gaim_debug(GAIM_DEBUG_INFO, "imgstore", "freed image id %d\n", priv->id); g_free(priv); imgstore = g_slist_remove(imgstore, priv); } /* public functions */ int gaim_imgstore_add(const void *data, size_t size, const char *filename) { GaimStoredImagePriv *priv; GaimStoredImage *img; g_return_val_if_fail(data != NULL, 0); g_return_val_if_fail(size > 0, 0); img = g_new0(GaimStoredImage, 1); img->data = g_memdup(data, size); img->size = size; img->filename = g_strdup(filename); priv = g_new0(GaimStoredImagePriv, 1); priv->id = ++nextid; priv->refcount = 1; priv->img = img; imgstore = g_slist_append(imgstore, priv); gaim_debug(GAIM_DEBUG_INFO, "imgstore", "added image id %d\n", priv->id); return priv->id; } GaimStoredImage *gaim_imgstore_get(int id) { GaimStoredImagePriv *priv = gaim_imgstore_get_priv(id); g_return_val_if_fail(priv != NULL, NULL); gaim_debug(GAIM_DEBUG_INFO, "imgstore", "retrieved image id %d\n", priv->id); return priv->img; } gpointer gaim_imgstore_get_data(GaimStoredImage *i) { return i->data; } size_t gaim_imgstore_get_size(GaimStoredImage *i) { return i->size; } const char *gaim_imgstore_get_filename(GaimStoredImage *i) { return i->filename; } void gaim_imgstore_ref(int id) { GaimStoredImagePriv *priv = gaim_imgstore_get_priv(id); g_return_if_fail(priv != NULL); (priv->refcount)++; gaim_debug(GAIM_DEBUG_INFO, "imgstore", "referenced image id %d (count now %d)\n", priv->id, priv->refcount); } void gaim_imgstore_unref(int id) { GaimStoredImagePriv *priv = gaim_imgstore_get_priv(id); g_return_if_fail(priv != NULL); g_return_if_fail(priv->refcount > 0); (priv->refcount)--; gaim_debug(GAIM_DEBUG_INFO, "imgstore", "unreferenced image id %d (count now %d)\n", priv->id, priv->refcount); if (priv->refcount == 0) gaim_imgstore_free_priv(priv); }