1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-26 18:35:20 +00:00
OpenMW/apps/openmw/mwgui/itemmodel.cpp

226 lines
6.7 KiB
C++
Raw Normal View History

2013-05-11 18:38:27 +02:00
#include "itemmodel.hpp"
2015-01-31 23:27:34 +01:00
#include <set>
2013-05-11 18:38:27 +02:00
#include "../mwworld/class.hpp"
#include "../mwworld/containerstore.hpp"
#include "../mwworld/store.hpp"
#include "../mwworld/esmstore.hpp"
#include "../mwbase/world.hpp"
#include "../mwbase/environment.hpp"
2013-05-11 18:38:27 +02:00
namespace MWGui
{
ItemStack::ItemStack(const MWWorld::Ptr &base, ItemModel *creator, size_t count)
: mType(Type_Normal)
2013-05-11 18:38:27 +02:00
, mFlags(0)
, mCreator(creator)
, mCount(count)
2013-05-11 18:38:27 +02:00
, mBase(base)
{
if (base.getClass().getEnchantment(base) != "")
2013-05-11 18:38:27 +02:00
mFlags |= Flag_Enchanted;
2014-09-11 22:45:30 -04:00
static std::set<std::string> boundItemIDCache;
// If this is empty then we haven't executed the GMST cache logic yet; or there isn't any sMagicBound* GMST's for some reason
if (boundItemIDCache.empty())
{
// Build a list of known bound item ID's
const MWWorld::Store<ESM::GameSetting> &gameSettings = MWBase::Environment::get().getWorld()->getStore().get<ESM::GameSetting>();
for (MWWorld::Store<ESM::GameSetting>::iterator currentIteration = gameSettings.begin(); currentIteration != gameSettings.end(); ++currentIteration)
{
const ESM::GameSetting &currentSetting = *currentIteration;
std::string currentGMSTID = currentSetting.mId;
2015-12-07 22:49:15 +01:00
Misc::StringUtils::lowerCaseInPlace(currentGMSTID);
// Don't bother checking this GMST if it's not a sMagicBound* one.
2014-09-26 17:12:48 +02:00
const std::string& toFind = "smagicbound";
if (currentGMSTID.compare(0, toFind.length(), toFind) != 0)
continue;
// All sMagicBound* GMST's should be of type string
std::string currentGMSTValue = currentSetting.getString();
2015-12-07 22:49:15 +01:00
Misc::StringUtils::lowerCaseInPlace(currentGMSTValue);
2014-09-11 22:45:30 -04:00
boundItemIDCache.insert(currentGMSTValue);
}
}
// Perform bound item check and assign the Flag_Bound bit if it passes
std::string tempItemID = base.getCellRef().getRefId();
2015-12-07 22:49:15 +01:00
Misc::StringUtils::lowerCaseInPlace(tempItemID);
if (boundItemIDCache.count(tempItemID) != 0)
mFlags |= Flag_Bound;
2013-05-11 18:38:27 +02:00
}
ItemStack::ItemStack()
: mType(Type_Normal)
2013-05-11 18:38:27 +02:00
, mFlags(0)
, mCreator(NULL)
, mCount(0)
2013-05-11 18:38:27 +02:00
{
}
bool ItemStack::stacks(const ItemStack &other)
{
if(mBase == other.mBase)
return true;
2013-05-27 02:18:36 +02: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 18:38:27 +02:00
}
bool operator == (const ItemStack& left, const ItemStack& right)
{
if (left.mType != right.mType)
return false;
2013-05-27 02:18:36 +02:00
2013-05-11 18:38:27 +02:00
if(left.mBase == right.mBase)
return true;
2013-05-27 02:18:36 +02: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 18:38:27 +02:00
}
ItemModel::ItemModel()
{
}
MWWorld::Ptr ItemModel::moveItem(const ItemStack &item, size_t count, ItemModel *otherModel)
{
MWWorld::Ptr ret = otherModel->copyItem(item, count);
removeItem(item, count);
return ret;
}
bool ItemModel::allowedToUseItems() const
{
return true;
}
2016-03-05 19:53:24 +01:00
bool ItemModel::allowedToInsertItems() const
{
return true;
}
2017-10-04 23:26:06 +04:00
bool ItemModel::onDropItem(const MWWorld::Ptr &item, int count)
2017-10-04 22:37:08 +04:00
{
return true;
}
2017-10-04 23:26:06 +04:00
bool ItemModel::onTakeItem(const MWWorld::Ptr &item, int count)
2017-10-04 21:25:22 +04:00
{
return true;
}
2013-05-11 18:38:27 +02:00
ProxyItemModel::ProxyItemModel()
: mSourceModel(NULL)
{
}
2013-05-11 18:38:27 +02:00
ProxyItemModel::~ProxyItemModel()
{
delete mSourceModel;
}
bool ProxyItemModel::allowedToUseItems() const
{
return mSourceModel->allowedToUseItems();
}
MWWorld::Ptr ProxyItemModel::copyItem (const ItemStack& item, size_t count, bool setNewOwner)
2013-05-11 18:38:27 +02:00
{
return mSourceModel->copyItem (item, count, setNewOwner);
2013-05-11 18:38:27 +02: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);
if (item.mBase == itemToSearch.mBase)
2013-05-11 18:38:27 +02: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);
if (item.mBase == itemToSearch.mBase)
2013-05-11 18:38:27 +02:00
return i;
}
return -1;
}
ItemModel::ModelIndex ProxyItemModel::getIndex (ItemStack item)
{
return mSourceModel->getIndex(item);
}
void ProxyItemModel::setSourceModel(ItemModel *sourceModel)
{
if (mSourceModel == sourceModel)
return;
if (mSourceModel)
{
delete mSourceModel;
mSourceModel = NULL;
}
mSourceModel = sourceModel;
}
2017-10-04 23:26:06 +04:00
void ProxyItemModel::onClose()
2017-10-04 22:37:08 +04:00
{
2017-10-04 23:26:06 +04:00
mSourceModel->onClose();
2017-10-04 22:37:08 +04:00
}
2017-10-04 23:26:06 +04:00
bool ProxyItemModel::onDropItem(const MWWorld::Ptr &item, int count)
2017-10-04 21:25:22 +04:00
{
2017-10-04 23:26:06 +04:00
return mSourceModel->onDropItem(item, count);
}
bool ProxyItemModel::onTakeItem(const MWWorld::Ptr &item, int count)
{
return mSourceModel->onTakeItem(item, count);
2017-10-04 21:25:22 +04:00
}
2013-05-11 18:38:27 +02:00
}