mirror of
https://github.com/EQEmu/Server.git
synced 2026-05-16 22:58:34 +00:00
[Commands] Consolidate #set-like commands into a singular #set command (#3486)
* 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>
This commit is contained in:
@@ -0,0 +1,41 @@
|
||||
#include "../../client.h"
|
||||
|
||||
void SetMana(Client *c, const Seperator *sep)
|
||||
{
|
||||
const auto arguments = sep->argnum;
|
||||
if (arguments < 2 || !sep->IsNumber(2)) {
|
||||
c->Message(Chat::White, "Usage: #set mana [Amount]");
|
||||
return;
|
||||
}
|
||||
|
||||
Mob* t = c;
|
||||
if (c->GetTarget()) {
|
||||
t = c->GetTarget();
|
||||
}
|
||||
|
||||
int64 mana = Strings::ToBigInt(sep->arg[2]);
|
||||
|
||||
if (t->IsClient()) {
|
||||
if (mana >= t->CastToClient()->CalcMaxMana()) {
|
||||
mana = t->CastToClient()->CalcMaxMana();
|
||||
}
|
||||
|
||||
t->CastToClient()->SetMana(mana);
|
||||
} else {
|
||||
if (mana >= t->CalcMaxMana()) {
|
||||
mana = t->CalcMaxMana();
|
||||
}
|
||||
|
||||
t->SetMana(mana);
|
||||
}
|
||||
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"Set {} to {} Mana.",
|
||||
c->GetTargetDescription(t),
|
||||
Strings::Commify(mana)
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user