#ifndef EXPRESSION_H #define EXPRESSION_H #include #include class ResourceCompiler; class Expression; class CompoundExpr; class IdentifierExpr; typedef std::shared_ptr ExprPtr; typedef std::shared_ptr CompoundExprPtr; typedef std::shared_ptr IdentifierExprPtr; enum class BinaryOp { XOR, OR, AND, SHIFTLEFT, SHIFTRIGHT, EQUAL, NOTEQUAL, PLUS, MINUS, MULTIPLY, DIVIDE }; enum class UnaryOp { MINUS, COMPLEMENT }; class TypeError { }; class Expression { public: virtual int evaluateInt(ResourceCompiler *ctx); virtual ~Expression(); }; class StringExpr : public Expression { std::string str; public: StringExpr(const std::string& str) : str(str) {} ~StringExpr(); }; class IntExpr : public Expression { int val; public: IntExpr(int val) : val(val) {} ~IntExpr(); virtual int evaluateInt(ResourceCompiler *ctx); }; class CompoundExpr : public Expression { std::vector items; public: void addItem(ExprPtr item); ExprPtr getItem(int i) const { return items[i]; } int size() const { return items.size(); } ~CompoundExpr(); }; class BinaryExpr : public Expression { BinaryOp op; ExprPtr a, b; public: BinaryExpr(BinaryOp op, ExprPtr a, ExprPtr b) : op(op), a(a), b(b) {} ~BinaryExpr(); virtual int evaluateInt(ResourceCompiler *ctx); }; class UnaryExpr : public Expression { UnaryOp op; ExprPtr a; public: UnaryExpr(UnaryOp op, ExprPtr a) : op(op), a(a) {} ~UnaryExpr(); virtual int evaluateInt(ResourceCompiler *ctx); }; class IdentifierExpr : public Expression { std::string id; std::vector arguments; bool isFunction; public: IdentifierExpr(std::string id, bool isFunction = false); void addArgument(ExprPtr e); virtual int evaluateInt(ResourceCompiler *ctx); }; #endif // EXPRESSION_H