2015-03-08 20:44:41 +01:00
|
|
|
#include "transport.hpp"
|
|
|
|
|
2018-10-12 10:36:50 +04:00
|
|
|
#include <components/debug/debuglog.hpp>
|
|
|
|
|
2015-03-08 20:44:41 +01:00
|
|
|
#include <components/esm/esmreader.hpp>
|
|
|
|
#include <components/esm/esmwriter.hpp>
|
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
|
|
|
|
void Transport::add(ESMReader &esm)
|
|
|
|
{
|
2016-05-07 20:32:51 +03:00
|
|
|
if (esm.retSubName().intval == ESM::FourCC<'D','O','D','T'>::value)
|
2015-03-08 20:44:41 +01:00
|
|
|
{
|
|
|
|
Dest dodt;
|
|
|
|
esm.getHExact(&dodt.mPos, 24);
|
|
|
|
mList.push_back(dodt);
|
|
|
|
}
|
2016-05-07 20:32:51 +03:00
|
|
|
else if (esm.retSubName().intval == ESM::FourCC<'D','N','A','M'>::value)
|
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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|