|
|
@ -16,7 +16,7 @@ using namespace Misc;
|
|
|
|
ESM_Context ESMReader::getContext()
|
|
|
|
ESM_Context ESMReader::getContext()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Update the file position before returning
|
|
|
|
// Update the file position before returning
|
|
|
|
mCtx.filePos = mEsm->tell();
|
|
|
|
mCtx.filePos = mEsm->tellg();
|
|
|
|
return mCtx;
|
|
|
|
return mCtx;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -44,12 +44,12 @@ void ESMReader::restoreContext(const ESM_Context &rc)
|
|
|
|
mCtx = rc;
|
|
|
|
mCtx = rc;
|
|
|
|
|
|
|
|
|
|
|
|
// Make sure we seek to the right place
|
|
|
|
// Make sure we seek to the right place
|
|
|
|
mEsm->seek(mCtx.filePos);
|
|
|
|
mEsm->seekg(mCtx.filePos);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ESMReader::close()
|
|
|
|
void ESMReader::close()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mEsm.setNull();
|
|
|
|
mEsm.reset();
|
|
|
|
mCtx.filename.clear();
|
|
|
|
mCtx.filename.clear();
|
|
|
|
mCtx.leftFile = 0;
|
|
|
|
mCtx.leftFile = 0;
|
|
|
|
mCtx.leftRec = 0;
|
|
|
|
mCtx.leftRec = 0;
|
|
|
@ -59,15 +59,22 @@ void ESMReader::close()
|
|
|
|
mCtx.subName.val = 0;
|
|
|
|
mCtx.subName.val = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ESMReader::openRaw(Ogre::DataStreamPtr _esm, const std::string &name)
|
|
|
|
void ESMReader::openRaw(Files::IStreamPtr _esm, const std::string& name)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
close();
|
|
|
|
close();
|
|
|
|
mEsm = _esm;
|
|
|
|
mEsm = _esm;
|
|
|
|
mCtx.filename = name;
|
|
|
|
mCtx.filename = name;
|
|
|
|
mCtx.leftFile = mEsm->size();
|
|
|
|
mEsm->seekg(0, mEsm->end);
|
|
|
|
|
|
|
|
mCtx.leftFile = mEsm->tellg();
|
|
|
|
|
|
|
|
mEsm->seekg(0, mEsm->beg);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ESMReader::open(Ogre::DataStreamPtr _esm, const std::string &name)
|
|
|
|
void ESMReader::openRaw(const std::string& filename)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
openRaw(Files::openConstrainedFileStream(filename.c_str()), filename);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void ESMReader::open(Files::IStreamPtr _esm, const std::string &name)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
openRaw(_esm, name);
|
|
|
|
openRaw(_esm, name);
|
|
|
|
|
|
|
|
|
|
|
@ -81,12 +88,7 @@ void ESMReader::open(Ogre::DataStreamPtr _esm, const std::string &name)
|
|
|
|
|
|
|
|
|
|
|
|
void ESMReader::open(const std::string &file)
|
|
|
|
void ESMReader::open(const std::string &file)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
open (openConstrainedFileDataStream (file.c_str ()), file);
|
|
|
|
open (Files::openConstrainedFileStream (file.c_str ()), file);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void ESMReader::openRaw(const std::string &file)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
openRaw (openConstrainedFileDataStream (file.c_str ()), file);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int64_t ESMReader::getHNLong(const char *name)
|
|
|
|
int64_t ESMReader::getHNLong(const char *name)
|
|
|
@ -296,9 +298,7 @@ void ESMReader::getExact(void*x, int size)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
try
|
|
|
|
try
|
|
|
|
{
|
|
|
|
{
|
|
|
|
int t = mEsm->read(x, size);
|
|
|
|
mEsm->read((char*)x, size);
|
|
|
|
if (t != size)
|
|
|
|
|
|
|
|
fail("Read error");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (std::exception& e)
|
|
|
|
catch (std::exception& e)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -340,8 +340,8 @@ void ESMReader::fail(const std::string &msg)
|
|
|
|
ss << "\n File: " << mCtx.filename;
|
|
|
|
ss << "\n File: " << mCtx.filename;
|
|
|
|
ss << "\n Record: " << mCtx.recName.toString();
|
|
|
|
ss << "\n Record: " << mCtx.recName.toString();
|
|
|
|
ss << "\n Subrecord: " << mCtx.subName.toString();
|
|
|
|
ss << "\n Subrecord: " << mCtx.subName.toString();
|
|
|
|
if (!mEsm.isNull())
|
|
|
|
if (mEsm.get())
|
|
|
|
ss << "\n Offset: 0x" << hex << mEsm->tell();
|
|
|
|
ss << "\n Offset: 0x" << hex << mEsm->tellg();
|
|
|
|
throw std::runtime_error(ss.str());
|
|
|
|
throw std::runtime_error(ss.str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -350,4 +350,14 @@ void ESMReader::setEncoder(ToUTF8::Utf8Encoder* encoder)
|
|
|
|
mEncoder = encoder;
|
|
|
|
mEncoder = encoder;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
size_t ESMReader::getFileOffset()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return mEsm->tellg();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void ESMReader::skip(int bytes)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
mEsm->seekg(getFileOffset()+bytes);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|