mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-26 09:35:28 +00:00
65cdd489fb
Fixed some types removed useless header applied clang format fixed compile tests fixed clang tidy, and closer to logic before this MR Removed hardcoded refids unless there is a returned value we don't use static RefIds can use == between RefId and hardcoded string Fix clang format Fixed a few instances where std::string was used, when only const std::string& was needed removed unused variable
46 lines
1.4 KiB
C++
46 lines
1.4 KiB
C++
#include "stolenitems.hpp"
|
|
|
|
#include <components/esm3/esmreader.hpp>
|
|
#include <components/esm3/esmwriter.hpp>
|
|
|
|
namespace ESM
|
|
{
|
|
|
|
void StolenItems::write(ESMWriter& esm) const
|
|
{
|
|
for (StolenItemsMap::const_iterator it = mStolenItems.begin(); it != mStolenItems.end(); ++it)
|
|
{
|
|
esm.writeHNString("NAME", it->first.getRefIdString());
|
|
for (auto ownerIt = it->second.begin(); ownerIt != it->second.end(); ++ownerIt)
|
|
{
|
|
if (ownerIt->first.second)
|
|
esm.writeHNString("FNAM", ownerIt->first.first.getRefIdString());
|
|
else
|
|
esm.writeHNString("ONAM", ownerIt->first.first.getRefIdString());
|
|
esm.writeHNT("COUN", ownerIt->second);
|
|
}
|
|
}
|
|
}
|
|
|
|
void StolenItems::load(ESMReader& esm)
|
|
{
|
|
while (esm.isNextSub("NAME"))
|
|
{
|
|
ESM::RefId itemid = esm.getRefId();
|
|
|
|
std::map<std::pair<ESM::RefId, bool>, int> ownerMap;
|
|
while (esm.isNextSub("FNAM") || esm.isNextSub("ONAM"))
|
|
{
|
|
const bool isFaction = (esm.retSubName() == "FNAM");
|
|
ESM::RefId owner = esm.getRefId();
|
|
int count;
|
|
esm.getHNT(count, "COUN");
|
|
ownerMap.emplace(std::make_pair(std::move(owner), isFaction), count);
|
|
}
|
|
|
|
mStolenItems.insert_or_assign(std::move(itemid), std::move(ownerMap));
|
|
}
|
|
}
|
|
|
|
}
|