Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/pickups/src/core/Functor.h @ 2968

Last change on this file since 2968 was 2710, checked in by rgrieder, 16 years ago

Merged buildsystem3 containing buildsystem2 containing Adi's buildsystem branch back to the trunk.
Please update the media directory if you were not using buildsystem3 before.

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