1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-25 13:26:38 +00:00
openmw/components/esm/loadcrea.hpp
2014-01-17 11:27:13 +01:00

104 lines
2.2 KiB
C++

#ifndef OPENMW_ESM_CREA_H
#define OPENMW_ESM_CREA_H
#include <string>
#include "loadcont.hpp"
#include "spelllist.hpp"
#include "aipackage.hpp"
namespace ESM
{
class ESMReader;
class ESMWriter;
/*
* Creature definition
*
*/
struct Creature
{
static unsigned int sRecordId;
// Default is 0x48?
enum Flags
{
// Movement types
Bipedal = 0x001,
Swims = 0x010,
Flies = 0x020, // Don't know what happens if several
Walks = 0x040, // of these are set
Respawn = 0x002,
Weapon = 0x004, // Has weapon and shield
None = 0x008, // ??
Essential = 0x080,
// Blood types
Skeleton = 0x400,
Metal = 0x800
};
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 mFlags;
bool mPersistent;
float mScale;
std::string mId, mModel, mName, mScript;
std::string mOriginal; // Base creature that this is a modification of
InventoryList mInventory;
SpellList mSpells;
bool mHasAI;
AIData mAiData;
AIPackageList mAiPackage;
void load(ESMReader &esm);
void save(ESMWriter &esm) const;
void blank();
///< Set record to default state (does not touch the ID).
};
}
#endif