mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-31 19:26:38 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			102 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
	
		
			2.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef OPENMW_ESM_CREA_H
 | |
| #define OPENMW_ESM_CREA_H
 | |
| 
 | |
| #include <string>
 | |
| 
 | |
| #include "loadcont.hpp"
 | |
| #include "spelllist.hpp"
 | |
| #include "aipackage.hpp"
 | |
| #include "transport.hpp"
 | |
| 
 | |
| namespace ESM
 | |
| {
 | |
| 
 | |
| class ESMReader;
 | |
| class ESMWriter;
 | |
| 
 | |
| /*
 | |
|  * Creature definition
 | |
|  *
 | |
|  */
 | |
| 
 | |
| struct Creature
 | |
| {
 | |
|     static unsigned int sRecordId;
 | |
|     /// Return a string descriptor for this record type. Currently used for debugging / error logs only.
 | |
|     static std::string_view getRecordType() { return "Creature"; }
 | |
| 
 | |
|     // Default is 0x48?
 | |
|     enum Flags
 | |
|     {
 | |
|         Bipedal       = 0x01,
 | |
|         Respawn       = 0x02,
 | |
|         Weapon        = 0x04, // Has weapon and shield
 | |
|         Base          = 0x08, // This flag is set for every actor in Bethesda ESMs
 | |
|         Swims         = 0x10,
 | |
|         Flies         = 0x20, // Don't know what happens if several
 | |
|         Walks         = 0x40, // of these are set
 | |
|         Essential     = 0x80
 | |
|     };
 | |
| 
 | |
|     enum Type
 | |
|     {
 | |
|         Creatures = 0,
 | |
|         Daedra  = 1,
 | |
|         Undead = 2,
 | |
|         Humanoid = 3
 | |
|     };
 | |
| 
 | |
|     struct NPDTstruct
 | |
|     {
 | |
|         int mType;
 | |
|         // For creatures we obviously have to use ints, not shorts and
 | |
|         // bytes like we use for NPCs.... this file format just makes so
 | |
|         // much sense! (Still, _much_ easier to decode than the NIFs.)
 | |
|         int mLevel;
 | |
|         int mStrength,
 | |
|             mIntelligence,
 | |
|             mWillpower,
 | |
|             mAgility,
 | |
|             mSpeed,
 | |
|             mEndurance,
 | |
|             mPersonality,
 | |
|             mLuck;
 | |
| 
 | |
|         int mHealth, mMana, mFatigue; // Stats
 | |
|         int mSoul; // The creatures soul value (used with soul gems.)
 | |
|         // Creatures have generalized combat, magic and stealth stats which substitute for
 | |
|         // the specific skills (in the same way as specializations).
 | |
|         int mCombat, mMagic, mStealth;
 | |
|         int mAttack[6]; // AttackMin1, AttackMax1, ditto2, ditto3
 | |
|         int mGold;
 | |
|     }; // 96 byte
 | |
| 
 | |
|     NPDTstruct mData;
 | |
| 
 | |
|     int mBloodType;
 | |
|     unsigned char mFlags;
 | |
| 
 | |
|     float mScale;
 | |
| 
 | |
|     unsigned int mRecordFlags;
 | |
|     std::string mId, mModel, mName, mScript;
 | |
|     std::string mOriginal; // Base creature that this is a modification of
 | |
| 
 | |
|     InventoryList mInventory;
 | |
|     SpellList mSpells;
 | |
| 
 | |
|     AIData mAiData;
 | |
|     AIPackageList mAiPackage;
 | |
|     Transport mTransport;
 | |
| 
 | |
|     const std::vector<Transport::Dest>& getTransport() const;
 | |
| 
 | |
|     void load(ESMReader &esm, bool &isDeleted);
 | |
|     void save(ESMWriter &esm, bool isDeleted = false) const;
 | |
| 
 | |
|     void blank();
 | |
|     ///< Set record to default state (does not touch the ID).
 | |
| };
 | |
| 
 | |
| }
 | |
| #endif
 |