aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2020-08-17 11:52:44 +0200
committerShauren <shauren.trinity@gmail.com>2022-01-31 00:20:30 +0100
commit87b1c3700e8b8e5722b31fef2de124a2f39915c0 (patch)
tree73c5e1dd6f73515596917c95f9551bf6a16d4246
parent48d491ae2ffbebc05aae46cad2c012a4e983fb11 (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.cpp42
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;