2015-01-18 22:52:11 +01:00
|
|
|
#include "importinventory.hpp"
|
|
|
|
|
2015-01-23 15:33:30 +01:00
|
|
|
#include <stdexcept>
|
|
|
|
|
2022-01-22 15:58:41 +01:00
|
|
|
#include <components/esm3/esmreader.hpp>
|
2015-01-18 22:52:11 +01:00
|
|
|
|
|
|
|
namespace ESSImport
|
|
|
|
{
|
|
|
|
|
|
|
|
void Inventory::load(ESM::ESMReader& esm)
|
|
|
|
{
|
|
|
|
while (esm.isNextSub("NPCO"))
|
|
|
|
{
|
2019-12-05 23:42:12 +03:00
|
|
|
ContItem contItem;
|
2023-12-17 14:03:45 +01:00
|
|
|
esm.getHT(contItem.mCount, contItem.mItem.mData);
|
2015-01-19 12:22:51 +01:00
|
|
|
|
2015-01-18 22:52:11 +01:00
|
|
|
InventoryItem item;
|
2019-12-05 23:42:12 +03:00
|
|
|
item.mId = contItem.mItem.toString();
|
2015-01-19 12:22:51 +01:00
|
|
|
item.mCount = contItem.mCount;
|
2015-01-23 15:33:30 +01:00
|
|
|
item.mRelativeEquipmentSlot = -1;
|
2018-08-01 20:18:37 +04:00
|
|
|
item.mLockLevel = 0;
|
2023-07-28 14:01:40 +04:00
|
|
|
item.mChargeIntRemainder = 0;
|
2015-01-18 22:52:11 +01:00
|
|
|
|
2016-04-12 21:37:26 +02:00
|
|
|
unsigned int itemCount = std::abs(item.mCount);
|
|
|
|
bool separateStacks = false;
|
|
|
|
for (unsigned int i = 0; i < itemCount; ++i)
|
2015-01-18 22:52:11 +01:00
|
|
|
{
|
2016-04-12 21:37:26 +02:00
|
|
|
bool newStack = esm.isNextSub("XIDX");
|
|
|
|
if (newStack)
|
|
|
|
{
|
2023-12-17 14:03:45 +01:00
|
|
|
uint32_t idx;
|
2016-04-12 21:37:26 +02:00
|
|
|
esm.getHT(idx);
|
|
|
|
separateStacks = true;
|
|
|
|
item.mCount = 1;
|
|
|
|
}
|
2015-01-18 22:52:11 +01:00
|
|
|
|
2015-01-22 03:54:33 +01:00
|
|
|
item.mSCRI.load(esm);
|
2015-01-20 01:21:44 +01:00
|
|
|
|
|
|
|
// for XSOL and XCHG seen so far, but probably others too
|
2015-07-21 21:49:36 +03:00
|
|
|
bool isDeleted = false;
|
|
|
|
item.ESM::CellRef::loadData(esm, isDeleted);
|
2015-01-20 01:21:44 +01:00
|
|
|
|
2023-12-17 14:03:45 +01:00
|
|
|
int32_t charge = -1;
|
2015-01-23 15:33:39 +01:00
|
|
|
esm.getHNOT(charge, "XHLT");
|
|
|
|
item.mChargeInt = charge;
|
2016-04-12 21:37:26 +02:00
|
|
|
|
|
|
|
if (newStack)
|
|
|
|
mItems.push_back(item);
|
2015-01-20 01:21:44 +01:00
|
|
|
}
|
2015-01-18 22:52:11 +01:00
|
|
|
|
2016-04-12 21:37:26 +02:00
|
|
|
if (!separateStacks)
|
|
|
|
mItems.push_back(item);
|
2015-01-18 22:52:11 +01:00
|
|
|
}
|
|
|
|
|
2015-01-19 12:22:51 +01:00
|
|
|
// equipped items
|
2015-01-18 22:52:11 +01:00
|
|
|
while (esm.isNextSub("WIDX"))
|
|
|
|
{
|
2015-01-19 12:22:51 +01:00
|
|
|
// note: same item can be equipped 2 items (e.g. 2 rings)
|
|
|
|
// and will be *stacked* in the NPCO list, unlike openmw!
|
2015-01-23 15:33:30 +01:00
|
|
|
// this is currently not handled properly.
|
|
|
|
|
2015-01-19 12:22:51 +01:00
|
|
|
esm.getSubHeader();
|
2023-12-17 14:03:45 +01:00
|
|
|
int32_t itemIndex; // index of the item in the NPCO list
|
2015-01-19 12:22:51 +01:00
|
|
|
esm.getT(itemIndex);
|
|
|
|
|
2015-01-23 15:33:30 +01:00
|
|
|
if (itemIndex < 0 || itemIndex >= int(mItems.size()))
|
|
|
|
esm.fail("equipment item index out of range");
|
|
|
|
|
2015-01-19 12:22:51 +01:00
|
|
|
// appears to be a relative index for only the *possible* slots this item can be equipped in,
|
2015-01-23 15:33:30 +01:00
|
|
|
// i.e. 0 most of the time
|
2023-12-17 14:03:45 +01:00
|
|
|
int32_t slotIndex;
|
2015-01-19 12:22:51 +01:00
|
|
|
esm.getT(slotIndex);
|
2015-01-23 15:33:30 +01:00
|
|
|
|
|
|
|
mItems[itemIndex].mRelativeEquipmentSlot = slotIndex;
|
2015-01-18 22:52:11 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|