scummvm/engines/gob/expression.h
2009-11-02 21:54:57 +00:00

179 lines
4.5 KiB
C++

/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* $URL$
* $Id$
*
*/
#ifndef GOB_EXPRESSION_H
#define GOB_EXPRESSION_H
#include "common/scummsys.h"
namespace Gob {
class GobEngine;
enum {
OP_NEG = 1,
OP_ADD = 2,
OP_SUB = 3,
OP_BITOR = 4,
OP_MUL = 5,
OP_DIV = 6,
OP_MOD = 7,
OP_BITAND = 8,
OP_BEGIN_EXPR = 9,
OP_END_EXPR = 10,
OP_NOT = 11,
OP_END_MARKER = 12, // Marks end of an array or string
OP_ARRAY_INT8 = 16,
OP_LOAD_VAR_INT16 = 17,
OP_LOAD_VAR_INT8 = 18,
OP_LOAD_IMM_INT32 = 19,
OP_LOAD_IMM_INT16 = 20,
OP_LOAD_IMM_INT8 = 21,
OP_LOAD_IMM_STR = 22,
OP_LOAD_VAR_INT32 = 23,
OP_LOAD_VAR_INT32_AS_INT16 = 24,
OP_LOAD_VAR_STR = 25,
OP_ARRAY_INT32 = 26,
OP_ARRAY_INT16 = 27,
OP_ARRAY_STR = 28,
OP_FUNC = 29,
OP_OR = 30, // Logical OR
OP_AND = 31, // Logical AND
OP_LESS = 32,
OP_LEQ = 33,
OP_GREATER = 34,
OP_GEQ = 35,
OP_EQ = 36,
OP_NEQ = 37
};
enum {
FUNC_SQRT1 = 0,
FUNC_SQRT2 = 1,
FUNC_SQRT3 = 6,
FUNC_SQR = 5,
FUNC_ABS = 7,
FUNC_RAND = 10
};
enum {
TYPE_IMM_INT8 = OP_LOAD_IMM_INT8, // 21
TYPE_IMM_INT32 = OP_LOAD_IMM_INT32, // 19
TYPE_IMM_INT16 = OP_LOAD_IMM_INT16, // 20
TYPE_IMM_STR = OP_LOAD_IMM_STR, // 22
TYPE_VAR_INT8 = OP_LOAD_VAR_INT8, // 18
TYPE_VAR_INT16 = OP_LOAD_VAR_INT16, // 17
TYPE_VAR_INT32 = OP_LOAD_VAR_INT32, // 23
TYPE_VAR_STR = OP_LOAD_VAR_STR, // 25
TYPE_ARRAY_INT8 = OP_ARRAY_INT8, // 16
TYPE_ARRAY_INT16 = OP_ARRAY_INT16, // 27
TYPE_ARRAY_INT32 = OP_ARRAY_INT32, // 26
TYPE_ARRAY_STR = OP_ARRAY_STR, // 28
TYPE_VAR_INT32_AS_INT16 = OP_LOAD_VAR_INT32_AS_INT16 // 24
};
enum {
// FIXME: The following two 'truth values' are stored inside the list
// of "operators". So they somehow coincide with OP_LOAD_VAR_INT32
// and OP_LOAD_VAR_INT32_AS_INT16. I haven't yet quite understood
// how, resp. what that means. You have been warned.
GOB_TRUE = 24,
GOB_FALSE = 23
};
class Expression {
public:
Expression(GobEngine *vm);
virtual ~Expression() {}
void skipExpr(char stopToken);
void printExpr(char stopToken);
void printVarIndex();
int16 parseVarIndex(uint16 *size = 0, uint16 *type = 0);
int16 parseValExpr(byte stopToken = 99);
int16 parseExpr(byte stopToken, byte *type);
int32 getResultInt();
char *getResultStr();
private:
class Stack {
public:
byte *opers;
int32 *values;
Stack(size_t size = 20);
~Stack();
};
class StackFrame {
public:
byte *opers;
int32 *values;
int16 pos;
StackFrame(const Stack &stack);
void push(int count = 1);
void pop(int count = 1);
};
enum PointerType {
kExecPtr = 0,
kInterVar = 1,
kResStr = 2
};
GobEngine *_vm;
int32 _resultInt;
char _resultStr[200];
int32 encodePtr(byte *ptr, int type);
byte *decodePtr(int32 n);
void printExpr_internal(char stopToken);
bool getVarBase(uint32 &varBase, bool mindStop = false,
uint16 *size = 0, uint16 *type = 0);
int cmpHelper(const StackFrame &stackFrame);
void loadValue(byte operation, uint32 varBase, const StackFrame &stackFrame);
void simpleArithmetic1(StackFrame &stackFrame);
void simpleArithmetic2(StackFrame &stackFrame);
bool complexArithmetic(Stack &stack, StackFrame &stackFrame, int16 brackStart);
void getResult(byte operation, int32 value, byte *type);
};
} // End of namespace Gob
#endif // GOB_EXPRESSION_H