/* * ORXONOX - the hottest 3D action shooter ever to exist * > www.orxonox.net < * * * License notice: * * 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. * * Author: * Fabian 'x3n' Landau * Co-authors: * ... * * Inspiration: Executor by Benjamin Grauer */ #ifndef _Executor_H__ #define _Executor_H__ #include "core/CorePrereqs.h" #include #include "util/MultiType.h" #include "Functor.h" #include "ExecutorPtr.h" namespace orxonox { class _CoreExport Executor { public: Executor(const FunctorPtr& functor, const std::string& name = ""); Executor(const Executor& other); virtual ~Executor(); inline MultiType operator()() const { return (*this->functor_)(this->defaultValue_[0], this->defaultValue_[1], this->defaultValue_[2], this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(const MultiType& param1) const { return (*this->functor_)(param1, this->defaultValue_[1], this->defaultValue_[2], this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(const MultiType& param1, const MultiType& param2) const { return (*this->functor_)(param1, param2, this->defaultValue_[2], this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(const MultiType& param1, const MultiType& param2, const MultiType& param3) const { return (*this->functor_)(param1, param2, param3, this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(const MultiType& param1, const MultiType& param2, const MultiType& param3, const MultiType& param4) const { return (*this->functor_)(param1, param2, param3, param4, this->defaultValue_[4]); } inline MultiType operator()(const MultiType& param1, const MultiType& param2, const MultiType& param3, const MultiType& param4, const MultiType& param5) const { return (*this->functor_)(param1, param2, param3, param4, param5); } MultiType parse(const std::string& arguments, int* error = 0, const std::string& delimiter = " ", bool bPrintError = false) const; MultiType parse(const SubString& arguments, int* error = 0, const std::string& delimiter = " ", bool bPrintError = false) const; int evaluateParams(const SubString& arguments, MultiType param[MAX_FUNCTOR_ARGUMENTS], int* error = 0, const std::string& delimiter = " ") const; inline void setFunctor(const FunctorPtr& functor) { this->functor_ = functor; } inline const FunctorPtr& getFunctor() const { return this->functor_; } inline void setName(const std::string& name) { this->name_ = name; } inline const std::string& getName() const { return this->name_; } inline unsigned int getParamCount() const { return this->functor_->getParamCount(); } inline bool hasReturnvalue() const { return this->functor_->hasReturnvalue(); } inline Functor::Type::Enum getType() const { return this->functor_->getType(); } inline std::string getTypenameParam(unsigned int param) const { return this->functor_->getTypenameParam(param); } inline std::string getTypenameReturnvalue() const { return this->functor_->getTypenameReturnvalue(); } void setDefaultValues(const MultiType& param1); void setDefaultValues(const MultiType& param1, const MultiType& param2); void setDefaultValues(const MultiType& param1, const MultiType& param2, const MultiType& param3); void setDefaultValues(const MultiType& param1, const MultiType& param2, const MultiType& param3, const MultiType& param4); void setDefaultValues(const MultiType& param1, const MultiType& param2, const MultiType& param3, const MultiType& param4, const MultiType& param5); void setDefaultValue(unsigned int index, const MultiType& param); inline MultiType getDefaultValue(unsigned int index) const { if (index < MAX_FUNCTOR_ARGUMENTS) return this->defaultValue_[index]; return MT_Type::Null; } bool allDefaultValuesSet() const; inline bool defaultValueSet(unsigned int index) const { if (index < MAX_FUNCTOR_ARGUMENTS) return !this->defaultValue_[index].null(); return false; } protected: FunctorPtr functor_; std::string name_; MultiType defaultValue_[MAX_FUNCTOR_ARGUMENTS]; }; class _CoreExport ExecutorStatic : public Executor { public: ExecutorStatic(const FunctorStaticPtr& functor, const std::string& name = "") : Executor(functor, name) {} virtual ~ExecutorStatic() {} }; template class ExecutorMember : public Executor { public: ExecutorMember(const FunctorMemberPtr& functor, const std::string& name = "") : Executor(functor, name), functorMember_(functor) {} virtual ~ExecutorMember() {} using Executor::operator(); inline MultiType operator()(T* object) const { return (*this->functorMember_)(object, this->defaultValue_[0], this->defaultValue_[1], this->defaultValue_[2], this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(T* object, const MultiType& param1) const { return (*this->functorMember_)(object, param1, this->defaultValue_[1], this->defaultValue_[2], this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(T* object, const MultiType& param1, const MultiType& param2) const { return (*this->functorMember_)(object, param1, param2, this->defaultValue_[2], this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(T* object, const MultiType& param1, const MultiType& param2, const MultiType& param3) const { return (*this->functorMember_)(object, param1, param2, param3, this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(T* object, const MultiType& param1, const MultiType& param2, const MultiType& param3, const MultiType& param4) const { return (*this->functorMember_)(object, param1, param2, param3, param4, this->defaultValue_[4]); } inline MultiType operator()(T* object, const MultiType& param1, const MultiType& param2, const MultiType& param3, const MultiType& param4, const MultiType& param5) const { return (*this->functorMember_)(object, param1, param2, param3, param4, param5); } inline MultiType operator()(const T* object) const { return (*this->functorMember_)(object, this->defaultValue_[0], this->defaultValue_[1], this->defaultValue_[2], this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(const T* object, const MultiType& param1) const { return (*this->functorMember_)(object, param1, this->defaultValue_[1], this->defaultValue_[2], this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(const T* object, const MultiType& param1, const MultiType& param2) const { return (*this->functorMember_)(object, param1, param2, this->defaultValue_[2], this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(const T* object, const MultiType& param1, const MultiType& param2, const MultiType& param3) const { return (*this->functorMember_)(object, param1, param2, param3, this->defaultValue_[3], this->defaultValue_[4]); } inline MultiType operator()(const T* object, const MultiType& param1, const MultiType& param2, const MultiType& param3, const MultiType& param4) const { return (*this->functorMember_)(object, param1, param2, param3, param4, this->defaultValue_[4]); } inline MultiType operator()(const T* object, const MultiType& param1, const MultiType& param2, const MultiType& param3, const MultiType& param4, const MultiType& param5) const { return (*this->functorMember_)(object, param1, param2, param3, param4, param5); } inline void setObject(T* object) const { this->functorMember_->setObject(object); } inline void setObject(const T* object) const { this->functorMember_->setObject(object); } using Executor::parse; MultiType parse(T* object, const std::string& params, int* error = 0, const std::string& delimiter = " ", bool bPrintError = false) const { T* oldobject = this->functorMember_->getObject(); this->functorMember_->setObject(object); const MultiType& result = this->Executor::parse(params, error, delimiter, bPrintError); this->functorMember_->setObject(oldobject); return result; } MultiType parse(const T* object, const std::string& params, int* error = 0, const std::string& delimiter = " ", bool bPrintError = false) const { T* oldobject = this->functorMember_->getObject(); this->functorMember_->setObject(object); const MultiType& result = this->Executor::parse(params, error, delimiter, bPrintError); this->functorMember_->setObjects(oldobject); return result; } protected: FunctorMemberPtr functorMember_; }; inline ExecutorPtr createExecutor(const FunctorPtr& functor, const std::string& name = "") { return new Executor(functor, name); } template inline ExecutorMemberPtr createExecutor(const FunctorMemberPtr& functor, const std::string& name = "") { return new ExecutorMember(functor, name); } inline ExecutorStaticPtr createExecutor(const FunctorStaticPtr& functor, const std::string& name = "") { return new ExecutorStatic(functor, name); } } #endif /* _Executor_H__ */