X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Utils%2Fimpl%2Fmembind.hh;h=8c69a1c46707a2298248c8ecdf22412b4e91606f;hb=d498c7507e2eaa191e859ae525df97dc257e0d7a;hp=ef1850023a47122b8f6f6829381d3584ca9f11ac;hpb=c52cd7d87dbb525c1267aad27391b8b7365dbb57;p=senf.git diff --git a/Utils/impl/membind.hh b/Utils/impl/membind.hh index ef18500..8c69a1c 100644 --- a/Utils/impl/membind.hh +++ b/Utils/impl/membind.hh @@ -1,9 +1,9 @@ // $Id$ // -// Copyright (C) 2006 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) -// Stefan Bund +// Copyright (C) 2006 +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY +// Stefan Bund // // 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 @@ -20,7 +20,7 @@ // Free Software Foundation, Inc., // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. // -// NEVER INCLUDE DIRECTLY !! INCLUDE satcom/membind.hh +// NEVER INCLUDE DIRECTLY !! INCLUDE senf/membind.hh #if !BOOST_PP_IS_ITERATING @@ -28,31 +28,57 @@ #include #include -template -boost::function membind(R (T::* fn)(),scOBTYPE ob) +template +boost::function membind(R (T1::* fn)(),T2 scOBTYPE ob) { - return boost::bind(fn,ob); + return boost::bind(fn,static_cast(ob)); +} + +template +boost::function membind(R (T1::* fn)() const, T2 const scOBTYPE ob) +{ + return boost::bind(fn,static_cast(ob)); +} + +template +boost::function membind(R (T1::* fn)() const, T2 scOBTYPE ob) +{ + return boost::bind(fn,static_cast(ob)); } // for BOOST_PP_ITERATION() in 2..9 do -#define BOOST_PP_ITERATION_PARAMS_1 (4, (2, 9, "Utils/impl/membind.hh", 1)) +#define BOOST_PP_ITERATION_PARAMS_1 (4, (2, 9, SENF_ABSOLUTE_INCLUDE_PATH(Utils/impl/membind.hh), 1)) #include BOOST_PP_ITERATE() #elif BOOST_PP_ITERATION_DEPTH()==1 && BOOST_PP_ITERATION_FLAGS()==1 // {{ #define scARG(z,n,d) BOOST_PP_CAT(d,n) #define scPARAMS(d) BOOST_PP_ENUM_SHIFTED(BOOST_PP_ITERATION(),scARG,d) - -template < typename R, typename T, scPARAMS(typename A) > -boost::function -membind(R (T::* fn)( scPARAMS(A) ), scOBTYPE ob) + +template < typename R, typename T1, typename T2, scPARAMS(typename A) > +boost::function +membind(R (T1::* fn)( scPARAMS(A) ), T2 scOBTYPE ob) { - return boost::bind(fn, ob, scPARAMS(_) ); + return boost::bind(fn, static_cast(ob), scPARAMS(_) ); +} + +template < typename R, typename T1, typename T2, scPARAMS(typename A) > +boost::function +membind(R (T1::* fn)( scPARAMS(A) ) const, T2 const scOBTYPE ob) +{ + return boost::bind(fn, static_cast(ob), scPARAMS(_) ); +} + +template < typename R, typename T1, typename T2, scPARAMS(typename A) > +boost::function +membind(R (T1::* fn)( scPARAMS(A) ) const, T2 scOBTYPE ob) +{ + return boost::bind(fn, static_cast(ob), scPARAMS(_) ); } #undef scPARAMS #undef scARG - + // } #endif // done @@ -60,4 +86,10 @@ membind(R (T::* fn)( scPARAMS(A) ), scOBTYPE ob) // Local Variables: // mode: c++ +// fill-column: 100 +// c-file-style: "senf" +// indent-tabs-mode: nil +// ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: