diff options
author | Duarte Duarte <dnpd.dd@gmail.com> | 2015-02-11 15:17:01 +0000 |
---|---|---|
committer | Nayd <dnpd.dd@gmail.com> | 2015-02-11 20:39:09 +0000 |
commit | 102d03b0259fe437f8c8f377136e818c75028f2c (patch) | |
tree | 40ab833699e8813c92c48d8781e7b8ac429c10ec | |
parent | 582313e5452de0d34fca02f90bf78a421a062167 (diff) |
Merge pull request #13963 from tkrokli/3.3.5
Fix Cooldown for Raise Dead (Ghoul)
(cherry picked from commit 1d627ca1ea2e5bc15907ab9b81bf3f03f9effb36)
-rw-r--r-- | src/server/game/Entities/Player/Player.cpp | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/src/server/game/Entities/Player/Player.cpp b/src/server/game/Entities/Player/Player.cpp index 679429b8b6c..7e35c5281c1 100644 --- a/src/server/game/Entities/Player/Player.cpp +++ b/src/server/game/Entities/Player/Player.cpp @@ -22063,6 +22063,34 @@ void Player::SendCooldownEvent(SpellInfo const* spellInfo, uint32 itemId /*= 0*/ data << uint32(spellInfo->Id); data << GetGUID(); SendDirectMessage(&data); + + uint32 cat = spellInfo->GetCategory(); + if (cat && spellInfo->CategoryRecoveryTime) + { + SpellCategoryStore::const_iterator ct = sSpellsByCategoryStore.find(cat); + if (ct != sSpellsByCategoryStore.end()) + { + SpellCategorySet const& catSet = ct->second; + for (SpellCooldowns::const_iterator i = m_spellCooldowns.begin(); i != m_spellCooldowns.end(); ++i) + { + if (i->first == spellInfo->Id) // skip main spell, already handled above + continue; + + SpellInfo const* spellInfo2 = sSpellMgr->GetSpellInfo(i->first); + if (!spellInfo2 || !spellInfo2->IsCooldownStartedOnEvent()) + continue; + + if (catSet.find(i->first) != catSet.end()) + { + // Send activate cooldown timer (possible 0) at client side + WorldPacket data(SMSG_COOLDOWN_EVENT, 4 + 8); + data << uint32(i->first); + data << uint64(GetGUID()); + SendDirectMessage(&data); + } + } + } + } } void Player::UpdatePotionCooldown(Spell* spell) |