diff --git a/test/functional/invoke.cpp b/test/functional/invoke.cpp index 3ee2d6dc..686554bc 100644 --- a/test/functional/invoke.cpp +++ b/test/functional/invoke.cpp @@ -10,11 +10,11 @@ #include #include -#include - #include #include +#include + #include #include @@ -337,25 +337,19 @@ void test_sequence(Sequence & seq) void result_type_tests() { - using boost::fusion::detail::has_type; + using boost::is_same; - BOOST_TEST(( has_type< - fusion::result_of::invoke + BOOST_TEST(( is_same< + fusion::result_of::invoke::type, int >::value )); - BOOST_TEST(( has_type< - fusion::result_of::invoke > + BOOST_TEST(( is_same< + fusion::result_of::invoke >::type, int >::value )); - BOOST_TEST(( ! has_type< - fusion::result_of::invoke > + BOOST_TEST(( is_same< + fusion::result_of::invoke >::type, int >::value )); - BOOST_TEST(( has_type< - fusion::result_of::invoke > - >::value )); - BOOST_TEST(( has_type< - fusion::result_of::invoke > - >::value )); - BOOST_TEST(( ! has_type< - fusion::result_of::invoke > + BOOST_TEST(( is_same< + fusion::result_of::invoke >::type, int >::value )); } diff --git a/test/functional/make_unfused_generic.cpp b/test/functional/make_unfused_generic.cpp index 491fc93b..0e7e81c8 100644 --- a/test/functional/make_unfused_generic.cpp +++ b/test/functional/make_unfused_generic.cpp @@ -42,7 +42,7 @@ struct test_func struct result; template - struct result< Self(Seq) > + struct result< Self(Seq &) > : mpl::if_< mpl::and_< fusion::result_of::empty, RemoveNullary >, boost::blank, mpl::identity >::type { }; diff --git a/test/functional/make_unfused_lvalue_args.cpp b/test/functional/make_unfused_lvalue_args.cpp index 20dae6ed..af94256c 100644 --- a/test/functional/make_unfused_lvalue_args.cpp +++ b/test/functional/make_unfused_lvalue_args.cpp @@ -41,7 +41,7 @@ struct test_func struct result; template - struct result< Self(Seq) > + struct result< Self(Seq &) > : mpl::if_< mpl::and_< fusion::result_of::empty, RemoveNullary >, boost::blank, mpl::identity >::type { }; diff --git a/test/functional/make_unfused_rvalue_args.cpp b/test/functional/make_unfused_rvalue_args.cpp index 8746a6af..383fcc0b 100644 --- a/test/functional/make_unfused_rvalue_args.cpp +++ b/test/functional/make_unfused_rvalue_args.cpp @@ -39,7 +39,7 @@ struct test_func struct result; template - struct result< Self(Seq) > + struct result< Self(Seq &) > : mpl::if_< mpl::and_< fusion::result_of::empty, RemoveNullary >, boost::blank, mpl::identity >::type { }; diff --git a/test/functional/unfused_generic.cpp b/test/functional/unfused_generic.cpp index 3810bdcb..f1f86515 100644 --- a/test/functional/unfused_generic.cpp +++ b/test/functional/unfused_generic.cpp @@ -10,19 +10,14 @@ #include #include -#include #include #include -#include -#include -#include #include #include -#include #include namespace fusion = boost::fusion; @@ -31,7 +26,7 @@ namespace mpl = boost::mpl; using boost::noncopyable; typedef mpl::true_ no_nullary_call; -template +template struct test_func : Base { @@ -39,9 +34,8 @@ struct test_func struct result; template - struct result< Self(Seq) > - : mpl::if_< mpl::and_< fusion::result_of::empty, RemoveNullary >, - boost::blank, mpl::identity >::type + struct result< Self (Seq) > + : mpl::identity { }; template @@ -62,8 +56,6 @@ struct test_func struct fold_op { - typedef long result_type; - template long operator()(T const & elem, long value) const { @@ -76,22 +68,23 @@ struct test_func elem += sizeof(T); return value; } + + template + struct result; + + template struct result< Self(T0,T1) > + : mpl::identity + { }; }; }; void result_type_tests() { using boost::is_same; - using boost::fusion::detail::has_type; - typedef fusion::unfused_generic< test_func > test_func_1; - typedef fusion::unfused_generic< test_func > test_func_0; - - BOOST_TEST(( has_type< test_func_0::result >::value )); - BOOST_TEST(( has_type< test_func_1::result >::value )); - BOOST_TEST(( ! has_type< test_func_1::result >::value )); - BOOST_TEST(( is_same< boost::result_of< test_func_0() >::type, long >::value )); - BOOST_TEST(( is_same< boost::result_of< test_func_1(int) >::type, long >::value )); + typedef fusion::unfused_generic< test_func<> > t; + BOOST_TEST(( is_same< boost::result_of< t () >::type, long >::value )); + BOOST_TEST(( is_same< boost::result_of< t (int) >::type, long >::value )); } int main() diff --git a/test/functional/unfused_lvalue_args.cpp b/test/functional/unfused_lvalue_args.cpp index 26b4535d..e7972499 100644 --- a/test/functional/unfused_lvalue_args.cpp +++ b/test/functional/unfused_lvalue_args.cpp @@ -12,9 +12,6 @@ #include #include -#include -#include -#include #include #include @@ -26,9 +23,8 @@ namespace fusion = boost::fusion; namespace mpl = boost::mpl; using boost::noncopyable; -typedef mpl::true_ no_nullary_call; -template +template struct test_func : Base { @@ -37,8 +33,7 @@ struct test_func template struct result< Self(Seq) > - : mpl::if_< mpl::and_< fusion::result_of::empty, RemoveNullary >, - boost::blank, mpl::identity >::type + : mpl::identity { }; template @@ -73,16 +68,10 @@ struct test_func void result_type_tests() { using boost::is_same; - using boost::fusion::detail::has_type; - typedef fusion::unfused_lvalue_args< test_func > test_func_1; - typedef fusion::unfused_lvalue_args< test_func > test_func_0; - - BOOST_TEST(( has_type< test_func_0::result >::value )); - BOOST_TEST(( has_type< test_func_1::result >::value )); - BOOST_TEST(( ! has_type< test_func_1::result >::value )); - BOOST_TEST(( is_same< boost::result_of< test_func_0() >::type, long >::value )); - BOOST_TEST(( is_same< boost::result_of< test_func_1(int) >::type, long >::value )); + typedef fusion::unfused_lvalue_args< test_func<> > t; + BOOST_TEST(( is_same< boost::result_of< t () >::type, long >::value )); + BOOST_TEST(( is_same< boost::result_of< t (int) >::type, long >::value )); } int main() diff --git a/test/functional/unfused_rvalue_args.cpp b/test/functional/unfused_rvalue_args.cpp index da694f07..349bf7fa 100644 --- a/test/functional/unfused_rvalue_args.cpp +++ b/test/functional/unfused_rvalue_args.cpp @@ -12,14 +12,10 @@ #include #include -#include -#include -#include #include #include -#include #include namespace fusion = boost::fusion; @@ -28,7 +24,7 @@ namespace mpl = boost::mpl; using boost::noncopyable; typedef mpl::true_ no_nullary_call; -template +template struct test_func : Base { @@ -37,8 +33,7 @@ struct test_func template struct result< Self(Seq) > - : mpl::if_< mpl::and_< fusion::result_of::empty, RemoveNullary >, - boost::blank, mpl::identity >::type + : mpl::identity { }; template @@ -72,16 +67,10 @@ struct test_func void result_type_tests() { using boost::is_same; - using boost::fusion::detail::has_type; - typedef fusion::unfused_rvalue_args< test_func > test_func_1; - typedef fusion::unfused_rvalue_args< test_func > test_func_0; - - BOOST_TEST(( has_type< test_func_0::result >::value )); - BOOST_TEST(( has_type< test_func_1::result >::value )); - BOOST_TEST(( ! has_type< test_func_1::result >::value )); - BOOST_TEST(( is_same< boost::result_of< test_func_0() >::type, long >::value )); - BOOST_TEST(( is_same< boost::result_of< test_func_1(int) >::type, long >::value )); + typedef fusion::unfused_rvalue_args< test_func<> > t; + BOOST_TEST(( is_same< boost::result_of< t () >::type, long >::value )); + BOOST_TEST(( is_same< boost::result_of< t (int) >::type, long >::value )); } int main() diff --git a/test/functional/unfused_typed.cpp b/test/functional/unfused_typed.cpp index 5b119ba3..7c1e3270 100644 --- a/test/functional/unfused_typed.cpp +++ b/test/functional/unfused_typed.cpp @@ -14,15 +14,10 @@ #include -#include -#include -#include #include -#include #include -#include #include namespace fusion = boost::fusion; @@ -33,12 +28,7 @@ using boost::noncopyable; typedef fusion::vector types; -typedef mpl::always< mpl::true_ > unconstrained; - -typedef mpl::equal_to< fusion::result_of::size<_>, - fusion::result_of::size > non_variadic; - -template +template struct test_func : Base { @@ -46,9 +36,8 @@ struct test_func struct result; template - struct result - : mpl::if_< typename mpl::apply::type, - mpl::identity, boost::blank >::type + struct result< Self(Seq) > + : mpl::identity { }; template @@ -89,16 +78,10 @@ struct test_func void result_type_tests() { using boost::is_same; - using boost::fusion::detail::has_type; - typedef fusion::unfused_typed< test_func, types > test_func_3; - typedef fusion::unfused_typed< test_func, types > test_func_0; - - BOOST_TEST(( has_type< test_func_0::result >::value )); - BOOST_TEST(( has_type< test_func_3::result >::value )); - BOOST_TEST(( ! has_type< test_func_3::result >::value )); - BOOST_TEST(( is_same< boost::result_of< test_func_0() >::type, long >::value )); - BOOST_TEST(( is_same< boost::result_of< test_func_3(long &, int, char) >::type, long >::value )); + typedef fusion::unfused_typed< test_func<>, types > t; + BOOST_TEST(( is_same< boost::result_of< t () >::type, long >::value )); + BOOST_TEST(( is_same< boost::result_of< t (int) >::type, long >::value )); } #if defined(BOOST_MSVC) && BOOST_MSVC < 1400