|
|
@ -13,6 +13,11 @@ ESM_Context ESMReader::getContext()
|
|
|
|
return mCtx;
|
|
|
|
return mCtx;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ESMReader::ESMReader(void):
|
|
|
|
|
|
|
|
mBuffer(50*1024)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ESMReader::restoreContext(const ESM_Context &rc)
|
|
|
|
void ESMReader::restoreContext(const ESM_Context &rc)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Reopen the file if necessary
|
|
|
|
// Reopen the file if necessary
|
|
|
@ -325,11 +330,21 @@ void ESMReader::getExact(void*x, int size)
|
|
|
|
|
|
|
|
|
|
|
|
std::string ESMReader::getString(int size)
|
|
|
|
std::string ESMReader::getString(int size)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
char *ptr = ToUTF8::getBuffer(size);
|
|
|
|
size_t s = size;
|
|
|
|
mEsm->read(ptr, size);
|
|
|
|
if (mBuffer.size() <= s)
|
|
|
|
|
|
|
|
// Add some extra padding to reduce the chance of having to resize
|
|
|
|
|
|
|
|
// again later.
|
|
|
|
|
|
|
|
mBuffer.resize(3*s);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// And make sure the string is zero terminated
|
|
|
|
|
|
|
|
mBuffer[s] = 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// read ESM data
|
|
|
|
|
|
|
|
char *ptr = &mBuffer[0];
|
|
|
|
|
|
|
|
getExact(ptr, size);
|
|
|
|
|
|
|
|
|
|
|
|
// Convert to UTF8 and return
|
|
|
|
// Convert to UTF8 and return
|
|
|
|
return ToUTF8::getUtf8(mEncoding);
|
|
|
|
return mEncoder.getUtf8(ptr, size);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ESMReader::fail(const std::string &msg)
|
|
|
|
void ESMReader::fail(const std::string &msg)
|
|
|
@ -350,6 +365,7 @@ void ESMReader::fail(const std::string &msg)
|
|
|
|
void ESMReader::setEncoding(const ToUTF8::FromType& encoding)
|
|
|
|
void ESMReader::setEncoding(const ToUTF8::FromType& encoding)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mEncoding = encoding;
|
|
|
|
mEncoding = encoding;
|
|
|
|
|
|
|
|
mEncoder.setEncoding(encoding);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|