[Database] Add Extra Haste to Bots/Character Tables (#4286)

* [Database] Add Extra Haste to Bots/Character Tables

* Remove Database::GetExtraHasteByCharacterID

* Update database.h

* Update mob.cpp

* Update database_update_manifest.cpp

---------

Co-authored-by: Akkadius <akkadius1@gmail.com>
This commit is contained in:
Alex King
2024-05-04 19:21:41 -04:00
committed by GitHub
parent a71ad416b4
commit 7ad97ce168
16 changed files with 380 additions and 255 deletions
+17 -9
View File
@@ -2,28 +2,36 @@
void SetHaste(Client *c, const Seperator *sep)
{
const auto arguments = sep->argnum;
const uint16 arguments = sep->argnum;
if (arguments < 2 || !sep->IsNumber(2)) {
c->Message(Chat::White, "Usage: #set haste [Percentage] - Set GM Bonus Haste (100 is 100% more Attack Speed)");
c->Message(Chat::White, "Usage: #set haste [Percentage] [Save] - Set GM Bonus Haste (100 is 100% more Attack Speed) (Save is optional)");
return;
}
auto t = c;
if (c->GetGM() && c->GetTarget() && c->GetTarget()->IsClient()) {
t = c->GetTarget()->CastToClient();
Mob* t = c;
if (c->GetGM() && c->GetTarget() && c->GetTarget()->IsOfClientBot()) {
t = c->GetTarget();
}
const int extra_haste = Strings::ToInt(sep->arg[2]);
const int extra_haste = Strings::ToInt(sep->arg[2]);
const bool need_to_save = sep->arg[3] ? Strings::ToBool(sep->arg[3]) : false;
t->SetExtraHaste(extra_haste, need_to_save);
if (t->IsBot()) {
t->CastToBot()->CalcBonuses();
} else if (t->IsClient()) {
t->CastToClient()->CalcBonuses();
}
t->SetExtraHaste(extra_haste);
t->CalcBonuses();
t->SetAttackTimer();
c->Message(
Chat::White,
fmt::format(
"GM Haste Bonus set to {}%% for {}.",
"GM Haste Bonus set to {}%%{} for {}.",
Strings::Commify(extra_haste),
need_to_save ? " and saved" : "",
c->GetTargetDescription(t)
).c_str()
);