aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKeader <keader.android@gmail.com>2017-09-14 11:15:28 -0300
committerShauren <shauren.trinity@gmail.com>2020-08-29 00:18:37 +0200
commit6210fc10ae28a06a92e7d4796b66115eb1fe028e (patch)
treedde223340e63c616c9325e533b777cef2442b322
parent8534c23dfe798207dcd3a8b164623ca760bf28d8 (diff)
Core/Handlers: Fixed changing equipment while charmed with equipament manager
Closes #20209 Followup: a1a12ec755e4aa5e2e8475d6a6158bac94f0977a (cherry picked from commit 42be04898c6fd001160ee4fdf00fc2ba5c5c1ee3)
-rw-r--r--src/server/game/Handlers/CharacterHandler.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/server/game/Handlers/CharacterHandler.cpp b/src/server/game/Handlers/CharacterHandler.cpp
index 17ca7dd0d2d..f35566d0b10 100644
--- a/src/server/game/Handlers/CharacterHandler.cpp
+++ b/src/server/game/Handlers/CharacterHandler.cpp
@@ -1874,6 +1874,9 @@ void WorldSession::HandleUseEquipmentSet(WorldPackets::EquipmentSet::UseEquipmen
InventoryResult inventoryResult = _player->CanStoreItem(NULL_BAG, NULL_SLOT, itemPosCountVec, uItem, false);
if (inventoryResult == EQUIP_ERR_OK)
{
+ if (_player->CanEquipItem(NULL_SLOT, dstPos, uItem, false) != EQUIP_ERR_OK)
+ continue;
+
_player->RemoveItem(INVENTORY_SLOT_BAG_0, i, true);
_player->StoreItem(itemPosCountVec, uItem, true);
}
@@ -1885,6 +1888,9 @@ void WorldSession::HandleUseEquipmentSet(WorldPackets::EquipmentSet::UseEquipmen
if (item->GetPos() == dstPos)
continue;
+ if (_player->CanUnequipItem(dstPos, true) != EQUIP_ERR_OK)
+ continue;
+
_player->SwapItem(item->GetPos(), dstPos);
}