diff options
| author | Wilmer van der Gaast <wilmer@gaast.net> | 2010-03-12 19:10:16 +0000 | 
|---|---|---|
| committer | Wilmer van der Gaast <wilmer@gaast.net> | 2010-03-12 19:10:16 +0000 | 
| commit | be609ff2b0ca885612c0e6d81f82c4f26ed4f58d (patch) | |
| tree | b9f83fdc44bd00921ffb9c23035b1f39d565ba93 /irc.c | |
| parent | 08e5bb2bb2fcc7125f837be4f225d3a9ebf320ed (diff) | |
| parent | 8b6b7405d3844271f7bff56e527bfeb1a4872975 (diff) | |
Merging mainline.
Diffstat (limited to 'irc.c')
| -rw-r--r-- | irc.c | 23 | 
1 files changed, 23 insertions, 0 deletions
| @@ -77,6 +77,25 @@ static char *set_eval_charset( set_t *set, char *value )  	return value;  } +static char *set_eval_away_status( set_t *set, char *value ) +{ +	irc_t *irc = set->data; +	account_t *a; +	 +	g_free( set->value ); +	set->value = g_strdup( value ); +	 +	for( a = irc->accounts; a; a = a->next ) +	{ +		struct im_connection *ic = a->ic; +		 +		if( ic && ic->flags & OPT_LOGGED_IN ) +			imc_away_send_update( ic ); +	} +	 +	return value; +} +  irc_t *irc_new( int fd )  {  	irc_t *irc; @@ -142,6 +161,8 @@ irc_t *irc_new( int fd )  	irc_connection_list = g_slist_append( irc_connection_list, irc ); +	s = set_add( &irc->set, "away", NULL,  set_eval_away_status, irc ); +	s->flags |= SET_NULL_OK;  	s = set_add( &irc->set, "away_devoice", "true",  set_eval_away_devoice, irc );  	s = set_add( &irc->set, "auto_connect", "true", set_eval_bool, irc );  	s = set_add( &irc->set, "auto_reconnect", "false", set_eval_bool, irc ); @@ -162,6 +183,8 @@ irc_t *irc_new( int fd )  	s = set_add( &irc->set, "root_nick", irc->mynick, set_eval_root_nick, irc );  	s = set_add( &irc->set, "save_on_quit", "true", set_eval_bool, irc );  	s = set_add( &irc->set, "simulate_netsplit", "true", set_eval_bool, irc ); +	s = set_add( &irc->set, "status", NULL,  set_eval_away_status, irc ); +	s->flags |= SET_NULL_OK;  	s = set_add( &irc->set, "strip_html", "true", NULL, irc );  	s = set_add( &irc->set, "to_char", ": ", set_eval_to_char, irc );  	s = set_add( &irc->set, "typing_notice", "false", set_eval_bool, irc ); | 
