#ifndef BOOST_BIND_APPLY_HPP_INCLUDED #define BOOST_BIND_APPLY_HPP_INCLUDED // // apply.hpp // // Copyright (c) 2002, 2003 Peter Dimov and Multi Media Ltd. // // Distributed under 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) // #include #include namespace boost { template struct apply { typedef R result_type; #if !defined(BOOST_NO_CXX11_RVALUE_REFERENCES) && !defined(BOOST_NO_CXX11_VARIADIC_TEMPLATES) template result_type operator()( F&& f, A&&... a ) const { return static_cast( f )( static_cast( a )... ); } #else template result_type operator()(F & f) const { return f(); } template result_type operator()(F & f, A1 & a1) const { return f(a1); } template result_type operator()(F & f, A1 & a1, A2 & a2) const { return f(a1, a2); } template result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3) const { return f(a1, a2, a3); } template result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4) const { return f(a1, a2, a3, a4); } template result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5) const { return f(a1, a2, a3, a4, a5); } template result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5, A6 & a6) const { return f(a1, a2, a3, a4, a5, a6); } template result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5, A6 & a6, A7 & a7) const { return f(a1, a2, a3, a4, a5, a6, a7); } template result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5, A6 & a6, A7 & a7, A8 & a8) const { return f(a1, a2, a3, a4, a5, a6, a7, a8); } template result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5, A6 & a6, A7 & a7, A8 & a8, A9 & a9) const { return f(a1, a2, a3, a4, a5, a6, a7, a8, a9); } #endif }; } // namespace boost #endif // #ifndef BOOST_BIND_APPLY_HPP_INCLUDED