mirror of
https://github.com/EQEmu/Server.git
synced 2025-12-14 11:31:30 +00:00
[Commands] Cleanup #permarace Command. (#1778)
- Cleanup message and logic.
This commit is contained in:
parent
7c12c5d5ef
commit
fb2f901539
@ -276,7 +276,7 @@ int command_init(void)
|
|||||||
command_add("peqzone", "[zonename] - Go to specified zone, if you have > 75% health", AccountStatus::Player, command_peqzone) ||
|
command_add("peqzone", "[zonename] - Go to specified zone, if you have > 75% health", AccountStatus::Player, command_peqzone) ||
|
||||||
command_add("permaclass", "[Class ID] - Change your or your player target's class, changed client is disconnected", AccountStatus::QuestTroupe, command_permaclass) ||
|
command_add("permaclass", "[Class ID] - Change your or your player target's class, changed client is disconnected", AccountStatus::QuestTroupe, command_permaclass) ||
|
||||||
command_add("permagender", "[gendernum] - Change your or your player target's gender (zone to take effect)", AccountStatus::QuestTroupe, command_permagender) ||
|
command_add("permagender", "[gendernum] - Change your or your player target's gender (zone to take effect)", AccountStatus::QuestTroupe, command_permagender) ||
|
||||||
command_add("permarace", "[racenum] - Change your or your player target's race (zone to take effect)", AccountStatus::QuestTroupe, command_permarace) ||
|
command_add("permarace", "[Race ID] - Change your or your player target's race", AccountStatus::QuestTroupe, command_permarace) ||
|
||||||
command_add("petitioninfo", "[petition number] - Get info about a petition", AccountStatus::ApprenticeGuide, command_petitioninfo) ||
|
command_add("petitioninfo", "[petition number] - Get info about a petition", AccountStatus::ApprenticeGuide, command_petitioninfo) ||
|
||||||
command_add("pf", "- Display additional mob coordinate and wandering data", AccountStatus::Player, command_pf) ||
|
command_add("pf", "- Display additional mob coordinate and wandering data", AccountStatus::Player, command_pf) ||
|
||||||
command_add("picklock", "Analog for ldon pick lock for the newer clients since we still don't have it working.", AccountStatus::Player, command_picklock) ||
|
command_add("picklock", "Analog for ldon pick lock for the newer clients since we still don't have it working.", AccountStatus::Player, command_picklock) ||
|
||||||
|
|||||||
@ -2,33 +2,43 @@
|
|||||||
|
|
||||||
void command_permarace(Client *c, const Seperator *sep)
|
void command_permarace(Client *c, const Seperator *sep)
|
||||||
{
|
{
|
||||||
Client *t = c;
|
int arguments = sep->argnum;
|
||||||
|
if (!arguments || !sep->IsNumber(1)) {
|
||||||
if (c->GetTarget() && c->GetTarget()->IsClient()) {
|
c->Message(Chat::White, "Usage: #permarace [Race ID]");
|
||||||
t = c->GetTarget()->CastToClient();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (sep->arg[1][0] == 0) {
|
|
||||||
c->Message(Chat::White, "Usage: #permarace <racenum>");
|
|
||||||
c->Message(
|
c->Message(
|
||||||
Chat::White,
|
Chat::White,
|
||||||
"NOTE: Not all models are global. If a model is not global, it will appear as a human on character select and in zones without the model."
|
"NOTE: Not all models are global. If a model is not global, it will appear as a human on character select and in zones without the model."
|
||||||
);
|
);
|
||||||
}
|
return;
|
||||||
else if (!t->IsClient()) {
|
|
||||||
c->Message(Chat::White, "Target is not a client.");
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
c->Message(Chat::White, "Setting %s's race - zone to take effect", t->GetName());
|
|
||||||
LogInfo("Permanant race change request from [{}] for [{}], requested race:[{}]",
|
|
||||||
c->GetName(),
|
|
||||||
t->GetName(),
|
|
||||||
atoi(sep->arg[1]));
|
|
||||||
uint32 tmp = Mob::GetDefaultGender(atoi(sep->arg[1]), t->GetBaseGender());
|
|
||||||
t->SetBaseRace(atoi(sep->arg[1]));
|
|
||||||
t->SetBaseGender(tmp);
|
|
||||||
t->Save();
|
|
||||||
t->SendIllusionPacket(atoi(sep->arg[1]));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Client *target = c;
|
||||||
|
if (c->GetTarget() && c->GetTarget()->IsClient()) {
|
||||||
|
target = c->GetTarget()->CastToClient();
|
||||||
|
}
|
||||||
|
|
||||||
|
auto race_id = std::stoi(sep->arg[1]);
|
||||||
|
auto gender_id = Mob::GetDefaultGender(race_id, target->GetBaseGender());
|
||||||
|
|
||||||
|
LogInfo("Race changed by {} for {} to {} ({})",
|
||||||
|
c->GetCleanName(),
|
||||||
|
target->GetCleanName(),
|
||||||
|
GetRaceIDName(race_id),
|
||||||
|
race_id
|
||||||
|
);
|
||||||
|
|
||||||
|
target->SetBaseRace(race_id);
|
||||||
|
target->SetBaseGender(gender_id);
|
||||||
|
target->Save();
|
||||||
|
target->SendIllusionPacket(race_id, gender_id);
|
||||||
|
|
||||||
|
c->Message(
|
||||||
|
Chat::White,
|
||||||
|
fmt::format(
|
||||||
|
"Race changed for {} to {} ({}).",
|
||||||
|
c == target ? "yourself" : target->GetCleanName(),
|
||||||
|
GetRaceIDName(race_id),
|
||||||
|
race_id
|
||||||
|
).c_str()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user