|
|
@ -36,10 +36,10 @@ public:
|
|
|
|
const std::string getDesc() const { return mHeader.mData.desc; }
|
|
|
|
const std::string getDesc() const { return mHeader.mData.desc; }
|
|
|
|
const std::vector<Header::MasterData> &getGameFiles() const { return mHeader.mMaster; }
|
|
|
|
const std::vector<Header::MasterData> &getGameFiles() const { return mHeader.mMaster; }
|
|
|
|
const Header& getHeader() const { return mHeader; }
|
|
|
|
const Header& getHeader() const { return mHeader; }
|
|
|
|
int getFormat() const;
|
|
|
|
int getFormat() const { return mHeader.mFormat; };
|
|
|
|
const NAME &retSubName() const { return mCtx.subName; }
|
|
|
|
const NAME &retSubName() const { return mCtx.subName; }
|
|
|
|
uint32_t getSubSize() const { return mCtx.leftSub; }
|
|
|
|
uint32_t getSubSize() const { return mCtx.leftSub; }
|
|
|
|
std::string getName() const;
|
|
|
|
std::string getName() const {return mCtx.filename; };
|
|
|
|
|
|
|
|
|
|
|
|
/*************************************************************************
|
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
*
|
|
|
@ -73,7 +73,7 @@ public:
|
|
|
|
void openRaw(const std::string &filename);
|
|
|
|
void openRaw(const std::string &filename);
|
|
|
|
|
|
|
|
|
|
|
|
/// Get the current position in the file. Make sure that the file has been opened!
|
|
|
|
/// Get the current position in the file. Make sure that the file has been opened!
|
|
|
|
size_t getFileOffset() const;
|
|
|
|
size_t getFileOffset() const { return mEsm->tellg(); };
|
|
|
|
|
|
|
|
|
|
|
|
// This is a quick hack for multiple esm/esp files. Each plugin introduces its own
|
|
|
|
// This is a quick hack for multiple esm/esp files. Each plugin introduces its own
|
|
|
|
// terrain palette, but ESMReader does not pass a reference to the correct plugin
|
|
|
|
// terrain palette, but ESMReader does not pass a reference to the correct plugin
|
|
|
@ -185,7 +185,7 @@ public:
|
|
|
|
bool peekNextSub(const char* name);
|
|
|
|
bool peekNextSub(const char* name);
|
|
|
|
|
|
|
|
|
|
|
|
// Store the current subrecord name for the next call of getSubName()
|
|
|
|
// Store the current subrecord name for the next call of getSubName()
|
|
|
|
void cacheSubName();
|
|
|
|
void cacheSubName() {mCtx.subCached = true; };
|
|
|
|
|
|
|
|
|
|
|
|
// Read subrecord name. This gets called a LOT, so I've optimized it
|
|
|
|
// Read subrecord name. This gets called a LOT, so I've optimized it
|
|
|
|
// slightly.
|
|
|
|
// slightly.
|
|
|
@ -247,13 +247,13 @@ public:
|
|
|
|
// them from native encoding to UTF8 in the process.
|
|
|
|
// them from native encoding to UTF8 in the process.
|
|
|
|
std::string getString(int size);
|
|
|
|
std::string getString(int size);
|
|
|
|
|
|
|
|
|
|
|
|
void skip(int bytes);
|
|
|
|
void skip(int bytes) { mEsm->seekg(getFileOffset()+bytes); };
|
|
|
|
|
|
|
|
|
|
|
|
/// Used for error handling
|
|
|
|
/// Used for error handling
|
|
|
|
[[noreturn]] void fail(const std::string &msg);
|
|
|
|
[[noreturn]] void fail(const std::string &msg);
|
|
|
|
|
|
|
|
|
|
|
|
/// Sets font encoder for ESM strings
|
|
|
|
/// Sets font encoder for ESM strings
|
|
|
|
void setEncoder(ToUTF8::Utf8Encoder* encoder);
|
|
|
|
void setEncoder(ToUTF8::Utf8Encoder* encoder) { mEncoder = encoder; };
|
|
|
|
|
|
|
|
|
|
|
|
/// Get record flags of last record
|
|
|
|
/// Get record flags of last record
|
|
|
|
unsigned int getRecordFlags() { return mRecordFlags; }
|
|
|
|
unsigned int getRecordFlags() { return mRecordFlags; }
|
|
|
|