mirror of
https://github.com/EQEmu/Server.git
synced 2025-12-13 06:21:28 +00:00
Revert "[BugFix] Charm Targeting and other issues. (#1655)"
This reverts commit df3161455a2314e0e8b774bbbe328ee5d0a41fe9.
This commit is contained in:
parent
873f1f7f34
commit
1231d44b55
@ -1514,9 +1514,7 @@ void EntityList::RemoveFromTargets(Mob *mob, bool RemoveFromXTargets)
|
||||
mob->CastToClient()->RemoveXTarget(m, false);
|
||||
}
|
||||
|
||||
if (m->IsAIControlled()) {
|
||||
m->RemoveFromHateList(mob);
|
||||
}
|
||||
m->RemoveFromHateList(mob);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -2875,7 +2875,7 @@ bool Mob::RemoveFromHateList(Mob* mob)
|
||||
ResetAssistCap();
|
||||
}
|
||||
}
|
||||
if(IsAIControlled() && GetTarget() == mob)
|
||||
if(GetTarget() == mob)
|
||||
{
|
||||
SetTarget(hate_list.GetEntWithMostHateOnList(this));
|
||||
}
|
||||
|
||||
@ -731,27 +731,6 @@ bool Mob::SpellEffect(Mob* caster, uint16 spell_id, float partial, int level_ove
|
||||
if (!caster) // can't be someone's pet unless we know who that someone is
|
||||
break;
|
||||
|
||||
if (IsClient() && caster->IsClient()) {
|
||||
caster->Message(Chat::White, "Unable to cast charm on a fellow player.");
|
||||
BuffFadeByEffect(SE_Charm);
|
||||
break;
|
||||
}
|
||||
else if (IsCorpse()) {
|
||||
caster->Message(Chat::White, "Unable to cast charm on a corpse.");
|
||||
BuffFadeByEffect(SE_Charm);
|
||||
break;
|
||||
}
|
||||
else if (caster->GetPet() != nullptr && caster->IsClient()) {
|
||||
caster->Message(Chat::White, "You cannot charm something when you already have a pet.");
|
||||
BuffFadeByEffect(SE_Charm);
|
||||
break;
|
||||
}
|
||||
else if (GetOwner()) {
|
||||
caster->Message(Chat::White, "You cannot charm someone else's pet!");
|
||||
BuffFadeByEffect(SE_Charm);
|
||||
break;
|
||||
}
|
||||
|
||||
if(IsNPC())
|
||||
{
|
||||
CastToNPC()->SaveGuardSpotCharm();
|
||||
@ -760,7 +739,25 @@ bool Mob::SpellEffect(Mob* caster, uint16 spell_id, float partial, int level_ove
|
||||
entity_list.RemoveDebuffs(this);
|
||||
entity_list.RemoveFromTargets(this);
|
||||
WipeHateList();
|
||||
|
||||
|
||||
if (IsClient() && caster->IsClient()) {
|
||||
caster->Message(Chat::White, "Unable to cast charm on a fellow player.");
|
||||
BuffFadeByEffect(SE_Charm);
|
||||
break;
|
||||
} else if(IsCorpse()) {
|
||||
caster->Message(Chat::White, "Unable to cast charm on a corpse.");
|
||||
BuffFadeByEffect(SE_Charm);
|
||||
break;
|
||||
} else if(caster->GetPet() != nullptr && caster->IsClient()) {
|
||||
caster->Message(Chat::White, "You cannot charm something when you already have a pet.");
|
||||
BuffFadeByEffect(SE_Charm);
|
||||
break;
|
||||
} else if(GetOwner()) {
|
||||
caster->Message(Chat::White, "You cannot charm someone else's pet!");
|
||||
BuffFadeByEffect(SE_Charm);
|
||||
break;
|
||||
}
|
||||
|
||||
Mob *my_pet = GetPet();
|
||||
if(my_pet)
|
||||
{
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user