1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
|
#ifndef INTERPRETER_MATHOPCODES_H_INCLUDED
#define INTERPRETER_MATHOPCODES_H_INCLUDED
#include <cmath>
#include <stdexcept>
#include "opcodes.hpp"
#include "runtime.hpp"
namespace Interpreter
{
template <typename T>
class OpAddInt : public Opcode0
{
public:
void execute(Runtime& runtime) override
{
T result = getData<T>(runtime[1]) + getData<T>(runtime[0]);
runtime.pop();
getData<T>(runtime[0]) = result;
}
};
template <typename T>
class OpSubInt : public Opcode0
{
public:
void execute(Runtime& runtime) override
{
T result = getData<T>(runtime[1]) - getData<T>(runtime[0]);
runtime.pop();
getData<T>(runtime[0]) = result;
}
};
template <typename T>
class OpMulInt : public Opcode0
{
public:
void execute(Runtime& runtime) override
{
T result = getData<T>(runtime[1]) * getData<T>(runtime[0]);
runtime.pop();
getData<T>(runtime[0]) = result;
}
};
template <typename T>
class OpDivInt : public Opcode0
{
public:
void execute(Runtime& runtime) override
{
T left = getData<T>(runtime[0]);
if (left == 0)
throw std::runtime_error("division by zero");
T result = getData<T>(runtime[1]) / left;
runtime.pop();
getData<T>(runtime[0]) = result;
}
};
template <typename T, typename C>
class OpCompare : public Opcode0
{
public:
void execute(Runtime& runtime) override
{
int result = C()(getData<T>(runtime[1]), getData<T>(runtime[0]));
runtime.pop();
runtime[0].mInteger = result;
}
};
}
#endif
|