diff options
author | Wilmer van der Gaast <wilmer@gaast.net> | 2010-06-07 01:58:07 +0100 |
---|---|---|
committer | Wilmer van der Gaast <wilmer@gaast.net> | 2010-06-07 01:58:07 +0100 |
commit | 0d9d53ed0b3eb068cf57355a4d1465beaf191f8a (patch) | |
tree | e081c819ca7af92548b833f6b79dafe64694dade /irc.c | |
parent | 36562b0f1a82bd2a5e9a24a7091845847e4242b4 (diff) |
Fixed "set password" and "set auto_reconnect_delay".
Diffstat (limited to 'irc.c')
-rw-r--r-- | irc.c | 18 |
1 files changed, 18 insertions, 0 deletions
@@ -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 ) |