--- gvpe/src/callback.pl 2006/01/14 11:21:12 1.8 +++ gvpe/src/callback.pl 2008/08/07 17:54:26 1.14 @@ -1,92 +1,106 @@ #!/usr/bin/perl +use strict; + print < - - This file is part of GVPE. - - GVPE is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2 of the License, or - (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with gvpe; if not, write to the Free Software - Foundation, Inc. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + * callback.h -- C++ callback mechanism + * Copyright (C) 2003-2008 Marc Lehmann + * + * This file is part of GVPE. + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 3 of the License, or (at your + * option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General + * Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, see . + * + * Additional permission under GNU GPL version 3 section 7 + * + * If you modify this Program, or any covered work, by linking or + * combining it with the OpenSSL project's OpenSSL library (or a modified + * version of that library), containing parts covered by the terms of the + * OpenSSL or SSLeay licenses, the licensors of this Program grant you + * additional permission to convey the resulting work. Corresponding + * Source for a non-source form of such a combination shall include the + * source code for the parts of OpenSSL used as well as that of the + * covered work. */ #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 { }; - - void *obj; - R (object::*meth)($TYPE); - - /* 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) const = 0; - }; - template - struct proxy : proxy_base { - virtual R call (void *obj, R (object::*meth)($TYPE)$_TYPEARG) const - { - return (R)((reinterpret_cast(obj)) ->* (reinterpret_cast(meth))) - ($ARG); - } - }; - - proxy_base *prxy; - -public: - template - explicit 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); - } +struct callback +{ + typedef R (*ptr_type)(void *self$_TYPE); + + 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); + } + +private: + + void *self; + ptr_type func; + + template + static R thunk (void *self$_TYPEARG) + { + klass *obj = static_cast(self); + return (obj->*method) ($ARG); + } }; EOF } print <