[Commands] Cleanup #xtargets Command. (#2545)

* [Commands] Cleanup #xtargets Command.

- Cleanup messages and logic.

* Update client.cpp

* Update client.cpp
This commit is contained in:
Kinglykrab
2022-11-16 19:11:35 -05:00
committed by GitHub
parent bd95daa1f3
commit ce4d96dc91
3 changed files with 69 additions and 25 deletions
+29 -17
View File
@@ -1,28 +1,40 @@
#include "../client.h"
#include "../../common/data_verification.h"
void command_xtargets(Client *c, const Seperator *sep)
{
Client *t;
auto t = c;
if (c->GetTarget() && c->GetTarget()->IsClient()) {
t = c->GetTarget()->CastToClient();
}
else {
t = c;
}
if (sep->arg[1][0]) {
uint8 NewMax = atoi(sep->arg[1]);
if ((NewMax < 5) || (NewMax > XTARGET_HARDCAP)) {
c->Message(Chat::Red, "Number of XTargets must be between 5 and %i", XTARGET_HARDCAP);
return;
}
t->SetMaxXTargets(NewMax);
c->Message(Chat::White, "Max number of XTargets set to %i", NewMax);
}
else {
auto arguments = sep->argnum;
if (!arguments || !sep->IsNumber(1)) {
t->ShowXTargets(c);
return;
}
}
const auto new_max = static_cast<uint8>(std::stoul(sep->arg[1]));
if (!EQ::ValueWithin(new_max, 5, XTARGET_HARDCAP)) {
c->Message(
Chat::White,
fmt::format(
"Number of XTargets must be between 5 and {}.",
XTARGET_HARDCAP
).c_str()
);
return;
}
t->SetMaxXTargets(new_max);
c->Message(
Chat::White,
fmt::format(
"Max number of XTargets set to {} for {}.",
new_max,
c->GetTargetDescription(t, TargetDescriptionType::LCSelf)
).c_str()
);
}