From 0e8b3e855dfa370fe559729224b3bff1d4cf5b87 Mon Sep 17 00:00:00 2001 From: Wilmer van der Gaast Date: Mon, 7 Jun 2010 16:21:21 +0100 Subject: Changing away_devoice will change current voice statuses in all channels. --- irc.c | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) (limited to 'irc.c') diff --git a/irc.c b/irc.c index 61060796..4d528004 100644 --- a/irc.c +++ b/irc.c @@ -99,7 +99,7 @@ irc_t *irc_new( int fd ) b->ui_data = irc; b->ui = &irc_ui_funcs; - s = set_add( &b->set, "away_devoice", "true", NULL/*set_eval_away_devoice*/, irc ); + s = set_add( &b->set, "away_devoice", "true", set_eval_away_devoice, irc ); s = set_add( &b->set, "charset", "utf-8", set_eval_charset, irc ); s = set_add( &b->set, "default_target", "root", NULL, irc ); s = set_add( &b->set, "display_namechanges", "false", set_eval_bool, irc ); @@ -818,3 +818,20 @@ static char *set_eval_charset( set_t *set, char *value ) return value; } + +char *set_eval_away_devoice( set_t *set, char *value ) +{ + irc_t *irc = set->data; + + if( !is_bool( value ) ) + return SET_INVALID; + + /* The usual problem: The setting isn't actually changed at this + point and we need it to be, so do it by hand. */ + g_free( set->value ); + set->value = g_strdup( value ); + + bee_irc_channel_update( irc, NULL, NULL ); + + return value; +} -- cgit v1.2.3