Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/std/src/lib/util/executor/functor_list.h @ 7218

Last change on this file since 7218 was 7218, checked in by bensch, 18 years ago

orxonox/std:: more strings

File size: 5.9 KB
Line 
1/*
2   orxonox - the future of 3D-vertical-scrollers
3
4   Copyright (C) 2004 orx
5
6   This program is free software; you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation; either version 2, or (at your option)
9   any later version.
10   */
11
12/*!
13 * @file functors_list.h
14 * all the Different types of Functions one can include
15*/
16
17/**
18   useable FunctionParameters are:
19   l_INT:       int
20   l_LONG:      long
21   l_SHORT:     short
22   l_FLOAT:     float
23   l_CSTRING:    const char*
24   l_XML_ELEM:  TiXmlElement*
25 */
26
27#ifndef __FUNCTOR_PARAMETERS__
28#define __FUNCTOR_PARAMETERS__
29
30//! defines the maximum count of arguments function pointers might have
31#define FUNCTOR_MAX_ARGUMENTS                5
32#include "multi_type.h"
33
34#define l_BOOL_TYPE        bool                 //!< The type of an BOOL
35#define l_BOOL_FUNC        isBool               //!< The function to call to parse BOOL
36#define l_BOOL_NAME        "bool"               //!< The name of an BOOL
37#define l_BOOL_PARAM       MT_BOOL              //!< the type of the parameter BOOL
38#define l_BOOL_DEFAULT     false                //!< a default Value for an BOOL
39
40
41#define l_INT_TYPE         int                  //!< The type of an INT
42#define l_INT_FUNC         isInt                //!< The function to call to parse INT
43#define l_INT_NAME         "int"                //!< The name of an INT
44#define l_INT_PARAM        MT_INT               //!< the type of the parameter INT
45#define l_INT_DEFAULT      0                    //!< a default Value for an INT
46
47#define l_UINT_TYPE        unsigned int         //!< The type of an UINT
48#define l_UINT_FUNC        isInt                //!< The function to call to parse UINT
49#define l_UINT_NAME        "unsigned int"       //!< The name of an UINT
50#define l_UINT_PARAM       MT_INT        //!< the type of the parameter UINT
51#define l_UINT_DEFAULT     0                    //!< a default Value for an UINT
52
53#define l_LONG_TYPE        long                 //!< The type of a LONG
54#define l_LONG_FUNC        isInt                //!< The function to parse a LONG
55#define l_LONG_NAME        "long"               //!< The name of a LONG
56#define l_LONG_PARAM       MT_INT //!< the type of the parameter LONG
57#define l_LONG_DEFAULT     0                    //!< a default Value for a LONG
58
59// #define l_SHORT_TYPE       short                //!< The type of a SHORT
60// #define l_SHORT_FUNC       atoi                 //!< The function to parse a SHORT
61// #define l_SHORT_NAME       "short"              //!< The name of a SHORT
62// #define l_SHORT_PARAM      ParameterShort       //!< the type of the parameter SHORT
63// #define l_SHORT_DEFAULT    0                    //!< a default Value for a SHORT
64
65#define l_FLOAT_TYPE       float                //!< The type of a FLOAT
66#define l_FLOAT_FUNC       isFloat              //!< The function to parse a FLOAT
67#define l_FLOAT_NAME       "float"              //!< The name of a FLOAT
68#define l_FLOAT_PARAM      MT_FLOAT             //!< the type of the parameter FLOAT
69#define l_FLOAT_DEFAULT    0.0                  //!< a default Value for a FLOAT
70
71//#define l_VECTOR_TYPE      const Vector&        //!< The type of a VECTOR
72//#define l_VECTOR_FUNC      isVector             //!< The function to parse a VECTOR
73//#define l_VECTOR_NAME      "Vector[x/y/z]"      //!< The name of a VECTOR
74//#define l_VECTOR_DEFAULT   Vector(0,0,0)        //!< Default value for a VECTOR
75
76#define l_STRING_TYPE      const std::string&   //!< The type of a STRING
77#define l_STRING_FUNC      isString             //!< The function to parse a STRING
78#define l_STRING_NAME      "string"             //!< The name of a STRING
79#define l_STRING_PARAM     MT_STRING           //!< the type of the parameter STRING
80#define l_STRING_DEFAULT   ""                   //!< a default Value for an STRING
81
82#define l_XML_ELEM_TYPE    const TiXmlElement*  //!< The type of an XML_ELEM
83#define l_XML_ELEM_FUNC                         //!< The function to parse an XML_ELEM
84#define l_XML_ELEM_NAME    "XML"                //!< The name of an XML_ELEM
85//#define l_XML_ELEM_PARAM   Parameter            //!< the type of the parameter XML_ELEM
86#define l_XML_ELEM_DEFAULT NULL                 //!< The dafault Value for an XML_ELEM
87
88#endif /* __FUNCTOR_PARAMETERS__ */
89
90
91#ifdef FUNCTOR_LIST
92
93  FUNCTOR_LIST(0)();
94  //! makes functions with one string
95  FUNCTOR_LIST(1)(l_STRING);
96  //! makes functions with two strings
97  FUNCTOR_LIST(2)(l_STRING, l_STRING);
98  //! makes functions with three strings
99  FUNCTOR_LIST(3)(l_STRING, l_STRING, l_STRING);
100  //! makes functions with four strings
101  FUNCTOR_LIST(4)(l_STRING, l_STRING, l_STRING, l_STRING);
102
103
104  //! makes functions with one bool
105  FUNCTOR_LIST(1)(l_BOOL);
106
107  //! makes functions with one int
108  FUNCTOR_LIST(1)(l_INT);
109  //! makes functions with two ints
110  FUNCTOR_LIST(2)(l_INT, l_INT);
111  //! makes functions with three ints
112  FUNCTOR_LIST(3)(l_INT, l_INT, l_INT);
113  //! makes functions with four ints
114  FUNCTOR_LIST(4)(l_INT, l_INT, l_INT, l_INT);
115
116
117  //! makes functions with one unsigned int
118  FUNCTOR_LIST(1)(l_UINT);
119  //! makes functions with two unsigned ints
120  FUNCTOR_LIST(2)(l_UINT, l_UINT);
121  //! makes functions with three unsigned ints
122  FUNCTOR_LIST(3)(l_UINT, l_UINT, l_UINT);
123  //! makes functions with four unsigned ints
124  FUNCTOR_LIST(4)(l_UINT, l_UINT, l_UINT, l_UINT);
125
126  //! makes functions with one float
127  FUNCTOR_LIST(1)(l_FLOAT);
128  //! makes functions with two floats
129  FUNCTOR_LIST(2)(l_FLOAT, l_FLOAT);
130  //! makes functions with three floats
131  FUNCTOR_LIST(3)(l_FLOAT, l_FLOAT, l_FLOAT);
132  //! makes functions with four floats
133  FUNCTOR_LIST(4)(l_FLOAT, l_FLOAT, l_FLOAT, l_FLOAT);
134  //! makes functions with four floats
135  FUNCTOR_LIST(5)(l_FLOAT, l_FLOAT, l_FLOAT, l_FLOAT, l_FLOAT);
136
137  //! mixed values:
138  FUNCTOR_LIST(2)(l_STRING, l_FLOAT);
139  FUNCTOR_LIST(2)(l_UINT, l_LONG);
140  FUNCTOR_LIST(2)(l_STRING, l_UINT);
141
142  FUNCTOR_LIST(3)(l_STRING, l_FLOAT, l_UINT);
143
144
145#endif /* FUNCTOR_LIST */
Note: See TracBrowser for help on using the repository browser.