mirror of
https://github.com/EQEmu/Server.git
synced 2025-12-12 22:01:30 +00:00
* First push * Final push. * Consolidate zone commands in to one. * Update command.cpp * Remove debug messages. * Test * Add support for sub command status levels. * Update command.cpp * Update client.cpp * Update database_update_manifest.cpp * Update version.h * Update item.cpp * Update version.h * Update database_update_manifest.cpp * Fix command arguments. * Help message. * Update command.cpp * Do DB injection/deletion * Indent * Update server_locked.cpp * Update set.cpp * Lock aliases * Update command_subsettings_repository.h * Update set.cpp * Fix --------- Co-authored-by: Akkadius <akkadius1@gmail.com>
53 lines
995 B
C++
Executable File
53 lines
995 B
C++
Executable File
#include "../../client.h"
|
|
|
|
void SetRace(Client *c, const Seperator *sep)
|
|
{
|
|
const auto arguments = sep->argnum;
|
|
if (arguments < 2 || !sep->IsNumber(2)) {
|
|
c->Message(
|
|
Chat::White,
|
|
fmt::format(
|
|
"Usage: #set race [0-{}, 2253-2259] (0 for back to normal)",
|
|
RuleI(NPC, MaxRaceID)
|
|
).c_str()
|
|
);
|
|
|
|
return;
|
|
}
|
|
|
|
Mob* t = c;
|
|
if (c->GetTarget()) {
|
|
t = c->GetTarget();
|
|
}
|
|
|
|
const uint16 race_id = Strings::ToUnsignedInt(sep->arg[2]);
|
|
|
|
if (
|
|
!EQ::ValueWithin(race_id, RACE_DOUG_0, RuleI(NPC, MaxRaceID)) &&
|
|
!EQ::ValueWithin(race_id, 2253, 2259)
|
|
) {
|
|
c->Message(
|
|
Chat::White,
|
|
fmt::format(
|
|
"Usage: #race [0-{}, 2253-2259] (0 for back to normal)",
|
|
RuleI(NPC, MaxRaceID)
|
|
).c_str()
|
|
);
|
|
|
|
return;
|
|
}
|
|
|
|
t->SendIllusionPacket(race_id);
|
|
|
|
c->Message(
|
|
Chat::White,
|
|
fmt::format(
|
|
"{} {} now temporarily a(n) {} ({}).",
|
|
c->GetTargetDescription(t, TargetDescriptionType::UCYou),
|
|
c == t ? "are" : "is",
|
|
GetRaceIDName(race_id),
|
|
race_id
|
|
).c_str()
|
|
);
|
|
}
|