1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-19 21:53:51 +00:00

make 4 byte record type accessable from record struct

This commit is contained in:
Marc Zinnschlag 2013-09-24 13:17:28 +02:00
parent 6d9ff39390
commit c42e74dadf
87 changed files with 204 additions and 22 deletions

View file

@ -1,8 +1,6 @@
#include "saving.hpp" #include "saving.hpp"
#include <components/esm/defs.hpp>
#include "../world/data.hpp" #include "../world/data.hpp"
#include "../world/idcollection.hpp" #include "../world/idcollection.hpp"
@ -18,37 +16,37 @@ CSMDoc::Saving::Saving (Document& document)
appendStage (new WriteHeaderStage (mDocument, mState)); appendStage (new WriteHeaderStage (mDocument, mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Global> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Global> >
(mDocument.getData().getGlobals(), mState, ESM::REC_GLOB)); (mDocument.getData().getGlobals(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::GameSetting> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::GameSetting> >
(mDocument.getData().getGmsts(), mState, ESM::REC_GMST)); (mDocument.getData().getGmsts(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Skill> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Skill> >
(mDocument.getData().getSkills(), mState, ESM::REC_SKIL)); (mDocument.getData().getSkills(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Class> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Class> >
(mDocument.getData().getClasses(), mState, ESM::REC_CLAS)); (mDocument.getData().getClasses(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Faction> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Faction> >
(mDocument.getData().getFactions(), mState, ESM::REC_FACT)); (mDocument.getData().getFactions(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Race> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Race> >
(mDocument.getData().getRaces(), mState, ESM::REC_RACE)); (mDocument.getData().getRaces(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Sound> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Sound> >
(mDocument.getData().getSounds(), mState, ESM::REC_SOUN)); (mDocument.getData().getSounds(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Script> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Script> >
(mDocument.getData().getScripts(), mState, ESM::REC_SCPT)); (mDocument.getData().getScripts(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Region> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Region> >
(mDocument.getData().getRegions(), mState, ESM::REC_REGN)); (mDocument.getData().getRegions(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::BirthSign> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::BirthSign> >
(mDocument.getData().getBirthsigns(), mState, ESM::REC_BSGN)); (mDocument.getData().getBirthsigns(), mState));
appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Spell> > appendStage (new WriteCollectionStage<CSMWorld::IdCollection<ESM::Spell> >
(mDocument.getData().getSpells(), mState, ESM::REC_SPEL)); (mDocument.getData().getSpells(), mState));
appendStage (new CloseSaveStage (mState)); appendStage (new CloseSaveStage (mState));

View file

@ -1,8 +1,6 @@
#ifndef CSM_DOC_SAVINGSTAGES_H #ifndef CSM_DOC_SAVINGSTAGES_H
#define CSM_DOC_SAVINGSTAGES_H #define CSM_DOC_SAVINGSTAGES_H
#include <components/esm/defs.hpp>
#include "stage.hpp" #include "stage.hpp"
#include "savingstate.hpp" #include "savingstate.hpp"
@ -52,12 +50,10 @@ namespace CSMDoc
{ {
const CollectionT& mCollection; const CollectionT& mCollection;
SavingState& mState; SavingState& mState;
ESM::RecNameInts mRecordType;
public: public:
WriteCollectionStage (const CollectionT& collection, SavingState& state, WriteCollectionStage (const CollectionT& collection, SavingState& state);
ESM::RecNameInts recordType);
virtual int setup(); virtual int setup();
///< \return number of steps ///< \return number of steps
@ -68,8 +64,8 @@ namespace CSMDoc
template<class CollectionT> template<class CollectionT>
WriteCollectionStage<CollectionT>::WriteCollectionStage (const CollectionT& collection, WriteCollectionStage<CollectionT>::WriteCollectionStage (const CollectionT& collection,
SavingState& state, ESM::RecNameInts recordType) SavingState& state)
: mCollection (collection), mState (state), mRecordType (recordType) : mCollection (collection), mState (state)
{} {}
template<class CollectionT> template<class CollectionT>
@ -89,7 +85,7 @@ namespace CSMDoc
std::string type; std::string type;
for (int i=0; i<4; ++i) for (int i=0; i<4; ++i)
/// \todo make endianess agnostic (change ESMWriter interface?) /// \todo make endianess agnostic (change ESMWriter interface?)
type += reinterpret_cast<const char *> (&mRecordType)[i]; type += reinterpret_cast<const char *> (&mCollection.getRecord (stage).mModified.sRecordId)[i];
mState.getWriter().startRecord (type); mState.getWriter().startRecord (type);
mState.getWriter().writeHNCString ("NAME", mCollection.getId (stage)); mState.getWriter().writeHNCString ("NAME", mCollection.getId (stage));

View file

@ -2,9 +2,12 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Activator::sRecordId = REC_ACTI;
void Activator::load(ESMReader &esm) void Activator::load(ESMReader &esm)
{ {
mModel = esm.getHNString("MODL"); mModel = esm.getHNString("MODL");

View file

@ -11,6 +11,8 @@ class ESMWriter;
struct Activator struct Activator
{ {
static unsigned int sRecordId;
std::string mId, mName, mScript, mModel; std::string mId, mName, mScript, mModel;
void load(ESMReader &esm); void load(ESMReader &esm);

View file

@ -2,9 +2,12 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Potion::sRecordId = REC_ALCH;
void Potion::load(ESMReader &esm) void Potion::load(ESMReader &esm)
{ {
mModel = esm.getHNString("MODL"); mModel = esm.getHNString("MODL");

View file

@ -17,6 +17,8 @@ class ESMWriter;
struct Potion struct Potion
{ {
static unsigned int sRecordId;
struct ALDTstruct struct ALDTstruct
{ {
float mWeight; float mWeight;

View file

@ -2,9 +2,12 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Apparatus::sRecordId = REC_APPA;
void Apparatus::load(ESMReader &esm) void Apparatus::load(ESMReader &esm)
{ {
// we will not treat duplicated subrecords as errors here // we will not treat duplicated subrecords as errors here

View file

@ -15,6 +15,8 @@ class ESMWriter;
struct Apparatus struct Apparatus
{ {
static unsigned int sRecordId;
enum AppaType enum AppaType
{ {
MortarPestle = 0, MortarPestle = 0,

View file

@ -2,6 +2,7 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
@ -28,6 +29,8 @@ void PartReferenceList::save(ESMWriter &esm) const
} }
} }
unsigned int Armor::sRecordId = REC_ARMO;
void Armor::load(ESMReader &esm) void Armor::load(ESMReader &esm)
{ {
mModel = esm.getHNString("MODL"); mModel = esm.getHNString("MODL");

View file

@ -61,6 +61,8 @@ struct PartReferenceList
struct Armor struct Armor
{ {
static unsigned int sRecordId;
enum Type enum Type
{ {
Helmet = 0, Helmet = 0,

View file

@ -2,9 +2,12 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int BodyPart::sRecordId = REC_BODY;
void BodyPart::load(ESMReader &esm) void BodyPart::load(ESMReader &esm)
{ {

View file

@ -11,6 +11,8 @@ class ESMWriter;
struct BodyPart struct BodyPart
{ {
static unsigned int sRecordId;
enum MeshPart enum MeshPart
{ {
MP_Head = 0, MP_Head = 0,

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Book::sRecordId = REC_BOOK;
void Book::load(ESMReader &esm) void Book::load(ESMReader &esm)
{ {

View file

@ -14,6 +14,8 @@ class ESMWriter;
struct Book struct Book
{ {
static unsigned int sRecordId;
struct BKDTstruct struct BKDTstruct
{ {
float mWeight; float mWeight;

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int BirthSign::sRecordId = REC_BSGN;
void BirthSign::load(ESMReader &esm) void BirthSign::load(ESMReader &esm)
{ {

View file

@ -13,6 +13,8 @@ class ESMWriter;
struct BirthSign struct BirthSign
{ {
static unsigned int sRecordId;
std::string mId, mName, mDescription, mTexture; std::string mId, mName, mDescription, mTexture;
// List of powers and abilities that come with this birth sign. // List of powers and abilities that come with this birth sign.

View file

@ -7,9 +7,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Cell::sRecordId = REC_CELL;
/// Some overloaded compare operators. /// Some overloaded compare operators.
bool operator==(const MovedCellRef& ref, int pRefnum) bool operator==(const MovedCellRef& ref, int pRefnum)

View file

@ -16,7 +16,6 @@ namespace MWWorld
namespace ESM namespace ESM
{ {
class ESMReader; class ESMReader;
class ESMWriter; class ESMWriter;
@ -55,6 +54,8 @@ typedef std::list<CellRef> CellRefTracker;
*/ */
struct Cell struct Cell
{ {
static unsigned int sRecordId;
enum Flags enum Flags
{ {
Interior = 0x01, // Interior cell Interior = 0x01, // Interior cell

View file

@ -4,9 +4,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Class::sRecordId = REC_CLAS;
const Class::Specialization Class::sSpecializationIds[3] = { const Class::Specialization Class::sSpecializationIds[3] = {
Class::Combat, Class::Combat,

View file

@ -17,6 +17,8 @@ class ESMWriter;
// class // class
struct Class struct Class
{ {
static unsigned int sRecordId;
enum AutoCalc enum AutoCalc
{ {
Weapon = 0x00001, Weapon = 0x00001,

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Clothing::sRecordId = REC_CLOT;
void Clothing::load(ESMReader &esm) void Clothing::load(ESMReader &esm)
{ {

View file

@ -17,6 +17,8 @@ class ESMWriter;
struct Clothing struct Clothing
{ {
static unsigned int sRecordId;
enum Type enum Type
{ {
Pants = 0, Pants = 0,

View file

@ -2,6 +2,7 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
@ -24,6 +25,8 @@ void InventoryList::save(ESMWriter &esm) const
} }
} }
unsigned int Container::sRecordId = REC_CONT;
void Container::load(ESMReader &esm) void Container::load(ESMReader &esm)
{ {
mModel = esm.getHNString("MODL"); mModel = esm.getHNString("MODL");

View file

@ -32,6 +32,8 @@ struct InventoryList
struct Container struct Container
{ {
static unsigned int sRecordId;
enum Flags enum Flags
{ {
Organic = 1, // Objects cannot be placed in this container Organic = 1, // Objects cannot be placed in this container

View file

@ -2,9 +2,12 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM { namespace ESM {
unsigned int Creature::sRecordId = REC_CREA;
void Creature::load(ESMReader &esm) void Creature::load(ESMReader &esm)
{ {
mPersistent = esm.getRecordFlags() & 0x0400; mPersistent = esm.getRecordFlags() & 0x0400;

View file

@ -20,6 +20,8 @@ class ESMWriter;
struct Creature struct Creature
{ {
static unsigned int sRecordId;
// Default is 0x48? // Default is 0x48?
enum Flags enum Flags
{ {

View file

@ -17,6 +17,8 @@ class ESMWriter;
/// Changes a creature /// Changes a creature
struct LoadCREC struct LoadCREC
{ {
static unsigned int sRecordId;
std::string mId; std::string mId;
void load(ESMReader &esm) void load(ESMReader &esm)

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Dialogue::sRecordId = REC_DIAL;
void Dialogue::load(ESMReader &esm) void Dialogue::load(ESMReader &esm)
{ {

View file

@ -19,6 +19,8 @@ class ESMWriter;
struct Dialogue struct Dialogue
{ {
static unsigned int sRecordId;
enum Type enum Type
{ {
Topic = 0, Topic = 0,

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Door::sRecordId = REC_DOOR;
void Door::load(ESMReader &esm) void Door::load(ESMReader &esm)
{ {

View file

@ -11,6 +11,8 @@ class ESMWriter;
struct Door struct Door
{ {
static unsigned int sRecordId;
std::string mId, mName, mModel, mScript, mOpenSound, mCloseSound; std::string mId, mName, mModel, mScript, mOpenSound, mCloseSound;
void load(ESMReader &esm); void load(ESMReader &esm);

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Enchantment::sRecordId = REC_ENCH;
void Enchantment::load(ESMReader &esm) void Enchantment::load(ESMReader &esm)
{ {

View file

@ -17,6 +17,8 @@ class ESMWriter;
struct Enchantment struct Enchantment
{ {
static unsigned int sRecordId;
enum Type enum Type
{ {
CastOnce = 0, CastOnce = 0,

View file

@ -4,9 +4,12 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Faction::sRecordId = REC_FACT;
int& Faction::FADTstruct::getSkill (int index, bool ignored) int& Faction::FADTstruct::getSkill (int index, bool ignored)
{ {
if (index<0 || index>=6) if (index<0 || index>=6)

View file

@ -29,6 +29,8 @@ struct RankData
struct Faction struct Faction
{ {
static unsigned int sRecordId;
std::string mId, mName; std::string mId, mName;
struct FADTstruct struct FADTstruct

View file

@ -1,7 +1,11 @@
#include "loadglob.hpp" #include "loadglob.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Global::sRecordId = REC_GLOB;
void Global::load (ESMReader &esm) void Global::load (ESMReader &esm)
{ {
mValue.read (esm, ESM::Variant::Format_Global); mValue.read (esm, ESM::Variant::Format_Global);

View file

@ -17,6 +17,8 @@ class ESMWriter;
struct Global struct Global
{ {
static unsigned int sRecordId;
std::string mId; std::string mId;
Variant mValue; Variant mValue;

View file

@ -1,7 +1,11 @@
#include "loadgmst.hpp" #include "loadgmst.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int GameSetting::sRecordId = REC_GMST;
void GameSetting::load (ESMReader &esm) void GameSetting::load (ESMReader &esm)
{ {
mValue.read (esm, ESM::Variant::Format_Gmst); mValue.read (esm, ESM::Variant::Format_Gmst);

View file

@ -18,6 +18,8 @@ class ESMWriter;
struct GameSetting struct GameSetting
{ {
static unsigned int sRecordId;
std::string mId; std::string mId;
Variant mValue; Variant mValue;

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int DialInfo::sRecordId = REC_INFO;
void DialInfo::load(ESMReader &esm) void DialInfo::load(ESMReader &esm)
{ {

View file

@ -20,6 +20,8 @@ class ESMWriter;
struct DialInfo struct DialInfo
{ {
static unsigned int sRecordId;
enum Gender enum Gender
{ {
Male = 0, Male = 0,

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Ingredient::sRecordId = REC_INGR;
void Ingredient::load(ESMReader &esm) void Ingredient::load(ESMReader &esm)
{ {

View file

@ -15,6 +15,8 @@ class ESMWriter;
struct Ingredient struct Ingredient
{ {
static unsigned int sRecordId;
struct IRDTstruct struct IRDTstruct
{ {
float mWeight; float mWeight;

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Land::sRecordId = REC_LAND;
void Land::LandData::save(ESMWriter &esm) void Land::LandData::save(ESMWriter &esm)
{ {

View file

@ -17,6 +17,8 @@ class ESMWriter;
struct Land struct Land
{ {
static unsigned int sRecordId;
Land(); Land();
~Land(); ~Land();

View file

@ -2,6 +2,7 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
@ -52,4 +53,8 @@ void LeveledListBase::save(ESMWriter &esm) const
mChanceNone = 0; mChanceNone = 0;
mList.clear(); mList.clear();
} }
unsigned int CreatureLevList::sRecordId = REC_LEVC;
unsigned int ItemLevList::sRecordId = REC_LEVI;
} }

View file

@ -59,6 +59,8 @@ struct LeveledListBase
struct CreatureLevList: LeveledListBase struct CreatureLevList: LeveledListBase
{ {
static unsigned int sRecordId;
CreatureLevList() CreatureLevList()
{ {
mRecName = "CNAM"; mRecName = "CNAM";
@ -67,6 +69,8 @@ struct CreatureLevList: LeveledListBase
struct ItemLevList: LeveledListBase struct ItemLevList: LeveledListBase
{ {
static unsigned int sRecordId;
ItemLevList() ItemLevList()
{ {
mRecName = "INAM"; mRecName = "INAM";

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Light::sRecordId = REC_LIGH;
void Light::load(ESMReader &esm) void Light::load(ESMReader &esm)
{ {

View file

@ -16,6 +16,8 @@ class ESMWriter;
struct Light struct Light
{ {
static unsigned int sRecordId;
enum Flags enum Flags
{ {
Dynamic = 0x001, Dynamic = 0x001,

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Lockpick::sRecordId = REC_LOCK;
void Lockpick::load(ESMReader &esm) void Lockpick::load(ESMReader &esm)
{ {

View file

@ -11,6 +11,8 @@ class ESMWriter;
struct Lockpick struct Lockpick
{ {
static unsigned int sRecordId;
struct Data struct Data
{ {
float mWeight; float mWeight;

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int LandTexture::sRecordId = REC_LTEX;
void LandTexture::load(ESMReader &esm) void LandTexture::load(ESMReader &esm)
{ {

View file

@ -27,6 +27,8 @@ class ESMWriter;
struct LandTexture struct LandTexture
{ {
static unsigned int sRecordId;
std::string mId, mTexture; std::string mId, mTexture;
int mIndex; int mIndex;

View file

@ -6,6 +6,7 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace namespace
{ {
@ -34,6 +35,7 @@ namespace
namespace ESM namespace ESM
{ {
unsigned int MagicEffect::sRecordId = REC_MGEF;
void MagicEffect::load(ESMReader &esm) void MagicEffect::load(ESMReader &esm)
{ {

View file

@ -12,6 +12,8 @@ class ESMWriter;
struct MagicEffect struct MagicEffect
{ {
static unsigned int sRecordId;
enum Flags enum Flags
{ {
TargetSkill = 0x1, // Affects a specific skill, which is specified elsewhere in the effect structure. TargetSkill = 0x1, // Affects a specific skill, which is specified elsewhere in the effect structure.

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Miscellaneous::sRecordId = REC_MISC;
void Miscellaneous::load(ESMReader &esm) void Miscellaneous::load(ESMReader &esm)
{ {

View file

@ -16,6 +16,8 @@ class ESMWriter;
struct Miscellaneous struct Miscellaneous
{ {
static unsigned int sRecordId;
struct MCDTstruct struct MCDTstruct
{ {
float mWeight; float mWeight;

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int NPC::sRecordId = REC_NPC_;
void NPC::load(ESMReader &esm) void NPC::load(ESMReader &esm)
{ {

View file

@ -20,6 +20,8 @@ class ESMWriter;
struct NPC struct NPC
{ {
static unsigned int sRecordId;
// Services // Services
enum Services enum Services
{ {

View file

@ -78,6 +78,8 @@ class ESMWriter;
struct LoadNPCC struct LoadNPCC
{ {
static unsigned int sRecordId;
std::string mId; std::string mId;
void load(ESMReader &esm) void load(ESMReader &esm)

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Pathgrid::sRecordId = REC_PGRD;
void Pathgrid::load(ESMReader &esm) void Pathgrid::load(ESMReader &esm)
{ {

View file

@ -15,6 +15,8 @@ class ESMWriter;
*/ */
struct Pathgrid struct Pathgrid
{ {
static unsigned int sRecordId;
struct DATAstruct struct DATAstruct
{ {
int mX, mY; // Grid location, matches cell for exterior cells int mX, mY; // Grid location, matches cell for exterior cells

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Probe::sRecordId = REC_PROB;
void Probe::load(ESMReader &esm) void Probe::load(ESMReader &esm)
{ {

View file

@ -11,6 +11,8 @@ class ESMWriter;
struct Probe struct Probe
{ {
static unsigned int sRecordId;
struct Data struct Data
{ {
float mWeight; float mWeight;

View file

@ -2,9 +2,12 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Race::sRecordId = REC_RACE;
int Race::MaleFemale::getValue (bool male) const int Race::MaleFemale::getValue (bool male) const
{ {
return male ? mMale : mFemale; return male ? mMale : mFemale;

View file

@ -17,6 +17,8 @@ class ESMWriter;
struct Race struct Race
{ {
static unsigned int sRecordId;
struct SkillBonus struct SkillBonus
{ {
int mSkill; // SkillEnum int mSkill; // SkillEnum

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Region::sRecordId = REC_REGN;
void Region::load(ESMReader &esm) void Region::load(ESMReader &esm)
{ {

View file

@ -18,6 +18,8 @@ class ESMWriter;
struct Region struct Region
{ {
static unsigned int sRecordId;
#pragma pack(push) #pragma pack(push)
#pragma pack(1) #pragma pack(1)
struct WEATstruct struct WEATstruct

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Repair::sRecordId = REC_REPA;
void Repair::load(ESMReader &esm) void Repair::load(ESMReader &esm)
{ {

View file

@ -11,6 +11,8 @@ class ESMWriter;
struct Repair struct Repair
{ {
static unsigned int sRecordId;
struct Data struct Data
{ {
float mWeight; float mWeight;

View file

@ -2,6 +2,7 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
@ -12,6 +13,8 @@ struct SCHD
Script::SCHDstruct mData; Script::SCHDstruct mData;
}; };
unsigned int Script::sRecordId = REC_SCPT;
void Script::load(ESMReader &esm) void Script::load(ESMReader &esm)
{ {
SCHD data; SCHD data;

View file

@ -19,6 +19,8 @@ class ESMWriter;
class Script class Script
{ {
public: public:
static unsigned int sRecordId;
struct SCHDstruct struct SCHDstruct
{ {
/* Script name. /* Script name.

View file

@ -6,6 +6,7 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
@ -126,6 +127,8 @@ namespace ESM
HandToHand HandToHand
}}; }};
unsigned int Skill::sRecordId = REC_SKIL;
void Skill::load(ESMReader &esm) void Skill::load(ESMReader &esm)
{ {
esm.getHNT(mIndex, "INDX"); esm.getHNT(mIndex, "INDX");

View file

@ -19,6 +19,8 @@ class ESMWriter;
struct Skill struct Skill
{ {
static unsigned int sRecordId;
std::string mId; std::string mId;
struct SKDTstruct struct SKDTstruct

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int SoundGenerator::sRecordId = REC_SNDG;
void SoundGenerator::load(ESMReader &esm) void SoundGenerator::load(ESMReader &esm)
{ {

View file

@ -15,6 +15,8 @@ class ESMWriter;
struct SoundGenerator struct SoundGenerator
{ {
static unsigned int sRecordId;
enum Type enum Type
{ {
LeftFoot = 0, LeftFoot = 0,

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Sound::sRecordId = REC_SOUN;
void Sound::load(ESMReader &esm) void Sound::load(ESMReader &esm)
{ {

View file

@ -16,6 +16,8 @@ struct SOUNstruct
struct Sound struct Sound
{ {
static unsigned int sRecordId;
SOUNstruct mData; SOUNstruct mData;
std::string mId, mSound; std::string mId, mSound;

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Spell::sRecordId = REC_SPEL;
void Spell::load(ESMReader &esm) void Spell::load(ESMReader &esm)
{ {

View file

@ -13,6 +13,8 @@ class ESMWriter;
struct Spell struct Spell
{ {
static unsigned int sRecordId;
enum SpellType enum SpellType
{ {
ST_Spell = 0, // Normal spell, must be cast and costs mana ST_Spell = 0, // Normal spell, must be cast and costs mana

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int StartScript::sRecordId = REC_SSCR;
void StartScript::load(ESMReader &esm) void StartScript::load(ESMReader &esm)
{ {

View file

@ -19,6 +19,8 @@ class ESMWriter;
struct StartScript struct StartScript
{ {
static unsigned int sRecordId;
std::string mData; std::string mData;
std::string mId, mScript; std::string mId, mScript;

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Static::sRecordId = REC_STAT;
void Static::load(ESMReader &esm) void Static::load(ESMReader &esm)
{ {

View file

@ -22,6 +22,8 @@ class ESMWriter;
struct Static struct Static
{ {
static unsigned int sRecordId;
std::string mId, mModel; std::string mId, mModel;
void load(ESMReader &esm); void load(ESMReader &esm);

View file

@ -4,6 +4,7 @@
#include "esmcommon.hpp" #include "esmcommon.hpp"
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
void ESM::Header::blank() void ESM::Header::blank()
{ {

View file

@ -2,9 +2,11 @@
#include "esmreader.hpp" #include "esmreader.hpp"
#include "esmwriter.hpp" #include "esmwriter.hpp"
#include "defs.hpp"
namespace ESM namespace ESM
{ {
unsigned int Weapon::sRecordId = REC_WEAP;
void Weapon::load(ESMReader &esm) void Weapon::load(ESMReader &esm)
{ {

View file

@ -15,6 +15,8 @@ class ESMWriter;
struct Weapon struct Weapon
{ {
static unsigned int sRecordId;
enum Type enum Type
{ {
ShortBladeOneHand = 0, ShortBladeOneHand = 0,