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

98 lines
2.8 KiB
C++
Raw Normal View History

2013-05-11 18:38:27 +02:00
#include "inventoryitemmodel.hpp"
#include "../mwworld/containerstore.hpp"
#include "../mwworld/class.hpp"
#include "../mwworld/inventorystore.hpp"
namespace MWGui
{
InventoryItemModel::InventoryItemModel(const MWWorld::Ptr &actor)
: mActor(actor)
{
}
ItemStack InventoryItemModel::getItem (ModelIndex index)
{
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];
}
size_t InventoryItemModel::getItemCount()
{
return mItems.size();
}
ItemModel::ModelIndex InventoryItemModel::getIndex (ItemStack item)
{
size_t i = 0;
for (std::vector<ItemStack>::iterator it = mItems.begin(); it != mItems.end(); ++it)
{
if (*it == item)
return i;
++i;
}
return -1;
}
MWWorld::Ptr InventoryItemModel::copyItem (const ItemStack& item, size_t count, bool setNewOwner)
2013-05-11 18:38:27 +02:00
{
2013-08-25 17:40:08 +02:00
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, mActor, setNewOwner);
2013-05-11 18:38:27 +02:00
}
void InventoryItemModel::removeItem (const ItemStack& item, size_t count)
{
MWWorld::ContainerStore& store = mActor.getClass().getContainerStore(mActor);
int removed = store.remove(item.mBase, count, mActor);
2013-05-11 18:38:27 +02:00
if (removed == 0)
throw std::runtime_error("Item to remove not found in container store");
else if (removed < static_cast<int>(count))
throw std::runtime_error("Not enough items in the stack to remove");
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();
MWWorld::Ptr ret = otherModel->copyItem(item, count, false);
removeItem(item, count);
return ret;
}
2013-05-11 18:38:27 +02:00
void InventoryItemModel::update()
{
MWWorld::ContainerStore& store = mActor.getClass().getContainerStore(mActor);
2013-05-11 18:38:27 +02:00
mItems.clear();
for (MWWorld::ContainerStoreIterator it = store.begin(); it != store.end(); ++it)
{
MWWorld::Ptr item = *it;
if (!item.getClass().showsInInventory(item))
continue;
ItemStack newItem (item, this, item.getRefData().getCount());
2013-05-11 18:38:27 +02:00
if (mActor.getClass().hasInventoryStore(mActor))
2013-05-11 18:38:27 +02:00
{
MWWorld::InventoryStore& store = mActor.getClass().getInventoryStore(mActor);
if (store.isEquipped(newItem.mBase))
newItem.mType = ItemStack::Type_Equipped;
2013-05-11 18:38:27 +02:00
}
mItems.push_back(newItem);
}
}
}