mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-15 20:49:56 +00:00
90 lines
2.5 KiB
C++
90 lines
2.5 KiB
C++
#ifndef _ESM_SCPT_H
|
|
#define _ESM_SCPT_H
|
|
|
|
#include "esm_reader.hpp"
|
|
|
|
namespace ESM {
|
|
|
|
/*
|
|
* Script definitions
|
|
*/
|
|
|
|
struct Script
|
|
{
|
|
struct SCHDstruct
|
|
{
|
|
/* Script name.
|
|
|
|
NOTE: You should handle the name "Main" (case insensitive) with
|
|
care. With tribunal, modders got the ability to add 'start
|
|
scripts' to their mods, which is a script that is run at
|
|
startup and which runs throughout the game (I think.)
|
|
|
|
However, before Tribunal, there was only one startup script,
|
|
called "Main". If mods wanted to make their own start scripts,
|
|
they had to overwrite Main. This is obviously problem if
|
|
multiple mods to this at the same time.
|
|
|
|
Although most mods have switched to using Trib-style startup
|
|
scripts, some legacy mods might still overwrite Main, and this
|
|
can cause problems if several mods do it. I think the best
|
|
course of action is to NEVER overwrite main, but instead add
|
|
each with a separate unique name and add them to the start
|
|
script list. But there might be other problems with this
|
|
approach though.
|
|
*/
|
|
|
|
NAME32 name;
|
|
|
|
// These describe the sizes we need to allocate for the script
|
|
// data.
|
|
int numShorts, numLongs, numFloats,
|
|
scriptDataSize, stringTableSize;
|
|
}; // 52 bytes
|
|
|
|
SCHDstruct data;
|
|
|
|
std::vector<std::string> varNames; // Variable names
|
|
std::vector<char> scriptData; // Compiled bytecode
|
|
std::string scriptText; // Uncompiled script
|
|
|
|
void load(ESMReader &esm)
|
|
{
|
|
esm.getHNT(data, "SCHD", 52);
|
|
|
|
// List of local variables
|
|
if(esm.isNextSub("SCVR"))
|
|
{
|
|
int s = data.stringTableSize;
|
|
char* tmp = new char[s];
|
|
esm.getHExact(tmp, s);
|
|
|
|
// Set up the list of variable names
|
|
varNames.resize(data.numShorts +
|
|
data.numLongs +
|
|
data.numFloats);
|
|
|
|
// The tmp buffer is a null-byte separated string list, we
|
|
// just have to pick out one string at a time.
|
|
char* str = tmp;
|
|
for(int i=0; i< varNames.size(); i++)
|
|
{
|
|
varNames[i] = std::string(str);
|
|
str += varNames[i].size()+1;
|
|
|
|
if(str - tmp > s)
|
|
esm.fail("String table overflow");
|
|
}
|
|
delete[] tmp;
|
|
}
|
|
|
|
// Script data
|
|
scriptData.resize(data.scriptDataSize);
|
|
esm.getHNExact(&scriptData[0], scriptData.size(), "SCDT");
|
|
|
|
// Script text
|
|
scriptText = esm.getHNOString("SCTX");
|
|
}
|
|
};
|
|
}
|
|
#endif
|