Mercurial > pidgin
diff plugins/autorecon.c @ 1378:aedeb1218a0a
[gaim-migrate @ 1388]
libfaim has a bad cap for Games, update the TODO for Jabber stuff, and make autorecon.c work better, I hope
committer: Tailor Script <tailor@pidgin.im>
author | Eric Warmenhoven <eric@warmenhoven.org> |
---|---|
date | Fri, 05 Jan 2001 00:17:43 +0000 |
parents | 3daec853f3c6 |
children | 96e93119268d |
line wrap: on
line diff
--- a/plugins/autorecon.c Thu Jan 04 23:29:52 2001 +0000 +++ b/plugins/autorecon.c Fri Jan 05 00:17:43 2001 +0000 @@ -4,10 +4,11 @@ extern GtkWidget *imaway; -static int recon; static int away_state; static int forced_off = 0; -static struct away_message *last_away; +static struct away_message *last_away = NULL; +GSList *reconnects = NULL; +GSList *recontim = NULL; char *name() { return "Auto Reconnect"; @@ -17,23 +18,39 @@ return "When AOL kicks you off, this auto-reconnects you."; } -void do_signon(char *name) { - struct aim_user *u = find_user(name, -1); - g_free(name); - gtk_timeout_remove(recon); - if (!u) return; - serv_login(u); - forced_off = 0; +static void now_online(struct gaim_connection *gc, void *m) { + gint place; + guint recon; + if (!g_slist_find(reconnects, gc->user)) + return; + place = g_slist_index(reconnects, gc->user); + recon = (guint)g_slist_nth(recontim, place); + reconnects = g_slist_remove(reconnects, gc->user); + recontim = g_slist_remove(recontim, (void *)recon); if (away_state) do_away_message(NULL, last_away); } -void reconnect(struct gaim_connection *gc, void *m) { - char *name = g_strdup(gc->username); - recon = gtk_timeout_add(8000, (GtkFunction)do_signon, name); +static void do_signon(struct aim_user *u) { + gint place; + guint recon; + place = g_slist_index(reconnects, u); + recon = (guint)g_slist_nth(recontim, place); + gtk_timeout_remove(recon); + forced_off = 0; + serv_login(u); +} + +static void reconnect(struct gaim_connection *gc, void *m) { + guint recon; + if (g_slist_find(reconnects, gc->user)) + return; + recon = gtk_timeout_add(8000, (GtkFunction)do_signon, gc->user); + reconnects = g_slist_append(reconnects, gc->user); + recontim = g_slist_append(recontim, (void *)recon); forced_off = 1; } -void away_toggle(void *m) { +static void away_toggle(void *m) { if ((int)m == 1) { last_away = awaymessage; away_state = 1; @@ -51,6 +68,7 @@ gaim_signal_connect(handle, event_away, away_toggle, (void *)1); gaim_signal_connect(handle, event_back, away_toggle, (void *)0); gaim_signal_connect(handle, event_signoff, reconnect, NULL); + gaim_signal_connect(handle, event_signon, now_online, NULL); return NULL; }