aboutsummaryrefslogtreecommitdiffstats
path: root/irc.c
diff options
context:
space:
mode:
authorWilmer van der Gaast <wilmer@gaast.net>2010-06-07 01:58:07 +0100
committerWilmer van der Gaast <wilmer@gaast.net>2010-06-07 01:58:07 +0100
commit0d9d53ed0b3eb068cf57355a4d1465beaf191f8a (patch)
treee081c819ca7af92548b833f6b79dafe64694dade /irc.c
parent36562b0f1a82bd2a5e9a24a7091845847e4242b4 (diff)
Fixed "set password" and "set auto_reconnect_delay".
Diffstat (limited to 'irc.c')
-rw-r--r--irc.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/irc.c b/irc.c
index 49395ee4..6862b6fb 100644
--- a/irc.c
+++ b/irc.c
@@ -30,6 +30,7 @@ GSList *irc_connection_list;
static gboolean irc_userping( gpointer _irc, gint fd, b_input_condition cond );
static char *set_eval_charset( set_t *set, char *value );
+static char *set_eval_password( set_t *set, char *value );
irc_t *irc_new( int fd )
{
@@ -109,6 +110,8 @@ irc_t *irc_new( int fd )
s->old_key = g_strdup( "buddy_sendbuffer" );
s = set_add( &b->set, "paste_buffer_delay", "200", set_eval_int, irc );
s->old_key = g_strdup( "buddy_sendbuffer_delay" );
+ s = set_add( &b->set, "password", NULL, set_eval_password, irc );
+ s->flags |= SET_NULL_OK;
s = set_add( &b->set, "private", "true", set_eval_bool, irc );
s = set_add( &b->set, "query_order", "lifo", NULL, irc );
s = set_add( &b->set, "root_nick", ROOT_NICK, NULL/*set_eval_root_nick*/, irc );
@@ -274,6 +277,21 @@ void irc_setpass (irc_t *irc, const char *pass)
}
}
+static char *set_eval_password( set_t *set, char *value )
+{
+ irc_t *irc = set->data;
+
+ if( irc->status & USTATUS_IDENTIFIED && value )
+ {
+ irc_setpass( irc, value );
+ return NULL;
+ }
+ else
+ {
+ return SET_INVALID;
+ }
+}
+
static char **irc_splitlines( char *buffer );
void irc_process( irc_t *irc )