|
|
@ -119,7 +119,7 @@ namespace MWGui
|
|
|
|
return mBorrowedToUs;
|
|
|
|
return mBorrowedToUs;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void TradeItemModel::transferItems(const MWWorld::Ptr& transferFrom)
|
|
|
|
void TradeItemModel::transferItems()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::vector<ItemStack>::iterator it = mBorrowedToUs.begin();
|
|
|
|
std::vector<ItemStack>::iterator it = mBorrowedToUs.begin();
|
|
|
|
for (; it != mBorrowedToUs.end(); ++it)
|
|
|
|
for (; it != mBorrowedToUs.end(); ++it)
|
|
|
@ -135,11 +135,9 @@ namespace MWGui
|
|
|
|
if (i == sourceModel->getItemCount())
|
|
|
|
if (i == sourceModel->getItemCount())
|
|
|
|
throw std::runtime_error("The borrowed item disappeared");
|
|
|
|
throw std::runtime_error("The borrowed item disappeared");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// reset owner while copying, but only for items bought by the player
|
|
|
|
|
|
|
|
bool setNewOwner = (mMerchant.isEmpty());
|
|
|
|
const ItemStack& item = sourceModel->getItem(i);
|
|
|
|
const ItemStack& item = sourceModel->getItem(i);
|
|
|
|
|
|
|
|
|
|
|
|
bool setNewOwner = Misc::StringUtils::ciEqual(item.mBase.getCellRef().getOwner(), transferFrom.getCellRef().getRefId())
|
|
|
|
|
|
|
|
|| item.mBase.getCellRef().getOwner().empty();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// copy the borrowed items to our model
|
|
|
|
// copy the borrowed items to our model
|
|
|
|
copyItem(item, it->mCount, setNewOwner);
|
|
|
|
copyItem(item, it->mCount, setNewOwner);
|
|
|
|
// then remove them from the source model
|
|
|
|
// then remove them from the source model
|
|
|
|