diff options
| author | Vincent-Michael <Vincent_Michael@gmx.de> | 2013-07-23 02:03:35 +0200 | 
|---|---|---|
| committer | Vincent-Michael <Vincent_Michael@gmx.de> | 2013-07-23 02:03:35 +0200 | 
| commit | aca68428c28bf47fbe2fc08415ae99156a4c4aa6 (patch) | |
| tree | 4a4971d62d2f2368d22127e5702fc59e4765ce0b /src | |
| parent | 41ebf1493c3b48f7cba3767b3e3b00e4f6eedea1 (diff) | |
| parent | 5463f211b4217d769be61992fcb3480f4fc241b4 (diff) | |
Merge branch 'master' of github.com:TrinityCore/TrinityCore into 4.3.4
Conflicts:
	src/server/game/AI/CoreAI/TotemAI.cpp
	src/server/game/Entities/Unit/Unit.cpp
	src/server/game/Globals/ObjectMgr.cpp
	src/server/game/Handlers/ItemHandler.cpp
	src/server/game/Spells/Spell.cpp
	src/server/game/Spells/SpellEffects.cpp
	src/server/scripts/Spells/spell_shaman.cpp
	src/server/scripts/Spells/spell_warlock.cpp
Diffstat (limited to 'src')
27 files changed, 235 insertions, 258 deletions
| diff --git a/src/server/game/AI/CoreAI/PetAI.cpp b/src/server/game/AI/CoreAI/PetAI.cpp index 2a13e5c71bf..4d657ec2b2b 100644 --- a/src/server/game/AI/CoreAI/PetAI.cpp +++ b/src/server/game/AI/CoreAI/PetAI.cpp @@ -260,15 +260,15 @@ void PetAI::UpdateAI(uint32 diff)  void PetAI::UpdateAllies()  { -    Unit* owner = me->GetCharmerOrOwner(); -    Group* group = NULL; - -    m_updateAlliesTimer = 10*IN_MILLISECONDS;                //update friendly targets every 10 seconds, lesser checks increase performance +    m_updateAlliesTimer = 10 * IN_MILLISECONDS;                 // update friendly targets every 10 seconds, lesser checks increase performance +    Unit* owner = me->GetCharmerOrOwner();      if (!owner)          return; -    else if (owner->GetTypeId() == TYPEID_PLAYER) -        group = owner->ToPlayer()->GetGroup(); + +    Group* group = NULL; +    if (Player* player = owner->ToPlayer()) +        group = player->GetGroup();      //only pet and owner/not in group->ok      if (m_AllySet.size() == 2 && !group) @@ -285,7 +285,7 @@ void PetAI::UpdateAllies()          for (GroupReference* itr = group->GetFirstMember(); itr != NULL; itr = itr->next())          {              Player* Target = itr->GetSource(); -            if (!Target || !group->SameSubGroup((Player*)owner, Target)) +            if (!Target || !group->SameSubGroup(owner->ToPlayer(), Target))                  continue;              if (Target->GetGUID() == owner->GetGUID()) diff --git a/src/server/game/AI/ScriptedAI/ScriptedEscortAI.h b/src/server/game/AI/ScriptedAI/ScriptedEscortAI.h index 4a350acab2c..919b24a916c 100644 --- a/src/server/game/AI/ScriptedAI/ScriptedEscortAI.h +++ b/src/server/game/AI/ScriptedAI/ScriptedEscortAI.h @@ -92,7 +92,7 @@ struct npc_escortAI : public ScriptedAI          uint64 GetEventStarterGUID() { return m_uiPlayerGUID; }      protected: -        Player* GetPlayerForEscort() { return (Player*)Unit::GetUnit(*me, m_uiPlayerGUID); } +        Player* GetPlayerForEscort() { return ObjectAccessor::GetPlayer(*me, m_uiPlayerGUID); }      private:          bool AssistPlayerInCombat(Unit* who); diff --git a/src/server/game/Battlegrounds/Battleground.cpp b/src/server/game/Battlegrounds/Battleground.cpp index be2aa7711a9..055f6b6c2bc 100644 --- a/src/server/game/Battlegrounds/Battleground.cpp +++ b/src/server/game/Battlegrounds/Battleground.cpp @@ -1498,6 +1498,29 @@ void Battleground::RemovePlayerFromResurrectQueue(uint64 player_guid)      }  } +void Battleground::RelocateDeadPlayers(uint32 queueIndex) +{ +    // Those who are waiting to resurrect at this node are taken to the closest own node's graveyard +    std::vector<uint64>& ghostList = m_ReviveQueue[queueIndex]; +    if (!ghostList.empty()) +    { +        WorldSafeLocsEntry const* closestGrave = NULL; +        for (std::vector<uint64>::const_iterator itr = ghostList.begin(); itr != ghostList.end(); ++itr) +        { +            Player* player = ObjectAccessor::FindPlayer(*itr); +            if (!player) +                continue; + +            if (!closestGrave) +                closestGrave = GetClosestGraveYard(player); + +            if (closestGrave) +                player->TeleportTo(GetMapId(), closestGrave->x, closestGrave->y, closestGrave->z, player->GetOrientation()); +        } +        ghostList.clear(); +    } +} +  bool Battleground::AddObject(uint32 type, uint32 entry, float x, float y, float z, float o, float rotation0, float rotation1, float rotation2, float rotation3, uint32 /*respawnTime*/)  {      // If the assert is called, means that BgObjects must be resized! diff --git a/src/server/game/Battlegrounds/Battleground.h b/src/server/game/Battlegrounds/Battleground.h index 13479e7ff30..264e2864a34 100644 --- a/src/server/game/Battlegrounds/Battleground.h +++ b/src/server/game/Battlegrounds/Battleground.h @@ -380,6 +380,9 @@ class Battleground          void AddPlayerToResurrectQueue(uint64 npc_guid, uint64 player_guid);          void RemovePlayerFromResurrectQueue(uint64 player_guid); +        /// Relocate all players in ReviveQueue to the closest graveyard +        void RelocateDeadPlayers(uint32 queueIndex); +          void StartBattleground();          GameObject* GetBGObject(uint32 type); diff --git a/src/server/game/Battlegrounds/Zones/BattlegroundAB.cpp b/src/server/game/Battlegrounds/Zones/BattlegroundAB.cpp index f986a52e3c9..bef0e995988 100644 --- a/src/server/game/Battlegrounds/Zones/BattlegroundAB.cpp +++ b/src/server/game/Battlegrounds/Zones/BattlegroundAB.cpp @@ -397,24 +397,7 @@ void BattlegroundAB::_NodeDeOccupied(uint8 node)      if (node < BG_AB_DYNAMIC_NODES_COUNT)//only dynamic nodes, no start points          DelCreature(node+7);//NULL checks are in DelCreature! 0-6 spirit guides -    // Those who are waiting to resurrect at this node are taken to the closest own node's graveyard -    std::vector<uint64> ghost_list = m_ReviveQueue[BgCreatures[node]]; -    if (!ghost_list.empty()) -    { -        WorldSafeLocsEntry const* ClosestGrave = NULL; -        for (std::vector<uint64>::const_iterator itr = ghost_list.begin(); itr != ghost_list.end(); ++itr) -        { -            Player* player = ObjectAccessor::FindPlayer(*itr); -            if (!player) -                continue; - -            if (!ClosestGrave)                              // cache -                ClosestGrave = GetClosestGraveYard(player); - -            if (ClosestGrave) -                player->TeleportTo(GetMapId(), ClosestGrave->x, ClosestGrave->y, ClosestGrave->z, player->GetOrientation()); -        } -    } +    RelocateDeadPlayers(BgCreatures[node]);      if (BgCreatures[node])          DelCreature(node); diff --git a/src/server/game/Battlegrounds/Zones/BattlegroundAV.cpp b/src/server/game/Battlegrounds/Zones/BattlegroundAV.cpp index 5dc20ab8f07..a72b1eb4eb1 100644 --- a/src/server/game/Battlegrounds/Zones/BattlegroundAV.cpp +++ b/src/server/game/Battlegrounds/Zones/BattlegroundAV.cpp @@ -1049,25 +1049,8 @@ void BattlegroundAV::EventPlayerAssaultsPoint(Player* player, uint32 object)              //spawning/despawning of aura              SpawnBGObject(BG_AV_OBJECT_AURA_N_FIRSTAID_STATION+3*node, RESPAWN_IMMEDIATELY); //neutral aura spawn              SpawnBGObject(BG_AV_OBJECT_AURA_A_FIRSTAID_STATION+GetTeamIndexByTeamId(owner)+3*node, RESPAWN_ONE_DAY); //teeamaura despawn -            // Those who are waiting to resurrect at this object are taken to the closest own object's graveyard -            std::vector<uint64> ghost_list = m_ReviveQueue[BgCreatures[node]]; -            if (!ghost_list.empty()) -            { -                Player* waitingPlayer;  // player waiting at graveyard for resurrection -                WorldSafeLocsEntry const* closestGrave = NULL; -                for (std::vector<uint64>::iterator itr = ghost_list.begin(); itr != ghost_list.end(); ++itr) -                { -                    waitingPlayer = ObjectAccessor::FindPlayer(*ghost_list.begin()); -                    if (!waitingPlayer) -                        continue; - -                    if (!closestGrave) -                        closestGrave = GetClosestGraveYard(waitingPlayer); -                    else -                        waitingPlayer->TeleportTo(GetMapId(), closestGrave->x, closestGrave->y, closestGrave->z, player->GetOrientation()); -                } -                m_ReviveQueue[BgCreatures[node]].clear(); -            } + +            RelocateDeadPlayers(BgCreatures[node]);          }          DePopulateNode(node);      } diff --git a/src/server/game/Battlegrounds/Zones/BattlegroundIC.cpp b/src/server/game/Battlegrounds/Zones/BattlegroundIC.cpp index b5b8a7ce7e2..0b32072d583 100644 --- a/src/server/game/Battlegrounds/Zones/BattlegroundIC.cpp +++ b/src/server/game/Battlegrounds/Zones/BattlegroundIC.cpp @@ -481,28 +481,6 @@ void BattlegroundIC::EndBattleground(uint32 winner)      Battleground::EndBattleground(winner);  } -void BattlegroundIC::RealocatePlayers(ICNodePointType nodeType) -{ -    // Those who are waiting to resurrect at this node are taken to the closest own node's graveyard -    std::vector<uint64> ghost_list = m_ReviveQueue[BgCreatures[BG_IC_NPC_SPIRIT_GUIDE_1+nodeType-2]]; -    if (!ghost_list.empty()) -    { -        WorldSafeLocsEntry const* ClosestGrave = NULL; -        for (std::vector<uint64>::const_iterator itr = ghost_list.begin(); itr != ghost_list.end(); ++itr) -        { -            Player* player = ObjectAccessor::FindPlayer(*itr); -            if (!player) -                continue; - -            if (!ClosestGrave)                              // cache -                ClosestGrave = GetClosestGraveYard(player); - -            if (ClosestGrave) -                player->TeleportTo(GetMapId(), ClosestGrave->x, ClosestGrave->y, ClosestGrave->z, player->GetOrientation()); -        } -    } -} -  void BattlegroundIC::EventPlayerClickedOnFlag(Player* player, GameObject* target_obj)  {      if (GetStatus() != STATUS_IN_PROGRESS) @@ -531,7 +509,7 @@ void BattlegroundIC::EventPlayerClickedOnFlag(Player* player, GameObject* target                  nodePoint[i].timer = BANNER_STATE_CHANGE_TIME; // 1 minute for last change (real faction banner)                  nodePoint[i].needChange = true; -                RealocatePlayers(nodePoint[i].nodeType); +                RelocateDeadPlayers(BgCreatures[BG_IC_NPC_SPIRIT_GUIDE_1 + nodePoint[i].nodeType - 2]);                  // if we are here means that the point has been lost, or it is the first capture diff --git a/src/server/game/Battlegrounds/Zones/BattlegroundIC.h b/src/server/game/Battlegrounds/Zones/BattlegroundIC.h index 7845c002155..f25fbe297b3 100644 --- a/src/server/game/Battlegrounds/Zones/BattlegroundIC.h +++ b/src/server/game/Battlegrounds/Zones/BattlegroundIC.h @@ -950,7 +950,6 @@ class BattlegroundIC : public Battleground              return uws;          } -        void RealocatePlayers(ICNodePointType nodeType);          void UpdateNodeWorldState(ICNodePoint* nodePoint);          void HandleCapturedNodes(ICNodePoint* nodePoint, bool recapture);          void HandleContestedNodes(ICNodePoint* nodePoint); diff --git a/src/server/game/Entities/Pet/Pet.cpp b/src/server/game/Entities/Pet/Pet.cpp index 687f1ab40b5..4fa02decdf8 100644 --- a/src/server/game/Entities/Pet/Pet.cpp +++ b/src/server/game/Entities/Pet/Pet.cpp @@ -371,7 +371,7 @@ void Pet::SavePetToDB(PetSaveMode mode)      if (!IS_PLAYER_GUID(GetOwnerGUID()))          return; -    Player* owner = (Player*)GetOwner(); +    Player* owner = GetOwner();      if (!owner)          return; @@ -1100,7 +1100,7 @@ void Pet::_LoadSpellCooldowns()          while (result->NextRow());          if (!m_CreatureSpellCooldowns.empty() && GetOwner()) -            ((Player*)GetOwner())->GetSession()->SendPacket(&data); +            GetOwner()->GetSession()->SendPacket(&data);      }  } diff --git a/src/server/game/Entities/Player/Player.cpp b/src/server/game/Entities/Player/Player.cpp index 2949cbc80df..72124cd238f 100644 --- a/src/server/game/Entities/Player/Player.cpp +++ b/src/server/game/Entities/Player/Player.cpp @@ -23326,8 +23326,8 @@ void Player::resetSpells(bool myClassOnly)                  continue;              // skip spells with first rank learned as talent (and all talents then also) -            uint32 first_rank = sSpellMgr->GetFirstSpellInChain(spellInfo->Id); -            if (GetTalentSpellCost(first_rank) > 0) +            uint32 firstRank = spellInfo->GetFirstRankSpell()->Id; +            if (GetTalentSpellCost(firstRank) > 0)                  continue;              // skip broken spells @@ -23397,15 +23397,14 @@ void Player::learnQuestRewardedSpells(Quest const* quest)      uint32 learned_0 = spellInfo->Effects[0].TriggerSpell;      if (sSpellMgr->GetSpellRank(learned_0) > 1 && !HasSpell(learned_0))      { -        // not have first rank learned (unlearned prof?) -        uint32 first_spell = sSpellMgr->GetFirstSpellInChain(learned_0); -        if (!HasSpell(first_spell)) -            return; -          SpellInfo const* learnedInfo = sSpellMgr->GetSpellInfo(learned_0);          if (!learnedInfo)              return; +        // not have first rank learned (unlearned prof?) +        if (!HasSpell(learnedInfo->GetFirstRankSpell()->Id)) +            return; +          SpellsRequiringSpellMapBounds spellsRequired = sSpellMgr->GetSpellsRequiredForSpellBounds(learned_0);          for (SpellsRequiringSpellMap::const_iterator itr2 = spellsRequired.first; itr2 != spellsRequired.second; ++itr2)          { diff --git a/src/server/game/Entities/Unit/Unit.cpp b/src/server/game/Entities/Unit/Unit.cpp index f724f67a990..130da917276 100644 --- a/src/server/game/Entities/Unit/Unit.cpp +++ b/src/server/game/Entities/Unit/Unit.cpp @@ -7836,16 +7836,17 @@ Player* Unit::GetCharmerOrOwnerPlayerOrPlayerItself() const      if (IS_PLAYER_GUID(guid))          return ObjectAccessor::GetPlayer(*this, guid); -    return GetTypeId() == TYPEID_PLAYER ? (Player*)this : NULL; +    return const_cast<Unit*>(this)->ToPlayer();  }  Player* Unit::GetAffectingPlayer() const  {      if (!GetCharmerOrOwnerGUID()) -        return GetTypeId() == TYPEID_PLAYER ? (Player*)this : NULL; +        return const_cast<Unit*>(this)->ToPlayer();      if (Unit* owner = GetCharmerOrOwner())          return owner->GetCharmerOrOwnerPlayerOrPlayerItself(); +      return NULL;  } @@ -12711,13 +12712,14 @@ uint64 Unit::GetCharmerOrOwnerOrOwnGUID() const  Player* Unit::GetSpellModOwner() const  { -    if (GetTypeId() == TYPEID_PLAYER) -        return (Player*)this; +    if (Player* player = const_cast<Unit*>(this)->ToPlayer()) +        return player; +      if (ToCreature()->IsPet() || ToCreature()->IsTotem())      { -        Unit* owner = GetOwner(); -        if (owner && owner->GetTypeId() == TYPEID_PLAYER) -            return (Player*)owner; +        if (Unit* owner = GetOwner()) +            if (Player* player = owner->ToPlayer()) +                return player;      }      return NULL;  } @@ -13233,7 +13235,7 @@ Pet* Unit::CreateTamedPetFrom(Creature* creatureTarget, uint32 spell_id)      if (GetTypeId() != TYPEID_PLAYER)          return NULL; -    Pet* pet = new Pet((Player*)this, HUNTER_PET); +    Pet* pet = new Pet(ToPlayer(), HUNTER_PET);      if (!pet->CreateBaseAtCreature(creatureTarget))      { @@ -13257,7 +13259,7 @@ Pet* Unit::CreateTamedPetFrom(uint32 creatureEntry, uint32 spell_id)      if (!creatureInfo)          return NULL; -    Pet* pet = new Pet((Player*)this, HUNTER_PET); +    Pet* pet = new Pet(ToPlayer(), HUNTER_PET);      if (!pet->CreateBaseAtCreatureInfo(creatureInfo, this) || !InitTamedPet(pet, getLevel(), spell_id))      { @@ -13750,8 +13752,8 @@ void Unit::Kill(Unit* victim, bool durabilityLoss)      {          if (Battleground* bg = player->GetBattleground())          { -            if (victim->GetTypeId() == TYPEID_PLAYER) -                bg->HandleKillPlayer((Player*)victim, player); +            if (Player* playerVictim = victim->ToPlayer()) +                bg->HandleKillPlayer(playerVictim, player);              else                  bg->HandleKillUnit(victim->ToCreature(), player);          } @@ -14673,14 +14675,15 @@ void Unit::SendMoveKnockBack(Player* player, float speedXY, float speedZ, float  void Unit::KnockbackFrom(float x, float y, float speedXY, float speedZ)  { -    Player* player = NULL; -    if (GetTypeId() == TYPEID_PLAYER) -        player = ToPlayer(); -    else if (Unit* charmer = GetCharmer()) +    Player* player = ToPlayer(); +    if (!player)      { -        player = charmer->ToPlayer(); -        if (player && player->m_mover != this) -            player = NULL; +        if (Unit* charmer = GetCharmer()) +        { +            player = charmer->ToPlayer(); +            if (player && player->m_mover != this) +                player = NULL; +        }      }      if (!player) diff --git a/src/server/game/Globals/ObjectMgr.cpp b/src/server/game/Globals/ObjectMgr.cpp index 75d0a8e7bb0..30a14a80898 100644 --- a/src/server/game/Globals/ObjectMgr.cpp +++ b/src/server/game/Globals/ObjectMgr.cpp @@ -4853,7 +4853,7 @@ void ObjectMgr::LoadSpellScriptNames()              while (spellInfo)              {                  _spellScriptsStore.insert(SpellScriptsContainer::value_type(spellInfo->Id, GetScriptId(scriptName))); -                spellInfo = sSpellMgr->GetSpellInfo(spellInfo->Id)->GetNextRankSpell(); +                spellInfo = spellInfo->GetNextRankSpell();              }          }          else diff --git a/src/server/game/Grids/Notifiers/GridNotifiers.cpp b/src/server/game/Grids/Notifiers/GridNotifiers.cpp index 363d6927cc1..570819afca1 100644 --- a/src/server/game/Grids/Notifiers/GridNotifiers.cpp +++ b/src/server/game/Grids/Notifiers/GridNotifiers.cpp @@ -106,10 +106,10 @@ void VisibleChangesNotifier::Visit(CreatureMapType &m)  void VisibleChangesNotifier::Visit(DynamicObjectMapType &m)  {      for (DynamicObjectMapType::iterator iter = m.begin(); iter != m.end(); ++iter) -        if (IS_PLAYER_GUID(iter->GetSource()->GetCasterGUID())) -            if (Player* caster = (Player*)iter->GetSource()->GetCaster()) -                if (caster->m_seer == iter->GetSource()) -                    caster->UpdateVisibilityOf(&i_object); +        if (Unit* caster = iter->GetSource()->GetCaster()) +            if (Player* player = caster->ToPlayer()) +                if (player->m_seer == iter->GetSource()) +                    player->UpdateVisibilityOf(&i_object);  }  inline void CreatureUnitRelocationWorker(Creature* c, Unit* u) @@ -299,12 +299,12 @@ void MessageDistDeliverer::Visit(DynamicObjectMapType &m)          if (target->GetExactDist2dSq(i_source) > i_distSq)              continue; -        if (IS_PLAYER_GUID(target->GetCasterGUID())) +        if (Unit* caster = target->GetCaster())          {              // Send packet back to the caster if the caster has vision of dynamic object -            Player* caster = (Player*)target->GetCaster(); -            if (caster && caster->m_seer == target) -                SendPacket(caster); +            Player* player = caster->ToPlayer(); +            if (player && player->m_seer == target) +                SendPacket(player);          }      }  } diff --git a/src/server/game/Grids/Notifiers/GridNotifiers.h b/src/server/game/Grids/Notifiers/GridNotifiers.h index 6984321e55b..209d2527e0d 100644 --- a/src/server/game/Grids/Notifiers/GridNotifiers.h +++ b/src/server/game/Grids/Notifiers/GridNotifiers.h @@ -132,10 +132,14 @@ namespace Trinity          Player const* skipped_receiver;          MessageDistDeliverer(WorldObject* src, WorldPacket* msg, float dist, bool own_team_only = false, Player const* skipped = NULL)              : i_source(src), i_message(msg), i_phaseMask(src->GetPhaseMask()), i_distSq(dist * dist) -            , team((own_team_only && src->GetTypeId() == TYPEID_PLAYER) ? ((Player*)src)->GetTeam() : 0) +            , team(0)              , skipped_receiver(skipped)          { +            if (own_team_only) +                if (Player* player = src->ToPlayer()) +                    team = player->GetTeam();          } +          void Visit(PlayerMapType &m);          void Visit(CreatureMapType &m);          void Visit(DynamicObjectMapType &m); diff --git a/src/server/game/Handlers/PetHandler.cpp b/src/server/game/Handlers/PetHandler.cpp index 3106b66c212..a608eb500c7 100644 --- a/src/server/game/Handlers/PetHandler.cpp +++ b/src/server/game/Handlers/PetHandler.cpp @@ -346,19 +346,19 @@ void WorldSession::HandlePetActionHelper(Unit* pet, uint64 guid1, uint32 spellid                  if (unit_target)                  {                      pet->SetInFront(unit_target); -                    if (unit_target->GetTypeId() == TYPEID_PLAYER) -                        pet->SendUpdateToPlayer((Player*)unit_target); +                    if (Player* player = unit_target->ToPlayer()) +                        pet->SendUpdateToPlayer(player);                  }                  else if (Unit* unit_target2 = spell->m_targets.GetUnitTarget())                  {                      pet->SetInFront(unit_target2); -                    if (unit_target2->GetTypeId() == TYPEID_PLAYER) -                        pet->SendUpdateToPlayer((Player*)unit_target2); +                    if (Player* player = unit_target2->ToPlayer()) +                        pet->SendUpdateToPlayer(player);                  }                  if (Unit* powner = pet->GetCharmerOrOwner()) -                    if (powner->GetTypeId() == TYPEID_PLAYER) -                        pet->SendUpdateToPlayer(powner->ToPlayer()); +                    if (Player* player = powner->ToPlayer()) +                        pet->SendUpdateToPlayer(player);                  result = SPELL_CAST_OK;              } @@ -637,9 +637,9 @@ void WorldSession::HandlePetRename(WorldPacket& recvData)      pet->SetName(name); -    Unit* owner = pet->GetOwner(); -    if (owner && (owner->GetTypeId() == TYPEID_PLAYER) && owner->ToPlayer()->GetGroup()) -        owner->ToPlayer()->SetGroupUpdateFlag(GROUP_UPDATE_FLAG_PET_NAME); +    Player* owner = pet->GetOwner(); +    if (owner && owner->GetGroup()) +        owner->SetGroupUpdateFlag(GROUP_UPDATE_FLAG_PET_NAME);      pet->RemoveByteFlag(UNIT_FIELD_BYTES_2, 2, UNIT_CAN_BE_RENAMED); diff --git a/src/server/game/Spells/Auras/SpellAuraEffects.cpp b/src/server/game/Spells/Auras/SpellAuraEffects.cpp index f3bc8119d05..d0768ee46ce 100644 --- a/src/server/game/Spells/Auras/SpellAuraEffects.cpp +++ b/src/server/game/Spells/Auras/SpellAuraEffects.cpp @@ -5009,20 +5009,19 @@ void AuraEffect::HandleForceReaction(AuraApplication const* aurApp, uint8 mode,      Unit* target = aurApp->GetTarget(); -    if (target->GetTypeId() != TYPEID_PLAYER) +    Player* player = target->ToPlayer(); +    if (!player)          return; -    Player* player = (Player*)target; - -    uint32 faction_id = GetMiscValue(); -    ReputationRank faction_rank = ReputationRank(m_amount); +    uint32 factionId = GetMiscValue(); +    ReputationRank factionRank = ReputationRank(m_amount); -    player->GetReputationMgr().ApplyForceReaction(faction_id, faction_rank, apply); +    player->GetReputationMgr().ApplyForceReaction(factionId, factionRank, apply);      player->GetReputationMgr().SendForceReactions();      // stop fighting if at apply forced rank friendly or at remove real rank friendly -    if ((apply && faction_rank >= REP_FRIENDLY) || (!apply && player->GetReputationRank(faction_id) >= REP_FRIENDLY)) -        player->StopAttackFaction(faction_id); +    if ((apply && factionRank >= REP_FRIENDLY) || (!apply && player->GetReputationRank(factionId) >= REP_FRIENDLY)) +        player->StopAttackFaction(factionId);  }  void AuraEffect::HandleAuraEmpathy(AuraApplication const* aurApp, uint8 mode, bool apply) const @@ -5088,11 +5087,10 @@ void AuraEffect::HandleAuraConvertRune(AuraApplication const* aurApp, uint8 mode      Unit* target = aurApp->GetTarget(); -    if (target->GetTypeId() != TYPEID_PLAYER) +    Player* player = target->ToPlayer(); +    if (!player)          return; -    Player* player = (Player*)target; -      if (player->getClass() != CLASS_DEATH_KNIGHT)          return; diff --git a/src/server/game/Spells/Auras/SpellAuras.cpp b/src/server/game/Spells/Auras/SpellAuras.cpp index 2ffa96449a5..23f84169419 100644 --- a/src/server/game/Spells/Auras/SpellAuras.cpp +++ b/src/server/game/Spells/Auras/SpellAuras.cpp @@ -1100,7 +1100,7 @@ void Aura::HandleAuraSpecificMods(AuraApplication const* aurApp, Unit* caster, b          for (SpellAreaForAreaMap::const_iterator itr = saBounds.first; itr != saBounds.second; ++itr)          {              // some auras remove at aura remove -            if (!itr->second->IsFitToRequirements((Player*)target, zone, area)) +            if (!itr->second->IsFitToRequirements(target->ToPlayer(), zone, area))                  target->RemoveAurasDueToSpell(itr->second->spellId);              // some auras applied at aura apply              else if (itr->second->autocast) diff --git a/src/server/game/Spells/Spell.cpp b/src/server/game/Spells/Spell.cpp index 0be1c5df308..01de77ba366 100644 --- a/src/server/game/Spells/Spell.cpp +++ b/src/server/game/Spells/Spell.cpp @@ -2142,7 +2142,7 @@ void Spell::AddUnitTarget(Unit* target, uint32 effectMask, bool checkIfValid /*=              ihit->scaleAura = false;              if (m_auraScaleMask && ihit->effectMask == m_auraScaleMask && m_caster != target)              { -                SpellInfo const* auraSpell = sSpellMgr->GetSpellInfo(sSpellMgr->GetFirstSpellInChain(m_spellInfo->Id)); +                SpellInfo const* auraSpell = m_spellInfo->GetFirstRankSpell();                  if (uint32(target->getLevel() + 10) >= auraSpell->SpellLevel)                      ihit->scaleAura = true;              } @@ -2163,7 +2163,7 @@ void Spell::AddUnitTarget(Unit* target, uint32 effectMask, bool checkIfValid /*=      targetInfo.scaleAura  = false;      if (m_auraScaleMask && targetInfo.effectMask == m_auraScaleMask && m_caster != target)      { -        SpellInfo const* auraSpell = sSpellMgr->GetSpellInfo(sSpellMgr->GetFirstSpellInChain(m_spellInfo->Id)); +        SpellInfo const* auraSpell = m_spellInfo->GetFirstRankSpell();          if (uint32(target->getLevel() + 10) >= auraSpell->SpellLevel)              targetInfo.scaleAura = true;      } @@ -3548,11 +3548,10 @@ void Spell::_handle_finish_phase()  void Spell::SendSpellCooldown()  { -    if (m_caster->GetTypeId() != TYPEID_PLAYER) +    Player* _player = m_caster->ToPlayer(); +    if (!_player)          return; -    Player* _player = (Player*)m_caster; -      // mana/health/etc potions, disabled by client (until combat out as declarate)      if (m_CastItem && m_CastItem->IsPotion())      { @@ -4386,7 +4385,11 @@ void Spell::SendResurrectRequest(Player* target)  void Spell::TakeCastItem()  { -    if (!m_CastItem || m_caster->GetTypeId() != TYPEID_PLAYER) +    if (!m_CastItem) +        return; + +    Player* player = m_caster->ToPlayer(); +    if (!player)          return;      // not remove cast item at triggered spell (equipping, weapon damage, etc) @@ -4424,7 +4427,7 @@ void Spell::TakeCastItem()                      (charges > 0) ? --charges : ++charges;  // abs(charges) less at 1 after use                      if (proto->Stackable == 1)                          m_CastItem->SetSpellCharges(i, charges); -                    m_CastItem->SetState(ITEM_CHANGED, (Player*)m_caster); +                    m_CastItem->SetState(ITEM_CHANGED, player);                  }                  // all charges used @@ -4538,16 +4541,14 @@ SpellCastResult Spell::CheckRuneCost(uint32 runeCostID)      if (m_spellInfo->PowerType != POWER_RUNES || !runeCostID)          return SPELL_CAST_OK; -    if (m_caster->GetTypeId() != TYPEID_PLAYER) +    Player* player = m_caster->ToPlayer(); +    if (!player)          return SPELL_CAST_OK; -    Player* player = (Player*)m_caster; -      if (player->getClass() != CLASS_DEATH_KNIGHT)          return SPELL_CAST_OK;      SpellRuneCostEntry const* src = sSpellRuneCostStore.LookupEntry(runeCostID); -      if (!src)          return SPELL_CAST_OK; @@ -5975,11 +5976,10 @@ SpellCastResult Spell::CheckPower()  SpellCastResult Spell::CheckItems()  { -    if (m_caster->GetTypeId() != TYPEID_PLAYER) +    Player* player = m_caster->ToPlayer(); +    if (!player)          return SPELL_CAST_OK; -    Player* p_caster = (Player*)m_caster; -      if (!m_CastItem)      {          if (m_castItemGUID) @@ -5988,14 +5988,14 @@ SpellCastResult Spell::CheckItems()      else      {          uint32 itemid = m_CastItem->GetEntry(); -        if (!p_caster->HasItemCount(itemid)) +        if (!player->HasItemCount(itemid))              return SPELL_FAILED_ITEM_NOT_READY;          ItemTemplate const* proto = m_CastItem->GetTemplate();          if (!proto)              return SPELL_FAILED_ITEM_NOT_READY; -        for (int i = 0; i < MAX_ITEM_SPELLS; ++i) +        for (uint8 i = 0; i < MAX_ITEM_SPELLS; ++i)              if (proto->Spells[i].SpellCharges)                  if (m_CastItem->GetSpellCharges(i) == 0)                      return SPELL_FAILED_NO_CHARGES_REMAIN; @@ -6005,10 +6005,10 @@ SpellCastResult Spell::CheckItems()          {              // such items should only fail if there is no suitable effect at all - see Rejuvenation Potions for example              SpellCastResult failReason = SPELL_CAST_OK; -            for (int i = 0; i < MAX_SPELL_EFFECTS; i++) +            for (uint8 i = 0; i < MAX_SPELL_EFFECTS; ++i)              { -                    // skip check, pet not required like checks, and for TARGET_UNIT_PET m_targets.GetUnitTarget() is not the real target but the caster -                    if (m_spellInfo->Effects[i].TargetA.GetTarget() == TARGET_UNIT_PET) +                // skip check, pet not required like checks, and for TARGET_UNIT_PET m_targets.GetUnitTarget() is not the real target but the caster +                if (m_spellInfo->Effects[i].TargetA.GetTarget() == TARGET_UNIT_PET)                      continue;                  if (m_spellInfo->Effects[i].Effect == SPELL_EFFECT_HEAL) @@ -6055,9 +6055,6 @@ SpellCastResult Spell::CheckItems()      // check target item      if (m_targets.GetItemTargetGUID())      { -        if (m_caster->GetTypeId() != TYPEID_PLAYER) -            return SPELL_FAILED_BAD_TARGETS; -          if (!m_targets.GetItemTarget())              return SPELL_FAILED_ITEM_GONE; @@ -6068,7 +6065,7 @@ SpellCastResult Spell::CheckItems()      else      {          if (!(_triggeredCastFlags & TRIGGERED_IGNORE_EQUIPPED_ITEM_REQUIREMENT)) -            if (m_caster->GetTypeId() == TYPEID_PLAYER && !m_caster->ToPlayer()->HasItemFitToSpellRequirements(m_spellInfo)) +            if (!player->HasItemFitToSpellRequirements(m_spellInfo))                  return SPELL_FAILED_EQUIPPED_ITEM_CLASS;      } @@ -6095,7 +6092,7 @@ SpellCastResult Spell::CheckItems()      // do not take reagents for these item casts      if (!(m_CastItem && m_CastItem->GetTemplate()->Flags & ITEM_PROTO_FLAG_TRIGGERED_CAST))      { -        bool checkReagents = !(_triggeredCastFlags & TRIGGERED_IGNORE_POWER_AND_REAGENT_COST) && !p_caster->CanNoReagentCast(m_spellInfo); +        bool checkReagents = !(_triggeredCastFlags & TRIGGERED_IGNORE_POWER_AND_REAGENT_COST) && !player->CanNoReagentCast(m_spellInfo);          // Not own traded item (in trader trade slot) requires reagents even if triggered spell          if (!checkReagents)              if (Item* targetItem = m_targets.GetItemTarget()) @@ -6119,7 +6116,7 @@ SpellCastResult Spell::CheckItems()                      ItemTemplate const* proto = m_CastItem->GetTemplate();                      if (!proto)                          return SPELL_FAILED_ITEM_NOT_READY; -                    for (int s=0; s < MAX_ITEM_PROTO_SPELLS; ++s) +                    for (uint8 s = 0; s < MAX_ITEM_PROTO_SPELLS; ++s)                      {                          // CastItem will be used up and does not count as reagent                          int32 charges = m_CastItem->GetSpellCharges(s); @@ -6130,31 +6127,32 @@ SpellCastResult Spell::CheckItems()                          }                      }                  } -                if (!p_caster->HasItemCount(itemid, itemcount)) +                if (!player->HasItemCount(itemid, itemcount))                      return SPELL_FAILED_REAGENTS;              }          }          // check totem-item requirements (items presence in inventory)          uint32 totems = 2; -        for (int i = 0; i < 2; ++i) +        for (uint8 i = 0; i < 2; ++i)          {              if (m_spellInfo->Totem[i] != 0)              { -                if (p_caster->HasItemCount(m_spellInfo->Totem[i])) +                if (player->HasItemCount(m_spellInfo->Totem[i]))                  {                      totems -= 1;                      continue;                  } -            }else -            totems -= 1; +            } +            else +                totems -= 1;          }          if (totems != 0)              return SPELL_FAILED_TOTEMS;      }      // special checks for spell effects -    for (int i = 0; i < MAX_SPELL_EFFECTS; i++) +    for (uint8 i = 0; i < MAX_SPELL_EFFECTS; ++i)      {          switch (m_spellInfo->Effects[i].Effect)          { @@ -6164,24 +6162,24 @@ SpellCastResult Spell::CheckItems()                  if (!IsTriggered() && m_spellInfo->Effects[i].ItemType)                  {                      ItemPosCountVec dest; -                    InventoryResult msg = p_caster->CanStoreNewItem(NULL_BAG, NULL_SLOT, dest, m_spellInfo->Effects[i].ItemType, 1); +                    InventoryResult msg = player->CanStoreNewItem(NULL_BAG, NULL_SLOT, dest, m_spellInfo->Effects[i].ItemType, 1);                      if (msg != EQUIP_ERR_OK)                      {                          ItemTemplate const* pProto = sObjectMgr->GetItemTemplate(m_spellInfo->Effects[i].ItemType);                          /// @todo Needs review                          if (pProto && !(pProto->ItemLimitCategory))                          { -                            p_caster->SendEquipError(msg, NULL, NULL, m_spellInfo->Effects[i].ItemType); +                            player->SendEquipError(msg, NULL, NULL, m_spellInfo->Effects[i].ItemType);                              return SPELL_FAILED_DONT_REPORT;                          }                          else                          {                              if (!(m_spellInfo->SpellFamilyName == SPELLFAMILY_MAGE && (m_spellInfo->SpellFamilyFlags[0] & 0x40000000)))                                  return SPELL_FAILED_TOO_MANY_OF_ITEM; -                            else if (!(p_caster->HasItemCount(m_spellInfo->Effects[i].ItemType))) +                            else if (!(player->HasItemCount(m_spellInfo->Effects[i].ItemType)))                                  return SPELL_FAILED_TOO_MANY_OF_ITEM;                              else -                                p_caster->CastSpell(m_caster, m_spellInfo->Effects[EFFECT_1].CalcValue(), false);        // move this to anywhere +                                player->CastSpell(m_caster, m_spellInfo->Effects[EFFECT_1].CalcValue(), false);        // move this to anywhere                              return SPELL_FAILED_DONT_REPORT;                          }                      } @@ -6199,10 +6197,10 @@ SpellCastResult Spell::CheckItems()                      if (m_CastItem && m_CastItem->GetTemplate()->Flags & ITEM_PROTO_FLAG_TRIGGERED_CAST)                          return SPELL_FAILED_TOTEM_CATEGORY;                      ItemPosCountVec dest; -                    InventoryResult msg = p_caster->CanStoreNewItem(NULL_BAG, NULL_SLOT, dest, m_spellInfo->Effects[i].ItemType, 1); +                    InventoryResult msg = player->CanStoreNewItem(NULL_BAG, NULL_SLOT, dest, m_spellInfo->Effects[i].ItemType, 1);                      if (msg != EQUIP_ERR_OK)                      { -                        p_caster->SendEquipError(msg, NULL, NULL, m_spellInfo->Effects[i].ItemType); +                        player->SendEquipError(msg, NULL, NULL, m_spellInfo->Effects[i].ItemType);                          return SPELL_FAILED_DONT_REPORT;                      }                  } @@ -6283,7 +6281,7 @@ SpellCastResult Spell::CheckItems()                  uint32 item_disenchantskilllevel = itemProto->RequiredDisenchantSkill;                  if (item_disenchantskilllevel == uint32(-1))                      return SPELL_FAILED_CANT_BE_DISENCHANTED; -                if (item_disenchantskilllevel > p_caster->GetSkillValue(SKILL_ENCHANTING)) +                if (item_disenchantskilllevel > player->GetSkillValue(SKILL_ENCHANTING))                      return SPELL_FAILED_LOW_CASTLEVEL;                  if (item_quality > 4 || item_quality < 2)                      return SPELL_FAILED_CANT_BE_DISENCHANTED; @@ -6305,7 +6303,7 @@ SpellCastResult Spell::CheckItems()                      return SPELL_FAILED_CANT_BE_PROSPECTED;                  //Check for enough skill in jewelcrafting                  uint32 item_prospectingskilllevel = m_targets.GetItemTarget()->GetTemplate()->RequiredSkillRank; -                if (item_prospectingskilllevel >p_caster->GetSkillValue(SKILL_JEWELCRAFTING)) +                if (item_prospectingskilllevel >player->GetSkillValue(SKILL_JEWELCRAFTING))                      return SPELL_FAILED_LOW_CASTLEVEL;                  //make sure the player has the required ores in inventory                  if (m_targets.GetItemTarget()->GetCount() < 5) @@ -6328,7 +6326,7 @@ SpellCastResult Spell::CheckItems()                      return SPELL_FAILED_CANT_BE_MILLED;                  //Check for enough skill in inscription                  uint32 item_millingskilllevel = m_targets.GetItemTarget()->GetTemplate()->RequiredSkillRank; -                if (item_millingskilllevel >p_caster->GetSkillValue(SKILL_INSCRIPTION)) +                if (item_millingskilllevel > player->GetSkillValue(SKILL_INSCRIPTION))                      return SPELL_FAILED_LOW_CASTLEVEL;                  //make sure the player has the required herbs in inventory                  if (m_targets.GetItemTarget()->GetCount() < 5) @@ -6342,13 +6340,10 @@ SpellCastResult Spell::CheckItems()              case SPELL_EFFECT_WEAPON_DAMAGE:              case SPELL_EFFECT_WEAPON_DAMAGE_NOSCHOOL:              { -                if (m_caster->GetTypeId() != TYPEID_PLAYER) -                    return SPELL_FAILED_TARGET_NOT_PLAYER; -                  if (m_attackType != RANGED_ATTACK)                      break; -                Item* pItem = m_caster->ToPlayer()->GetWeaponForAttack(m_attackType); +                Item* pItem = player->GetWeaponForAttack(m_attackType);                  if (!pItem || pItem->IsBroken())                      return SPELL_FAILED_EQUIPPED_ITEM; @@ -6357,10 +6352,10 @@ SpellCastResult Spell::CheckItems()                      case ITEM_SUBCLASS_WEAPON_THROWN:                      {                          uint32 ammo = pItem->GetEntry(); -                        if (!m_caster->ToPlayer()->HasItemCount(ammo)) +                        if (!player->HasItemCount(ammo))                              return SPELL_FAILED_NO_AMMO; -                    }; -                    break; +                        break; +                    }                      case ITEM_SUBCLASS_WEAPON_GUN:                      case ITEM_SUBCLASS_WEAPON_BOW:                      case ITEM_SUBCLASS_WEAPON_CROSSBOW: @@ -6379,7 +6374,7 @@ SpellCastResult Spell::CheckItems()                   if (!pProto)                       return SPELL_FAILED_ITEM_AT_MAX_CHARGES; -                 if (Item* pitem = p_caster->GetItemByEntry(item_id)) +                 if (Item* pitem = player->GetItemByEntry(item_id))                   {                       for (int x = 0; x < MAX_ITEM_PROTO_SPELLS; ++x)                           if (pProto->Spells[x].SpellCharges != 0 && pitem->GetSpellCharges(x) == pProto->Spells[x].SpellCharges) diff --git a/src/server/game/Spells/SpellEffects.cpp b/src/server/game/Spells/SpellEffects.cpp index c5bf99c2f43..b8e0c872f8e 100644 --- a/src/server/game/Spells/SpellEffects.cpp +++ b/src/server/game/Spells/SpellEffects.cpp @@ -505,9 +505,9 @@ void Spell::EffectSchoolDMG(SpellEffIndex effIndex)                  // Eviscerate                  else if (m_spellInfo->SpellFamilyFlags[0] & 0x00020000)                  { -                    if (m_caster->GetTypeId() == TYPEID_PLAYER) +                    if (Player* player = m_caster->ToPlayer())                      { -                        if (uint32 combo = ((Player*)m_caster)->GetComboPoints()) +                        if (uint32 combo = player->GetComboPoints())                          {                              float ap = m_caster->GetTotalAttackPowerValue(BASE_ATTACK);                              damage += irand(int32(ap * combo * 0.03f), int32(ap * combo * 0.07f)); @@ -2553,30 +2553,30 @@ void Spell::EffectEnchantItemPerm(SpellEffIndex effIndex)      if (effectHandleMode != SPELL_EFFECT_HANDLE_HIT_TARGET)          return; -    if (m_caster->GetTypeId() != TYPEID_PLAYER) -        return;      if (!itemTarget)          return; -    Player* p_caster = (Player*)m_caster; +    Player* player = m_caster->ToPlayer(); +    if (!player) +        return;      // Handle vellums      if (itemTarget->IsVellum())      {          // destroy one vellum from stack          uint32 count = 1; -        p_caster->DestroyItemCount(itemTarget, count, true); -        unitTarget=p_caster; +        player->DestroyItemCount(itemTarget, count, true); +        unitTarget = player;          // and add a scroll          DoCreateItem(effIndex, m_spellInfo->Effects[effIndex].ItemType); -        itemTarget=NULL; +        itemTarget = NULL;          m_targets.SetItemTarget(NULL);      }      else      {          // do not increase skill if vellum used          if (!(m_CastItem && m_CastItem->GetTemplate()->Flags & ITEM_PROTO_FLAG_TRIGGERED_CAST)) -            p_caster->UpdateCraftSkill(m_spellInfo->Id); +            player->UpdateCraftSkill(m_spellInfo->Id);          uint32 enchant_id = m_spellInfo->Effects[effIndex].MiscValue;          if (!enchant_id) @@ -2591,10 +2591,10 @@ void Spell::EffectEnchantItemPerm(SpellEffIndex effIndex)          if (!item_owner)              return; -        if (item_owner != p_caster && p_caster->GetSession()->HasPermission(RBAC_PERM_LOG_GM_TRADE)) +        if (item_owner != player && player->GetSession()->HasPermission(RBAC_PERM_LOG_GM_TRADE))          { -            sLog->outCommand(p_caster->GetSession()->GetAccountId(), "GM %s (Account: %u) enchanting(perm): %s (Entry: %d) for player: %s (Account: %u)", -                p_caster->GetName().c_str(), p_caster->GetSession()->GetAccountId(), +            sLog->outCommand(player->GetSession()->GetAccountId(), "GM %s (Account: %u) enchanting(perm): %s (Entry: %d) for player: %s (Account: %u)", +                player->GetName().c_str(), player->GetSession()->GetAccountId(),                  itemTarget->GetTemplate()->Name1.c_str(), itemTarget->GetEntry(),                  item_owner->GetName().c_str(), item_owner->GetSession()->GetAccountId());          } @@ -2617,19 +2617,19 @@ void Spell::EffectEnchantItemPrismatic(SpellEffIndex effIndex)      if (effectHandleMode != SPELL_EFFECT_HANDLE_HIT_TARGET)          return; -    if (m_caster->GetTypeId() != TYPEID_PLAYER) -        return;      if (!itemTarget)          return; -    Player* p_caster = (Player*)m_caster; +    Player* player = m_caster->ToPlayer(); +    if (!player) +        return; -    uint32 enchant_id = m_spellInfo->Effects[effIndex].MiscValue; -    if (!enchant_id) +    uint32 enchantId = m_spellInfo->Effects[effIndex].MiscValue; +    if (!enchantId)          return; -    SpellItemEnchantmentEntry const* pEnchant = sSpellItemEnchantmentStore.LookupEntry(enchant_id); -    if (!pEnchant) +    SpellItemEnchantmentEntry const* enchant = sSpellItemEnchantmentStore.LookupEntry(enchantId); +    if (!enchant)          return;      // support only enchantings with add socket in this slot @@ -2637,7 +2637,7 @@ void Spell::EffectEnchantItemPrismatic(SpellEffIndex effIndex)          bool add_socket = false;          for (uint8 i = 0; i < MAX_ITEM_ENCHANTMENT_EFFECTS; ++i)          { -            if (pEnchant->type[i] == ITEM_ENCHANTMENT_TYPE_PRISMATIC_SOCKET) +            if (enchant->type[i] == ITEM_ENCHANTMENT_TYPE_PRISMATIC_SOCKET)              {                  add_socket = true;                  break; @@ -2656,10 +2656,10 @@ void Spell::EffectEnchantItemPrismatic(SpellEffIndex effIndex)      if (!item_owner)          return; -    if (item_owner != p_caster && p_caster->GetSession()->HasPermission(RBAC_PERM_LOG_GM_TRADE)) +    if (item_owner != player && player->GetSession()->HasPermission(RBAC_PERM_LOG_GM_TRADE))      { -        sLog->outCommand(p_caster->GetSession()->GetAccountId(), "GM %s (Account: %u) enchanting(perm): %s (Entry: %d) for player: %s (Account: %u)", -            p_caster->GetName().c_str(), p_caster->GetSession()->GetAccountId(), +        sLog->outCommand(player->GetSession()->GetAccountId(), "GM %s (Account: %u) enchanting(perm): %s (Entry: %d) for player: %s (Account: %u)", +            player->GetName().c_str(), player->GetSession()->GetAccountId(),              itemTarget->GetTemplate()->Name1.c_str(), itemTarget->GetEntry(),              item_owner->GetName().c_str(), item_owner->GetSession()->GetAccountId());      } @@ -2667,7 +2667,7 @@ void Spell::EffectEnchantItemPrismatic(SpellEffIndex effIndex)      // remove old enchanting before applying new if equipped      item_owner->ApplyEnchantment(itemTarget, PRISMATIC_ENCHANTMENT_SLOT, false); -    itemTarget->SetEnchantment(PRISMATIC_ENCHANTMENT_SLOT, enchant_id, 0, 0, m_caster->GetGUID()); +    itemTarget->SetEnchantment(PRISMATIC_ENCHANTMENT_SLOT, enchantId, 0, 0, m_caster->GetGUID());      // add new enchanting if equipped      item_owner->ApplyEnchantment(itemTarget, PRISMATIC_ENCHANTMENT_SLOT, true); @@ -2681,11 +2681,10 @@ void Spell::EffectEnchantItemTmp(SpellEffIndex effIndex)      if (effectHandleMode != SPELL_EFFECT_HANDLE_HIT_TARGET)          return; -    if (m_caster->GetTypeId() != TYPEID_PLAYER) +    Player* player = m_caster->ToPlayer(); +    if (!player)          return; -    Player* p_caster = (Player*)m_caster; -      if (!itemTarget)          return; @@ -2738,10 +2737,10 @@ void Spell::EffectEnchantItemTmp(SpellEffIndex effIndex)      if (!item_owner)          return; -    if (item_owner != p_caster && p_caster->GetSession()->HasPermission(RBAC_PERM_LOG_GM_TRADE)) +    if (item_owner != player && player->GetSession()->HasPermission(RBAC_PERM_LOG_GM_TRADE))      { -        sLog->outCommand(p_caster->GetSession()->GetAccountId(), "GM %s (Account: %u) enchanting(temp): %s (Entry: %d) for player: %s (Account: %u)", -            p_caster->GetName().c_str(), p_caster->GetSession()->GetAccountId(), +        sLog->outCommand(player->GetSession()->GetAccountId(), "GM %s (Account: %u) enchanting(temp): %s (Entry: %d) for player: %s (Account: %u)", +            player->GetName().c_str(), player->GetSession()->GetAccountId(),              itemTarget->GetTemplate()->Name1.c_str(), itemTarget->GetEntry(),              item_owner->GetName().c_str(), item_owner->GetSession()->GetAccountId());      } @@ -4096,21 +4095,20 @@ void Spell::EffectStuck(SpellEffIndex /*effIndex*/)      if (effectHandleMode != SPELL_EFFECT_HANDLE_HIT)          return; -    if (!m_caster || m_caster->GetTypeId() != TYPEID_PLAYER) -        return; -      if (!sWorld->getBoolConfig(CONFIG_CAST_UNSTUCK))          return; -    Player* target = (Player*)m_caster; +    Player* player = m_caster->ToPlayer(); +    if (!player) +        return;      TC_LOG_DEBUG(LOG_FILTER_SPELLS_AURAS, "Spell Effect: Stuck"); -    TC_LOG_INFO(LOG_FILTER_SPELLS_AURAS, "Player %s (guid %u) used auto-unstuck future at map %u (%f, %f, %f)", target->GetName().c_str(), target->GetGUIDLow(), m_caster->GetMapId(), m_caster->GetPositionX(), target->GetPositionY(), target->GetPositionZ()); +    TC_LOG_INFO(LOG_FILTER_SPELLS_AURAS, "Player %s (guid %u) used auto-unstuck future at map %u (%f, %f, %f)", player->GetName().c_str(), player->GetGUIDLow(), player->GetMapId(), player->GetPositionX(), player->GetPositionY(), player->GetPositionZ()); -    if (target->IsInFlight()) +    if (player->IsInFlight())          return; -    target->TeleportTo(target->GetStartPosition(), TELE_TO_SPELL); +    player->TeleportTo(player->GetStartPosition(), TELE_TO_SPELL);      // homebind location is loaded always      // target->TeleportTo(target->m_homebindMapId, target->m_homebindX, target->m_homebindY, target->m_homebindZ, target->GetOrientation(), (m_caster == m_caster ? TELE_TO_SPELL : 0)); @@ -4118,7 +4116,7 @@ void Spell::EffectStuck(SpellEffIndex /*effIndex*/)      SpellInfo const* spellInfo = sSpellMgr->GetSpellInfo(8690);      if (!spellInfo)          return; -    Spell spell(target, spellInfo, TRIGGERED_FULL_MASK); +    Spell spell(player, spellInfo, TRIGGERED_FULL_MASK);      spell.SendSpellCooldown();  } @@ -4168,10 +4166,12 @@ void Spell::EffectApplyGlyph(SpellEffIndex effIndex)      if (effectHandleMode != SPELL_EFFECT_HANDLE_HIT)          return; -    if (m_caster->GetTypeId() != TYPEID_PLAYER || m_glyphIndex >= MAX_GLYPH_SLOT_INDEX) +    if (m_glyphIndex >= MAX_GLYPH_SLOT_INDEX)          return; -    Player* player = (Player*)m_caster; +    Player* player = m_caster->ToPlayer(); +    if (!player) +        return;      // glyph sockets level requirement      uint8 minLevel = 0; @@ -5111,10 +5111,10 @@ void Spell::EffectProspecting(SpellEffIndex /*effIndex*/)      if (effectHandleMode != SPELL_EFFECT_HANDLE_HIT_TARGET)          return; -    if (m_caster->GetTypeId() != TYPEID_PLAYER) +    Player* player = m_caster->ToPlayer(); +    if (!player)          return; -    Player* p_caster = (Player*)m_caster;      if (!itemTarget || !(itemTarget->GetTemplate()->Flags & ITEM_PROTO_FLAG_PROSPECTABLE))          return; @@ -5123,12 +5123,12 @@ void Spell::EffectProspecting(SpellEffIndex /*effIndex*/)      if (sWorld->getBoolConfig(CONFIG_SKILL_PROSPECTING))      { -        uint32 SkillValue = p_caster->GetPureSkillValue(SKILL_JEWELCRAFTING); +        uint32 SkillValue = player->GetPureSkillValue(SKILL_JEWELCRAFTING);          uint32 reqSkillValue = itemTarget->GetTemplate()->RequiredSkillRank; -        p_caster->UpdateGatherSkill(SKILL_JEWELCRAFTING, SkillValue, reqSkillValue); +        player->UpdateGatherSkill(SKILL_JEWELCRAFTING, SkillValue, reqSkillValue);      } -    m_caster->ToPlayer()->SendLoot(itemTarget->GetGUID(), LOOT_PROSPECTING); +    player->SendLoot(itemTarget->GetGUID(), LOOT_PROSPECTING);  }  void Spell::EffectMilling(SpellEffIndex /*effIndex*/) @@ -5136,10 +5136,10 @@ void Spell::EffectMilling(SpellEffIndex /*effIndex*/)      if (effectHandleMode != SPELL_EFFECT_HANDLE_HIT_TARGET)          return; -    if (m_caster->GetTypeId() != TYPEID_PLAYER) +    Player* player = m_caster->ToPlayer(); +    if (!player)          return; -    Player* p_caster = (Player*)m_caster;      if (!itemTarget || !(itemTarget->GetTemplate()->Flags & ITEM_PROTO_FLAG_MILLABLE))          return; @@ -5148,12 +5148,12 @@ void Spell::EffectMilling(SpellEffIndex /*effIndex*/)      if (sWorld->getBoolConfig(CONFIG_SKILL_MILLING))      { -        uint32 SkillValue = p_caster->GetPureSkillValue(SKILL_INSCRIPTION); +        uint32 SkillValue = player->GetPureSkillValue(SKILL_INSCRIPTION);          uint32 reqSkillValue = itemTarget->GetTemplate()->RequiredSkillRank; -        p_caster->UpdateGatherSkill(SKILL_INSCRIPTION, SkillValue, reqSkillValue); +        player->UpdateGatherSkill(SKILL_INSCRIPTION, SkillValue, reqSkillValue);      } -    m_caster->ToPlayer()->SendLoot(itemTarget->GetGUID(), LOOT_MILLING); +    player->SendLoot(itemTarget->GetGUID(), LOOT_MILLING);  }  void Spell::EffectSkill(SpellEffIndex /*effIndex*/) @@ -5193,10 +5193,13 @@ void Spell::EffectSkinPlayerCorpse(SpellEffIndex /*effIndex*/)          return;      TC_LOG_DEBUG(LOG_FILTER_SPELLS_AURAS, "Effect: SkinPlayerCorpse"); -    if ((m_caster->GetTypeId() != TYPEID_PLAYER) || (unitTarget->GetTypeId() != TYPEID_PLAYER) || (unitTarget->IsAlive())) + +    Player* player = m_caster->ToPlayer(); +    Player* target = unitTarget->ToPlayer(); +    if (!player || !target || target->IsAlive())          return; -    unitTarget->ToPlayer()->RemovedInsignia((Player*)m_caster); +    target->RemovedInsignia(player);  }  void Spell::EffectStealBeneficialBuff(SpellEffIndex effIndex) diff --git a/src/server/scripts/Commands/cs_debug.cpp b/src/server/scripts/Commands/cs_debug.cpp index 1846e7fbfeb..da9aa9eccb3 100644 --- a/src/server/scripts/Commands/cs_debug.cpp +++ b/src/server/scripts/Commands/cs_debug.cpp @@ -259,7 +259,7 @@ public:          if (!unit || (unit->GetTypeId() != TYPEID_PLAYER))              player = handler->GetSession()->GetPlayer();          else -            player = (Player*)unit; +            player = unit->ToPlayer();          if (!unit)              unit = player; diff --git a/src/server/scripts/Commands/cs_honor.cpp b/src/server/scripts/Commands/cs_honor.cpp index 9732e2557e9..75c7fcf71e2 100644 --- a/src/server/scripts/Commands/cs_honor.cpp +++ b/src/server/scripts/Commands/cs_honor.cpp @@ -90,8 +90,9 @@ public:          }          // check online security -        if (target->GetTypeId() == TYPEID_PLAYER && handler->HasLowerSecurity((Player*)target, 0)) -            return false; +        if (Player* player = target->ToPlayer()) +            if (handler->HasLowerSecurity(player, 0)) +                return false;          handler->GetSession()->GetPlayer()->RewardHonor(target, 1);          return true; diff --git a/src/server/scripts/Commands/cs_misc.cpp b/src/server/scripts/Commands/cs_misc.cpp index 5da7c8bf01e..e0047a2592f 100644 --- a/src/server/scripts/Commands/cs_misc.cpp +++ b/src/server/scripts/Commands/cs_misc.cpp @@ -654,11 +654,9 @@ public:              return false;          } -        if (target->GetTypeId() == TYPEID_PLAYER) -        { -            if (handler->HasLowerSecurity((Player*)target, 0, false)) +        if (Player* player = target->ToPlayer()) +            if (handler->HasLowerSecurity(player, 0, false))                  return false; -        }          if (target->IsAlive())          { @@ -2226,11 +2224,9 @@ public:              return false;          } -        if (target->GetTypeId() == TYPEID_PLAYER) -        { -            if (handler->HasLowerSecurity((Player*)target, 0, false)) +        if (Player* player = target->ToPlayer()) +            if (handler->HasLowerSecurity(player, 0, false))                  return false; -        }          if (!target->IsAlive())              return true; diff --git a/src/server/scripts/Spells/spell_dk.cpp b/src/server/scripts/Spells/spell_dk.cpp index a6018474898..45a8199609e 100644 --- a/src/server/scripts/Spells/spell_dk.cpp +++ b/src/server/scripts/Spells/spell_dk.cpp @@ -1025,11 +1025,15 @@ class spell_dk_will_of_the_necropolis : public SpellScriptLoader              bool Validate(SpellInfo const* spellInfo) OVERRIDE              { +                SpellInfo const* firstRankSpellInfo = sSpellMgr->GetSpellInfo(SPELL_DK_WILL_OF_THE_NECROPOLIS_AURA_R1); +                if (!firstRankSpellInfo) +                    return false; +                  // can't use other spell than will of the necropolis due to spell_ranks dependency -                if (sSpellMgr->GetFirstSpellInChain(SPELL_DK_WILL_OF_THE_NECROPOLIS_AURA_R1) != sSpellMgr->GetFirstSpellInChain(spellInfo->Id)) +                if (!spellInfo->IsRankOf(firstRankSpellInfo))                      return false; -                uint8 rank = sSpellMgr->GetSpellRank(spellInfo->Id); +                uint8 rank = spellInfo->GetRank();                  if (!sSpellMgr->GetSpellWithRank(SPELL_DK_WILL_OF_THE_NECROPOLIS_TALENT_R1, rank, true))                      return false; @@ -1053,7 +1057,7 @@ class spell_dk_will_of_the_necropolis : public SpellScriptLoader              void Absorb(AuraEffect* /*aurEff*/, DamageInfo & dmgInfo, uint32 & absorbAmount)              {                  // min pct of hp is stored in effect 0 of talent spell -                uint32 rank = sSpellMgr->GetSpellRank(GetSpellInfo()->Id); +                uint8 rank = GetSpellInfo()->GetRank();                  SpellInfo const* talentProto = sSpellMgr->GetSpellInfo(sSpellMgr->GetSpellWithRank(SPELL_DK_WILL_OF_THE_NECROPOLIS_TALENT_R1, rank));                  int32 remainingHp = int32(GetTarget()->GetHealth() - dmgInfo.GetDamage()); diff --git a/src/server/scripts/Spells/spell_paladin.cpp b/src/server/scripts/Spells/spell_paladin.cpp index fcb8c47cfbe..0458e4966ca 100644 --- a/src/server/scripts/Spells/spell_paladin.cpp +++ b/src/server/scripts/Spells/spell_paladin.cpp @@ -636,16 +636,17 @@ class spell_pal_holy_shock : public SpellScriptLoader          {              PrepareSpellScript(spell_pal_holy_shock_SpellScript); -            bool Validate(SpellInfo const* spell) OVERRIDE +            bool Validate(SpellInfo const* spellInfo) OVERRIDE              { -                if (!sSpellMgr->GetSpellInfo(SPELL_PALADIN_HOLY_SHOCK_R1)) +                SpellInfo const* firstRankSpellInfo = sSpellMgr->GetSpellInfo(SPELL_PALADIN_HOLY_SHOCK_R1); +                if (!firstRankSpellInfo)                      return false;                  // can't use other spell than holy shock due to spell_ranks dependency -                if (sSpellMgr->GetFirstSpellInChain(SPELL_PALADIN_HOLY_SHOCK_R1) != sSpellMgr->GetFirstSpellInChain(spell->Id)) +                if (!spellInfo->IsRankOf(firstRankSpellInfo))                      return false; -                uint8 rank = sSpellMgr->GetSpellRank(spell->Id); +                uint8 rank = spellInfo->GetRank();                  if (!sSpellMgr->GetSpellWithRank(SPELL_PALADIN_HOLY_SHOCK_R1_DAMAGE, rank, true) || !sSpellMgr->GetSpellWithRank(SPELL_PALADIN_HOLY_SHOCK_R1_HEALING, rank, true))                      return false; @@ -657,11 +658,11 @@ class spell_pal_holy_shock : public SpellScriptLoader                  Unit* caster = GetCaster();                  if (Unit* unitTarget = GetHitUnit())                  { -                    uint8 rank = sSpellMgr->GetSpellRank(GetSpellInfo()->Id); +                    uint8 rank = GetSpellInfo()->GetRank();                      if (caster->IsFriendlyTo(unitTarget)) -                        caster->CastSpell(unitTarget, sSpellMgr->GetSpellWithRank(SPELL_PALADIN_HOLY_SHOCK_R1_HEALING, rank), true, 0); +                        caster->CastSpell(unitTarget, sSpellMgr->GetSpellWithRank(SPELL_PALADIN_HOLY_SHOCK_R1_HEALING, rank), true);                      else -                        caster->CastSpell(unitTarget, sSpellMgr->GetSpellWithRank(SPELL_PALADIN_HOLY_SHOCK_R1_DAMAGE, rank), true, 0); +                        caster->CastSpell(unitTarget, sSpellMgr->GetSpellWithRank(SPELL_PALADIN_HOLY_SHOCK_R1_DAMAGE, rank), true);                  }              } diff --git a/src/server/scripts/Spells/spell_priest.cpp b/src/server/scripts/Spells/spell_priest.cpp index 9ee4075bd38..552d54410cd 100644 --- a/src/server/scripts/Spells/spell_priest.cpp +++ b/src/server/scripts/Spells/spell_priest.cpp @@ -589,13 +589,15 @@ class spell_pri_penance : public SpellScriptLoader              bool Validate(SpellInfo const* spellInfo) OVERRIDE              { -                if (!sSpellMgr->GetSpellInfo(SPELL_PRIEST_PENANCE_R1)) +                SpellInfo const* firstRankSpellInfo = sSpellMgr->GetSpellInfo(SPELL_PRIEST_PENANCE_R1); +                if (!firstRankSpellInfo)                      return false; +                  // can't use other spell than this penance due to spell_ranks dependency -                if (sSpellMgr->GetFirstSpellInChain(SPELL_PRIEST_PENANCE_R1) != sSpellMgr->GetFirstSpellInChain(spellInfo->Id)) +                if (!spellInfo->IsRankOf(firstRankSpellInfo))                      return false; -                uint8 rank = sSpellMgr->GetSpellRank(spellInfo->Id); +                uint8 rank = spellInfo->GetRank();                  if (!sSpellMgr->GetSpellWithRank(SPELL_PRIEST_PENANCE_R1_DAMAGE, rank, true))                      return false;                  if (!sSpellMgr->GetSpellWithRank(SPELL_PRIEST_PENANCE_R1_HEAL, rank, true)) @@ -612,12 +614,12 @@ class spell_pri_penance : public SpellScriptLoader                      if (!unitTarget->IsAlive())                          return; -                    uint8 rank = sSpellMgr->GetSpellRank(GetSpellInfo()->Id); +                    uint8 rank = GetSpellInfo()->GetRank();                      if (caster->IsFriendlyTo(unitTarget)) -                        caster->CastSpell(unitTarget, sSpellMgr->GetSpellWithRank(SPELL_PRIEST_PENANCE_R1_HEAL, rank), false, 0); +                        caster->CastSpell(unitTarget, sSpellMgr->GetSpellWithRank(SPELL_PRIEST_PENANCE_R1_HEAL, rank), false);                      else -                        caster->CastSpell(unitTarget, sSpellMgr->GetSpellWithRank(SPELL_PRIEST_PENANCE_R1_DAMAGE, rank), false, 0); +                        caster->CastSpell(unitTarget, sSpellMgr->GetSpellWithRank(SPELL_PRIEST_PENANCE_R1_DAMAGE, rank), false);                  }              } diff --git a/src/server/scripts/Spells/spell_shaman.cpp b/src/server/scripts/Spells/spell_shaman.cpp index 71a0cfe85ad..3fcf767ef75 100644 --- a/src/server/scripts/Spells/spell_shaman.cpp +++ b/src/server/scripts/Spells/spell_shaman.cpp @@ -508,7 +508,8 @@ class spell_sha_flame_shock : public SpellScriptLoader                      // Lava Flows                      if (AuraEffect const* aurEff = caster->GetDummyAuraEffect(SPELLFAMILY_SHAMAN, SHAMAN_ICON_ID_SHAMAN_LAVA_FLOW, EFFECT_0))                      { -                        if (sSpellMgr->GetFirstSpellInChain(SPELL_SHAMAN_LAVA_FLOWS_R1) != sSpellMgr->GetFirstSpellInChain(aurEff->GetId())) +                        SpellInfo const* firstRankSpellInfo = sSpellMgr->GetSpellInfo(SPELL_SHAMAN_LAVA_FLOWS_R1); +                        if (!aurEff->GetSpellInfo()->IsRankOf(firstRankSpellInfo))                              return;                          int32 basepoints = aurEff->GetAmount(); diff --git a/src/server/scripts/Spells/spell_warrior.cpp b/src/server/scripts/Spells/spell_warrior.cpp index 56da8ced4e1..6485b4da7fd 100644 --- a/src/server/scripts/Spells/spell_warrior.cpp +++ b/src/server/scripts/Spells/spell_warrior.cpp @@ -236,7 +236,7 @@ class spell_warr_deep_wounds : public SpellScriptLoader                      // apply percent damage mods                      damage = caster->SpellDamageBonusDone(target, GetSpellInfo(), damage, SPELL_DIRECT_DAMAGE); -                    ApplyPct(damage, 16 * sSpellMgr->GetSpellRank(GetSpellInfo()->Id)); +                    ApplyPct(damage, 16 * GetSpellInfo()->GetRank());                      damage = target->SpellDamageBonusTaken(caster, GetSpellInfo(), damage, SPELL_DIRECT_DAMAGE); @@ -440,8 +440,9 @@ class spell_warr_last_stand : public SpellScriptLoader              void HandleDummy(SpellEffIndex /*effIndex*/)              { -                int32 healthModSpellBasePoints0 = int32(GetCaster()->CountPctFromMaxHealth(GetEffectValue())); -                GetCaster()->CastCustomSpell(GetCaster(), SPELL_WARRIOR_LAST_STAND_TRIGGERED, &healthModSpellBasePoints0, NULL, NULL, true, NULL); +                Unit* caster = GetCaster(); +                int32 healthModSpellBasePoints0 = int32(caster->CountPctFromMaxHealth(GetEffectValue())); +                caster->CastCustomSpell(caster, SPELL_WARRIOR_LAST_STAND_TRIGGERED, &healthModSpellBasePoints0, NULL, NULL, true, NULL);              }              void Register() OVERRIDE | 
