Browse Source

nickname conflicts are now handled slightly better

release/0.19 v0.18
Jessica James 9 years ago
parent
commit
c378c17880
  1. 37
      Jupiter/IRC_Client.cpp
  2. BIN
      Release/Jupiter.lib

37
Jupiter/IRC_Client.cpp

@ -776,7 +776,7 @@ int Jupiter::IRC::Client::process_line(const Jupiter::ReadableString &line)
case 3: // Registration sent, but not verified. case 3: // Registration sent, but not verified.
{ {
bool completelyBadNick = false; bool erroneous_nickname = false;
switch (numeric) switch (numeric)
{ {
// We'll take any of these 4, just in-case any of them are missing. In general, this will trigger on 001. // We'll take any of these 4, just in-case any of them are missing. In general, this will trigger on 001.
@ -791,37 +791,45 @@ int Jupiter::IRC::Client::process_line(const Jupiter::ReadableString &line)
// You have a bad nickname! Try the alt. // You have a bad nickname! Try the alt.
//case IRC_ERR_NONICKNAMEGIVEN: // 431 -- Not consistently usable due to lack of command field. //case IRC_ERR_NONICKNAMEGIVEN: // 431 -- Not consistently usable due to lack of command field.
case IRC_ERR_ERRONEOUSNICKNAME: // 432 case IRC_ERR_ERRONEOUSNICKNAME: // 432
completelyBadNick = true; erroneous_nickname = true;
case IRC_ERR_NICKNAMEINUSE: // 433 case IRC_ERR_NICKNAMEINUSE: // 433
case IRC_ERR_NICKCOLLISION: // 436 case IRC_ERR_NICKCOLLISION: // 436
case IRC_ERR_BANNICKCHANGE: // 437 -- Note: This conflicts with another token. case IRC_ERR_BANNICKCHANGE: // 437 -- Note: This conflicts with another token.
const Jupiter::ReadableString &altNick = Jupiter::IRC::Client::readConfigValue("AltNick"_jrs, "Jupiter"_jrs); const Jupiter::ReadableString &altNick = Jupiter::IRC::Client::readConfigValue("AltNick"_jrs);
const Jupiter::ReadableString &configNick = Jupiter::IRC::Client::readConfigValue("Nick"_jrs, "Jupiter"_jrs); const Jupiter::ReadableString &configNick = Jupiter::IRC::Client::readConfigValue("Nick"_jrs, "Jupiter"_jrs);
/*
* Possible Issues: if (altNick.isNotEmpty() && Jupiter::IRC::Client::data_->nickname.equalsi(altNick)) // The alternate nick failed.
* altNick != nickname after first nick change -- loop initiated?
* completelyBadNick will apply to altNick if it was tried, not the actual nick.
*/
if (Jupiter::IRC::Client::data_->nickname.equalsi(altNick)) // The alternate nick failed.
{ {
Jupiter::IRC::Client::data_->nickname = configNick; Jupiter::IRC::Client::data_->nickname = configNick;
Jupiter::IRC::Client::data_->nickname += "1"; Jupiter::IRC::Client::data_->nickname += "1";
Jupiter::IRC::Client::data_->sock->send("NICK "_jrs + Jupiter::IRC::Client::data_->nickname + ENDL);
} }
else if (Jupiter::IRC::Client::data_->nickname.equalsi(configNick)) else if (Jupiter::IRC::Client::data_->nickname.equalsi(configNick)) // The config nick failed
{ {
if (altNick.isEmpty())
{
if (erroneous_nickname)
break; // If this nick is invalid, adding numbers won't help.
Jupiter::IRC::Client::data_->nickname += '1';
}
else
Jupiter::IRC::Client::data_->nickname = altNick; Jupiter::IRC::Client::data_->nickname = altNick;
if (Jupiter::IRC::Client::data_->nickname.isNotEmpty())
Jupiter::IRC::Client::data_->sock->send(Jupiter::StringS::Format("NICK %.*s" ENDL, Jupiter::IRC::Client::data_->nickname.size(), Jupiter::IRC::Client::data_->nickname.ptr())); Jupiter::IRC::Client::data_->sock->send("NICK "_jrs + Jupiter::IRC::Client::data_->nickname + ENDL);
} }
// Note: Add a series of contains() functions to String_Type. // Note: Add a series of contains() functions to String_Type.
else else
{ {
if (completelyBadNick == false) // If this nick is invalid, adding numbers won't help. if (erroneous_nickname == false) // If this nick is invalid, adding numbers won't help.
{ {
if (Jupiter::IRC::Client::data_->nickname.size() > configNick.size()) if (Jupiter::IRC::Client::data_->nickname.size() > configNick.size())
{ {
int n = Jupiter_strtoi_nospace_s(Jupiter::IRC::Client::data_->nickname.ptr() + configNick.size(), Jupiter::IRC::Client::data_->nickname.size() - configNick.size(), 10); int n = Jupiter_strtoi_nospace_s(Jupiter::IRC::Client::data_->nickname.ptr() + configNick.size(), Jupiter::IRC::Client::data_->nickname.size() - configNick.size(), 10);
Jupiter::IRC::Client::data_->nickname.format("%.*s%d", configNick.size(), configNick.ptr(), n); Jupiter::IRC::Client::data_->nickname.format("%.*s%d", configNick.size(), configNick.ptr(), n + 1);
Jupiter::IRC::Client::data_->sock->send("NICK "_jrs + Jupiter::IRC::Client::data_->nickname + ENDL);
} }
else else
{ {
@ -829,6 +837,7 @@ int Jupiter::IRC::Client::process_line(const Jupiter::ReadableString &line)
// This can be somewhat edgy -- this will only trigger if someone rehashes AND the new nickname is shorter. // This can be somewhat edgy -- this will only trigger if someone rehashes AND the new nickname is shorter.
// However, it won't be fatal even if the new nickname's length is >= the old. // However, it won't be fatal even if the new nickname's length is >= the old.
Jupiter::IRC::Client::data_->nickname = configNick; Jupiter::IRC::Client::data_->nickname = configNick;
Jupiter::IRC::Client::data_->sock->send("NICK "_jrs + Jupiter::IRC::Client::data_->nickname + ENDL);
} }
} }
else else

BIN
Release/Jupiter.lib

Binary file not shown.
Loading…
Cancel
Save