2015-01-18 21:52:11 +00:00
|
|
|
#include "importinventory.hpp"
|
|
|
|
|
2015-01-20 22:58:24 +00:00
|
|
|
#include <stdexcept>
|
|
|
|
|
2015-01-18 21:52:11 +00:00
|
|
|
#include <components/esm/esmreader.hpp>
|
|
|
|
|
2015-01-19 11:22:51 +00:00
|
|
|
#include <components/esm/loadcont.hpp>
|
|
|
|
|
2015-01-18 21:52:11 +00:00
|
|
|
namespace ESSImport
|
|
|
|
{
|
|
|
|
|
|
|
|
void Inventory::load(ESM::ESMReader &esm)
|
|
|
|
{
|
|
|
|
while (esm.isNextSub("NPCO"))
|
|
|
|
{
|
2015-01-19 11:22:51 +00:00
|
|
|
ESM::ContItem contItem;
|
|
|
|
esm.getHT(contItem);
|
|
|
|
|
2015-01-18 21:52:11 +00:00
|
|
|
InventoryItem item;
|
2015-01-19 11:22:51 +00:00
|
|
|
item.mId = contItem.mItem.toString();
|
|
|
|
item.mCount = contItem.mCount;
|
2015-01-20 22:58:24 +00:00
|
|
|
item.mRelativeEquipmentSlot = -1;
|
2015-01-18 21:52:11 +00:00
|
|
|
|
2015-01-20 00:21:44 +00:00
|
|
|
// seems that a stack of items can have a set of subrecords for each item? rings0000.ess
|
|
|
|
// doesn't make any sense to me, if the values were different then the items shouldn't stack in the first place?
|
|
|
|
// I guess we should double check the stacking logic in OpenMW
|
|
|
|
for (int i=0;i<std::abs(item.mCount);++i)
|
2015-01-18 21:52:11 +00:00
|
|
|
{
|
2015-01-20 00:21:44 +00:00
|
|
|
if (esm.isNextSub("XIDX")) // index in the stack?
|
2015-01-18 21:52:11 +00:00
|
|
|
esm.skipHSub();
|
|
|
|
|
2015-01-20 00:21:44 +00:00
|
|
|
std::string script = esm.getHNOString("SCRI");
|
|
|
|
// script variables?
|
|
|
|
// unsure if before or after ESM::CellRef
|
|
|
|
if (!script.empty())
|
|
|
|
{
|
|
|
|
if (esm.isNextSub("SLCS"))
|
|
|
|
esm.skipHSub();
|
|
|
|
if (esm.isNextSub("SLSD")) // Short Data?
|
|
|
|
esm.skipHSub();
|
|
|
|
if (esm.isNextSub("SLFD")) // Float Data?
|
|
|
|
esm.skipHSub();
|
|
|
|
}
|
|
|
|
|
|
|
|
// for XSOL and XCHG seen so far, but probably others too
|
|
|
|
item.ESM::CellRef::loadData(esm);
|
|
|
|
|
2015-01-21 00:59:45 +00:00
|
|
|
int charge=-1;
|
|
|
|
esm.getHNOT(charge, "XHLT");
|
|
|
|
item.mChargeInt = charge;
|
2015-01-20 00:21:44 +00:00
|
|
|
}
|
2015-01-18 21:52:11 +00:00
|
|
|
|
|
|
|
mItems.push_back(item);
|
|
|
|
}
|
|
|
|
|
2015-01-19 11:22:51 +00:00
|
|
|
// equipped items
|
2015-01-18 21:52:11 +00:00
|
|
|
while (esm.isNextSub("WIDX"))
|
|
|
|
{
|
2015-01-19 11:22:51 +00: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-20 22:58:24 +00:00
|
|
|
// this is currently not handled properly.
|
|
|
|
|
2015-01-19 11:22:51 +00:00
|
|
|
esm.getSubHeader();
|
|
|
|
int itemIndex; // index of the item in the NPCO list
|
|
|
|
esm.getT(itemIndex);
|
|
|
|
|
2015-01-20 22:58:24 +00:00
|
|
|
if (itemIndex < 0 || itemIndex >= int(mItems.size()))
|
|
|
|
esm.fail("equipment item index out of range");
|
|
|
|
|
2015-01-19 11:22:51 +00:00
|
|
|
// appears to be a relative index for only the *possible* slots this item can be equipped in,
|
2015-01-20 22:58:24 +00:00
|
|
|
// i.e. 0 most of the time
|
2015-01-19 11:22:51 +00:00
|
|
|
int slotIndex;
|
|
|
|
esm.getT(slotIndex);
|
2015-01-20 22:58:24 +00:00
|
|
|
|
|
|
|
mItems[itemIndex].mRelativeEquipmentSlot = slotIndex;
|
2015-01-18 21:52:11 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|