mirror of
https://github.com/mangosfour/server.git
synced 2025-12-14 07:37:01 +00:00
[7559] Implement function Player::RewardPlayerAndGroupAtEvent for reward (quest objective only) player and group at special kill-like events.
Use it for Spell::EffectKillCredit and some dummy code. Signed-off-by: VladimirMangos <vladimir@getmangos.com>
This commit is contained in:
parent
2dd36d688f
commit
00d0718124
4 changed files with 29 additions and 3 deletions
|
|
@ -18654,6 +18654,31 @@ bool Player::RewardPlayerAndGroupAtKill(Unit* pVictim)
|
||||||
return xp || honored_kill;
|
return xp || honored_kill;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Player::RewardPlayerAndGroupAtEvent(uint32 creature_id, WorldObject* pRewardSource)
|
||||||
|
{
|
||||||
|
uint64 creature_guid = pRewardSource->GetTypeId()==TYPEID_UNIT ? pRewardSource->GetGUID() : uint64(0);
|
||||||
|
|
||||||
|
// prepare data for near group iteration
|
||||||
|
if(Group *pGroup = GetGroup())
|
||||||
|
{
|
||||||
|
for(GroupReference *itr = pGroup->GetFirstMember(); itr != NULL; itr = itr->next())
|
||||||
|
{
|
||||||
|
Player* pGroupGuy = itr->getSource();
|
||||||
|
if(!pGroupGuy)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if(!pGroupGuy->IsAtGroupRewardDistance(pRewardSource))
|
||||||
|
continue; // member (alive or dead) or his corpse at req. distance
|
||||||
|
|
||||||
|
// quest objectives updated only for alive group member or dead but with not released body
|
||||||
|
if(pGroupGuy->isAlive()|| !pGroupGuy->GetCorpse())
|
||||||
|
pGroupGuy->KilledMonster(creature_id, creature_guid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else // if (!pGroup)
|
||||||
|
KilledMonster(creature_id, creature_guid);
|
||||||
|
}
|
||||||
|
|
||||||
bool Player::IsAtGroupRewardDistance(WorldObject const* pRewardSource) const
|
bool Player::IsAtGroupRewardDistance(WorldObject const* pRewardSource) const
|
||||||
{
|
{
|
||||||
if(pRewardSource->GetDistance(this) <= sWorld.getConfig(CONFIG_GROUP_XP_DISTANCE))
|
if(pRewardSource->GetDistance(this) <= sWorld.getConfig(CONFIG_GROUP_XP_DISTANCE))
|
||||||
|
|
|
||||||
|
|
@ -1665,6 +1665,7 @@ class MANGOS_DLL_SPEC Player : public Unit
|
||||||
|
|
||||||
bool IsAtGroupRewardDistance(WorldObject const* pRewardSource) const;
|
bool IsAtGroupRewardDistance(WorldObject const* pRewardSource) const;
|
||||||
bool RewardPlayerAndGroupAtKill(Unit* pVictim);
|
bool RewardPlayerAndGroupAtKill(Unit* pVictim);
|
||||||
|
void RewardPlayerAndGroupAtEvent(uint32 creature_id,WorldObject* pRewardSource);
|
||||||
bool isHonorOrXPTarget(Unit* pVictim);
|
bool isHonorOrXPTarget(Unit* pVictim);
|
||||||
|
|
||||||
ReputationMgr& GetReputationMgr() { return m_reputationMgr; }
|
ReputationMgr& GetReputationMgr() { return m_reputationMgr; }
|
||||||
|
|
|
||||||
|
|
@ -1053,7 +1053,7 @@ void Spell::EffectDummy(uint32 i)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
pCreature->SetHealth(health);
|
pCreature->SetHealth(health);
|
||||||
((Player*)m_caster)->KilledMonster(16992,pCreature->GetGUID());
|
((Player*)m_caster)->RewardPlayerAndGroupAtEvent(16992,pCreature);
|
||||||
|
|
||||||
if (pCreature->AI())
|
if (pCreature->AI())
|
||||||
pCreature->AI()->AttackStart(m_caster);
|
pCreature->AI()->AttackStart(m_caster);
|
||||||
|
|
@ -6508,7 +6508,7 @@ void Spell::EffectKillCredit(uint32 i)
|
||||||
if(!unitTarget || unitTarget->GetTypeId() != TYPEID_PLAYER)
|
if(!unitTarget || unitTarget->GetTypeId() != TYPEID_PLAYER)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
((Player*)unitTarget)->KilledMonster(m_spellInfo->EffectMiscValue[i], 0);
|
((Player*)unitTarget)->RewardPlayerAndGroupAtEvent(m_spellInfo->EffectMiscValue[i], unitTarget);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Spell::EffectQuestFail(uint32 i)
|
void Spell::EffectQuestFail(uint32 i)
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
#ifndef __REVISION_NR_H__
|
#ifndef __REVISION_NR_H__
|
||||||
#define __REVISION_NR_H__
|
#define __REVISION_NR_H__
|
||||||
#define REVISION_NR "7558"
|
#define REVISION_NR "7559"
|
||||||
#endif // __REVISION_NR_H__
|
#endif // __REVISION_NR_H__
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue