mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-04-28 21:07:59 +03:00
move most of the files from esm to esm3, keep common code in esm; this is make space for a future with esm4
esm typo esm typo
This commit is contained in:
parent
c263bbf0f6
commit
d1fb854521
448 changed files with 686 additions and 683 deletions
147
components/esm3/loaddial.cpp
Normal file
147
components/esm3/loaddial.cpp
Normal file
|
@ -0,0 +1,147 @@
|
|||
#include "loaddial.hpp"
|
||||
|
||||
#include <components/debug/debuglog.hpp>
|
||||
|
||||
#include "esmreader.hpp"
|
||||
#include "esmwriter.hpp"
|
||||
#include "components/esm/defs.hpp"
|
||||
|
||||
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 ESM::FourCC<'D','A','T','A'>::value:
|
||||
{
|
||||
esm.getSubHeader();
|
||||
int size = esm.getSubSize();
|
||||
if (size == 1)
|
||||
{
|
||||
esm.getT(mType);
|
||||
}
|
||||
else
|
||||
{
|
||||
esm.skip(size);
|
||||
}
|
||||
break;
|
||||
}
|
||||
case ESM::SREC_DELE:
|
||||
esm.skipHSub();
|
||||
mType = Unknown;
|
||||
isDeleted = true;
|
||||
break;
|
||||
default:
|
||||
esm.fail("Unknown subrecord");
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
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)
|
||||
{
|
||||
ESM::DialInfo info;
|
||||
bool isDeleted = false;
|
||||
info.load(esm, isDeleted);
|
||||
|
||||
if (!merge || mInfo.empty())
|
||||
{
|
||||
mLookup[info.mId] = std::make_pair(mInfo.insert(mInfo.end(), info), isDeleted);
|
||||
return;
|
||||
}
|
||||
|
||||
InfoContainer::iterator it = mInfo.end();
|
||||
|
||||
LookupMap::iterator lookup;
|
||||
lookup = mLookup.find(info.mId);
|
||||
|
||||
if (lookup != mLookup.end())
|
||||
{
|
||||
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);
|
||||
}
|
||||
|
||||
if (info.mNext.empty())
|
||||
{
|
||||
mLookup[info.mId] = std::make_pair(mInfo.insert(mInfo.end(), info), isDeleted);
|
||||
return;
|
||||
}
|
||||
if (info.mPrev.empty())
|
||||
{
|
||||
mLookup[info.mId] = std::make_pair(mInfo.insert(mInfo.begin(), info), isDeleted);
|
||||
return;
|
||||
}
|
||||
|
||||
lookup = mLookup.find(info.mPrev);
|
||||
if (lookup != mLookup.end())
|
||||
{
|
||||
it = lookup->second.first;
|
||||
|
||||
mLookup[info.mId] = std::make_pair(mInfo.insert(++it, info), isDeleted);
|
||||
return;
|
||||
}
|
||||
|
||||
lookup = mLookup.find(info.mNext);
|
||||
if (lookup != mLookup.end())
|
||||
{
|
||||
it = lookup->second.first;
|
||||
|
||||
mLookup[info.mId] = std::make_pair(mInfo.insert(it, info), isDeleted);
|
||||
return;
|
||||
}
|
||||
|
||||
Log(Debug::Warning) << "Warning: Failed to insert info " << info.mId;
|
||||
}
|
||||
|
||||
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();
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue