diff options
author | megamage <none@none> | 2008-11-26 11:41:03 -0600 |
---|---|---|
committer | megamage <none@none> | 2008-11-26 11:41:03 -0600 |
commit | 77b753b45260b24f846d51c5527c90fffd1cf3d5 (patch) | |
tree | f0fdd06ee0810584606af757be037cb980e3ecfa /src | |
parent | 9e3c9124f2b63e048e7a62a44c1ea36249e9a85a (diff) |
*Fix the bug that neutral creatures do not fight back.
--HG--
branch : trunk
Diffstat (limited to 'src')
-rw-r--r-- | src/game/Creature.cpp | 2 | ||||
-rw-r--r-- | src/game/Unit.cpp | 9 | ||||
-rw-r--r-- | src/game/Unit.h | 2 |
3 files changed, 9 insertions, 4 deletions
diff --git a/src/game/Creature.cpp b/src/game/Creature.cpp index 623b13f9dd2..94aa3c2151c 100644 --- a/src/game/Creature.cpp +++ b/src/game/Creature.cpp @@ -1576,7 +1576,7 @@ bool Creature::canStartAttack(Unit const* who) const || !IsWithinDistInMap(who, GetAttackDistance(who))) return false; - if(!canAttack(who)) + if(!canAttack(who, false)) return false; return IsWithinLOSInMap(who); diff --git a/src/game/Unit.cpp b/src/game/Unit.cpp index 0ff6aacb5ef..571ff991147 100644 --- a/src/game/Unit.cpp +++ b/src/game/Unit.cpp @@ -8557,11 +8557,16 @@ bool Unit::isTargetableForAttack() const return isAttackableByAOE() && !hasUnitState(UNIT_STAT_DIED); } -bool Unit::canAttack(Unit const* target) const +bool Unit::canAttack(Unit const* target, bool force) const { assert(target); - if(!IsHostileTo(target)) + if(force) + { + if(IsFriendlyTo(target)) + return false; + } + else if(!IsHostileTo(target)) return false; if(!target->isAttackableByAOE() || target->hasUnitState(UNIT_STAT_DIED)) diff --git a/src/game/Unit.h b/src/game/Unit.h index a8a60fa5ec9..24122368e61 100644 --- a/src/game/Unit.h +++ b/src/game/Unit.h @@ -928,7 +928,7 @@ class TRINITY_DLL_SPEC Unit : public WorldObject bool isTargetableForAttack() const; bool isAttackableByAOE() const; - bool canAttack(Unit const* target) const; + bool canAttack(Unit const* target, bool force = true) const; virtual bool IsInWater() const; virtual bool IsUnderWater() const; bool isInAccessiblePlaceFor(Creature const* c) const; |