2015-03-08 20:44:41 +01:00
|
|
|
#include "transport.hpp"
|
|
|
|
|
2018-10-12 10:36:50 +04:00
|
|
|
#include <components/debug/debuglog.hpp>
|
|
|
|
|
2022-01-22 15:58:41 +01:00
|
|
|
#include <components/esm3/esmreader.hpp>
|
|
|
|
#include <components/esm3/esmwriter.hpp>
|
2015-03-08 20:44:41 +01:00
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
|
|
|
|
void Transport::add(ESMReader &esm)
|
|
|
|
{
|
2022-04-12 00:18:39 +02:00
|
|
|
if (esm.retSubName().toInt() == fourCC("DODT"))
|
2015-03-08 20:44:41 +01:00
|
|
|
{
|
|
|
|
Dest dodt;
|
|
|
|
esm.getHExact(&dodt.mPos, 24);
|
|
|
|
mList.push_back(dodt);
|
|
|
|
}
|
2022-04-12 00:18:39 +02:00
|
|
|
else if (esm.retSubName().toInt() == fourCC("DNAM"))
|
2015-03-08 20:44:41 +01:00
|
|
|
{
|
2018-10-12 10:36:50 +04:00
|
|
|
const std::string name = esm.getHString();
|
|
|
|
if (mList.empty())
|
|
|
|
Log(Debug::Warning) << "Encountered DNAM record without DODT record, skipped.";
|
|
|
|
else
|
|
|
|
mList.back().mCellName = name;
|
2015-03-08 20:44:41 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void Transport::save(ESMWriter &esm) const
|
|
|
|
{
|
|
|
|
typedef std::vector<Dest>::const_iterator DestIter;
|
|
|
|
for (DestIter it = mList.begin(); it != mList.end(); ++it)
|
|
|
|
{
|
|
|
|
esm.writeHNT("DODT", it->mPos, sizeof(it->mPos));
|
|
|
|
esm.writeHNOCString("DNAM", it->mCellName);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|