|
|
@ -183,7 +183,7 @@ int MWWorld::ContainerStore::count(const std::string &id) const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
int total=0;
|
|
|
|
int total=0;
|
|
|
|
for (const auto&& iter : *this)
|
|
|
|
for (const auto&& iter : *this)
|
|
|
|
if (Misc::StringUtils::ciEqual(iter.getCellRef().getRefIdRef(), id))
|
|
|
|
if (Misc::StringUtils::ciEqual(iter.getCellRef().getRefId(), id))
|
|
|
|
total += iter.getRefData().getCount();
|
|
|
|
total += iter.getRefData().getCount();
|
|
|
|
return total;
|
|
|
|
return total;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -248,7 +248,7 @@ bool MWWorld::ContainerStore::stacks(const ConstPtr& ptr1, const ConstPtr& ptr2)
|
|
|
|
const MWWorld::Class& cls1 = ptr1.getClass();
|
|
|
|
const MWWorld::Class& cls1 = ptr1.getClass();
|
|
|
|
const MWWorld::Class& cls2 = ptr2.getClass();
|
|
|
|
const MWWorld::Class& cls2 = ptr2.getClass();
|
|
|
|
|
|
|
|
|
|
|
|
if (!Misc::StringUtils::ciEqual(ptr1.getCellRef().getRefIdRef(), ptr2.getCellRef().getRefIdRef()))
|
|
|
|
if (!Misc::StringUtils::ciEqual(ptr1.getCellRef().getRefId(), ptr2.getCellRef().getRefId()))
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
// If it has an enchantment, don't stack when some of the charge is already used
|
|
|
|
// If it has an enchantment, don't stack when some of the charge is already used
|
|
|
@ -363,7 +363,7 @@ MWWorld::ContainerStoreIterator MWWorld::ContainerStore::addImp (const Ptr& ptr,
|
|
|
|
|
|
|
|
|
|
|
|
for (MWWorld::ContainerStoreIterator iter (begin(type)); iter!=end(); ++iter)
|
|
|
|
for (MWWorld::ContainerStoreIterator iter (begin(type)); iter!=end(); ++iter)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (Misc::StringUtils::ciEqual(iter->getCellRef().getRefIdRef(), MWWorld::ContainerStore::sGoldId))
|
|
|
|
if (Misc::StringUtils::ciEqual(iter->getCellRef().getRefId(), MWWorld::ContainerStore::sGoldId))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
iter->getRefData().setCount(addItems(iter->getRefData().getCount(false), realCount));
|
|
|
|
iter->getRefData().setCount(addItems(iter->getRefData().getCount(false), realCount));
|
|
|
|
flagAsModified();
|
|
|
|
flagAsModified();
|
|
|
@ -464,7 +464,7 @@ int MWWorld::ContainerStore::remove(const std::string& itemId, int count, const
|
|
|
|
int toRemove = count;
|
|
|
|
int toRemove = count;
|
|
|
|
|
|
|
|
|
|
|
|
for (ContainerStoreIterator iter(begin()); iter != end() && toRemove > 0; ++iter)
|
|
|
|
for (ContainerStoreIterator iter(begin()); iter != end() && toRemove > 0; ++iter)
|
|
|
|
if (Misc::StringUtils::ciEqual(iter->getCellRef().getRefIdRef(), itemId))
|
|
|
|
if (Misc::StringUtils::ciEqual(iter->getCellRef().getRefId(), itemId))
|
|
|
|
toRemove -= remove(*iter, toRemove, actor, equipReplacement, resolveFirst);
|
|
|
|
toRemove -= remove(*iter, toRemove, actor, equipReplacement, resolveFirst);
|
|
|
|
|
|
|
|
|
|
|
|
flagAsModified();
|
|
|
|
flagAsModified();
|
|
|
@ -739,7 +739,7 @@ MWWorld::Ptr MWWorld::ContainerStore::findReplacement(const std::string& id)
|
|
|
|
for (auto&& iter : *this)
|
|
|
|
for (auto&& iter : *this)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
int iterHealth = iter.getClass().hasItemHealth(iter) ? iter.getClass().getItemHealth(iter) : 1;
|
|
|
|
int iterHealth = iter.getClass().hasItemHealth(iter) ? iter.getClass().getItemHealth(iter) : 1;
|
|
|
|
if (Misc::StringUtils::ciEqual(iter.getCellRef().getRefIdRef(), id))
|
|
|
|
if (Misc::StringUtils::ciEqual(iter.getCellRef().getRefId(), id))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Prefer the stack with the lowest remaining uses
|
|
|
|
// Prefer the stack with the lowest remaining uses
|
|
|
|
// Try to get item with zero durability only if there are no other items found
|
|
|
|
// Try to get item with zero durability only if there are no other items found
|
|
|
|