--- gvpe/src/callback.pl 2005/12/27 16:36:16 1.7 +++ gvpe/src/callback.pl 2007/12/04 17:17:19 1.12 @@ -1,5 +1,7 @@ #!/usr/bin/perl +use strict; + print < + Copyright (C) 2003-2007 Marc Lehmann This file is part of GVPE. @@ -29,64 +31,78 @@ #ifndef CALLBACK_H__ #define CALLBACK_H__ +#define CALLBACK_H_VERSION 3 + +template +struct callback; + EOF -for my $a (0..7) { +for my $a (0..10) { my $CLASS = join "", map ", class A$_", 1..$a; my $TYPE = join ", ", map "A$_", 1..$a; my $ARG = join ", ", map "a$_", 1..$a; my $TYPEARG = join ", ", map "A$_ a$_", 1..$a; + my $TYPEDEFS = join " ", map "typedef A$_ arg$_\_type;", 1..$a; + my $TYPEvoid = $TYPE ? $TYPE : "void"; my $_ARG = $ARG ? ", $ARG" : ""; + my $_TYPE = $TYPE ? ", $TYPE" : ""; my $_TYPEARG = $TYPEARG ? ", $TYPEARG" : ""; + my $_TTYPE = $a ? join "", map ", typename T::arg$_\_type", 1..$a : ""; print < -class callback$a { - struct object { }; +struct callback +{ + typedef R (*ptr_type)(void *self$_TYPE); - void *obj; - R (object::*meth)($TYPE); +private: - /* a proxy is a kind of recipe on how to call a specific class method */ - struct proxy_base { - virtual R call (void *obj, R (object::*meth)($TYPE)$_TYPEARG) = 0; - }; - template - struct proxy : proxy_base { - virtual R call (void *obj, R (object::*meth)($TYPE)$_TYPEARG) - { - return (R)((reinterpret_cast(obj)) ->* (reinterpret_cast(meth))) - ($ARG); - } + void *self; + ptr_type func; + +protected: + + template + struct thunktype; + + template + struct thunktype + { + typedef klass K; }; - proxy_base *prxy; + template + static R thunk (void *self$_TYPEARG) + { + klass *obj = static_cast(self); + return (obj->*method) ($ARG); + } public: - template - callback$a (O1 *object, R (O2::*method)($TYPE)) - { - static proxy p; - obj = reinterpret_cast(object); - meth = reinterpret_cast(method); - prxy = &p; - } - - R call($TYPEARG) const - { - return prxy->call (obj, meth$_ARG); - } + template + void set (K *object) + { + self = object; + func = thunk; + } + + R call ($TYPEARG) const + { + return func (self$_ARG); + } R operator ()($TYPEARG) const - { - return call ($ARG); - } + { + return call ($ARG); + } }; EOF } print <