2013-05-11 16:38:27 +00:00
|
|
|
#include "itemmodel.hpp"
|
|
|
|
|
2015-01-31 22:27:34 +00:00
|
|
|
#include <set>
|
|
|
|
|
2013-05-11 16:38:27 +00:00
|
|
|
#include "../mwworld/class.hpp"
|
|
|
|
#include "../mwworld/containerstore.hpp"
|
2014-09-12 00:46:21 +00:00
|
|
|
#include "../mwworld/store.hpp"
|
|
|
|
#include "../mwworld/esmstore.hpp"
|
2014-09-11 23:33:45 +00:00
|
|
|
|
|
|
|
#include "../mwbase/world.hpp"
|
|
|
|
#include "../mwbase/environment.hpp"
|
2017-11-10 05:43:22 +00:00
|
|
|
#include "../mwbase/mechanicsmanager.hpp"
|
2013-05-11 16:38:27 +00:00
|
|
|
|
|
|
|
namespace MWGui
|
|
|
|
{
|
|
|
|
|
|
|
|
ItemStack::ItemStack(const MWWorld::Ptr &base, ItemModel *creator, size_t count)
|
2015-05-01 00:24:27 +00:00
|
|
|
: mType(Type_Normal)
|
2013-05-11 16:38:27 +00:00
|
|
|
, mFlags(0)
|
2015-05-01 00:24:27 +00:00
|
|
|
, mCreator(creator)
|
|
|
|
, mCount(count)
|
2013-05-11 16:38:27 +00:00
|
|
|
, mBase(base)
|
|
|
|
{
|
2014-05-22 18:37:22 +00:00
|
|
|
if (base.getClass().getEnchantment(base) != "")
|
2013-05-11 16:38:27 +00:00
|
|
|
mFlags |= Flag_Enchanted;
|
2014-09-11 23:33:45 +00:00
|
|
|
|
2017-11-10 05:43:22 +00:00
|
|
|
if (MWBase::Environment::get().getMechanicsManager()->isBoundItem(base))
|
2014-09-11 23:33:45 +00:00
|
|
|
mFlags |= Flag_Bound;
|
2013-05-11 16:38:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ItemStack::ItemStack()
|
2015-05-01 00:24:27 +00:00
|
|
|
: mType(Type_Normal)
|
2013-05-11 16:38:27 +00:00
|
|
|
, mFlags(0)
|
2015-05-01 00:24:27 +00:00
|
|
|
, mCreator(NULL)
|
|
|
|
, mCount(0)
|
2013-05-11 16:38:27 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
bool ItemStack::stacks(const ItemStack &other)
|
|
|
|
{
|
|
|
|
if(mBase == other.mBase)
|
|
|
|
return true;
|
2013-05-27 00:18:36 +00:00
|
|
|
|
|
|
|
// If one of the items is in an inventory and currently equipped, we need to check stacking both ways to be sure
|
|
|
|
if (mBase.getContainerStore() && other.mBase.getContainerStore())
|
|
|
|
return mBase.getContainerStore()->stacks(mBase, other.mBase)
|
|
|
|
&& other.mBase.getContainerStore()->stacks(mBase, other.mBase);
|
|
|
|
|
|
|
|
if (mBase.getContainerStore())
|
|
|
|
return mBase.getContainerStore()->stacks(mBase, other.mBase);
|
|
|
|
if (other.mBase.getContainerStore())
|
|
|
|
return other.mBase.getContainerStore()->stacks(mBase, other.mBase);
|
|
|
|
|
|
|
|
MWWorld::ContainerStore store;
|
|
|
|
return store.stacks(mBase, other.mBase);
|
|
|
|
|
2013-05-11 16:38:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bool operator == (const ItemStack& left, const ItemStack& right)
|
|
|
|
{
|
|
|
|
if (left.mType != right.mType)
|
|
|
|
return false;
|
2013-05-27 00:18:36 +00:00
|
|
|
|
2013-05-11 16:38:27 +00:00
|
|
|
if(left.mBase == right.mBase)
|
|
|
|
return true;
|
2013-05-27 00:18:36 +00:00
|
|
|
|
|
|
|
// If one of the items is in an inventory and currently equipped, we need to check stacking both ways to be sure
|
|
|
|
if (left.mBase.getContainerStore() && right.mBase.getContainerStore())
|
|
|
|
return left.mBase.getContainerStore()->stacks(left.mBase, right.mBase)
|
|
|
|
&& right.mBase.getContainerStore()->stacks(left.mBase, right.mBase);
|
|
|
|
|
|
|
|
if (left.mBase.getContainerStore())
|
|
|
|
return left.mBase.getContainerStore()->stacks(left.mBase, right.mBase);
|
|
|
|
if (right.mBase.getContainerStore())
|
|
|
|
return right.mBase.getContainerStore()->stacks(left.mBase, right.mBase);
|
|
|
|
|
|
|
|
MWWorld::ContainerStore store;
|
|
|
|
return store.stacks(left.mBase, right.mBase);
|
2013-05-11 16:38:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ItemModel::ItemModel()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-05-15 02:41:31 +00:00
|
|
|
MWWorld::Ptr ItemModel::moveItem(const ItemStack &item, size_t count, ItemModel *otherModel)
|
2014-04-27 03:40:07 +00:00
|
|
|
{
|
2014-05-15 02:41:31 +00:00
|
|
|
MWWorld::Ptr ret = otherModel->copyItem(item, count);
|
2014-04-27 03:40:07 +00:00
|
|
|
removeItem(item, count);
|
2014-05-15 02:41:31 +00:00
|
|
|
return ret;
|
2014-04-27 03:40:07 +00:00
|
|
|
}
|
|
|
|
|
2017-10-03 05:59:31 +00:00
|
|
|
bool ItemModel::allowedToUseItems() const
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-03-05 18:53:24 +00:00
|
|
|
bool ItemModel::allowedToInsertItems() const
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2017-10-04 19:26:06 +00:00
|
|
|
bool ItemModel::onDropItem(const MWWorld::Ptr &item, int count)
|
2017-10-04 18:37:08 +00:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2017-10-04 19:26:06 +00:00
|
|
|
bool ItemModel::onTakeItem(const MWWorld::Ptr &item, int count)
|
2017-10-04 17:25:22 +00:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-05-11 16:38:27 +00:00
|
|
|
|
2015-08-16 15:49:37 +00:00
|
|
|
ProxyItemModel::ProxyItemModel()
|
|
|
|
: mSourceModel(NULL)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2013-05-11 16:38:27 +00:00
|
|
|
ProxyItemModel::~ProxyItemModel()
|
|
|
|
{
|
|
|
|
delete mSourceModel;
|
|
|
|
}
|
|
|
|
|
2017-10-03 05:59:31 +00:00
|
|
|
bool ProxyItemModel::allowedToUseItems() const
|
|
|
|
{
|
|
|
|
return mSourceModel->allowedToUseItems();
|
|
|
|
}
|
|
|
|
|
2014-05-15 02:41:31 +00:00
|
|
|
MWWorld::Ptr ProxyItemModel::copyItem (const ItemStack& item, size_t count, bool setNewOwner)
|
2013-05-11 16:38:27 +00:00
|
|
|
{
|
2014-05-15 02:41:31 +00:00
|
|
|
return mSourceModel->copyItem (item, count, setNewOwner);
|
2013-05-11 16:38:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void ProxyItemModel::removeItem (const ItemStack& item, size_t count)
|
|
|
|
{
|
|
|
|
mSourceModel->removeItem (item, count);
|
|
|
|
}
|
|
|
|
|
|
|
|
ItemModel::ModelIndex ProxyItemModel::mapToSource (ModelIndex index)
|
|
|
|
{
|
|
|
|
const ItemStack& itemToSearch = getItem(index);
|
|
|
|
for (size_t i=0; i<mSourceModel->getItemCount(); ++i)
|
|
|
|
{
|
|
|
|
const ItemStack& item = mSourceModel->getItem(i);
|
2014-05-31 11:24:13 +00:00
|
|
|
if (item.mBase == itemToSearch.mBase)
|
2013-05-11 16:38:27 +00:00
|
|
|
return i;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
ItemModel::ModelIndex ProxyItemModel::mapFromSource (ModelIndex index)
|
|
|
|
{
|
|
|
|
const ItemStack& itemToSearch = mSourceModel->getItem(index);
|
|
|
|
for (size_t i=0; i<getItemCount(); ++i)
|
|
|
|
{
|
|
|
|
const ItemStack& item = getItem(i);
|
2014-05-31 11:24:13 +00:00
|
|
|
if (item.mBase == itemToSearch.mBase)
|
2013-05-11 16:38:27 +00:00
|
|
|
return i;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
ItemModel::ModelIndex ProxyItemModel::getIndex (ItemStack item)
|
|
|
|
{
|
|
|
|
return mSourceModel->getIndex(item);
|
|
|
|
}
|
|
|
|
|
2015-08-16 15:49:37 +00:00
|
|
|
void ProxyItemModel::setSourceModel(ItemModel *sourceModel)
|
|
|
|
{
|
|
|
|
if (mSourceModel == sourceModel)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (mSourceModel)
|
|
|
|
{
|
|
|
|
delete mSourceModel;
|
|
|
|
mSourceModel = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
mSourceModel = sourceModel;
|
|
|
|
}
|
|
|
|
|
2017-10-04 19:26:06 +00:00
|
|
|
void ProxyItemModel::onClose()
|
2017-10-04 18:37:08 +00:00
|
|
|
{
|
2017-10-04 19:26:06 +00:00
|
|
|
mSourceModel->onClose();
|
2017-10-04 18:37:08 +00:00
|
|
|
}
|
|
|
|
|
2017-10-04 19:26:06 +00:00
|
|
|
bool ProxyItemModel::onDropItem(const MWWorld::Ptr &item, int count)
|
2017-10-04 17:25:22 +00:00
|
|
|
{
|
2017-10-04 19:26:06 +00:00
|
|
|
return mSourceModel->onDropItem(item, count);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool ProxyItemModel::onTakeItem(const MWWorld::Ptr &item, int count)
|
|
|
|
{
|
|
|
|
return mSourceModel->onTakeItem(item, count);
|
2017-10-04 17:25:22 +00:00
|
|
|
}
|
2013-05-11 16:38:27 +00:00
|
|
|
}
|