Skip to content

Commit

Permalink
Fixed clone items and crash if classicEquipmentSlots is true (#464)
Browse files Browse the repository at this point in the history
  • Loading branch information
dudantas authored Jul 27, 2022
1 parent beafc99 commit be3fb37
Showing 1 changed file with 53 additions and 39 deletions.
92 changes: 53 additions & 39 deletions src/game/game.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -416,38 +416,41 @@ void Game::onPressHotkeyEquip(uint32_t playerId, uint16_t itemId)
Thing* ammothing = player->getThing(slotP);
if (ammothing) {
Item* ammoItem = ammothing->getItem();
if (ammoItem) {
ObjectCategory_t category = getObjectCategory(ammoItem);
if (ammoItem->getID() == item->getID()) {
if (item->getDuration() > 0 ||
ammoItem->getItemCount() == 100 ||
ammoItem->getItemCount() == player->getItemTypeCount(ammoItem->getID())) {
ret = internalQuickLootItem(player, ammoItem, category);
if (ret != RETURNVALUE_NOERROR) {
ret = internalMoveItem(ammoItem->getParent(), player, 0, ammoItem, ammoItem->getItemCount(), nullptr);
}
if (ret != RETURNVALUE_NOERROR) {
player->sendCancelMessage(ret);
}
return;
}
}
else {
if (ammoItem == nullptr) {
SPDLOG_DEBUG("[Game::onPressHotkeyEquip] - Player {} ammoItem is nullptr {}.", player->getName());
return;
}

ObjectCategory_t category = getObjectCategory(ammoItem);
if (ammoItem->getID() == item->getID()){
if (item->getDuration() > 0 ||
ammoItem->getItemCount() == 100 ||
ammoItem->getItemCount() == player->getItemTypeCount(ammoItem->getID()))
{
ret = internalQuickLootItem(player, ammoItem, category);
if (ret != RETURNVALUE_NOERROR) {
ret = internalMoveItem(ammoItem->getParent(), player, 0, ammoItem, ammoItem->getItemCount(), nullptr);
}
if (ret != RETURNVALUE_NOERROR) {
player->sendCancelMessage(ret);
}
return;
}
}
else {
return;
ret = internalQuickLootItem(player, ammoItem, category);
if (ret != RETURNVALUE_NOERROR) {
ret = internalMoveItem(ammoItem->getParent(), player, 0, ammoItem, ammoItem->getItemCount(), nullptr);
}
}
}
ReturnValue ret2 = player->queryAdd(slotP, *item, item->getItemCount(), 0);
if (ret2 != RETURNVALUE_NOERROR) {
player->sendCancelMessage(ret2);
if (ReturnValue returnQueryAdd = player->queryAdd(slotP, *item, item->getItemCount(), 0);
returnQueryAdd != RETURNVALUE_NOERROR)
{
player->sendCancelMessage(returnQueryAdd);
return;
}

if (item->getItemCount() < 100 &&
item->getItemCount() < player->getItemTypeCount(item->getID(), -1) &&
item->getDuration() <= 0) {
Expand All @@ -456,24 +459,36 @@ void Game::onPressHotkeyEquip(uint32_t playerId, uint16_t itemId)
if (count == 100) {
break;
}
Container* mainBP = player->getInventoryItem(CONST_SLOT_BACKPACK)->getContainer();
Item* _item = findItemOfType(mainBP, item->getID());

if (!_item) {
Item* playerItem = player->getInventoryItem(CONST_SLOT_BACKPACK);
if(playerItem == nullptr) {
SPDLOG_DEBUG("[Game::onPressHotkeyEquip] - Player {} has no backpack. Item is nullptr.", player->getName());
break;
}
Container* mainBP = playerItem->getContainer();
if(mainBP == nullptr) {
SPDLOG_DEBUG("[Game::onPressHotkeyEquip] - Player {} backpack is not a container. Container is nullptr.", player->getName());
break;
}
Item* removeItem = findItemOfType(mainBP, item->getID());
if (removeItem == nullptr) {
SPDLOG_DEBUG("[Game::onPressHotkeyEquip] - Player {} item is nullptr.", player->getName());
break;
}

if (_item->getItemCount() > 100 - count) {
internalRemoveItem(_item, 100 - count);
if (removeItem->getItemCount() > 100 - count) {
internalRemoveItem(removeItem, 100 - count);
count = 100;
}
else {
count = count + _item->getItemCount();
internalRemoveItem(_item, _item->getItemCount());
count = count + removeItem->getItemCount();
internalRemoveItem(removeItem, removeItem->getItemCount());
}
}
Item* newSlotitem = Item::CreateItem(item->getID(), count);
internalAddItem(player, newSlotitem, slotP, FLAG_NOLIMIT);
if(Item* newSlotitem = Item::CreateItem(item->getID(), count);
newSlotitem && count > 0)
{
internalAddItem(player, newSlotitem, slotP, FLAG_NOLIMIT);
}
return;
}
else {
Expand All @@ -484,15 +499,15 @@ void Game::onPressHotkeyEquip(uint32_t playerId, uint16_t itemId)
Thing* slotthing = player->getThing(slotP);
if (slotthing) {
Item* slotItem = slotthing->getItem();
if (slotItem) {
ret = internalMoveItem(slotItem->getParent(), player, 0, slotItem, slotItem->getItemCount(), nullptr);
if (slotItem->getID() == item->getID()) {
removed = true;
}
}
else {
if (slotItem == nullptr) {
SPDLOG_DEBUG("[Game::onPressHotkeyEquip] - Player {} slotitem is nullptr.", player->getName());
return;
}

ret = internalMoveItem(slotItem->getParent(), player, 0, slotItem, slotItem->getItemCount(), nullptr);
if (slotItem->getID() == item->getID()) {
removed = true;
}
}
if (!removed) {
ret = internalMoveItem(item->getParent(), player, slotP, item, item->getItemCount(), nullptr);
Expand All @@ -504,7 +519,6 @@ void Game::onPressHotkeyEquip(uint32_t playerId, uint16_t itemId)
if (ret != RETURNVALUE_NOERROR) {
player->sendCancelMessage(ret);
}
return;
}

void Game::saveGameState()
Expand Down

0 comments on commit be3fb37

Please sign in to comment.