1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-22 03:53:52 +00:00
openmw-tes3mp/components/interpreter/runtime.cpp

117 lines
2.5 KiB
C++
Raw Normal View History

2010-06-28 17:20:45 +00:00
#include "runtime.hpp"
2010-06-28 19:49:48 +00:00
#include <stdexcept>
#include <cassert>
#include <cstring>
2010-06-28 19:49:48 +00:00
2010-06-28 17:20:45 +00:00
namespace Interpreter
{
2013-07-31 16:46:32 +00:00
Runtime::Runtime() : mContext (0), mCode (0), mPC (0), mCodeSize(0) {}
2010-06-28 18:46:15 +00:00
int Runtime::getPC() const
{
return mPC;
}
2010-06-28 19:49:48 +00:00
int Runtime::getIntegerLiteral (int index) const
{
assert (index>=0 && index<static_cast<int> (mCode[1]));
2010-06-28 19:49:48 +00:00
const Type_Code *literalBlock = mCode + 4 + mCode[0];
2010-06-28 19:49:48 +00:00
return *reinterpret_cast<const int *> (&literalBlock[index]);
}
2010-06-28 19:49:48 +00:00
float Runtime::getFloatLiteral (int index) const
{
assert (index>=0 && index<static_cast<int> (mCode[2]));
2010-06-28 19:49:48 +00:00
const Type_Code *literalBlock = mCode + 4 + mCode[0] + mCode[1];
2010-06-28 19:49:48 +00:00
return *reinterpret_cast<const float *> (&literalBlock[index]);
}
std::string Runtime::getStringLiteral (int index) const
{
assert (index>=0 && static_cast<int> (mCode[3])>0);
const char *literalBlock =
reinterpret_cast<const char *> (mCode + 4 + mCode[0] + mCode[1] + mCode[2]);
int offset = 0;
for (; index; --index)
{
offset += std::strlen (literalBlock+offset) + 1;
assert (offset/4<static_cast<int> (mCode[3]));
}
return literalBlock+offset;
}
void Runtime::configure (const Type_Code *code, int codeSize, Context& context)
{
2010-06-28 17:20:45 +00:00
clear();
mContext = &context;
2010-06-28 17:20:45 +00:00
mCode = code;
mCodeSize = codeSize;
2010-06-28 18:46:15 +00:00
mPC = 0;
2010-06-28 17:20:45 +00:00
}
void Runtime::clear()
{
mContext = 0;
2010-06-28 17:20:45 +00:00
mCode = 0;
mCodeSize = 0;
2010-06-28 19:49:48 +00:00
mStack.clear();
2010-06-28 17:20:45 +00:00
}
2010-06-28 18:46:15 +00:00
void Runtime::setPC (int PC)
{
mPC = PC;
}
void Runtime::push (const Data& data)
2010-06-28 19:49:48 +00:00
{
mStack.push_back (data);
}
void Runtime::push (Type_Integer value)
{
Data data;
data.mInteger = value;
push (data);
}
void Runtime::push (Type_Float value)
{
Data data;
data.mFloat = value;
push (data);
}
2010-06-28 19:49:48 +00:00
void Runtime::pop()
{
if (mStack.empty())
throw std::runtime_error ("stack underflow");
2010-06-28 19:49:48 +00:00
mStack.resize (mStack.size()-1);
}
Data& Runtime::operator[] (int Index)
2010-06-28 19:49:48 +00:00
{
if (Index<0 || Index>=static_cast<int> (mStack.size()))
throw std::runtime_error ("stack index out of range");
2010-06-28 19:49:48 +00:00
return mStack[mStack.size()-Index-1];
}
2010-06-28 19:49:48 +00:00
Context& Runtime::getContext()
{
assert (mContext);
return *mContext;
2010-06-28 19:49:48 +00:00
}
2010-06-28 17:20:45 +00:00
}