diff options
| author | Wilmer van der Gaast <wilmer@gaast.net> | 2010-03-07 18:41:45 +0000 | 
|---|---|---|
| committer | Wilmer van der Gaast <wilmer@gaast.net> | 2010-03-07 18:41:45 +0000 | 
| commit | c32f492758759c04d8b6239a7862648c9d32c4d8 (patch) | |
| tree | 628612ec0d2c431519a0a3741df7e4c6609db7f1 /irc.c | |
| parent | 1c2eaa3c99a2e7fbe264b06e559f3d709b9a080d (diff) | |
| parent | 0e99548ba9c6ec9c78367e05b676dab90b5261a4 (diff) | |
Merging in improved away/status message code.
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 ); | 
