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