apply.hpp 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. #ifndef BOOST_BIND_APPLY_HPP_INCLUDED
  2. #define BOOST_BIND_APPLY_HPP_INCLUDED
  3. //
  4. // apply.hpp
  5. //
  6. // Copyright (c) 2002, 2003 Peter Dimov and Multi Media Ltd.
  7. //
  8. // Distributed under the Boost Software License, Version 1.0. (See
  9. // accompanying file LICENSE_1_0.txt or copy at
  10. // http://www.boost.org/LICENSE_1_0.txt)
  11. //
  12. #include <boost/config.hpp>
  13. namespace boost
  14. {
  15. template<class R> struct apply
  16. {
  17. typedef R result_type;
  18. #if !defined(BOOST_NO_CXX11_RVALUE_REFERENCES) && !defined(BOOST_NO_CXX11_VARIADIC_TEMPLATES)
  19. template<class F, class... A> result_type operator()( F&& f, A&&... a ) const
  20. {
  21. return static_cast<F&&>( f )( static_cast<A&&>( a )... );
  22. }
  23. #else
  24. template<class F> result_type operator()(F & f) const
  25. {
  26. return f();
  27. }
  28. template<class F, class A1> result_type operator()(F & f, A1 & a1) const
  29. {
  30. return f(a1);
  31. }
  32. template<class F, class A1, class A2> result_type operator()(F & f, A1 & a1, A2 & a2) const
  33. {
  34. return f(a1, a2);
  35. }
  36. template<class F, class A1, class A2, class A3> result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3) const
  37. {
  38. return f(a1, a2, a3);
  39. }
  40. template<class F, class A1, class A2, class A3, class A4> result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4) const
  41. {
  42. return f(a1, a2, a3, a4);
  43. }
  44. template<class F, class A1, class A2, class A3, class A4, class A5> result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5) const
  45. {
  46. return f(a1, a2, a3, a4, a5);
  47. }
  48. template<class F, class A1, class A2, class A3, class A4, class A5, class A6> result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5, A6 & a6) const
  49. {
  50. return f(a1, a2, a3, a4, a5, a6);
  51. }
  52. template<class F, class A1, class A2, class A3, class A4, class A5, class A6, class A7> result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5, A6 & a6, A7 & a7) const
  53. {
  54. return f(a1, a2, a3, a4, a5, a6, a7);
  55. }
  56. template<class F, class A1, class A2, class A3, class A4, class A5, class A6, class A7, class A8> result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5, A6 & a6, A7 & a7, A8 & a8) const
  57. {
  58. return f(a1, a2, a3, a4, a5, a6, a7, a8);
  59. }
  60. template<class F, class A1, class A2, class A3, class A4, class A5, class A6, class A7, class A8, class A9> result_type operator()(F & f, A1 & a1, A2 & a2, A3 & a3, A4 & a4, A5 & a5, A6 & a6, A7 & a7, A8 & a8, A9 & a9) const
  61. {
  62. return f(a1, a2, a3, a4, a5, a6, a7, a8, a9);
  63. }
  64. #endif
  65. };
  66. } // namespace boost
  67. #endif // #ifndef BOOST_BIND_APPLY_HPP_INCLUDED