/****************************************************************************** * Icinga 2 * * Copyright (C) 2012-2014 Icinga Development Team (http://www.icinga.org) * * * * 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 St, Fifth Floor, Boston, MA 02110-1301, USA. * ******************************************************************************/ #ifndef EXPRESSION_H #define EXPRESSION_H #include "config/i2-config.hpp" #include "base/debuginfo.hpp" #include "base/array.hpp" #include "base/dictionary.hpp" namespace icinga { struct DebugHint { std::vector > Messages; std::map Children; inline void AddMessage(const String& message, const DebugInfo& di) { Messages.push_back(std::make_pair(message, di)); } inline DebugHint *GetChild(const String& name) { return &Children[name]; } Dictionary::Ptr ToDictionary(void) const; }; enum CombinedSetOp { OpSetLiteral, OpSetAdd, OpSetSubtract, OpSetMultiply, OpSetDivide }; /** * @ingroup config */ class I2_CONFIG_API Expression : public Object { public: DECLARE_OBJECT(Expression); typedef Value (*OpCallback)(const Expression *, const Dictionary::Ptr&, DebugHint *dhint); Expression(OpCallback op, const Value& operand1, const DebugInfo& di); Expression(OpCallback op, const Value& operand1, const Value& operand2, const DebugInfo& di); Value Evaluate(const Dictionary::Ptr& locals, DebugHint *dhint = NULL) const; void MakeInline(void); void Dump(std::ostream& stream, int indent = 0) const; static Value OpLiteral(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpVariable(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpNegate(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpLogicalNegate(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpAdd(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpSubtract(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpMultiply(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpDivide(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpBinaryAnd(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpBinaryOr(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpShiftLeft(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpShiftRight(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpEqual(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpNotEqual(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpLessThan(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpGreaterThan(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpLessThanOrEqual(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpGreaterThanOrEqual(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpIn(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpNotIn(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpLogicalAnd(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpLogicalOr(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpFunctionCall(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpArray(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpDict(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpSet(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpIndexer(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpImport(const Expression *expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpFunction(const Expression* expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpApply(const Expression* expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpObject(const Expression* expr, const Dictionary::Ptr& locals, DebugHint *dhint); static Value OpFor(const Expression* expr, const Dictionary::Ptr& locals, DebugHint *dhint); private: OpCallback m_Operator; Value m_Operand1; Value m_Operand2; DebugInfo m_DebugInfo; Value EvaluateOperand1(const Dictionary::Ptr& locals, DebugHint *dhint = NULL) const; Value EvaluateOperand2(const Dictionary::Ptr& locals, DebugHint *dhint = NULL) const; static void DumpOperand(std::ostream& stream, const Value& operand, int indent); static Value FunctionWrapper(const std::vector& arguments, const Array::Ptr& funcargs, const Expression::Ptr& expr, const Dictionary::Ptr& scope); }; I2_CONFIG_API Expression::Ptr MakeLiteral(const Value& lit = Value()); } #endif /* EXPRESSION_H */