From e22eec0585092a4fd92c0df2830a09dbdcbc6815 Mon Sep 17 00:00:00 2001 From: Mads Buvik Sandvei Date: Mon, 17 Jul 2023 15:10:54 +0200 Subject: [PATCH] optimize moveItem() by unsetting refnum instead of calling unstackItem. --- apps/openmw/mwgui/itemmodel.cpp | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/apps/openmw/mwgui/itemmodel.cpp b/apps/openmw/mwgui/itemmodel.cpp index 25b66c28c1..a9edae34b7 100644 --- a/apps/openmw/mwgui/itemmodel.cpp +++ b/apps/openmw/mwgui/itemmodel.cpp @@ -2,6 +2,7 @@ #include "../mwworld/class.hpp" #include "../mwworld/containerstore.hpp" +#include "../mwworld/worldmodel.hpp" #include "../mwbase/environment.hpp" #include "../mwbase/mechanicsmanager.hpp" @@ -58,10 +59,15 @@ namespace MWGui MWWorld::Ptr ItemModel::moveItem(const ItemStack& item, size_t count, ItemModel* otherModel, bool allowAutoEquip) { MWWorld::Ptr ret = otherModel->addItem(item, count, allowAutoEquip); - // Unstacking here ensures that new a refnum is assigned to the leftover stack if there is a leftover. - // Otherwise we end up with duplicated instances. - unstackItem(item, count); removeItem(item, count); + // Although logically the same as an unstack, to avoid unneccesarily allocating a new stack + // and then immediately removing it, we assign a new refnum here instead of calling unstack() + if (!item.mBase.getRefData().isDeleted()) + { + ret.getCellRef().unsetRefNum(); + ret.getRefData().setLuaScripts(nullptr); + MWBase::Environment::get().getWorldModel()->registerPtr(ret); + } return ret; }