# HG changeset patch # User Mark Doliner # Date 1058128613 0 # Node ID 30d4c432101c16c12658b4232bc234b633f6c3bf # Parent a22c151463e1c053e1ef68d24f71fb4e663c94ad [gaim-migrate @ 6575] Fix a memleak in the status code (a temporary g_hash_table was not getting freed) Make the auto-reconnect plugin fully multi-protocol aware. Previously, if it was waiting to sign on more than one account, and you unload the plugin, it would continue to attempt to sign on all but one of the accounts. Set wants_to_die to TRUE if Buddies->Signoff was chosen. Get rid of some unneeded oscar debugging lines for faceprint :-) Make oscar not attempt to signon again if you were disconnected because you signed on from another location. committer: Tailor Script diff -r a22c151463e1 -r 30d4c432101c plugins/autorecon.c --- a/plugins/autorecon.c Sun Jul 13 19:25:44 2003 +0000 +++ b/plugins/autorecon.c Sun Jul 13 20:36:53 2003 +0000 @@ -9,42 +9,70 @@ #define INITIAL 8000 #define MAXTIME 2048000 -static GHashTable *hash = NULL; +typedef struct { + int delay; + guint timeout; +} GaimAutoRecon; -static guint tim = 0; +static GHashTable *hash = NULL; static gboolean do_signon(gpointer data) { GaimAccount *account = data; + GaimAutoRecon *info; + gaim_debug(GAIM_DEBUG_INFO, "autorecon", "do_signon called\n"); + g_return_val_if_fail(account != NULL, FALSE); + info = g_hash_table_lookup(hash, account); if (g_list_index(gaim_accounts_get_all(), account) < 0) return FALSE; + gaim_debug(GAIM_DEBUG_INFO, "autorecon", "calling gaim_account_connect\n"); gaim_account_connect(account); gaim_debug(GAIM_DEBUG_INFO, "autorecon", "done calling gaim_account_connect\n"); - tim = 0; + + info->timeout = 0; + return FALSE; } static void reconnect(GaimConnection *gc, void *m) { + GaimAccount *account; + GaimAutoRecon *info; + + g_return_if_fail(gc != NULL); + account = gaim_connection_get_account(gc); + info = g_hash_table_lookup(hash, account); + if (!gc->wants_to_die) { - int del; - del = (int)g_hash_table_lookup(hash, gc->account); - if (!del) - del = INITIAL; - else - del = MIN(2 * del, MAXTIME); - tim = g_timeout_add(del, do_signon, gc->account); - g_hash_table_insert(hash, gc->account, (gpointer)del); - } else { - g_hash_table_remove(hash, gc->account); + if (info == NULL) { + info = g_new0(GaimAutoRecon, 1); + g_hash_table_insert(hash, account, info); + info->delay = INITIAL; + } else + info->delay = MIN(2 * info->delay, MAXTIME); + info->timeout = g_timeout_add(info->delay, do_signon, account); + } else if (info != NULL) { + g_hash_table_remove(hash, account); + g_free(info); } } +static void +free_auto_recon(gpointer data) +{ + GaimAutoRecon *info = data; + + if (info->timeout != 0) + g_source_remove(info->timeout); + + g_free(info); +} + static gboolean plugin_load(GaimPlugin *plugin) { - hash = g_hash_table_new(g_int_hash, g_int_equal); + hash = g_hash_table_new_full(g_int_hash, g_int_equal, NULL, free_auto_recon); gaim_signal_connect(plugin, event_signoff, reconnect, NULL); @@ -54,15 +82,10 @@ static gboolean plugin_unload(GaimPlugin *plugin) { - if (tim) - g_source_remove(tim); - gaim_signal_disconnect(plugin, event_signoff, reconnect); g_hash_table_destroy(hash); - hash = NULL; - tim = 0; return TRUE; } diff -r a22c151463e1 -r 30d4c432101c src/connection.c --- a/src/connection.c Sun Jul 13 19:25:44 2003 +0000 +++ b/src/connection.c Sun Jul 13 20:36:53 2003 +0000 @@ -407,9 +407,13 @@ gaim_connections_disconnect_all(void) { GList *l; + GaimConnection *gc; - while ((l = gaim_connections_get_all()) != NULL) - gaim_connection_destroy(l->data); + while ((l = gaim_connections_get_all()) != NULL) { + gc = l->data; + gc->wants_to_die = TRUE; + gaim_connection_destroy(gc); + } } GList * diff -r a22c151463e1 -r 30d4c432101c src/protocols/oscar/info.c --- a/src/protocols/oscar/info.c Sun Jul 13 19:25:44 2003 +0000 +++ b/src/protocols/oscar/info.c Sun Jul 13 20:36:53 2003 +0000 @@ -643,7 +643,10 @@ outinfo->present |= AIM_USERINFO_PRESENT_SESSIONLEN; } else if (type == 0x0019) { - faimdprintf(sess, 0, "userinfo: **warning: unexpected TLV type 0x0019: from %s\n", outinfo->sn); +/* faimdprintf(sess, 0, "userinfo: **warning: unexpected TLV type 0x0019: from %s\n", outinfo->sn); */ + + } else if (type == 0x001b) { +/* faimdprintf(sess, 0, "userinfo: **warning: unexpected TLV type 0x001b: from %s\n", outinfo->sn); */ } else if (type == 0x001d) { /* diff -r a22c151463e1 -r 30d4c432101c src/protocols/oscar/oscar.c --- a/src/protocols/oscar/oscar.c Sun Jul 13 19:25:44 2003 +0000 +++ b/src/protocols/oscar/oscar.c Sun Jul 13 20:36:53 2003 +0000 @@ -3699,6 +3699,7 @@ "Disconnected. Code is 0x%04x and msg is %s\n", code, msg); if ((fr) && (fr->conn) && (fr->conn->type == AIM_CONN_TYPE_BOS)) { if (code == 0x0001) { + gc->wants_to_die = TRUE; gaim_connection_error(gc, _("You have been disconnected because you have signed on with this screen name at another location.")); } else { gaim_connection_error(gc, _("You have been signed off for an unknown reason.")); diff -r a22c151463e1 -r 30d4c432101c src/status.c --- a/src/status.c Sun Jul 13 19:25:44 2003 +0000 +++ b/src/status.c Sun Jul 13 20:36:53 2003 +0000 @@ -136,6 +136,8 @@ data->tag = TAG_MESSAGE; } + + g_hash_table_destroy(atts); } static void