diff options
Diffstat (limited to 'src/boost/libs/phoenix/test/function')
15 files changed, 1088 insertions, 0 deletions
diff --git a/src/boost/libs/phoenix/test/function/adapt_function.cpp b/src/boost/libs/phoenix/test/function/adapt_function.cpp new file mode 100644 index 00000000..77cca41d --- /dev/null +++ b/src/boost/libs/phoenix/test/function/adapt_function.cpp @@ -0,0 +1,84 @@ +/*============================================================================= + Copyright (c) 2011 Thomas Heller + Copyright (c) 2015 John Fletcher + + 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 <iostream> +#include <cmath> +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function.hpp> + +namespace impl +{ + void + test() + { + std::cout << "Test adapting functions...\n"; + } + + int + negate(int n) + { + return -n; + } + + int + plus(int a, int b) + { + return a + b; + } + + template <typename T> + T + plus(T a, T b, T c) + { + return a + b + c; + } + + int + plus4(int a, int b, int c, int d) + { + return a + b + c + d; + } +} + +BOOST_PHOENIX_ADAPT_FUNCTION_NULLARY(void, test, impl::test) +BOOST_PHOENIX_ADAPT_FUNCTION(int, negate, impl::negate, 1) +BOOST_PHOENIX_ADAPT_FUNCTION(int, plus, impl::plus, 2) +BOOST_PHOENIX_ADAPT_FUNCTION( + typename boost::remove_reference<A0>::type + , plus + , impl::plus + , 3 +) +BOOST_PHOENIX_ADAPT_FUNCTION(int, plus4, impl::plus4, 4) + +// Test of solution to bug when using namespace +using namespace boost::phoenix; + +BOOST_PHOENIX_ADAPT_FUNCTION_NULLARY(void, test2, impl::test) +BOOST_PHOENIX_ADAPT_FUNCTION(int, negate2, impl::negate, 1) + + +int +main() +{ + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + + int a = 123; + int b = 256; + + test()(); + test2()(); + BOOST_TEST(::negate(arg1)(a) == -a); + BOOST_TEST(::negate2(arg1)(a) == -a); + BOOST_TEST(::plus(arg1, arg2)(a, b) == a+b); + BOOST_TEST(::plus(arg1, arg2, 3)(a, b) == a+b+3); + BOOST_TEST(plus4(arg1, arg2, 3, 4)(a, b) == a+b+3+4); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/function_tests.cpp b/src/boost/libs/phoenix/test/function/function_tests.cpp new file mode 100644 index 00000000..6f979faf --- /dev/null +++ b/src/boost/libs/phoenix/test/function/function_tests.cpp @@ -0,0 +1,140 @@ +/*============================================================================= + Copyright (c) 2001-2007 Joel de Guzman + + 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 <iostream> +#include <cmath> +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/operator.hpp> +#include <boost/phoenix/function.hpp> + +#define BOOST_MPL_CFG_NO_PREPROCESSED_HEADERS +#include <boost/mpl/multiplies.hpp> +#undef BOOST_MPL_CFG_NO_PREPROCESSED_HEADERS + +struct test_impl +{ + typedef void result_type; + void operator()() const + { + std::cout << "Test lazy functions...\n"; + } +}; + +boost::phoenix::function<test_impl> test; + +struct sqr_impl +{ + template <typename Signature> + struct result; + + template <typename This, typename Arg> + struct result<This(Arg)> + { + typedef typename boost::remove_reference<Arg>::type type; + }; + + template <typename Arg> + Arg + operator()(Arg n) const + { + return n * n; + } +}; + +boost::phoenix::function<sqr_impl> sqr; + +struct fact_impl +{ + template <typename Signature> + struct result; + + template <typename This, typename Arg> + struct result<This(Arg)> + { + typedef typename boost::remove_reference<Arg>::type type; + }; + + template <typename Arg> + Arg + operator()(Arg n) const + { + return (n <= 0) ? 1 : n * (*this)(n-1); + } +}; + +boost::phoenix::function<fact_impl> fact; + +struct pow_impl +{ + + template <typename Sig> + struct result; + + template <typename This, typename Arg1, typename Arg2> + struct result<This(Arg1, Arg2)> + { + typedef typename boost::remove_reference<Arg1>::type type; + }; + + template <typename Arg1, typename Arg2> + Arg1 + operator()(Arg1 a, Arg2 b) const + { + return std::pow(a, b); + } +}; + +boost::phoenix::function<pow_impl> power; + +struct add_impl +{ + template <typename Sig> + struct result; + + template <typename This, typename Arg1, typename Arg2, typename Arg3, typename Arg4> + struct result<This(Arg1, Arg2, Arg3, Arg4)> + { + typedef typename boost::remove_reference<Arg1>::type type; + }; + + template <typename Arg1, typename Arg2, typename Arg3, typename Arg4> + Arg1 + operator()(Arg1 a, Arg2 b, Arg3 c, Arg4 d) const + { + return a + b + c + d; + } +}; + +boost::phoenix::function<add_impl> add; + +int +main() +{ + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + + int i5 = 5; + double d5 = 5, d3 = 3; + + test()(); + BOOST_TEST(sqr(arg1)(i5) == (i5*i5)); + BOOST_TEST(fact(4)() == 24); + BOOST_TEST(fact(arg1)(i5) == 120); + BOOST_TEST((int)power(arg1, arg2)(d5, d3) == (int)std::pow(d5, d3)); + BOOST_TEST((sqr(arg1) + 5)(i5) == ((i5*i5)+5)); + BOOST_TEST(add(arg1, arg1, arg1, arg1)(i5) == (5+5+5+5)); + + // testing composition + BOOST_TEST(add(arg1, arg1, arg1, power(arg1, 2))(d5) == (5+5+5+25)); + + int const ic5 = 5; + // testing consts + BOOST_TEST(sqr(arg1)(ic5) == (ic5*ic5)); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/function_tests_phx2.cpp b/src/boost/libs/phoenix/test/function/function_tests_phx2.cpp new file mode 100644 index 00000000..bff3a720 --- /dev/null +++ b/src/boost/libs/phoenix/test/function/function_tests_phx2.cpp @@ -0,0 +1,116 @@ +/*============================================================================= + Copyright (c) 2001-2007 Joel de Guzman + + 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 <iostream> +#include <cmath> +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/operator.hpp> +#include <boost/phoenix/function.hpp> + +using namespace boost::phoenix; +using namespace boost::phoenix::arg_names; +using namespace std; + + struct test_impl + { + typedef void result_type; + void operator()() const + { + cout << "Test lazy functions...\n"; + } + }; + + function<test_impl> test; + + struct sqr_impl + { + template <typename Arg> + struct result + { + typedef Arg type; + }; + + template <typename Arg> + Arg operator()(Arg n) const + { + return n * n; + } + }; + + function<sqr_impl> sqr; + + struct fact_impl + { + template <typename Arg> + struct result + { + typedef Arg type; + }; + + template <typename Arg> + Arg operator()(Arg n) const + { + return (n <= 0) ? 1 : n * (*this)(n-1); + } + }; + + function<fact_impl> fact; + + struct pow_impl + { + template <typename Arg1, typename Arg2> + struct result + { + typedef Arg1 type; + }; + + template <typename Arg1, typename Arg2> + Arg1 operator()(Arg1 a, Arg2 b) const + { + return pow(a, b); + } + }; + + function<pow_impl> power; + + struct add_impl + { + template <typename Arg1, typename Arg2, typename Arg3, typename Arg4> + struct result + { + typedef Arg1 type; + }; + + template <typename Arg1, typename Arg2, typename Arg3, typename Arg4> + Arg1 operator()(Arg1 a, Arg2 b, Arg3 c, Arg4 d) const + { + return a + b + c + d; + } + }; + + function<add_impl> add; + +int +main() +{ + int i5 = 5; + double d5 = 5, d3 = 3; + + test()(); + BOOST_TEST(sqr(arg1)(i5) == (i5*i5)); + BOOST_TEST(fact(4)() == 24); + BOOST_TEST(fact(arg1)(i5) == 120); + BOOST_TEST((int)power(arg1, arg2)(d5, d3) == (int)pow(d5, d3)); + BOOST_TEST((sqr(arg1) + 5)(i5) == ((i5*i5)+5)); + BOOST_TEST(add(arg1, arg1, arg1, arg1)(i5) == (5+5+5+5)); + + int const ic5 = 5; + // testing consts + BOOST_TEST(sqr(arg1)(ic5) == (ic5*ic5)); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_argument_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_argument_tests.cpp new file mode 100644 index 00000000..a45f501f --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_argument_tests.cpp @@ -0,0 +1,53 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_argument_tests.cpp +// +// lazy argument tests passing lazy function as argument. +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function.hpp> + +namespace example { + struct G { + + template <typename Sig> + struct result; + + template <typename This, typename A0> + struct result<This(A0)> + : boost::remove_reference<A0> + {}; + + template <typename T> + T operator()(T t) const { return ++t; } + + }; +} + +typedef boost::phoenix::function<example::G> GG; +boost::phoenix::function<example::G> gg; + +template <typename F,typename T> +T h(F f, T const& t) +{ + return f(t)(); +} + +int main() +{ + BOOST_TEST( h(gg,1) == 2); + BOOST_TEST(( h<GG,int>(gg,1) == 2)); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_compose_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_compose_tests.cpp new file mode 100644 index 00000000..ea031e32 --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_compose_tests.cpp @@ -0,0 +1,40 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_compose_tests.cpp +// +// tests on compose +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function/lazy_prelude.hpp> + + +int main() +{ + namespace phx = boost::phoenix; + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + using namespace phx; + + BOOST_TEST(compose(id,id)(arg1)(1) == 1); + BOOST_TEST(compose(id,id)(1)() == 1); + BOOST_TEST(compose(inc,inc)(arg1)(1) == 3); + BOOST_TEST(compose(inc,plus)(arg1,arg2)(2,3) == 6); + BOOST_TEST(compose(plus,inc,dec)(arg1)(1) == 2); + BOOST_TEST(compose(plus,plus,minus)(arg1,arg2)(3,1) == 6); + + + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_fold_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_fold_tests.cpp new file mode 100644 index 00000000..5c542575 --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_fold_tests.cpp @@ -0,0 +1,44 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_fold_tests.cpp +// +// tests on foldl foldr and compose +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function/lazy_prelude.hpp> + + +int main() +{ + namespace phx = boost::phoenix; + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + using boost::phoenix::arg_names::arg3; + using namespace phx; + + list<int> l = enum_from(2); + list<int> evens = filter(even,l); + list<int> even4 = take(4,evens)(); + + BOOST_TEST(foldr(plus,0,even4)() == 20); + BOOST_TEST(foldr(multiplies,1,even4)() == 384); + BOOST_TEST(foldr1(plus,even4)() == 20 ); + BOOST_TEST(foldl(plus,arg1,even4)(0) == 20); + BOOST_TEST(foldl1(plus,even4)() == 20); + BOOST_TEST(compose(inc,foldr)(plus,0,even4)() == 21); + BOOST_TEST(compose(plus,foldl,foldr)(arg1,arg2,arg3)(plus,0,even4) == 40); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_list2_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_list2_tests.cpp new file mode 100644 index 00000000..c294a8f8 --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_list2_tests.cpp @@ -0,0 +1,42 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_list2_tests.cpp +// +// more tests on list<T> +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function/lazy_prelude.hpp> + + +int main() +{ + namespace phx = boost::phoenix; + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + using namespace phx; + + list<int> l0; + list<int> l1 = list_with<>()(1,2,3,4,5); + list<int> l2 = all_but_last(l1)(); + + BOOST_TEST(null(l0)()); + BOOST_TEST(head(l1)() == 1); + BOOST_TEST(head(tail(l1))() == 2); + BOOST_TEST(last(l1)() == 5); + BOOST_TEST(last(l2)() == 4); + BOOST_TEST(head(drop(2,l2))() == 3); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_list3_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_list3_tests.cpp new file mode 100644 index 00000000..9e4bc6d0 --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_list3_tests.cpp @@ -0,0 +1,54 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_list3_tests.cpp +// +// more tests on list<T> +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function/lazy_prelude.hpp> + + +int main() +{ + namespace phx = boost::phoenix; + //using boost::phoenix::arg_names::arg1; + //using boost::phoenix::arg_names::arg2; + using namespace phx; + + list<int> l = enum_from(2); + list<int> ll = take(4,l); + list<int> lll = take(12,l); + list<int> l2 = enum_from_to(2,10); + list<int> ll2 = take(4,l2); + list<int> lll2 = take(12,l2); + list<int> evens = filter(even,l); + list<int> odds = filter(odd,l); + list<int> even4 = take(4,evens)(); + list<int> odd4 = take(4,odds)(); + list<int> itersome = take(4,iterate(dec,1))(); + list<int> repeatsome = take(4,repeat(1))(); + + BOOST_TEST(last(ll)() == 5); + BOOST_TEST(last(lll)() == 13); + BOOST_TEST(last(ll2)() == 5); + BOOST_TEST(last(lll2)() == 10); + BOOST_TEST(length(lll2)() == 9); + BOOST_TEST(at_(even4,3)() == 8); + BOOST_TEST(at_(odd4,2)() == 7); + BOOST_TEST(at_(itersome,3)() == -3); + BOOST_TEST(at_(repeatsome,3)() == 1); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_list_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_list_tests.cpp new file mode 100644 index 00000000..47caf649 --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_list_tests.cpp @@ -0,0 +1,78 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_list_tests.cpp +// +// tests on list<T> +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function/lazy_prelude.hpp> + + +int main() +{ + namespace phx = boost::phoenix; + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + using phx::null; + using phx::list; + using phx::head; + using phx::tail; + using phx::cons; + using phx::cat; + using phx::take; + using phx::NIL; + + list<int> l0; + list<int> l1 = cons(1,l0); + list<int> l2 = cons(2,l1); + list<int> l3 = cons(3,l2); + list<int> l4 = cons(4,l3); + list<int> l5 = cons(5,NIL); + list<int> l6 = take(2,l4)(); + list<int> l7 = cons(7,take(2,l4)); + list<int> l8 = take(1,take(3,l4))(); + + BOOST_TEST(null(l0)()); + BOOST_TEST(null(arg1)(l0)); + BOOST_TEST(head(l1)() == 1); + BOOST_TEST(head(arg1)(l1) == 1); + BOOST_TEST(head(tail(l2))() == 1); + BOOST_TEST(head(tail(arg1))(l2) == 1); + BOOST_TEST(head(tail(tail(l3)))() == 1); + BOOST_TEST(head(tail(tail(arg1)))(l3) == 1); + BOOST_TEST(head(tail(tail(l4)))() == 2); + BOOST_TEST(head(tail(tail(arg1)))(l4) == 2); + BOOST_TEST(head(l5)() == 5); + BOOST_TEST(head(arg1)(l5) == 5); + BOOST_TEST(head(tail(l6))() == 3); + BOOST_TEST(head(tail(arg1))(l6) == 3); + BOOST_TEST(head(tail(l7))() == 4); + BOOST_TEST(head(tail(arg1))(l7) == 4); + BOOST_TEST(head(l8)() == 4); + BOOST_TEST(head(arg1)(l8) == 4); + + list<int> l9 = cat(l8,take(2,l4)); + list<int> l10 = cat(l8,NIL); + list<int> l11 = cat(l0,l7); + list<int> l12 = cat(l10,l8); + + BOOST_TEST(head(tail(l9))() == 4); + BOOST_TEST(head(l10)() == 4); + BOOST_TEST(head(arg1)(l11) == 7); + BOOST_TEST(head(l12)() == 4); + + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_make_pair_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_make_pair_tests.cpp new file mode 100644 index 00000000..09fccf5c --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_make_pair_tests.cpp @@ -0,0 +1,109 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_make_pair_tests.cpp +// +// lazy make_pair test solving the optimizer problem. +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function.hpp> + +namespace boost { + + namespace phoenix { + +#ifdef BOOST_RESULT_OF_USE_TR1 + + namespace result_of { + + template < + typename Arg1 + , typename Arg2 + > + class make_pair + { + public: + typedef typename boost::remove_reference<Arg1>::type Arg1Type; + typedef typename boost::remove_reference<Arg2>::type Arg2Type; + typedef std::pair<Arg1Type,Arg2Type> type; + }; + } +#endif + + namespace impl + { + + struct make_pair { + + +#ifdef BOOST_RESULT_OF_USE_TR1 + template <typename Sig> + struct result; + // This fails with -O2 unless refs are removed from A1 and A2. + template <typename This, typename A0, typename A1> + struct result<This(A0, A1)> + { + typedef typename result_of::make_pair<A0,A1>::type type; + }; +#else + template <typename Sig> + struct result; + + template <typename This, typename A0, typename A1> + struct result<This(A0, A1)> + : boost::remove_reference<std::pair<A0, A1> > + {}; + +#endif + + + template <typename A0, typename A1> +#ifdef BOOST_RESULT_OF_USE_TR1 + typename result<make_pair(A0,A1)>::type +#else + std::pair<A0, A1> +#endif + operator()(A0 const & a0, A1 const & a1) const + { + return std::make_pair(a0,a1); + } + + }; + } + +BOOST_PHOENIX_ADAPT_CALLABLE(make_pair, impl::make_pair, 2) + + } + +} + +int main() +{ + namespace phx = boost::phoenix; + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + int a = 99; int b = 256; + + std::pair<int,int> ab1 = phx::make_pair(a,b)(); + //std::cout << ab1.first << "," << ab1.second << std::endl; + BOOST_TEST(ab1.first == 99 && ab1.second == 256); + std::pair<int,int> ab2 = phx::make_pair(arg1,b)(a); + //std::cout << ab2.first << "," << ab2.second << std::endl; + BOOST_TEST(ab2.first == 99 && ab2.second == 256); + std::pair<int,int> ab3 = phx::make_pair(arg1,arg2)(a,b); + //std::cout << ab3.first << "," << ab3.second << std::endl; + BOOST_TEST(ab3.first == 99 && ab3.second == 256); + + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_operator_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_operator_tests.cpp new file mode 100644 index 00000000..ef05717c --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_operator_tests.cpp @@ -0,0 +1,46 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_operator_tests.cpp +// +// lazy operator tests +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function/lazy_operator.hpp> + + +int main() +{ + using boost::phoenix::plus; + using boost::phoenix::minus; + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + + int a = 123; + int b = 256; + + BOOST_TEST(plus(arg1, arg2)(a, b) == a+b); + BOOST_TEST(plus(arg1, arg2, 3)(a, b) == a+b+3); + BOOST_TEST(plus(arg1, b)(a) == a+b); + BOOST_TEST(plus(a, arg2)(a,b) == a+b); + BOOST_TEST(plus(a, arg1)(b) == a+b); + BOOST_TEST(plus(a, b)() == a+b); + BOOST_TEST(minus(a, b)() == a-b); + BOOST_TEST(plus(minus(a, b),b)() == a); + BOOST_TEST(plus(minus(arg1, b),b)(a) == a); + BOOST_TEST(plus(minus(arg1, arg2),b)(a,b) == a); + BOOST_TEST(plus(minus(arg1, arg2),arg2)(a,b) ==a); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_ptr_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_ptr_tests.cpp new file mode 100644 index 00000000..22b1f157 --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_ptr_tests.cpp @@ -0,0 +1,110 @@ +////////////////////////////////////////////////////////////////// +// +// lazy_ptr_tests.cpp +// +// Tests for ptr_to_fun, ptr_to_fun0 and ptr_to_mem_fun. +// +// +/*============================================================================= + Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <iostream> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function.hpp> +#include <boost/shared_ptr.hpp> +#include <boost/phoenix/function/lazy_prelude.hpp> + +#include <boost/detail/lightweight_test.hpp> + +using namespace boost::phoenix; + +using std::cout; +using std::endl; + +namespace example { + + int footle() + { + return 0; + } + + int foobar(int x) + { + return 2*x; + } + + int foxy(int x,int y) + { + return x*y; + } + + int foxyz(int x,int y,int z) + { + return x*y + z; + } + + int fwxyz(int w,int x,int y,int z) + { + return w + x*y + z; + } + +} + +struct O { + int aa; + O( int a ) : aa(a) {} + int cf( int x ) const { return x+1; } + int f( int x ) { return ++aa + x; } + int a() const { return aa; } +}; + + +int main() { + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + using boost::phoenix::arg_names::arg3; + using boost::phoenix::arg_names::arg4; + + BOOST_TEST( ptr_to_fun0(&example::footle)()() == 0 ); + BOOST_TEST( ptr_to_fun(&example::foobar)(arg1)(1) == 2 ); + BOOST_TEST( ptr_to_fun(&example::foxy)(arg1,arg2)(2,3) == 6 ); + BOOST_TEST( ptr_to_fun(&example::foxyz)(arg1,arg2,arg3)(2,3,4) == 10 ); + BOOST_TEST( ptr_to_fun(&example::fwxyz)(arg1,arg2,arg3,arg4)(1,2,3,4) == 11); + + O o(1); + BOOST_TEST( ptr_to_mem_fun( &O::a )( &o )() == 1 ); + BOOST_TEST( ptr_to_mem_fun( &O::cf )( &o, 1 )() == 2 ); + BOOST_TEST( ptr_to_mem_fun( &O::f )( &o, 1 )() == 3 ); + BOOST_TEST( ptr_to_mem_fun( &O::f )( &o, 1 )() == 4 ); + BOOST_TEST( ptr_to_mem_fun( &O::cf )( &o, 1 )() == 2 ); + + O oo(1); + BOOST_TEST( ptr_to_mem_fun( &O::a )( arg1 )( &oo ) == 1 ); + BOOST_TEST( ptr_to_mem_fun( &O::cf )( &oo, arg1 )(1) == 2 ); + BOOST_TEST( ptr_to_mem_fun( &O::f )( &oo, arg1 )(1) == 3 ); + BOOST_TEST( ptr_to_mem_fun( &O::f )( &oo, arg1 )(1) == 4 ); + BOOST_TEST( ptr_to_mem_fun( &O::cf )( &oo, arg1 )(1) == 2 ); + + const O p(1); + BOOST_TEST( ptr_to_mem_fun( &O::a )( &p )() == 1 ); + BOOST_TEST( ptr_to_mem_fun( &O::cf )( &p, 1 )() == 2 ); + + boost::shared_ptr<O> r( new O(3) ); + BOOST_TEST( ptr_to_mem_fun( &O::a )( r )() == 3 ); + BOOST_TEST( ptr_to_mem_fun( &O::cf )( r, 1 )() == 2 ); + BOOST_TEST( ptr_to_mem_fun( &O::f )( r, 1 )() == 5 ); + BOOST_TEST( ptr_to_mem_fun( &O::f )( r, 1 )() == 6 ); + BOOST_TEST( ptr_to_mem_fun( &O::cf )( r, 1 )() == 2 ); + + boost::shared_ptr<const O> s( new O(3) ); + BOOST_TEST( ptr_to_mem_fun( &O::a )( s )() == 3 ); + BOOST_TEST( ptr_to_mem_fun( &O::cf )( s, 1 )() == 2 ); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_scan_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_scan_tests.cpp new file mode 100644 index 00000000..0567951b --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_scan_tests.cpp @@ -0,0 +1,56 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_scan_tests.cpp +// +// tests on scanl scanr map zip and zip_with +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function/lazy_prelude.hpp> + + +int main() +{ + namespace phx = boost::phoenix; + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + using boost::phoenix::arg_names::arg3; + using namespace phx; + + list<int> l = enum_from(2); + list<int> evens = filter(even,l); + list<int> odds = filter(odd,l); + list<int> even4 = take(4,evens)(); + list<int> odd4 = take(4,odds)(); + + BOOST_TEST(head(scanr(plus,0,even4))() == 20); + BOOST_TEST(last(scanl(plus,0,even4))() == 20); + BOOST_TEST(head(scanr1(plus,even4))() == 20); + BOOST_TEST(last(scanl1(plus,even4))() == 20); + + list<int> map_result = map(inc,even4)(); + list<int> zip_with_result = zip_with(plus,even4,odd4)(); + + BOOST_TEST(foldl1(plus,map_result)() == 24); + BOOST_TEST(last(zip_with_result)() == 17); + + typedef std::pair<int,int> pair_ii; + list<pair_ii> zip_result1 = zip_with(make_pair,even4,odd4)(); + list<pair_ii> zip_result2 = zip(even4,odd4)(); + + BOOST_TEST(head(zip_result1)().first == 2); + BOOST_TEST(last(zip_result2)().second == 9); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_templated_struct_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_templated_struct_tests.cpp new file mode 100644 index 00000000..b7c99043 --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_templated_struct_tests.cpp @@ -0,0 +1,68 @@ +//////////////////////////////////////////////////////////////////////////// +// lazy_templated_struct_tests.cpp +// +// lazy templated struct test to check this works everywhere. +// +//////////////////////////////////////////////////////////////////////////// +/*============================================================================= + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <boost/phoenix/core/limits.hpp> + +#include <boost/detail/lightweight_test.hpp> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function.hpp> +#include <boost/function.hpp> + +namespace example { + + namespace impl { + // Example of templated struct. + template <typename Result> + struct what { + + typedef Result result_type; + + Result operator()(Result const & r) const + { + return r; + } + }; + + template <typename Result> + struct what0 { + + typedef Result result_type; + + Result operator()() const + { + return Result(100); + } + + }; + + } + + boost::function1<int, int > what_int = impl::what<int>(); + boost::function0<int> what0_int = impl::what0<int>(); + BOOST_PHOENIX_ADAPT_FUNCTION(int,what,what_int,1) + BOOST_PHOENIX_ADAPT_FUNCTION_NULLARY(int,what0,what0_int) +} + +int main() +{ + int a = 99; + using boost::phoenix::arg_names::arg1; + BOOST_TEST(example::what_int(a) == a); + BOOST_TEST(example::what(a)() == a); + BOOST_TEST(example::what(arg1)(a) == a); + BOOST_TEST(example::what0_int() == 100); + BOOST_TEST(example::what0()() == 100); + + return boost::report_errors(); +} diff --git a/src/boost/libs/phoenix/test/function/lazy_thunk_tests.cpp b/src/boost/libs/phoenix/test/function/lazy_thunk_tests.cpp new file mode 100644 index 00000000..f44e991e --- /dev/null +++ b/src/boost/libs/phoenix/test/function/lazy_thunk_tests.cpp @@ -0,0 +1,48 @@ +////////////////////////////////////////////////////////////////// +// +// lazy_thunk_tests.cpp +// +// Tests for thunk functions. +// +// +/*============================================================================= + Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis + Copyright (c) 2001-2007 Joel de Guzman + Copyright (c) 2015 John Fletcher + + 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 <iostream> +#include <boost/phoenix/core.hpp> +#include <boost/phoenix/function.hpp> +#include <boost/shared_ptr.hpp> +#include <boost/phoenix/function/lazy_prelude.hpp> + +#include <boost/detail/lightweight_test.hpp> + +using namespace boost::phoenix; + +using std::cout; +using std::endl; + + + +int main() { + using boost::phoenix::arg_names::arg1; + using boost::phoenix::arg_names::arg2; + + BOOST_TEST( thunk1(inc,1)()() == 2); + BOOST_TEST( thunk1(inc,arg1)(1)() == 2); + BOOST_TEST( thunk2(plus,1,2)()() == 3); + BOOST_TEST( thunk2(plus,arg1,arg2)(1,2)() == 3); + + list<int> l = enum_from_to(1,5); + list<int> l4 = take(4,l)(); + BOOST_TEST( foldl(plus,0,l4)() == 10); + BOOST_TEST( thunk3(foldl,plus,0,l4)()() == 10); + BOOST_TEST( thunk3(foldl,plus,arg1,l4)(0)() == 10); + + return boost::report_errors(); +} |