// // Boost.Pointer Container // // Copyright Thorsten Ottosen 2003-2007. Use, modification and // distribution is subject to the Boost Software License, Version // 1.0. (See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) // // For more information, see http://www.boost.org/libs/ptr_container/ // #ifndef BOOST_PTR_CONTAINER_INDIRECT_FUN_HPP #define BOOST_PTR_CONTAINER_INDIRECT_FUN_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) #pragma once #endif #include #ifdef BOOST_NO_SFINAE #else #include #include #endif // BOOST_NO_SFINAE #include #include #include #include namespace boost { namespace ptr_container_detail { template struct make_lazy { typedef typename Type::type type; }; } template < class Fun #ifdef BOOST_NO_SFINAE , class Result = bool #endif > class indirect_fun { Fun fun; public: indirect_fun() : fun(Fun()) { } indirect_fun( Fun f ) : fun(f) { } template< class T > #ifdef BOOST_NO_SFINAE Result #else typename boost::result_of< const Fun( typename pointee::type& ) >::type #endif operator()( const T& r ) const { return fun( *r ); } template< class T, class U > #ifdef BOOST_NO_SFINAE Result #else typename boost::result_of< const Fun( typename pointee::type&, typename pointee::type& ) >::type #endif operator()( const T& r, const U& r2 ) const { return fun( *r, *r2 ); } }; template< class Fun > inline indirect_fun make_indirect_fun( Fun f ) { return indirect_fun( f ); } template < class Fun, class Arg1, class Arg2 = Arg1 #ifdef BOOST_NO_SFINAE , class Result = bool #endif > class void_ptr_indirect_fun { Fun fun; public: void_ptr_indirect_fun() : fun(Fun()) { } void_ptr_indirect_fun( Fun f ) : fun(f) { } template< class Void > #ifdef BOOST_NO_SFINAE Result #else typename ptr_container_detail::make_lazy< boost::result_of, Void>::type #endif operator()( const Void* r ) const { BOOST_STATIC_ASSERT(boost::is_void::value); BOOST_ASSERT( r != 0 ); return fun( * static_cast( r ) ); } template< class Void > #ifdef BOOST_NO_SFINAE Result #else typename ptr_container_detail::make_lazy< boost::result_of, Void>::type #endif operator()( const Void* l, const Void* r ) const { BOOST_STATIC_ASSERT(boost::is_void::value); BOOST_ASSERT( l != 0 && r != 0 ); return fun( * static_cast( l ), * static_cast( r ) ); } }; template< class Arg, class Fun > inline void_ptr_indirect_fun make_void_ptr_indirect_fun( Fun f ) { return void_ptr_indirect_fun( f ); } } // namespace 'boost' #endif