From 523a6fad097cedd31a6931a29d91bab0d391df63 Mon Sep 17 00:00:00 2001 From: Alexander Barton Date: Thu, 24 Apr 2008 23:52:54 +0200 Subject: [PATCH] Report ERR_NOTONCHANNEL when trying to part a channel one is not member of. When trying to part a channel ("PART #channel") the client is not member of the daemon now correctly reports the numeric ERR_NOTONCHANNEL (442) insted of ERR_NOSUCHCHANNEL (403). --- src/ngircd/channel.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/ngircd/channel.c b/src/ngircd/channel.c index a4eca1f1..32f911a2 100644 --- a/src/ngircd/channel.c +++ b/src/ngircd/channel.c @@ -218,11 +218,16 @@ Channel_Part(CLIENT * Client, CLIENT * Origin, const char *Name, const char *Rea assert(Reason != NULL); chan = Channel_Search(Name); - if ((!chan) || (!Get_Cl2Chan(chan, Client))) { + if (!chan) { IRC_WriteStrClient(Client, ERR_NOSUCHCHANNEL_MSG, Client_ID(Client), Name); return false; } + if (!Get_Cl2Chan(chan, Client)) { + IRC_WriteStrClient(Client, ERR_NOTONCHANNEL_MSG, + Client_ID(Client), Name); + return false; + } if (!Remove_Client(REMOVE_PART, chan, Client, Origin, Reason, true)) return false; -- 2.39.2