1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-15 21:49:56 +00:00
openmw-tes3mp/components/esm/loadinfo.hpp

112 lines
2.5 KiB
C++
Raw Normal View History

2012-09-23 18:11:08 +00:00
#ifndef OPENMW_ESM_INFO_H
#define OPENMW_ESM_INFO_H
2010-02-26 15:36:54 +00:00
2012-09-17 07:37:50 +00:00
#include <string>
#include <vector>
2010-02-26 15:36:54 +00:00
#include "defs.hpp"
2013-03-04 12:59:06 +00:00
#include "variant.hpp"
2010-02-26 15:36:54 +00:00
namespace ESM
{
2010-02-26 15:36:54 +00:00
2012-09-30 20:51:54 +00:00
class ESMReader;
class ESMWriter;
2010-02-26 15:36:54 +00:00
/*
* Dialogue information. A series of these follow after DIAL records,
* and form a linked list of dialogue items.
*/
struct DialInfo
2010-02-26 15:36:54 +00:00
{
static unsigned int sRecordId;
enum Gender
{
Male = 0,
Female = 1,
NA = -1
};
struct DATAstruct
{
2012-09-17 07:37:50 +00:00
int mUnknown1;
int mDisposition;
signed char mRank; // Rank of NPC
signed char mGender; // See Gender enum
signed char mPCrank; // Player rank
signed char mUnknown2;
}; // 12 bytes
2012-09-17 07:37:50 +00:00
DATAstruct mData;
// The rules for whether or not we will select this dialog item.
struct SelectStruct
2010-02-26 15:36:54 +00:00
{
2012-09-17 07:37:50 +00:00
std::string mSelectRule; // This has a complicated format
Variant mValue;
2010-02-26 15:36:54 +00:00
};
// Journal quest indices (introduced with the quest system in Tribunal)
enum QuestStatus
2010-02-26 15:36:54 +00:00
{
QS_None = 0,
QS_Name = 1,
QS_Finished = 2,
QS_Restart = 3,
QS_Deleted
2010-02-26 15:36:54 +00:00
};
// Rules for when to include this item in the final list of options
// visible to the player.
2012-09-17 07:37:50 +00:00
std::vector<SelectStruct> mSelects;
2010-02-26 15:36:54 +00:00
// Id of this, previous and next INFO items
std::string mId, mPrev, mNext;
2010-02-26 15:36:54 +00:00
// Various references used in determining when to select this item.
std::string mActor, mRace, mClass, mFaction, mPcFaction, mCell;
2010-02-26 15:36:54 +00:00
2012-09-17 07:37:50 +00:00
// Sound and text associated with this item
std::string mSound, mResponse;
2010-02-26 15:36:54 +00:00
// Result script (uncompiled) to run whenever this dialog item is
2012-09-17 07:37:50 +00:00
// selected
std::string mResultScript;
2010-02-26 15:36:54 +00:00
// ONLY include this item the NPC is not part of any faction.
2012-09-17 07:37:50 +00:00
bool mFactionLess;
2010-02-26 15:36:54 +00:00
// Status of this quest item
2012-09-17 07:37:50 +00:00
QuestStatus mQuestStatus;
2010-02-26 15:36:54 +00:00
// Hexadecimal versions of the various subrecord names.
enum SubNames
2010-02-26 15:36:54 +00:00
{
REC_ONAM = 0x4d414e4f,
REC_RNAM = 0x4d414e52,
REC_CNAM = 0x4d414e43,
REC_FNAM = 0x4d414e46,
REC_ANAM = 0x4d414e41,
REC_DNAM = 0x4d414e44,
REC_SNAM = 0x4d414e53,
REC_NAME = 0x454d414e,
REC_SCVR = 0x52564353,
REC_BNAM = 0x4d414e42,
REC_QSTN = 0x4e545351,
REC_QSTF = 0x46545351,
REC_QSTR = 0x52545351,
REC_DELE = 0x454c4544
2010-02-26 15:36:54 +00:00
};
void load(ESMReader &esm);
void save(ESMWriter &esm) const;
void blank();
///< Set record to default state (does not touch the ID).
2010-02-26 15:36:54 +00:00
};
}
#endif