mirror of
https://github.com/mangosfour/server.git
synced 2025-12-13 22:37:03 +00:00
[10335] Make sure DynamicObjectUpdater::VisitHelper does not overwrite existing PersistentAreaAura and leave orphaned aura in m_modAuras.
This commit is contained in:
parent
344dff303e
commit
7e251dd408
2 changed files with 26 additions and 17 deletions
|
|
@ -172,28 +172,37 @@ inline void MaNGOS::DynamicObjectUpdater::VisitHelper(Unit* target)
|
|||
return;
|
||||
|
||||
// Apply PersistentAreaAura on target
|
||||
|
||||
// in case 2 dynobject overlap areas for same spell, same holder is selected, so dynobjects share holder
|
||||
SpellAuraHolder *holder = target->GetSpellAuraHolder(spellInfo->Id, i_dynobject.GetCaster()->GetGUID());
|
||||
|
||||
bool addedToExisting = true;
|
||||
if (!holder)
|
||||
{
|
||||
holder = CreateSpellAuraHolder(spellInfo, target, i_dynobject.GetCaster());
|
||||
addedToExisting = false;
|
||||
|
||||
}
|
||||
PersistentAreaAura* Aur = new PersistentAreaAura(spellInfo, eff_index, NULL, holder, target, i_dynobject.GetCaster());
|
||||
holder->AddAura(Aur, eff_index);
|
||||
|
||||
if (addedToExisting)
|
||||
if (holder)
|
||||
{
|
||||
target->AddAuraToModList(Aur);
|
||||
holder->SetInUse(true);
|
||||
Aur->ApplyModifier(true,true);
|
||||
holder->SetInUse(false);
|
||||
if (Aura* aura = holder->GetAuraByEffectIndex(eff_index))
|
||||
{
|
||||
// already exists, refresh duration
|
||||
if (aura->GetAuraDuration() < i_dynobject.GetDuration())
|
||||
{
|
||||
aura->SetAuraDuration(i_dynobject.GetDuration());
|
||||
holder->SendAuraUpdate(false);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
PersistentAreaAura* Aur = new PersistentAreaAura(spellInfo, eff_index, NULL, holder, target, i_dynobject.GetCaster());
|
||||
holder->AddAura(Aur, eff_index);
|
||||
target->AddAuraToModList(Aur);
|
||||
holder->SetInUse(true);
|
||||
Aur->ApplyModifier(true,true);
|
||||
holder->SetInUse(false);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
holder = CreateSpellAuraHolder(spellInfo, target, i_dynobject.GetCaster());
|
||||
PersistentAreaAura* Aur = new PersistentAreaAura(spellInfo, eff_index, NULL, holder, target, i_dynobject.GetCaster());
|
||||
holder->AddAura(Aur, eff_index);
|
||||
target->AddSpellAuraHolder(holder);
|
||||
}
|
||||
|
||||
i_dynobject.AddAffected(target);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
#ifndef __REVISION_NR_H__
|
||||
#define __REVISION_NR_H__
|
||||
#define REVISION_NR "10334"
|
||||
#define REVISION_NR "10335"
|
||||
#endif // __REVISION_NR_H__
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue