diff options
author | Shauren <shauren.trinity@gmail.com> | 2020-08-17 11:52:44 +0200 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2022-01-31 00:20:30 +0100 |
commit | 87b1c3700e8b8e5722b31fef2de124a2f39915c0 (patch) | |
tree | 73c5e1dd6f73515596917c95f9551bf6a16d4246 | |
parent | 48d491ae2ffbebc05aae46cad2c012a4e983fb11 (diff) |
Core/Spells: Fix summoning warlock pets in case that pet has never been summoned before
(cherry picked from commit bbcf00257ebdb75fa30f0484cb185058139f8ae4)
-rw-r--r-- | src/server/game/Spells/Spell.cpp | 42 |
1 files changed, 22 insertions, 20 deletions
diff --git a/src/server/game/Spells/Spell.cpp b/src/server/game/Spells/Spell.cpp index c6013ea0e68..95fd1f1a61d 100644 --- a/src/server/game/Spells/Spell.cpp +++ b/src/server/game/Spells/Spell.cpp @@ -5999,32 +5999,34 @@ SpellCastResult Spell::CheckCast(bool strict, int32* param1 /*= nullptr*/, int32 if (playerCaster && playerCaster->GetPetStable()) { std::pair<PetStable::PetInfo const*, PetSaveMode> info = Pet::GetLoadPetInfo(*playerCaster->GetPetStable(), spellEffectInfo.MiscValue, 0, false); - if (!info.first) + if (info.first) { - playerCaster->SendTameFailure(PetTameResult::NoPetAvailable); - return SPELL_FAILED_DONT_REPORT; - } - - if (info.first->Type == HUNTER_PET) - { - if (!info.first->Health) + if (info.first->Type == HUNTER_PET) { - playerCaster->SendTameFailure(PetTameResult::Dead); - return SPELL_FAILED_DONT_REPORT; - } + if (!info.first->Health) + { + playerCaster->SendTameFailure(PetTameResult::Dead); + return SPELL_FAILED_DONT_REPORT; + } - CreatureTemplate const* creatureInfo = sObjectMgr->GetCreatureTemplate(info.first->CreatureId); - if (!creatureInfo || !creatureInfo->IsTameable(playerCaster->CanTameExoticPets())) - { - // if problem in exotic pet - if (creatureInfo && creatureInfo->IsTameable(true)) - playerCaster->SendTameFailure(PetTameResult::CantControlExotic); - else - playerCaster->SendTameFailure(PetTameResult::NoPetAvailable); + CreatureTemplate const* creatureInfo = sObjectMgr->GetCreatureTemplate(info.first->CreatureId); + if (!creatureInfo || !creatureInfo->IsTameable(playerCaster->CanTameExoticPets())) + { + // if problem in exotic pet + if (creatureInfo && creatureInfo->IsTameable(true)) + playerCaster->SendTameFailure(PetTameResult::CantControlExotic); + else + playerCaster->SendTameFailure(PetTameResult::NoPetAvailable); - return SPELL_FAILED_DONT_REPORT; + return SPELL_FAILED_DONT_REPORT; + } } } + else if (!spellEffectInfo.MiscValue) // when miscvalue is present it is allowed to create new pets + { + playerCaster->SendTameFailure(PetTameResult::NoPetAvailable); + return SPELL_FAILED_DONT_REPORT; + } } break; |