2004-08-10 13:57:30 +00:00
|
|
|
// Boost result_of library
|
|
|
|
|
|
|
|
// Copyright Douglas Gregor 2004. 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/utility
|
2004-05-02 19:55:02 +00:00
|
|
|
#if !defined(BOOST_PP_IS_ITERATING)
|
|
|
|
# error Boost result_of - do not include this file!
|
|
|
|
#endif
|
|
|
|
|
2010-03-01 19:39:52 +00:00
|
|
|
#if !defined(BOOST_NO_DECLTYPE)
|
2008-05-09 22:08:46 +00:00
|
|
|
|
|
|
|
// As of N2588, C++0x result_of only supports function call
|
|
|
|
// expressions of the form f(x). This precludes support for member
|
|
|
|
// function pointers, which are invoked with expressions of the form
|
|
|
|
// o->*f(x). This implementation supports both.
|
|
|
|
template<typename F BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
|
|
|
|
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
|
|
|
|
struct result_of<F(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T))>
|
|
|
|
: mpl::if_<
|
|
|
|
mpl::or_< is_pointer<F>, is_member_function_pointer<F> >
|
|
|
|
, detail::result_of_impl<
|
2008-09-05 19:58:30 +00:00
|
|
|
typename remove_cv<F>::type,
|
|
|
|
typename remove_cv<F>::type(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), false
|
2008-05-09 22:08:46 +00:00
|
|
|
>
|
|
|
|
, detail::result_of_decltype_impl<
|
|
|
|
F(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T))
|
|
|
|
>
|
|
|
|
>::type
|
|
|
|
{};
|
|
|
|
|
|
|
|
namespace detail {
|
|
|
|
|
|
|
|
# define BOOST_RESULT_OF_STATIC_MEMBERS(z, n, _) \
|
|
|
|
static T ## n t ## n; \
|
|
|
|
/**/
|
|
|
|
|
|
|
|
template<typename F BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
|
|
|
|
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
|
|
|
|
class result_of_decltype_impl<F(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T))>
|
|
|
|
{
|
|
|
|
static F f;
|
|
|
|
BOOST_PP_REPEAT(BOOST_PP_ITERATION(), BOOST_RESULT_OF_STATIC_MEMBERS, _)
|
|
|
|
public:
|
|
|
|
typedef decltype(f(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),t))) type;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace detail
|
|
|
|
|
|
|
|
#else // defined(BOOST_HAS_DECLTYPE)
|
|
|
|
|
2004-05-02 19:55:02 +00:00
|
|
|
// CWPro8 requires an argument in a function type specialization
|
|
|
|
#if BOOST_WORKAROUND(__MWERKS__, BOOST_TESTED_AT(0x3002)) && BOOST_PP_ITERATION() == 0
|
|
|
|
# define BOOST_RESULT_OF_ARGS void
|
|
|
|
#else
|
|
|
|
# define BOOST_RESULT_OF_ARGS BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551))
|
|
|
|
template<typename F BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
|
|
|
|
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
|
|
|
|
struct result_of<F(BOOST_RESULT_OF_ARGS)>
|
2008-09-05 19:58:30 +00:00
|
|
|
: mpl::if_<
|
|
|
|
mpl::or_< is_pointer<F>, is_member_function_pointer<F> >
|
|
|
|
, boost::detail::result_of_impl<
|
|
|
|
typename remove_cv<F>::type,
|
|
|
|
typename remove_cv<F>::type(BOOST_RESULT_OF_ARGS),
|
|
|
|
(boost::detail::has_result_type<F>::value)>
|
|
|
|
, boost::detail::result_of_impl<
|
|
|
|
F,
|
|
|
|
F(BOOST_RESULT_OF_ARGS),
|
|
|
|
(boost::detail::has_result_type<F>::value)> >::type { };
|
2004-05-02 19:55:02 +00:00
|
|
|
#endif
|
|
|
|
|
2007-01-24 06:44:20 +00:00
|
|
|
#undef BOOST_RESULT_OF_ARGS
|
|
|
|
|
2008-05-09 22:08:46 +00:00
|
|
|
#endif // defined(BOOST_HAS_DECLTYPE)
|
|
|
|
|
2007-01-24 06:44:20 +00:00
|
|
|
#if BOOST_PP_ITERATION() >= 1
|
|
|
|
|
2004-05-02 19:55:02 +00:00
|
|
|
namespace detail {
|
|
|
|
|
|
|
|
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
|
|
|
|
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
|
2007-01-24 06:44:20 +00:00
|
|
|
struct result_of_impl<R (*)(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), FArgs, false>
|
2004-05-02 19:55:02 +00:00
|
|
|
{
|
|
|
|
typedef R type;
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
|
|
|
|
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
|
2007-01-24 06:44:20 +00:00
|
|
|
struct result_of_impl<R (&)(BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),T)), FArgs, false>
|
2004-05-02 19:55:02 +00:00
|
|
|
{
|
|
|
|
typedef R type;
|
|
|
|
};
|
|
|
|
|
2007-01-24 06:44:20 +00:00
|
|
|
#if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x551))
|
2004-05-02 19:55:02 +00:00
|
|
|
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
|
|
|
|
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
|
2006-05-16 22:55:27 +00:00
|
|
|
struct result_of_impl<R (T0::*)
|
2004-05-02 19:55:02 +00:00
|
|
|
(BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T)),
|
2007-01-08 20:38:51 +00:00
|
|
|
FArgs, false>
|
2004-05-02 19:55:02 +00:00
|
|
|
{
|
|
|
|
typedef R type;
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
|
|
|
|
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
|
2006-05-16 22:55:27 +00:00
|
|
|
struct result_of_impl<R (T0::*)
|
2004-05-02 19:55:02 +00:00
|
|
|
(BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T))
|
|
|
|
const,
|
2007-01-08 20:38:51 +00:00
|
|
|
FArgs, false>
|
2004-05-02 19:55:02 +00:00
|
|
|
{
|
|
|
|
typedef R type;
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
|
|
|
|
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
|
2006-05-16 22:55:27 +00:00
|
|
|
struct result_of_impl<R (T0::*)
|
2004-05-02 19:55:02 +00:00
|
|
|
(BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T))
|
|
|
|
volatile,
|
2007-01-08 20:38:51 +00:00
|
|
|
FArgs, false>
|
2004-05-02 19:55:02 +00:00
|
|
|
{
|
|
|
|
typedef R type;
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename R, typename FArgs BOOST_PP_COMMA_IF(BOOST_PP_ITERATION())
|
|
|
|
BOOST_PP_ENUM_PARAMS(BOOST_PP_ITERATION(),typename T)>
|
2006-05-16 22:55:27 +00:00
|
|
|
struct result_of_impl<R (T0::*)
|
2004-05-02 19:55:02 +00:00
|
|
|
(BOOST_PP_ENUM_SHIFTED_PARAMS(BOOST_PP_ITERATION(),T))
|
|
|
|
const volatile,
|
2007-01-08 20:38:51 +00:00
|
|
|
FArgs, false>
|
2004-05-02 19:55:02 +00:00
|
|
|
{
|
|
|
|
typedef R type;
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
2007-01-24 06:44:20 +00:00
|
|
|
#endif
|