aboutsummaryrefslogtreecommitdiff
path: root/src/game/Unit.cpp
diff options
context:
space:
mode:
authormaximius <none@none>2009-09-29 15:13:46 -0700
committermaximius <none@none>2009-09-29 15:13:46 -0700
commit4b79217bef70158f894607108ed6a335b4ca1f9a (patch)
tree748cdb4b64748eec0a2b0e665e42aea2aa47242e /src/game/Unit.cpp
parent21f08bff8e6c5f9366828a2be19bc16db781231d (diff)
*Passive targets under attack by players are not ideal targets for hostile creatures, so avoid them.
--HG-- branch : trunk
Diffstat (limited to 'src/game/Unit.cpp')
-rw-r--r--src/game/Unit.cpp5
1 files changed, 2 insertions, 3 deletions
diff --git a/src/game/Unit.cpp b/src/game/Unit.cpp
index da42631e135..2db1ad96a8a 100644
--- a/src/game/Unit.cpp
+++ b/src/game/Unit.cpp
@@ -11344,7 +11344,7 @@ Unit* Creature::SelectVictim()
else
return NULL;
- if(target && (!target->getVictim() || IsFriendlyTo(target->getVictim()))) // if victim(1) has a victim(2), only attack victim(1) if we are friendly with victim(2)
+ if(target && _IsTargetAcceptable(target))
{
SetInFront(target);
return target;
@@ -11358,7 +11358,6 @@ Unit* Creature::SelectVictim()
{
if((*itr) && canCreatureAttack(*itr) && (*itr)->GetTypeId() != TYPEID_PLAYER
&& !((Creature*)(*itr))->HasUnitTypeMask(UNIT_MASK_CONTROLABLE_GUARDIAN))
- // && (!(*itr)->getVictim() || IsFriendlyTo((*itr)->getVictim()))) // if victim(1) has a victim(2), only attack victim(1) if we are friendly with victim(2)
return NULL;
}
@@ -11369,7 +11368,7 @@ Unit* Creature::SelectVictim()
// search nearby enemy before enter evade mode
if(HasReactState(REACT_AGGRESSIVE))
if(target = SelectNearestTarget())
- if(!target->getVictim() || IsFriendlyTo(target->getVictim())) // if victim(1) has a victim(2), only attack victim(1) if we are friendly with victim(2)
+ if(_IsTargetAcceptable(target))
return target;
if(m_invisibilityMask)