diff --git a/src/game/SpellAuras.cpp b/src/game/SpellAuras.cpp index ea3e83715..c60809ec0 100644 --- a/src/game/SpellAuras.cpp +++ b/src/game/SpellAuras.cpp @@ -3067,21 +3067,28 @@ void Aura::HandleModPossess(bool apply, bool Real) m_target->StopMoving(); m_target->GetMotionMaster()->Clear(); m_target->GetMotionMaster()->MoveIdle(); - CharmInfo *charmInfo = ((Creature*)m_target)->InitCharmInfo(m_target); - charmInfo->InitPossessCreateSpells(); + } + else if(m_target->GetTypeId() == TYPEID_PLAYER) + { + ((Player*)m_target)->SetClientControl(m_target, 0); } + if(CharmInfo *charmInfo = m_target->InitCharmInfo(m_target)) + charmInfo->InitPossessCreateSpells(); + if(caster->GetTypeId() == TYPEID_PLAYER) - { ((Player*)caster)->PossessSpellInitialize(); - } } else { m_target->SetCharmerGUID(0); + caster->InterruptSpell(CURRENT_CHANNELED_SPELL); // the spell is not automatically canceled when interrupted, do it now if(m_target->GetTypeId() == TYPEID_PLAYER) + { ((Player*)m_target)->setFactionForRace(m_target->getRace()); + ((Player*)m_target)->SetClientControl(m_target, 1); + } else if(m_target->GetTypeId() == TYPEID_UNIT) { CreatureInfo const *cinfo = ((Creature*)m_target)->GetCreatureInfo(); @@ -3185,7 +3192,7 @@ void Aura::HandleModCharm(bool apply, bool Real) if(m_target->GetTypeId() == TYPEID_UNIT) { ((Creature*)m_target)->AIM_Initialize(); - CharmInfo *charmInfo = ((Creature*)m_target)->InitCharmInfo(m_target); + CharmInfo *charmInfo = m_target->InitCharmInfo(m_target); charmInfo->InitCharmCreateSpells(); charmInfo->SetReactState( REACT_DEFENSIVE ); diff --git a/src/game/Unit.cpp b/src/game/Unit.cpp index e3c46f3d5..c00003d1b 100644 --- a/src/game/Unit.cpp +++ b/src/game/Unit.cpp @@ -10177,11 +10177,11 @@ void CharmInfo::InitEmptyActionBar() void CharmInfo::InitPossessCreateSpells() { - if(m_unit->GetTypeId() == TYPEID_PLAYER) - return; - InitEmptyActionBar(); //charm action bar + if(m_unit->GetTypeId() == TYPEID_PLAYER) //possessed players don't have spells, keep the action bar empty + return; + for(uint32 x = 0; x < CREATURE_MAX_SPELLS; ++x) { if (IsPassiveSpell(((Creature*)m_unit)->m_spells[x])) diff --git a/src/shared/revision_nr.h b/src/shared/revision_nr.h index 2b70281bf..760ca52b7 100644 --- a/src/shared/revision_nr.h +++ b/src/shared/revision_nr.h @@ -1,4 +1,4 @@ #ifndef __REVISION_NR_H__ #define __REVISION_NR_H__ - #define REVISION_NR "7609" + #define REVISION_NR "7610" #endif // __REVISION_NR_H__