|
|
|
#ifndef OPENMW_ESM_DIAL_H
|
|
|
|
#define OPENMW_ESM_DIAL_H
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <list>
|
|
|
|
|
|
|
|
#include "loadinfo.hpp"
|
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
|
|
|
|
class ESMReader;
|
|
|
|
class ESMWriter;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Dialogue topic and journal entries. The actual data is contained in
|
|
|
|
* the INFO records following the DIAL.
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct Dialogue
|
|
|
|
{
|
|
|
|
static unsigned int sRecordId;
|
|
|
|
|
|
|
|
enum Type
|
|
|
|
{
|
|
|
|
Topic = 0,
|
|
|
|
Voice = 1,
|
|
|
|
Greeting = 2,
|
|
|
|
Persuasion = 3,
|
|
|
|
Journal = 4,
|
|
|
|
Deleted = -1
|
|
|
|
};
|
|
|
|
|
|
|
|
std::string mId;
|
|
|
|
signed char mType;
|
|
|
|
|
|
|
|
typedef std::list<DialInfo> InfoContainer;
|
|
|
|
|
|
|
|
InfoContainer mInfo;
|
|
|
|
|
|
|
|
void load(ESMReader &esm);
|
|
|
|
void save(ESMWriter &esm) const;
|
|
|
|
|
|
|
|
/// @param merge Merge with existing list, or just push each record to the end of the list?
|
|
|
|
void addInfo (const ESM::DialInfo& info, bool merge);
|
|
|
|
|
|
|
|
void blank();
|
|
|
|
///< Set record to default state (does not touch the ID and does not change the type).
|
|
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|