Mercurial > pidgin
view libpurple/dbus-useful.c @ 28882:36daf22b09f6
I think this is only the place this could leak...
==14064== 36 bytes in 2 blocks are definitely lost in loss record 13,092 of 20,211
==14064== at 0x4024C1C: malloc (vg_replace_malloc.c:195)
==14064== by 0x4A73B0F: __vasprintf_chk (vasprintf_chk.c:82)
==14064== by 0x485197E: g_vasprintf (in /lib/libglib-2.0.so.0.2200.3)
==14064== by 0x483D485: g_strdup_vprintf (in /lib/libglib-2.0.so.0.2200.3)
==14064== by 0x483D4A7: g_strdup_printf (in /lib/libglib-2.0.so.0.2200.3)
==14064== by 0x492FC6D: purple_mkstemp (util.c:2916)
==14064== by 0x80FEDD5: pidgin_convert_buddy_icon (gtkutils.c:2690)
author | Paul Aurich <paul@darkrain42.org> |
---|---|
date | Thu, 14 Jan 2010 18:37:32 +0000 |
parents | 32c366eeeb99 |
children | 4ca97b26a8fb f75041cb3fec |
line wrap: on
line source
#include <string.h> #include <glib.h> #include "dbus-useful.h" #include "conversation.h" #include "util.h" PurpleAccount * purple_accounts_find_ext(const char *name, const char *protocol_id, gboolean (*account_test)(const PurpleAccount *account)) { PurpleAccount *result = NULL; GList *l; char *who; if (name) who = g_strdup(purple_normalize(NULL, name)); else who = NULL; for (l = purple_accounts_get_all(); l != NULL; l = l->next) { PurpleAccount *account = (PurpleAccount *)l->data; if (who && strcmp(purple_normalize(NULL, purple_account_get_username(account)), who)) continue; if (protocol_id && strcmp(account->protocol_id, protocol_id)) continue; if (account_test && !account_test(account)) continue; result = account; break; } g_free(who); return result; } PurpleAccount *purple_accounts_find_any(const char *name, const char *protocol) { return purple_accounts_find_ext(name, protocol, NULL); } PurpleAccount *purple_accounts_find_connected(const char *name, const char *protocol) { return purple_accounts_find_ext(name, protocol, purple_account_is_connected); }