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
|
|
|
|
2011-04-08 13:58:21 +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.
|
|
|
|
*/
|
|
|
|
|
2012-09-30 19:34:53 +00:00
|
|
|
struct DialInfo
|
2010-02-26 15:36:54 +00:00
|
|
|
{
|
2013-09-24 11:17:28 +00:00
|
|
|
static unsigned int sRecordId;
|
2015-06-14 00:31:00 +00:00
|
|
|
/// Return a string descriptor for this record type. Currently used for debugging / error logs only.
|
|
|
|
static std::string getRecordType() { return "DialInfo"; }
|
2013-09-24 11:17:28 +00:00
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
enum Gender
|
|
|
|
{
|
|
|
|
Male = 0,
|
|
|
|
Female = 1,
|
|
|
|
NA = -1
|
|
|
|
};
|
|
|
|
|
|
|
|
struct DATAstruct
|
|
|
|
{
|
2012-09-17 07:37:50 +00:00
|
|
|
int mUnknown1;
|
2015-01-27 01:21:53 +00:00
|
|
|
union
|
|
|
|
{
|
|
|
|
int mDisposition; // Used for dialogue responses
|
|
|
|
int mJournalIndex; // Used for journal entries
|
|
|
|
};
|
2012-11-08 13:55:31 +00:00
|
|
|
signed char mRank; // Rank of NPC
|
|
|
|
signed char mGender; // See Gender enum
|
|
|
|
signed char mPCrank; // Player rank
|
|
|
|
signed char mUnknown2;
|
2011-04-08 13:58:21 +00:00
|
|
|
}; // 12 bytes
|
2012-09-17 07:37:50 +00:00
|
|
|
DATAstruct mData;
|
2011-04-08 13:58:21 +00:00
|
|
|
|
|
|
|
// 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
|
2013-03-05 08:40:41 +00:00
|
|
|
Variant mValue;
|
2010-02-26 15:36:54 +00:00
|
|
|
};
|
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
// Journal quest indices (introduced with the quest system in Tribunal)
|
|
|
|
enum QuestStatus
|
2010-02-26 15:36:54 +00:00
|
|
|
{
|
2013-10-31 11:54:55 +00:00
|
|
|
QS_None = 0,
|
|
|
|
QS_Name = 1,
|
|
|
|
QS_Finished = 2,
|
|
|
|
QS_Restart = 3,
|
2011-04-08 13:58:21 +00:00
|
|
|
QS_Deleted
|
2010-02-26 15:36:54 +00:00
|
|
|
};
|
|
|
|
|
2011-04-08 13:58:21 +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
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
// Id of this, previous and next INFO items
|
2012-09-30 19:34:53 +00:00
|
|
|
std::string mId, mPrev, mNext;
|
2010-02-26 15:36:54 +00:00
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
// Various references used in determining when to select this item.
|
2013-11-05 10:41:48 +00:00
|
|
|
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
|
|
|
|
2014-01-21 23:02:43 +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
|
|
|
|
2011-04-08 13:58:21 +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
|
|
|
|
2011-04-08 13:58:21 +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
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
// Hexadecimal versions of the various subrecord names.
|
|
|
|
enum SubNames
|
2010-02-26 15:36:54 +00:00
|
|
|
{
|
2011-04-08 13:58:21 +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,
|
2013-03-05 08:40:41 +00:00
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
REC_BNAM = 0x4d414e42,
|
|
|
|
REC_QSTN = 0x4e545351,
|
|
|
|
REC_QSTF = 0x46545351,
|
|
|
|
REC_QSTR = 0x52545351,
|
|
|
|
REC_DELE = 0x454c4544
|
2010-02-26 15:36:54 +00:00
|
|
|
};
|
|
|
|
|
2015-07-07 16:57:08 +00:00
|
|
|
bool mIsDeleted;
|
|
|
|
|
2015-07-09 18:45:24 +00:00
|
|
|
DialInfo();
|
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
void load(ESMReader &esm);
|
2015-07-13 07:53:31 +00:00
|
|
|
///< Loads all sub-records of Info record
|
|
|
|
void loadId(ESMReader &esm);
|
|
|
|
///< Loads only Id of Info record (INAM sub-record)
|
|
|
|
void loadInfo(ESMReader &esm);
|
|
|
|
///< Loads all sub-records of Info record, except INAM sub-record
|
|
|
|
|
2013-09-16 10:32:35 +00:00
|
|
|
void save(ESMWriter &esm) const;
|
2013-10-29 12:18:22 +00:00
|
|
|
|
|
|
|
void blank();
|
|
|
|
///< Set record to default state (does not touch the ID).
|
2010-02-26 15:36:54 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif
|