1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-22 23:23:53 +00:00
openmw/components/esm/loadscpt.cpp

117 lines
3.2 KiB
C++
Raw Normal View History

#include "loadscpt.hpp"
#include "esmreader.hpp"
#include "esmwriter.hpp"
#include "defs.hpp"
2012-09-17 07:37:50 +00:00
namespace ESM
{
struct SCHD
{
NAME32 mName;
Script::SCHDstruct mData;
};
unsigned int Script::sRecordId = REC_SCPT;
void Script::load(ESMReader &esm)
{
SCHD data;
esm.getHNT(data, "SCHD", 52);
mData = data.mData;
mId = data.mName.toString();
// List of local variables
if (esm.isNextSub("SCVR"))
{
2012-09-17 07:37:50 +00:00
int s = mData.mStringTableSize;
std::vector<char> tmp (s);
esm.getHExact (&tmp[0], s);
// Set up the list of variable names
2012-09-17 07:37:50 +00:00
mVarNames.resize(mData.mNumShorts + mData.mNumLongs + mData.mNumFloats);
// The tmp buffer is a null-byte separated string list, we
// just have to pick out one string at a time.
char* str = &tmp[0];
2012-09-17 07:37:50 +00:00
for (size_t i = 0; i < mVarNames.size(); i++)
{
// Support '\r' terminated strings like vanilla. See Bug #1324.
2014-05-17 21:34:13 +00:00
char *termsym = strchr(str, '\r');
if(termsym) *termsym = '\0';
2012-09-17 07:37:50 +00:00
mVarNames[i] = std::string(str);
str += mVarNames[i].size() + 1;
if (str - &tmp[0] > s)
{
// Apparently SCVR subrecord is not used and variable names are
// determined on the fly from the script text. Therefore don't throw
// an exeption, just log an error and continue.
std::stringstream ss;
ss << "ESM Error: " << "String table overflow";
ss << "\n File: " << esm.getName();
ss << "\n Record: " << esm.getContext().recName.toString();
ss << "\n Subrecord: " << "SCVR";
ss << "\n Offset: 0x" << std::hex << esm.getFileOffset();
2014-08-10 08:09:45 +00:00
std::cerr << ss.str() << std::endl;
break;
}
}
}
2012-09-17 07:37:50 +00:00
// Script mData
mScriptData.resize(mData.mScriptDataSize);
esm.getHNExact(&mScriptData[0], mScriptData.size(), "SCDT");
// Script text
2012-09-17 07:37:50 +00:00
mScriptText = esm.getHNOString("SCTX");
}
void Script::save(ESMWriter &esm) const
{
std::string varNameString;
2012-09-17 07:37:50 +00:00
if (!mVarNames.empty())
for (std::vector<std::string>::const_iterator it = mVarNames.begin(); it != mVarNames.end(); ++it)
varNameString.append(*it);
SCHD data;
memset(&data, 0, sizeof(data));
data.mData = mData;
memcpy(data.mName.name, mId.c_str(), mId.size());
esm.writeHNT("SCHD", data, 52);
2013-04-07 13:17:35 +00:00
2012-09-17 07:37:50 +00:00
if (!mVarNames.empty())
{
esm.startSubRecord("SCVR");
for (std::vector<std::string>::const_iterator it = mVarNames.begin(); it != mVarNames.end(); ++it)
{
esm.writeHCString(*it);
}
esm.endRecord("SCVR");
}
esm.startSubRecord("SCDT");
2013-04-07 13:17:35 +00:00
esm.write(reinterpret_cast<const char * >(&mScriptData[0]), mData.mScriptDataSize);
esm.endRecord("SCDT");
2012-09-17 07:37:50 +00:00
esm.writeHNOString("SCTX", mScriptText);
}
2013-04-07 13:17:35 +00:00
void Script::blank()
{
mData.mNumShorts = mData.mNumLongs = mData.mNumFloats = 0;
mData.mScriptDataSize = 0;
mData.mStringTableSize = 0;
mVarNames.clear();
mScriptData.clear();
mScriptText = "Begin " + mId + "\n\nEnd " + mId + "\n";
}
}