mirror of
https://github.com/EQEmu/Server.git
synced 2025-12-12 01:11:29 +00:00
[Commands] Cleanup #npccast Command. (#1699)
- Cleanup messages and display.
This commit is contained in:
parent
328a94e2d4
commit
248e6d44db
@ -2662,22 +2662,88 @@ void command_zclip(Client *c, const Seperator *sep)
|
||||
|
||||
void command_npccast(Client *c, const Seperator *sep)
|
||||
{
|
||||
if (c->GetTarget() && c->GetTarget()->IsNPC() && !sep->IsNumber(1) && sep->arg[1] != 0 && sep->IsNumber(2)) {
|
||||
Mob* spelltar = entity_list.GetMob(sep->arg[1]);
|
||||
if (spelltar)
|
||||
c->GetTarget()->CastSpell(atoi(sep->arg[2]), spelltar->GetID());
|
||||
else
|
||||
c->Message(Chat::White, "Error: %s not found", sep->arg[1]);
|
||||
if (c->GetTarget() && c->GetTarget()->IsNPC()) {
|
||||
NPC* target = c->GetTarget()->CastToNPC();
|
||||
if (!sep->IsNumber(1) && sep->arg[1] && sep->IsNumber(2)) {
|
||||
const char* entity_name = sep->arg[1] ? sep->arg[1] : 0;
|
||||
auto spell_id = sep->arg[2] ? std::stoul(sep->arg[2]) : 0;
|
||||
Mob* spell_target = entity_list.GetMob(entity_name);
|
||||
if (spell_target && IsValidSpell(spell_id) && spell_id < SPDAT_RECORDS) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"{} ({}) casting {} ({}) on {} ({}).",
|
||||
target->GetCleanName(),
|
||||
target->GetID(),
|
||||
GetSpellName(static_cast<uint16>(spell_id)),
|
||||
spell_id,
|
||||
spell_target->GetCleanName(),
|
||||
spell_target->GetID()
|
||||
).c_str()
|
||||
);
|
||||
|
||||
target->CastSpell(spell_id, spell_target->GetID());
|
||||
} else {
|
||||
if (!spell_target) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"Entity {} was not found",
|
||||
entity_name
|
||||
).c_str()
|
||||
);
|
||||
} else if (!spell_id || !IsValidSpell(spell_id)) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"Spell ID {} was not found",
|
||||
spell_id
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
else if (c->GetTarget() && c->GetTarget()->IsNPC() && sep->IsNumber(1) && sep->IsNumber(2) ) {
|
||||
Mob* spelltar = entity_list.GetMob(atoi(sep->arg[1]));
|
||||
if (spelltar)
|
||||
c->GetTarget()->CastSpell(atoi(sep->arg[2]), spelltar->GetID());
|
||||
else
|
||||
c->Message(Chat::White, "Error: target ID %i not found", atoi(sep->arg[1]));
|
||||
}
|
||||
else
|
||||
c->Message(Chat::White, "Usage: (needs NPC targeted) #npccast targetname/entityid spellid");
|
||||
} else if (sep->IsNumber(1) && sep->IsNumber(2) ) {
|
||||
uint16 entity_id = sep->arg[1] ? std::stoul(sep->arg[1]) : 0;
|
||||
auto spell_id = sep->arg[2] ? std::stoul(sep->arg[2]) : 0;
|
||||
Mob* spell_target = entity_list.GetMob(entity_id);
|
||||
if (spell_target && IsValidSpell(spell_id) && spell_id < SPDAT_RECORDS) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"{} ({}) casting {} ({}) on {} ({}).",
|
||||
target->GetCleanName(),
|
||||
target->GetID(),
|
||||
GetSpellName(static_cast<uint16>(spell_id)),
|
||||
spell_id,
|
||||
spell_target->GetCleanName(),
|
||||
spell_target->GetID()
|
||||
).c_str()
|
||||
);
|
||||
|
||||
target->CastSpell(spell_id, spell_target->GetID());
|
||||
} else {
|
||||
if (!spell_target) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"Entity ID {} was not found",
|
||||
entity_id
|
||||
).c_str()
|
||||
);
|
||||
} else if (!spell_id || !IsValidSpell(spell_id)) {
|
||||
c->Message(
|
||||
Chat::White,
|
||||
fmt::format(
|
||||
"Spell ID {} was not found",
|
||||
spell_id
|
||||
).c_str()
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
c->Message(Chat::White, "You must target an NPC to use this command.");
|
||||
}
|
||||
}
|
||||
|
||||
void command_zstats(Client *c, const Seperator *sep)
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user