mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 15:26:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			39 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include "transport.hpp"
 | |
| 
 | |
| #include <components/debug/debuglog.hpp>
 | |
| 
 | |
| #include <components/esm/esmreader.hpp>
 | |
| #include <components/esm/esmwriter.hpp>
 | |
| 
 | |
| namespace ESM
 | |
| {
 | |
| 
 | |
|     void Transport::add(ESMReader &esm)
 | |
|     {
 | |
|         if (esm.retSubName().intval == ESM::FourCC<'D','O','D','T'>::value)
 | |
|         {
 | |
|             Dest dodt;
 | |
|             esm.getHExact(&dodt.mPos, 24);
 | |
|             mList.push_back(dodt);
 | |
|         }
 | |
|         else if (esm.retSubName().intval == ESM::FourCC<'D','N','A','M'>::value)
 | |
|         {
 | |
|             const std::string name = esm.getHString();
 | |
|             if (mList.empty())
 | |
|                 Log(Debug::Warning) << "Encountered DNAM record without DODT record, skipped.";
 | |
|             else
 | |
|                 mList.back().mCellName = name;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     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);
 | |
|         }
 | |
|     }
 | |
| 
 | |
| }
 |