1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-18 13:12:50 +00:00
OpenMW/apps/openmw/mwgui/inventoryitemmodel.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

142 lines
4.4 KiB
C++
Raw Normal View History

2013-05-11 18:38:27 +02:00
#include "inventoryitemmodel.hpp"
#include <sstream>
#include "../mwmechanics/actorutil.hpp"
#include "../mwmechanics/npcstats.hpp"
2013-05-11 18:38:27 +02:00
#include "../mwworld/class.hpp"
#include "../mwworld/containerstore.hpp"
#include "../mwworld/inventorystore.hpp"
2017-10-04 21:25:22 +04:00
#include "../mwbase/environment.hpp"
#include "../mwbase/mechanicsmanager.hpp"
2013-05-11 18:38:27 +02:00
namespace MWGui
{
InventoryItemModel::InventoryItemModel(const MWWorld::Ptr& actor)
: mActor(actor)
2013-05-11 18:38:27 +02:00
{
}
ItemStack InventoryItemModel::getItem(ModelIndex index)
{
2013-05-11 18:38:27 +02:00
if (index < 0)
throw std::runtime_error("Invalid index supplied");
if (mItems.size() <= static_cast<size_t>(index))
throw std::runtime_error("Item index out of range");
return mItems[index];
}
2022-09-22 21:26:05 +03:00
size_t InventoryItemModel::getItemCount()
{
return mItems.size();
}
ItemModel::ModelIndex InventoryItemModel::getIndex(const ItemStack& item)
{
size_t i = 0;
for (ItemStack& itemStack : mItems)
2022-09-22 21:26:05 +03:00
{
if (itemStack == item)
return i;
2022-09-22 21:26:05 +03:00
++i;
}
return -1;
}
2022-09-22 21:26:05 +03:00
MWWorld::Ptr InventoryItemModel::copyItem(const ItemStack& item, size_t count, bool allowAutoEquip)
{
if (item.mBase.getContainerStore() == &mActor.getClass().getContainerStore(mActor))
throw std::runtime_error("Item to copy needs to be from a different container!");
return *mActor.getClass().getContainerStore(mActor).add(item.mBase, count, allowAutoEquip);
}
void InventoryItemModel::removeItem(const ItemStack& item, size_t count)
2022-09-22 21:26:05 +03:00
{
int removed = 0;
// Re-equipping makes sense only if a target has inventory
if (mActor.getClass().hasInventoryStore(mActor))
2022-09-22 21:26:05 +03:00
{
2016-10-31 00:23:51 +09:00
MWWorld::InventoryStore& store = mActor.getClass().getInventoryStore(mActor);
removed = store.remove(item.mBase, count, true);
2022-09-22 21:26:05 +03:00
}
else
{
MWWorld::ContainerStore& store = mActor.getClass().getContainerStore(mActor);
removed = store.remove(item.mBase, count);
}
std::stringstream error;
2013-05-11 18:38:27 +02:00
if (removed == 0)
2022-09-22 21:26:05 +03:00
{
2013-05-11 18:38:27 +02:00
error << "Item '" << item.mBase.getCellRef().getRefId() << "' was not found in container store to remove";
throw std::runtime_error(error.str());
2022-09-22 21:26:05 +03:00
}
else if (removed < static_cast<int>(count))
2022-09-22 21:26:05 +03:00
{
2013-05-11 18:38:27 +02:00
error << "Not enough items '" << item.mBase.getCellRef().getRefId() << "' in the stack to remove ("
<< static_cast<int>(count) << " requested, " << removed << " found)";
throw std::runtime_error(error.str());
2022-09-22 21:26:05 +03:00
}
}
2013-05-11 18:38:27 +02:00
MWWorld::Ptr InventoryItemModel::moveItem(const ItemStack& item, size_t count, ItemModel* otherModel)
{
// Can't move conjured items: This is a general fix that also takes care of issues with taking conjured items
// via the 'Take All' button.
if (item.mFlags & ItemStack::Flag_Bound)
return MWWorld::Ptr();
2022-09-22 21:26:05 +03:00
MWWorld::Ptr ret = otherModel->copyItem(item, count);
removeItem(item, count);
return ret;
2022-09-22 21:26:05 +03:00
}
void InventoryItemModel::update()
2022-09-22 21:26:05 +03:00
{
MWWorld::ContainerStore& store = mActor.getClass().getContainerStore(mActor);
mItems.clear();
2013-05-11 18:38:27 +02:00
for (MWWorld::ContainerStoreIterator it = store.begin(); it != store.end(); ++it)
2013-05-11 18:38:27 +02:00
{
2016-10-31 00:23:51 +09:00
MWWorld::Ptr item = *it;
2022-09-22 21:26:05 +03:00
2016-10-31 00:23:51 +09:00
if (!item.getClass().showsInInventory(item))
continue;
2013-05-11 18:38:27 +02:00
ItemStack newItem(item, this, item.getRefData().getCount());
2022-09-22 21:26:05 +03:00
if (mActor.getClass().hasInventoryStore(mActor))
2022-09-22 21:26:05 +03:00
{
MWWorld::InventoryStore& invStore = mActor.getClass().getInventoryStore(mActor);
2016-10-31 00:23:51 +09:00
if (invStore.isEquipped(newItem.mBase))
newItem.mType = ItemStack::Type_Equipped;
2022-09-22 21:26:05 +03:00
}
2013-05-11 18:38:27 +02:00
mItems.push_back(newItem);
2022-09-22 21:26:05 +03:00
}
2013-05-11 18:38:27 +02:00
}
2017-10-04 23:26:06 +04:00
bool InventoryItemModel::onTakeItem(const MWWorld::Ptr& item, int count)
2017-10-04 21:25:22 +04:00
{
// Looting a dead corpse is considered OK
if (mActor.getClass().isActor() && mActor.getClass().getCreatureStats(mActor).isDead())
return true;
2017-10-04 22:37:08 +04:00
2017-10-04 21:25:22 +04:00
MWWorld::Ptr player = MWMechanics::getPlayer();
MWBase::Environment::get().getMechanicsManager()->itemTaken(player, item, mActor, count);
return true;
}
bool InventoryItemModel::usesContainer(const MWWorld::Ptr& container)
{
return mActor == container;
}
2013-05-11 18:38:27 +02:00
}