mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2025-10-12 10:28:05 +00:00
fix: inventory items being in the wrong state due to changed IDs
Tested that the regenerated ids
This commit is contained in:
@@ -324,10 +324,13 @@ Inventory::~Inventory() {
|
|||||||
void Inventory::RegenerateItemIDs() {
|
void Inventory::RegenerateItemIDs() {
|
||||||
std::map<LWOOBJID, Item*> newItems{};
|
std::map<LWOOBJID, Item*> newItems{};
|
||||||
for (auto* const item : items | std::views::values) {
|
for (auto* const item : items | std::views::values) {
|
||||||
|
const bool equipped = item->IsEquipped();
|
||||||
|
if (equipped) item->UnEquip();
|
||||||
const auto oldID = item->GetId();
|
const auto oldID = item->GetId();
|
||||||
const auto newID = item->GenerateID();
|
const auto newID = item->GenerateID();
|
||||||
LOG("Updating item ID from %llu to %llu", oldID, newID);
|
LOG("Updating item ID from %llu to %llu", oldID, newID);
|
||||||
newItems.insert_or_assign(newID, item);
|
newItems.insert_or_assign(newID, item);
|
||||||
|
if (equipped) item->Equip();
|
||||||
}
|
}
|
||||||
|
|
||||||
// We don't want to delete the item pointers, we're just moving from map to map
|
// We don't want to delete the item pointers, we're just moving from map to map
|
||||||
|
Reference in New Issue
Block a user