Changeset 5135 in orxonox.OLD for trunk/src/util
- Timestamp:
- Aug 26, 2005, 12:51:27 PM (19 years ago)
- Location:
- trunk/src/util
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/util/loading/load_param.h
r5133 r5135 57 57 #define LOAD_PARAM_END_CYCLE element = element->NextSiblingElement(); \ 58 58 } 59 60 61 62 /**63 useable FunctionParameters are:64 l_INT: int65 l_LONG: long66 l_SHORT: short67 l_FLOAT: float68 l_STRING: const char*69 l_XML_ELEM: TiXmlElement*70 */71 72 #define l_BOOL_TYPE bool //!< The type of an BOOL73 #define l_BOOL_FUNC isBool //!< The function to call to parse BOOL74 #define l_BOOL_NAME "bool" //!< The name of an BOOL75 #define l_BOOL_DEFAULT false //!< a default Value for an BOOL76 77 78 #define l_INT_TYPE int //!< The type of an INT79 #define l_INT_FUNC isInt //!< The function to call to parse INT80 #define l_INT_NAME "int" //!< The name of an INT81 #define l_INT_DEFAULT 0 //!< a default Value for an INT82 83 #define l_UINT_TYPE unsigned int //!< The type of an UINT84 #define l_UINT_FUNC isInt //!< The function to call to parse UINT85 #define l_UINT_NAME "unsigned int" //!< The name of an UINT86 #define l_UINT_DEFAULT 0 //!< a default Value for an UINT87 88 #define l_LONG_TYPE long //!< The type of a LONG89 #define l_LONG_FUNC isInt //!< The function to parse a LONG90 #define l_LONG_NAME "long" //!< The name of a LONG91 #define l_LONG_DEFAULT 0 //!< a default Value for a LONG92 93 // #define l_SHORT_TYPE short //!< The type of a SHORT94 // #define l_SHORT_FUNC atoi //!< The function to parse a SHORT95 // #define l_SHORT_NAME "short" //!< The name of a SHORT96 // #define l_SHORT_DEFAULT 0 //!< a default Value for a SHORT97 98 #define l_FLOAT_TYPE float //!< The type of a FLOAT99 #define l_FLOAT_FUNC isFloat //!< The function to parse a FLOAT100 #define l_FLOAT_NAME "float" //!< The name of a FLOAT101 #define l_FLOAT_DEFAULT 0.0 //!< a default Value for a FLOAT102 103 //#define l_VECTOR_TYPE const Vector& //!< The type of a VECTOR104 //#define l_VECTOR_FUNC isVector //!< The function to parse a VECTOR105 //#define l_VECTOR_NAME "Vector[x/y/z]" //!< The name of a VECTOR106 //#define l_VECTOR_DEFAULT Vector(0,0,0) //!< Default value for a VECTOR107 108 #define l_STRING_TYPE const char* //!< The type of a STRING109 #define l_STRING_FUNC isString //!< The function to parse a STRING110 #define l_STRING_NAME "string" //!< The name of a STRING111 #define l_STRING_DEFAULT "" //!< a default Value for an STRING112 113 #define l_XML_ELEM_TYPE const TiXmlElement* //!< The type of an XML_ELEM114 #define l_XML_ELEM_FUNC //!< The function to parse an XML_ELEM115 #define l_XML_ELEM_NAME "XML" //!< The name of an XML_ELEM116 #define l_XML_ELEM_DEFAULT NULL //!< The dafault Value for an XML_ELEM117 59 118 60 -
trunk/src/util/shell.cc
r5130 r5135 78 78 //void ShellCommand<T>::registerCommand(const char* commandName, ClassID classID, T* object, void* functionPointer, unsigned int paramCount, ...) 79 79 80 ShellCommand<Shell>::registerCommand("clear", CL_NULL, this, &Shell::clear , 0, 1);80 ShellCommand<Shell>::registerCommand("clear", CL_NULL, this, &Shell::clear); 81 81 } 82 82 … … 457 457 this->inputHistory->add(newCommand); 458 458 459 if (!strcmp(this->inputLine, "clear")) 460 { 461 this->clear(); 462 } 459 ShellCommandBase::execute(this->inputLine); 460 // if (!strcmp(this->inputLine, "clear")) 461 // { 462 // this->clear(); 463 // } 463 464 464 465 this->flushInputLine(); -
trunk/src/util/shell_command.cc
r5130 r5135 28 28 using namespace std; 29 29 30 ShellCommandBase::ShellCommandBase(const char* commandName, ClassID classID, void* functionPointer, unsigned int paramCount, va_list parameters)30 ShellCommandBase::ShellCommandBase(const char* commandName, ClassID classID, unsigned int paramCount, ...) 31 31 { 32 va_list parameters; 33 va_start(parameters, paramCount); 34 32 35 this->classID = classID; 33 this->functionPointer = functionPointer;34 36 this->commandName = new char[strlen(commandName)+1]; 35 37 strcpy(this->commandName, commandName); … … 37 39 // handling parameters, and storing them: 38 40 this->paramCount = paramCount; 39 this->parameters = new ShellParameterType[paramCount];41 this->parameters = new ParameterType[paramCount]; 40 42 41 43 for (unsigned int i = 0; i < paramCount; i++) … … 55 57 tList<ShellCommandBase>* ShellCommandBase::commandList = NULL; 56 58 57 bool ShellCommandBase::isRegistered(const char* commandName, ClassID classID, unsigned int paramCount, va_list parameters)59 bool ShellCommandBase::isRegistered(const char* commandName, ClassID classID, unsigned int paramCount, ...) 58 60 { 61 62 va_list parameters; 63 va_start(parameters, paramCount); 64 59 65 if (ShellCommandBase::commandList == NULL) 60 66 { … … 80 86 81 87 88 bool ShellCommandBase::execute(const char* executionString) 89 { 90 if (ShellCommandBase::commandList == NULL) 91 return false; 92 93 const char* commandEnd = strchr(executionString, ' '); 94 if (commandEnd == NULL) 95 commandEnd = executionString + strlen(executionString); 96 97 tIterator<ShellCommandBase>* iterator = ShellCommandBase::commandList->getIterator(); 98 ShellCommandBase* elem = iterator->firstElement(); 99 while(elem != NULL) 100 { 101 if (!strncmp(executionString, elem->commandName, commandEnd - executionString)) 102 { 103 elem->executeCommand(commandEnd); 104 delete iterator; 105 return true; 106 } 107 elem = iterator->nextElement(); 108 } 109 delete iterator; 110 return true; 111 } 112 -
trunk/src/util/shell_command.h
r5130 r5135 13 13 #define MAX_SHELL_COMMAND_SIZE 14 14 15 typedef enum ShellParameterType 16 { 17 ShellParameterNull, 18 ShellParameterChar, 19 ShellParameterString, 20 ShellParameterInt, 21 ShellParameterUInt, 22 ShellParameterFloat, 23 /* ... */ 24 }; 15 #include "functor_list.h" 25 16 26 17 … … 29 20 template<class T> class tIterator; 30 21 22 23 /////////////////////// 24 // MACRO DEFINITIONS // 25 /////////////////////// 26 27 28 #define ShellCommand2(type1, type2) \ 29 public: \ 30 static void registerCommand(const char* commandName, ClassID classID, T* object, void (T::*function)(type1##_TYPE, type2##_TYPE) \ 31 type1##_TYPE default1 = type1##_DEFAULT, type2##_TYPE default2 = type2##_DEFAULT) \ 32 { \ 33 if (isRegistered(commandName, classID, 2, type1##_PARAM, type2##_PARAM) == true) \ 34 return; \ 35 else \ 36 ShellCommand<T>* newCommand = new ShellCommand<T>(commandName, classID, object, function); \ 37 } \ 38 private: \ 39 void (T::*functionPointer_##type1_##type2)(type1##_TYPE, type2##_TYPE); \ 40 ShellCommand(const char* commandName, ClassID classID, T* object, void (T::*function)(type1##_TYPE, type2##_TYPE) \ 41 type1##_TYPE default1 = type1##_DEFAULT, type2##_TYPE default2 = type2##_DEFAULT) \ 42 { \ 43 this->functionPointer_##type1_##type2 = function; \ 44 } 45 46 47 //////////////// 48 // BASE CLASS // 49 //////////////// 50 //! a baseClass for all possible ShellCommands 31 51 class ShellCommandBase : public BaseObject 32 52 { … … 34 54 static bool execute (const char* executionString); 35 55 36 // virtual void execute (...);56 virtual void executeCommand (const char* parameters) = NULL; 37 57 38 58 protected: 39 ShellCommandBase(const char* commandName, ClassID classID, void* functionPointer, unsigned int paramCount, va_list parameters);59 ShellCommandBase(const char* commandName, ClassID classID, unsigned int paramCount, ...); 40 60 ~ShellCommandBase(); 41 61 42 static bool isRegistered(const char* commandName, ClassID classID, unsigned int paramCount, va_list parameters);62 static bool isRegistered(const char* commandName, ClassID classID, unsigned int paramCount, ...); 43 63 44 64 … … 46 66 void* functionPointer; //!< The pointeer to the function of the Class (or static pointer if ClassID == CL_NULL ) 47 67 unsigned int paramCount; //!< the count of parameters 48 ShellParameterType*parameters; //!< Parameters68 ParameterType* parameters; //!< Parameters 49 69 50 70 private: … … 56 76 }; 57 77 78 79 80 58 81 //! keeps information about a ShellCommand 59 82 template<class T> class ShellCommand : public ShellCommandBase 60 83 { 61 84 public: 62 static void registerCommand(const char* commandName, ClassID classID, T* object, void (T::*functionPointer)(), unsigned int paramCount, ...);63 64 85 static void unregisterCommand(const char* commandNaame, ClassID classID); 65 86 87 static void registerCommand(const char* commandName, ClassID classID, T* object, void (T::*functionPointer)()) 88 { 89 if (isRegistered(commandName, classID, 0)== true) 90 return; 91 else 92 ShellCommand<T>* newCommand = new ShellCommand<T>(commandName, classID, object, functionPointer); 93 } 66 94 private: 67 ShellCommand(const char* command, ClassID classID, T* object, void* functionPointer, unsigned int paramCount, va_list parameters); 95 void (T::*functionPointer_NULL)(); 96 ShellCommand(const char* commandName, ClassID classID, T* object, void (T::*functionPointer)()) 97 : ShellCommandBase (commandName, classID, 0) 98 { 99 this->functionPointer_NULL = functionPointer; 100 this->objectPointer = object; 101 } 102 virtual void executeCommand (const char* parameters) 103 { 104 if (this->paramCount == 0) 105 (objectPointer->*functionPointer_NULL)(); 106 } 107 108 109 110 #define FUNCTOR_LIST(x) ShellCommand ## x 111 //#include "functor_list.h" 112 //ShellCommand2(l_INT, l_INT); 113 #undef FUNCTOR_LIST 114 115 private: 68 116 69 117 … … 72 120 }; 73 121 74 template<class T>75 ShellCommand<T>::ShellCommand(const char* commandName, ClassID classID, T* object, void* functionPointer, unsigned int paramCount, va_list parameters)76 : ShellCommandBase (commandName, classID, functionPointer, paramCount, parameters)77 {78 122 79 }80 81 template<class T>82 void ShellCommand<T>::registerCommand(const char* commandName, ClassID classID, T* object, void (T::*functionPointer)(), unsigned int paramCount, ...)83 {84 va_list parameters;85 va_start(parameters, paramCount);86 87 if (isRegistered(commandName, classID, paramCount, parameters) == true)88 return;89 else90 {91 92 // ShellCommand<T>* newCommand = new ShellCommand<T>(commandName, classID, object, functionPointer, paramCount, parameters);93 }94 }95 123 96 124 #endif /* _SHELL_COMMAND_H */
Note: See TracChangeset
for help on using the changeset viewer.