mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-09 21:42:13 +00:00
91 lines
2.5 KiB
C++
91 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
|