diff options
author | Seyden <saiifii@live.de> | 2022-12-22 23:45:35 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-12-22 23:45:35 +0100 |
commit | 64a1c7735e3888f7c6e413c2a70196f7f8d4a090 (patch) | |
tree | 492489516de62001fd1351c2be528687b227e1e5 /src | |
parent | 995fc6e781e48c70629bc6be80475a431b65b2bd (diff) |
Core/Creatures: Implemented AttackableBySummoner summon properties flag (#28489)
Diffstat (limited to 'src')
-rw-r--r-- | src/server/game/Entities/Object/Object.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/src/server/game/Entities/Object/Object.cpp b/src/server/game/Entities/Object/Object.cpp index a44fdac20e9..ba2ff05dc15 100644 --- a/src/server/game/Entities/Object/Object.cpp +++ b/src/server/game/Entities/Object/Object.cpp @@ -2635,6 +2635,25 @@ ReputationRank WorldObject::GetReactionTo(WorldObject const* target) const if (this == target) return REP_FRIENDLY; + auto isAttackableBySummoner = [&](Unit const* me, ObjectGuid const& targetGuid) + { + if (!me) + return false; + + TempSummon const* tempSummon = me->ToTempSummon(); + if (!tempSummon || !tempSummon->m_Properties) + return false; + + if (tempSummon->m_Properties->GetFlags().HasFlag(SummonPropertiesFlags::AttackableBySummoner) + && targetGuid == tempSummon->GetSummonerGUID()) + return true; + + return false; + }; + + if (isAttackableBySummoner(ToUnit(), target->GetGUID()) || isAttackableBySummoner(target->ToUnit(), GetGUID())) + return REP_NEUTRAL; + // always friendly to charmer or owner if (GetCharmerOrOwnerOrSelf() == target->GetCharmerOrOwnerOrSelf()) return REP_FRIENDLY; |