mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 06:56:38 +00:00 
			
		
		
		
	Nice side effects: - Subrecord name comparison now uses magic number instead of string (faster) - Improves the error message for unknown subrecords: will print the record in question instead of failing to read the next record with a strange error
		
			
				
	
	
		
			46 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include "loadacti.hpp"
 | |
| 
 | |
| #include "esmreader.hpp"
 | |
| #include "esmwriter.hpp"
 | |
| #include "defs.hpp"
 | |
| 
 | |
| namespace ESM
 | |
| {
 | |
|     unsigned int Activator::sRecordId = REC_ACTI;
 | |
| 
 | |
|     void Activator::load(ESMReader &esm)
 | |
|     {
 | |
|         while (esm.hasMoreSubs())
 | |
|         {
 | |
|             esm.getSubName();
 | |
|             uint32_t name = esm.retSubName().val;
 | |
|             switch (name)
 | |
|             {
 | |
|                 case ESM::FourCC<'M','O','D','L'>::value:
 | |
|                     mModel = esm.getHString();
 | |
|                     break;
 | |
|                 case ESM::FourCC<'F','N','A','M'>::value:
 | |
|                     mName = esm.getHString();
 | |
|                     break;
 | |
|                 case ESM::FourCC<'S','C','R','I'>::value:
 | |
|                     mScript = esm.getHString();
 | |
|                     break;
 | |
|                 default:
 | |
|                     esm.fail("Unknown subrecord");
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     void Activator::save(ESMWriter &esm) const
 | |
|     {
 | |
|         esm.writeHNCString("MODL", mModel);
 | |
|         esm.writeHNOCString("FNAM", mName);
 | |
|         esm.writeHNOCString("SCRI", mScript);
 | |
|     }
 | |
| 
 | |
|     void Activator::blank()
 | |
|     {
 | |
|         mName.clear();
 | |
|         mScript.clear();
 | |
|         mModel.clear();
 | |
|     }
 | |
| }
 |