1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-20 02:53:53 +00:00
openmw/components/esm3/loaddial.cpp

127 lines
3.1 KiB
C++
Raw Normal View History

#include "loaddial.hpp"
2018-08-14 15:42:41 +00:00
#include <components/debug/debuglog.hpp>
2014-02-20 15:59:20 +00:00
#include "esmreader.hpp"
#include "esmwriter.hpp"
#include "components/esm/defs.hpp"
2012-09-17 07:37:50 +00:00
namespace ESM
{
unsigned int Dialogue::sRecordId = REC_DIAL;
void Dialogue::load(ESMReader &esm, bool &isDeleted)
{
loadId(esm);
loadData(esm, isDeleted);
}
void Dialogue::loadId(ESMReader &esm)
{
mId = esm.getHNString("NAME");
}
void Dialogue::loadData(ESMReader &esm, bool &isDeleted)
{
isDeleted = false;
while (esm.hasMoreSubs())
{
esm.getSubName();
switch (esm.retSubName().toInt())
{
case fourCC("DATA"):
{
esm.getSubHeader();
int size = esm.getSubSize();
if (size == 1)
{
esm.getT(mType);
}
else
{
esm.skip(size);
}
break;
}
case SREC_DELE:
esm.skipHSub();
mType = Unknown;
isDeleted = true;
break;
default:
esm.fail("Unknown subrecord");
break;
}
}
2014-02-20 15:59:20 +00:00
}
void Dialogue::save(ESMWriter &esm, bool isDeleted) const
{
esm.writeHNCString("NAME", mId);
if (isDeleted)
{
esm.writeHNString("DELE", "", 3);
}
else
{
esm.writeHNT("DATA", mType);
}
}
void Dialogue::blank()
{
mInfo.clear();
}
void Dialogue::readInfo(ESMReader &esm, bool merge)
2014-02-20 15:59:20 +00:00
{
DialInfo info;
bool isDeleted = false;
2016-05-15 14:38:04 +00:00
info.load(esm, isDeleted);
if (!merge || mInfo.empty())
{
mLookup[info.mId] = std::make_pair(mInfo.insert(mInfo.end(), info), isDeleted);
return;
}
2022-03-16 17:09:21 +00:00
LookupMap::iterator lookup = mLookup.find(info.mId);
if (lookup != mLookup.end())
{
2022-03-16 17:09:21 +00:00
auto it = lookup->second.first;
// Since the new version of this record may have changed the next/prev linked list connection, we need to re-insert the record
mInfo.erase(it);
mLookup.erase(lookup);
}
2022-03-16 17:09:21 +00:00
if (!info.mPrev.empty())
{
2022-03-16 17:09:21 +00:00
lookup = mLookup.find(info.mPrev);
if (lookup != mLookup.end())
{
auto it = lookup->second.first;
2022-03-16 17:09:21 +00:00
mLookup[info.mId] = std::make_pair(mInfo.insert(++it, info), isDeleted);
return;
}
}
2022-03-16 17:09:21 +00:00
mLookup[info.mId] = std::make_pair(mInfo.insert(mInfo.begin(), info), isDeleted);
}
void Dialogue::clearDeletedInfos()
{
LookupMap::const_iterator current = mLookup.begin();
LookupMap::const_iterator end = mLookup.end();
for (; current != end; ++current)
{
if (current->second.second)
{
mInfo.erase(current->second.first);
}
}
mLookup.clear();
}
}