diff options
| author | Wilmer van der Gaast <wilmer@gaast.net> | 2010-07-10 00:25:07 +0100 | 
|---|---|---|
| committer | Wilmer van der Gaast <wilmer@gaast.net> | 2010-07-10 00:25:07 +0100 | 
| commit | b556e46f9bfeeb630b45a3c0f0951110ac3de0f2 (patch) | |
| tree | 503b810a5e9322b444dc7e84e4d8535dc0f4807e /irc_commands.c | |
| parent | c5bff810e6919dc3daf7f82f761197a27f04538b (diff) | |
| parent | 9a9b520df6044cfc034f9736fb97660a46e879b9 (diff) | |
Merging main ui-fix.
Diffstat (limited to 'irc_commands.c')
| -rw-r--r-- | irc_commands.c | 11 | 
1 files changed, 7 insertions, 4 deletions
| diff --git a/irc_commands.c b/irc_commands.c index 197a7e6e..0573601d 100644 --- a/irc_commands.c +++ b/irc_commands.c @@ -71,16 +71,18 @@ static void irc_cmd_user( irc_t *irc, char **cmd )  static void irc_cmd_nick( irc_t *irc, char **cmd )  { -	if( irc_user_by_name( irc, cmd[1] ) ) +	irc_user_t *iu; +	 +	if( ( iu = irc_user_by_name( irc, cmd[1] ) ) && iu != irc->user )  	{ -		irc_send_num( irc, 433, ":This nick is already in use" ); +		irc_send_num( irc, 433, "%s :This nick is already in use", cmd[1] );  	}  	else if( !nick_ok( cmd[1] ) )  	{  		/* [SH] Invalid characters. */ -		irc_send_num( irc, 432, ":This nick contains invalid characters" ); +		irc_send_num( irc, 432, "%s :This nick contains invalid characters", cmd[1] );  	} -	else if( irc->user->nick ) +	else if( irc->status & USTATUS_LOGGED_IN )  	{  		if( irc->status & USTATUS_IDENTIFIED )  		{ @@ -97,6 +99,7 @@ static void irc_cmd_nick( irc_t *irc, char **cmd )  	}  	else  	{ +		g_free( irc->user->nick );  		irc->user->nick = g_strdup( cmd[1] );  		irc_check_login( irc ); | 
