X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Utils%2Fimpl%2Fmembind.hh;h=8c69a1c46707a2298248c8ecdf22412b4e91606f;hb=d498c7507e2eaa191e859ae525df97dc257e0d7a;hp=fcf3eaf13001149721d6935a7f33e596fc48d3a8;hpb=a1a6c76a214ad1935032826713cabaf9ac57bf07;p=senf.git diff --git a/Utils/impl/membind.hh b/Utils/impl/membind.hh index fcf3eaf..8c69a1c 100644 --- a/Utils/impl/membind.hh +++ b/Utils/impl/membind.hh @@ -27,12 +27,23 @@ #include #include #include -#include "../../config.hh" -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 @@ -44,11 +55,25 @@ boost::function membind(R (T::* fn)(),scOBTYPE ob) #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) > +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, 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 (T::* fn)( scPARAMS(A) ), scOBTYPE ob) +membind(R (T1::* fn)( scPARAMS(A) ) const, T2 scOBTYPE ob) { - return boost::bind(fn, ob, scPARAMS(_) ); + return boost::bind(fn, static_cast(ob), scPARAMS(_) ); } #undef scPARAMS