Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/tutorialHS08/src/core/Functor.h @ 2518

Last change on this file since 2518 was 1786, checked in by rgrieder, 16 years ago

Corrected types when using 'const Type' constants

  • Property svn:eol-style set to native
File size: 20.2 KB
Line 
1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
3 *                    > www.orxonox.net <
4 *
5 *
6 *   License notice:
7 *
8 *   This program is free software; you can redistribute it and/or
9 *   modify it under the terms of the GNU General Public License
10 *   as published by the Free Software Foundation; either version 2
11 *   of the License, or (at your option) any later version.
12 *
13 *   This program is distributed in the hope that it will be useful,
14 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
15 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 *   GNU General Public License for more details.
17 *
18 *   You should have received a copy of the GNU General Public License
19 *   along with this program; if not, write to the Free Software
20 *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21 *
22 *   Author:
23 *      Fabian 'x3n' Landau
24 *   Co-authors:
25 *      ...
26 *
27 *   Inspiration: Functor by Benjamin Grauer
28 */
29
30#ifndef _Functor_H__
31#define _Functor_H__
32
33#include "CorePrereqs.h"
34
35#include "util/MultiType.h"
36#include "util/Debug.h"
37
38
39namespace orxonox
40{
41    const unsigned int MAX_FUNCTOR_ARGUMENTS = 5;
42
43    enum FunctionType
44    {
45        FT_MEMBER,
46        FT_CONSTMEMBER,
47        FT_STATIC
48    };
49
50
51    template <class T>
52    inline std::string typeToString() { return "unknown"; }
53
54#define CreateTypeToStringTemplate(type) \
55    template <> \
56    inline std::string typeToString<type>() { return #type; } \
57    template <> \
58    inline std::string typeToString<type&>() { return #type; } \
59    template <> \
60    inline std::string typeToString<const type>() { return #type; } \
61    template <> \
62    inline std::string typeToString<const type&>() { return #type; }
63
64    CreateTypeToStringTemplate(int);
65    CreateTypeToStringTemplate(unsigned int);
66    CreateTypeToStringTemplate(char);
67    CreateTypeToStringTemplate(unsigned char);
68    CreateTypeToStringTemplate(short);
69    CreateTypeToStringTemplate(unsigned short);
70    CreateTypeToStringTemplate(long);
71    CreateTypeToStringTemplate(unsigned long);
72    CreateTypeToStringTemplate(long long);
73    CreateTypeToStringTemplate(unsigned long long);
74    CreateTypeToStringTemplate(float);
75    CreateTypeToStringTemplate(double);
76    CreateTypeToStringTemplate(long double);
77    CreateTypeToStringTemplate(bool);
78    CreateTypeToStringTemplate(Vector2);
79    CreateTypeToStringTemplate(Vector3);
80    CreateTypeToStringTemplate(Quaternion);
81    CreateTypeToStringTemplate(ColourValue);
82    CreateTypeToStringTemplate(Radian);
83    CreateTypeToStringTemplate(Degree);
84
85    template <>
86    inline std::string typeToString<std::string>() { return "string"; }
87    template <>
88    inline std::string typeToString<std::string&>() { return "string"; }
89    template <>
90    inline std::string typeToString<const std::string>() { return "string"; }
91    template <>
92    inline std::string typeToString<const std::string&>() { return "string"; }
93
94    class _CoreExport Functor
95    {
96        public:
97            Functor() {}
98            virtual ~Functor() {}
99
100            virtual void operator()(const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null) = 0;
101
102            inline unsigned int getParamCount() const { return this->numParams_; }
103            inline bool hasReturnvalue() const { return this->hasReturnValue_; }
104            inline FunctionType getType() const { return this->type_; }
105            inline MultiType getReturnvalue() const { return this->returnedValue_; }
106
107            std::string getTypenameParam(unsigned int param) const { return (param >= 0 && param < 5) ? this->typeParam_[param] : ""; }
108            std::string getTypenameReturnvalue() const { return this->typeReturnvalue_; }
109
110            virtual void evaluateParam(unsigned int index, MultiType& param) const = 0;
111
112        protected:
113            unsigned int numParams_;
114            bool hasReturnValue_;
115            FunctionType type_;
116            MultiType returnedValue_;
117
118            std::string typeReturnvalue_;
119            std::string typeParam_[MAX_FUNCTOR_ARGUMENTS];
120    };
121
122    class _CoreExport FunctorStatic : public Functor
123    {
124        public:
125            virtual ~FunctorStatic() {}
126            virtual void operator()(const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null) = 0;
127    };
128
129    template <class T>
130    class FunctorMember : public Functor
131    {
132        public:
133            FunctorMember()
134            {
135                constObject_ = 0;
136                object_ = 0;
137                bConstObject_ = false;
138            }
139            virtual ~FunctorMember() {}
140
141            virtual void operator()(T* object, const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null) = 0;
142            virtual void operator()(const T* object, const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null) = 0;
143
144            virtual void operator()(const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null)
145            {
146                if (this->bConstObject_)
147                {
148                    if (this->constObject_)
149                        (*this)(this->constObject_, param1, param2, param3, param4, param5);
150                    else
151                    {
152                        COUT(1) << "An error occurred in Functor.h:" << std::endl;
153                        COUT(1) << "Error: No const object set." << std::endl;
154                    }
155                }
156                else
157                {
158                    if (this->object_)
159                        (*this)(this->object_, param1, param2, param3, param4, param5);
160                    else
161                    {
162                        COUT(1) << "An error occurred in Functor.h:" << std::endl;
163                        COUT(1) << "Error: No object set." << std::endl;
164                    }
165                }
166            }
167
168            void setObject(T* object)
169            {
170                this->bConstObject_ = false;
171                this->object_ = object;
172            }
173
174            void setObject(const T* object)
175            {
176                this->bConstObject_ = true;
177                this->constObject_ = object;
178            }
179
180        private:
181            const T* constObject_;
182            T* object_;
183            bool bConstObject_;
184    };
185
186
187
188#define FUNCTOR_TEMPLATE(ismember, returnvalue, numparams) FUNCTOR_TEMPLATE##ismember##returnvalue##numparams
189#define FUNCTOR_TEMPLATE000
190#define FUNCTOR_TEMPLATE001 template <class P1>
191#define FUNCTOR_TEMPLATE002 template <class P1, class P2>
192#define FUNCTOR_TEMPLATE003 template <class P1, class P2, class P3>
193#define FUNCTOR_TEMPLATE004 template <class P1, class P2, class P3, class P4>
194#define FUNCTOR_TEMPLATE005 template <class P1, class P2, class P3, class P4, class P5>
195#define FUNCTOR_TEMPLATE010 template <class R>
196#define FUNCTOR_TEMPLATE011 template <class R, class P1>
197#define FUNCTOR_TEMPLATE012 template <class R, class P1, class P2>
198#define FUNCTOR_TEMPLATE013 template <class R, class P1, class P2, class P3>
199#define FUNCTOR_TEMPLATE014 template <class R, class P1, class P2, class P3, class P4>
200#define FUNCTOR_TEMPLATE015 template <class R, class P1, class P2, class P3, class P4, class P5>
201#define FUNCTOR_TEMPLATE100 template <class T>
202#define FUNCTOR_TEMPLATE101 template <class T, class P1>
203#define FUNCTOR_TEMPLATE102 template <class T, class P1, class P2>
204#define FUNCTOR_TEMPLATE103 template <class T, class P1, class P2, class P3>
205#define FUNCTOR_TEMPLATE104 template <class T, class P1, class P2, class P3, class P4>
206#define FUNCTOR_TEMPLATE105 template <class T, class P1, class P2, class P3, class P4, class P5>
207#define FUNCTOR_TEMPLATE110 template <class T, class R>
208#define FUNCTOR_TEMPLATE111 template <class T, class R, class P1>
209#define FUNCTOR_TEMPLATE112 template <class T, class R, class P1, class P2>
210#define FUNCTOR_TEMPLATE113 template <class T, class R, class P1, class P2, class P3>
211#define FUNCTOR_TEMPLATE114 template <class T, class R, class P1, class P2, class P3, class P4>
212#define FUNCTOR_TEMPLATE115 template <class T, class R, class P1, class P2, class P3, class P4, class P5>
213
214
215
216#define FUNCTOR_TEMPLATE_CLASSES(ismember, returnvalue, numparams) FUNCTOR_TEMPLATE_CLASSES##ismember##returnvalue##numparams
217#define FUNCTOR_TEMPLATE_CLASSES000
218#define FUNCTOR_TEMPLATE_CLASSES001 <P1>
219#define FUNCTOR_TEMPLATE_CLASSES002 <P1, P2>
220#define FUNCTOR_TEMPLATE_CLASSES003 <P1, P2, P3>
221#define FUNCTOR_TEMPLATE_CLASSES004 <P1, P2, P3, P4>
222#define FUNCTOR_TEMPLATE_CLASSES005 <P1, P2, P3, P4, P5>
223#define FUNCTOR_TEMPLATE_CLASSES010 <R>
224#define FUNCTOR_TEMPLATE_CLASSES011 <R, P1>
225#define FUNCTOR_TEMPLATE_CLASSES012 <R, P1, P2>
226#define FUNCTOR_TEMPLATE_CLASSES013 <R, P1, P2, P3>
227#define FUNCTOR_TEMPLATE_CLASSES014 <R, P1, P2, P3, P4>
228#define FUNCTOR_TEMPLATE_CLASSES015 <R, P1, P2, P3, P4, P5>
229#define FUNCTOR_TEMPLATE_CLASSES100 <T>
230#define FUNCTOR_TEMPLATE_CLASSES101 <T, P1>
231#define FUNCTOR_TEMPLATE_CLASSES102 <T, P1, P2>
232#define FUNCTOR_TEMPLATE_CLASSES103 <T, P1, P2, P3>
233#define FUNCTOR_TEMPLATE_CLASSES104 <T, P1, P2, P3, P4>
234#define FUNCTOR_TEMPLATE_CLASSES105 <T, P1, P2, P3, P4, P5>
235#define FUNCTOR_TEMPLATE_CLASSES110 <T, R>
236#define FUNCTOR_TEMPLATE_CLASSES111 <T, R, P1>
237#define FUNCTOR_TEMPLATE_CLASSES112 <T, R, P1, P2>
238#define FUNCTOR_TEMPLATE_CLASSES113 <T, R, P1, P2, P3>
239#define FUNCTOR_TEMPLATE_CLASSES114 <T, R, P1, P2, P3, P4>
240#define FUNCTOR_TEMPLATE_CLASSES115 <T, R, P1, P2, P3, P4, P5>
241
242
243
244#define FUNCTOR_TYPENAME_PARAMS(numparams) FUNCTOR_TYPENAME_PARAMS##numparams
245#define FUNCTOR_TYPENAME_PARAMS0
246#define FUNCTOR_TYPENAME_PARAMS1 this->typeParam_[0] = typeToString<P1>();
247#define FUNCTOR_TYPENAME_PARAMS2 this->typeParam_[0] = typeToString<P1>(); this->typeParam_[1] = typeToString<P2>();
248#define FUNCTOR_TYPENAME_PARAMS3 this->typeParam_[0] = typeToString<P1>(); this->typeParam_[1] = typeToString<P2>(); this->typeParam_[2] = typeToString<P3>();
249#define FUNCTOR_TYPENAME_PARAMS4 this->typeParam_[0] = typeToString<P1>(); this->typeParam_[1] = typeToString<P2>(); this->typeParam_[2] = typeToString<P3>(); this->typeParam_[3] = typeToString<P4>();
250#define FUNCTOR_TYPENAME_PARAMS5 this->typeParam_[0] = typeToString<P1>(); this->typeParam_[1] = typeToString<P2>(); this->typeParam_[2] = typeToString<P3>(); this->typeParam_[3] = typeToString<P4>(); this->typeParam_[4] = typeToString<P5>();
251
252#define FUNCTOR_TYPENAME_RETURN(returnvalue) FUNCTOR_TYPENAME_RETURN##returnvalue
253#define FUNCTOR_TYPENAME_RETURN0
254#define FUNCTOR_TYPENAME_RETURN1 this->typeReturnvalue_ = typeToString<R>();
255
256
257
258#define FUNCTOR_FUNCTION_PARAMS(numparams) FUNCTOR_FUNCTION_PARAMS##numparams
259#define FUNCTOR_FUNCTION_PARAMS0
260#define FUNCTOR_FUNCTION_PARAMS1 P1 param1
261#define FUNCTOR_FUNCTION_PARAMS2 P1 param1, P2 param2
262#define FUNCTOR_FUNCTION_PARAMS3 P1 param1, P2 param2, P3 param3
263#define FUNCTOR_FUNCTION_PARAMS4 P1 param1, P2 param2, P3 param3, P4 param4
264#define FUNCTOR_FUNCTION_PARAMS5 P1 param1, P2 param2, P3 param3, P4 param4, P5 param5
265
266#define FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) FUNCTOR_FUNCTION_RETURNVALUE##returnvalue
267#define FUNCTOR_FUNCTION_RETURNVALUE0 void
268#define FUNCTOR_FUNCTION_RETURNVALUE1 R
269
270
271
272#define FUNCTOR_FUNCTION_CALL(numparams) FUNCTOR_FUNCTION_CALL##numparams
273#define FUNCTOR_FUNCTION_CALL0
274#define FUNCTOR_FUNCTION_CALL1 param1
275#define FUNCTOR_FUNCTION_CALL2 param1, param2
276#define FUNCTOR_FUNCTION_CALL3 param1, param2, param3
277#define FUNCTOR_FUNCTION_CALL4 param1, param2, param3, param4
278#define FUNCTOR_FUNCTION_CALL5 param1, param2, param3, param4, param5
279
280#define FUNCTOR_STORE_RETURNVALUE(returnvalue, functioncall) FUNCTOR_STORE_RETURNVALUE##returnvalue(functioncall)
281#define FUNCTOR_STORE_RETURNVALUE0(functioncall) functioncall
282#define FUNCTOR_STORE_RETURNVALUE1(functioncall) this->returnedValue_ = functioncall
283
284
285
286#define FUNCTOR_EVALUATE_PARAM(numparams) FUNCTOR_EVALUATE_PARAM##numparams
287#define FUNCTOR_EVALUATE_PARAM0
288#define FUNCTOR_EVALUATE_PARAM1 \
289    if (index == 0) { param.convert<P1>(); }
290#define FUNCTOR_EVALUATE_PARAM2 \
291    if (index == 0) { param.convert<P1>(); } \
292    else if (index == 1) { param.convert<P2>(); }
293#define FUNCTOR_EVALUATE_PARAM3 \
294    if (index == 0) { param.convert<P1>(); } \
295    else if (index == 1) { param.convert<P2>(); } \
296    else if (index == 2) { param.convert<P3>(); }
297#define FUNCTOR_EVALUATE_PARAM4 \
298    if (index == 0) { param.convert<P1>(); } \
299    else if (index == 1) { param.convert<P2>(); } \
300    else if (index == 2) { param.convert<P3>(); } \
301    else if (index == 3) { param.convert<P4>(); }
302#define FUNCTOR_EVALUATE_PARAM5 \
303    if (index == 0) { param.convert<P1>(); } \
304    else if (index == 1) { param.convert<P2>(); } \
305    else if (index == 2) { param.convert<P3>(); } \
306    else if (index == 3) { param.convert<P4>(); } \
307    else if (index == 4) { param.convert<P5>(); }
308
309
310
311
312
313#define CREATE_STATIC_FUNCTOR(returnvalue, numparams) \
314    FUNCTOR_TEMPLATE(0, returnvalue, numparams) \
315    class FunctorStatic##returnvalue##numparams : public FunctorStatic \
316    { \
317        public: \
318            FunctorStatic##returnvalue##numparams(FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) (*functionPointer)(FUNCTOR_FUNCTION_PARAMS(numparams))) \
319            { \
320                this->numParams_ = numparams; \
321                this->hasReturnValue_ = returnvalue; \
322                this->type_ = FT_STATIC; \
323                this->functionPointer_ = functionPointer; \
324                \
325                FUNCTOR_TYPENAME_PARAMS(numparams); \
326                FUNCTOR_TYPENAME_RETURN(returnvalue); \
327            } \
328    \
329            void operator()(const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null) \
330            { \
331                FUNCTOR_STORE_RETURNVALUE(returnvalue, (*this->functionPointer_)(FUNCTOR_FUNCTION_CALL(numparams))); \
332            } \
333    \
334            virtual void evaluateParam(unsigned int index, MultiType& param) const \
335            { \
336                FUNCTOR_EVALUATE_PARAM(numparams); \
337            } \
338    \
339        private: \
340            FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) (*functionPointer_)(FUNCTOR_FUNCTION_PARAMS(numparams)); \
341    }; \
342    \
343    \
344    FUNCTOR_TEMPLATE(0, returnvalue, numparams) \
345    inline FunctorStatic##returnvalue##numparams FUNCTOR_TEMPLATE_CLASSES(0, returnvalue, numparams)* createFunctor(FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) (*functionPointer)(FUNCTOR_FUNCTION_PARAMS(numparams))) \
346    { \
347        return new FunctorStatic##returnvalue##numparams FUNCTOR_TEMPLATE_CLASSES(0, returnvalue, numparams) (functionPointer); \
348    }
349
350
351
352
353
354#define CREATE_MEMBER_FUNCTOR(returnvalue, numparams) \
355    FUNCTOR_TEMPLATE(1, returnvalue, numparams) \
356    class FunctorMember##returnvalue##numparams : public FunctorMember<T> \
357    { \
358        public: \
359            FunctorMember##returnvalue##numparams(FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) (T::*functionPointer)(FUNCTOR_FUNCTION_PARAMS(numparams))) \
360            { \
361                this->numParams_ = numparams; \
362                this->hasReturnValue_ = returnvalue; \
363                this->type_ = FT_MEMBER; \
364                this->functionPointer_ = functionPointer; \
365            } \
366    \
367            void operator()(T* object, const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null) \
368            { \
369                FUNCTOR_STORE_RETURNVALUE(returnvalue, (*object.*this->functionPointer_)(FUNCTOR_FUNCTION_CALL(numparams))); \
370            } \
371    \
372            void operator()(const T* object, const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null) \
373            { \
374                COUT(1) << "An error occurred in Functor.h:" << std::endl; \
375                COUT(1) << "Error: Function is not const." << std::endl; \
376            } \
377    \
378            virtual void evaluateParam(unsigned int index, MultiType& param) const \
379            { \
380                FUNCTOR_EVALUATE_PARAM(numparams); \
381            } \
382    \
383        private: \
384            FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) (T::*functionPointer_)(FUNCTOR_FUNCTION_PARAMS(numparams)); \
385    }; \
386    \
387    \
388    FUNCTOR_TEMPLATE(1, returnvalue, numparams) \
389    class FunctorConstMember##returnvalue##numparams : public FunctorMember<T> \
390    { \
391        public: \
392            FunctorConstMember##returnvalue##numparams(FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) (T::*functionPointer)(FUNCTOR_FUNCTION_PARAMS(numparams)) const) \
393            { \
394                this->numParams_ = numparams; \
395                this->hasReturnValue_ = returnvalue; \
396                this->type_ = FT_CONSTMEMBER; \
397                this->functionPointer_ = functionPointer; \
398            } \
399    \
400            void operator()(T* object, const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null) \
401            { \
402                FUNCTOR_STORE_RETURNVALUE(returnvalue, (*object.*this->functionPointer_)(FUNCTOR_FUNCTION_CALL(numparams))); \
403            } \
404    \
405            void operator()(const T* object, const MultiType& param1 = MT_null, const MultiType& param2 = MT_null, const MultiType& param3 = MT_null, const MultiType& param4 = MT_null, const MultiType& param5 = MT_null) \
406            { \
407                FUNCTOR_STORE_RETURNVALUE(returnvalue, (*object.*this->functionPointer_)(FUNCTOR_FUNCTION_CALL(numparams))); \
408            } \
409    \
410            virtual void evaluateParam(unsigned int index, MultiType& param) const \
411            { \
412                FUNCTOR_EVALUATE_PARAM(numparams); \
413            } \
414    \
415        private: \
416            FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) (T::*functionPointer_)(FUNCTOR_FUNCTION_PARAMS(numparams)) const; \
417    }; \
418    \
419    \
420    FUNCTOR_TEMPLATE(1, returnvalue, numparams) \
421    inline FunctorMember##returnvalue##numparams FUNCTOR_TEMPLATE_CLASSES(1, returnvalue, numparams)* createFunctor(FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) (T::*functionPointer)(FUNCTOR_FUNCTION_PARAMS(numparams))) \
422    { \
423        return new FunctorMember##returnvalue##numparams FUNCTOR_TEMPLATE_CLASSES(1, returnvalue, numparams) (functionPointer); \
424    } \
425    \
426    \
427    FUNCTOR_TEMPLATE(1, returnvalue, numparams) \
428    inline FunctorConstMember##returnvalue##numparams FUNCTOR_TEMPLATE_CLASSES(1, returnvalue, numparams)* createFunctor(FUNCTOR_FUNCTION_RETURNVALUE(returnvalue) (T::*functionPointer)(FUNCTOR_FUNCTION_PARAMS(numparams)) const) \
429    { \
430        return new FunctorConstMember##returnvalue##numparams FUNCTOR_TEMPLATE_CLASSES(1, returnvalue, numparams) (functionPointer); \
431    }
432
433
434// disable annoying warning about forcing value to boolean
435#if ORXONOX_COMPILER == ORXONOX_COMPILER_MSVC
436#pragma warning(push)
437#pragma warning(disable:4100 4800)
438#endif
439
440#define CREATE_ALL_STATIC_FUNCTORS() \
441    CREATE_STATIC_FUNCTOR(0, 0); \
442    CREATE_STATIC_FUNCTOR(0, 1); \
443    CREATE_STATIC_FUNCTOR(0, 2); \
444    CREATE_STATIC_FUNCTOR(0, 3); \
445    CREATE_STATIC_FUNCTOR(0, 4); \
446    CREATE_STATIC_FUNCTOR(0, 5); \
447    CREATE_STATIC_FUNCTOR(1, 0); \
448    CREATE_STATIC_FUNCTOR(1, 1); \
449    CREATE_STATIC_FUNCTOR(1, 2); \
450    CREATE_STATIC_FUNCTOR(1, 3); \
451    CREATE_STATIC_FUNCTOR(1, 4); \
452    CREATE_STATIC_FUNCTOR(1, 5)
453
454
455#define CREATE_ALL_MEMBER_FUNCTORS() \
456    CREATE_MEMBER_FUNCTOR(0, 0); \
457    CREATE_MEMBER_FUNCTOR(0, 1); \
458    CREATE_MEMBER_FUNCTOR(0, 2); \
459    CREATE_MEMBER_FUNCTOR(0, 3); \
460    CREATE_MEMBER_FUNCTOR(0, 4); \
461    CREATE_MEMBER_FUNCTOR(0, 5); \
462    CREATE_MEMBER_FUNCTOR(1, 0); \
463    CREATE_MEMBER_FUNCTOR(1, 1); \
464    CREATE_MEMBER_FUNCTOR(1, 2); \
465    CREATE_MEMBER_FUNCTOR(1, 3); \
466    CREATE_MEMBER_FUNCTOR(1, 4); \
467    CREATE_MEMBER_FUNCTOR(1, 5)
468
469
470    CREATE_ALL_STATIC_FUNCTORS();
471    CREATE_ALL_MEMBER_FUNCTORS();
472}
473
474#if ORXONOX_COMPILER == ORXONOX_COMPILER_MSVC
475#pragma warning(pop)
476#endif
477
478#endif /* _Functor_H__ */
Note: See TracBrowser for help on using the repository browser.