Mon, 28 Feb 2011 07:12:27 +0000
Fix a memleak in the MSN prpl when removing a buddy from your buddy list.
We needed to call msn_user_unref() after calling msn_userlist_remove_user()
I chose to fix this by changing msn_userlist_add_user() and
msn_userlist_remove_user() to incremend and decrement the reference counter
themselves--after all, they ARE the ones who add/remove a reference to
the MsnUser struct. Conceptually I thought this made the most sense.
/* * Header file for common error description library. * * Copyright 1988, Student Information Processing Board of the * Massachusetts Institute of Technology. * * For copyright and distribution info, see the documentation supplied * with this package. */ #ifndef __COM_ERR_H #define __COM_ERR_H #define COM_ERR_BUF_LEN 25 /* Use __STDC__ to guess whether we can use stdarg, prototypes, and const. * This is a public header file, so autoconf can't help us here. */ #ifdef __STDC__ # include <stdarg.h> # define ETP(x) x # define ETCONST const #else # define ETP(x) () # define ETCONST #endif typedef void (*error_handler_t) ETP((ETCONST char *, long, ETCONST char *, va_list)); extern error_handler_t com_err_hook; void com_err ETP((ETCONST char *, long, ETCONST char *, ...)); ETCONST char *error_message ETP((long)); ETCONST char *error_message_r ETP((long, char *)); error_handler_t set_com_err_hook ETP((error_handler_t)); error_handler_t reset_com_err_hook ETP((void)); #undef ETP #endif /* ! defined(__COM_ERR_H) */