2015-01-19 11:22:51 +00:00
|
|
|
#include "convertinventory.hpp"
|
|
|
|
|
|
|
|
#include <components/misc/stringops.hpp>
|
2016-01-25 13:13:16 +00:00
|
|
|
#include <cstdlib>
|
2015-01-19 11:22:51 +00:00
|
|
|
|
|
|
|
namespace ESSImport
|
|
|
|
{
|
|
|
|
|
|
|
|
void convertInventory(const Inventory &inventory, ESM::InventoryState &state)
|
|
|
|
{
|
2015-01-23 15:45:47 +00:00
|
|
|
int index = 0;
|
2020-06-10 06:30:37 +00:00
|
|
|
for (const auto & item : inventory.mItems)
|
2015-01-19 11:22:51 +00:00
|
|
|
{
|
|
|
|
ESM::ObjectState objstate;
|
|
|
|
objstate.blank();
|
2020-06-10 06:30:37 +00:00
|
|
|
objstate.mRef = item;
|
|
|
|
objstate.mRef.mRefID = Misc::StringUtils::lowerCase(item.mId);
|
|
|
|
objstate.mCount = std::abs(item.mCount); // restocking items have negative count in the savefile
|
2015-01-19 11:22:51 +00:00
|
|
|
// openmw handles them differently, so no need to set any flags
|
2015-01-23 15:45:47 +00:00
|
|
|
state.mItems.push_back(objstate);
|
2020-06-10 06:30:37 +00:00
|
|
|
if (item.mRelativeEquipmentSlot != -1)
|
2015-01-23 15:45:47 +00:00
|
|
|
// Note we should really write the absolute slot here, which we do not know about
|
|
|
|
// Not a big deal, OpenMW will auto-correct to a valid slot, the only problem is when
|
|
|
|
// an item could be equipped in two different slots (e.g. equipped two rings)
|
2020-06-10 06:30:37 +00:00
|
|
|
state.mEquipmentSlots[index] = item.mRelativeEquipmentSlot;
|
2015-01-23 15:45:47 +00:00
|
|
|
++index;
|
2015-01-19 11:22:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|