lazy_ptr_tests.cpp 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. //////////////////////////////////////////////////////////////////
  2. //
  3. // lazy_ptr_tests.cpp
  4. //
  5. // Tests for ptr_to_fun, ptr_to_fun0 and ptr_to_mem_fun.
  6. //
  7. //
  8. /*=============================================================================
  9. Copyright (c) 2000-2003 Brian McNamara and Yannis Smaragdakis
  10. Copyright (c) 2001-2007 Joel de Guzman
  11. Copyright (c) 2015 John Fletcher
  12. Distributed under the Boost Software License, Version 1.0. (See accompanying
  13. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  14. ==============================================================================*/
  15. #include <iostream>
  16. #include <boost/phoenix/core.hpp>
  17. #include <boost/phoenix/function.hpp>
  18. #include <boost/shared_ptr.hpp>
  19. #include <boost/phoenix/function/lazy_prelude.hpp>
  20. #include <boost/detail/lightweight_test.hpp>
  21. using namespace boost::phoenix;
  22. using std::cout;
  23. using std::endl;
  24. namespace example {
  25. int footle()
  26. {
  27. return 0;
  28. }
  29. int foobar(int x)
  30. {
  31. return 2*x;
  32. }
  33. int foxy(int x,int y)
  34. {
  35. return x*y;
  36. }
  37. int foxyz(int x,int y,int z)
  38. {
  39. return x*y + z;
  40. }
  41. int fwxyz(int w,int x,int y,int z)
  42. {
  43. return w + x*y + z;
  44. }
  45. }
  46. struct O {
  47. int aa;
  48. O( int a ) : aa(a) {}
  49. int cf( int x ) const { return x+1; }
  50. int f( int x ) { return ++aa + x; }
  51. int a() const { return aa; }
  52. };
  53. int main() {
  54. using boost::phoenix::arg_names::arg1;
  55. using boost::phoenix::arg_names::arg2;
  56. using boost::phoenix::arg_names::arg3;
  57. using boost::phoenix::arg_names::arg4;
  58. BOOST_TEST( ptr_to_fun0(&example::footle)()() == 0 );
  59. BOOST_TEST( ptr_to_fun(&example::foobar)(arg1)(1) == 2 );
  60. BOOST_TEST( ptr_to_fun(&example::foxy)(arg1,arg2)(2,3) == 6 );
  61. BOOST_TEST( ptr_to_fun(&example::foxyz)(arg1,arg2,arg3)(2,3,4) == 10 );
  62. BOOST_TEST( ptr_to_fun(&example::fwxyz)(arg1,arg2,arg3,arg4)(1,2,3,4) == 11);
  63. O o(1);
  64. BOOST_TEST( ptr_to_mem_fun( &O::a )( &o )() == 1 );
  65. BOOST_TEST( ptr_to_mem_fun( &O::cf )( &o, 1 )() == 2 );
  66. BOOST_TEST( ptr_to_mem_fun( &O::f )( &o, 1 )() == 3 );
  67. BOOST_TEST( ptr_to_mem_fun( &O::f )( &o, 1 )() == 4 );
  68. BOOST_TEST( ptr_to_mem_fun( &O::cf )( &o, 1 )() == 2 );
  69. O oo(1);
  70. BOOST_TEST( ptr_to_mem_fun( &O::a )( arg1 )( &oo ) == 1 );
  71. BOOST_TEST( ptr_to_mem_fun( &O::cf )( &oo, arg1 )(1) == 2 );
  72. BOOST_TEST( ptr_to_mem_fun( &O::f )( &oo, arg1 )(1) == 3 );
  73. BOOST_TEST( ptr_to_mem_fun( &O::f )( &oo, arg1 )(1) == 4 );
  74. BOOST_TEST( ptr_to_mem_fun( &O::cf )( &oo, arg1 )(1) == 2 );
  75. const O p(1);
  76. BOOST_TEST( ptr_to_mem_fun( &O::a )( &p )() == 1 );
  77. BOOST_TEST( ptr_to_mem_fun( &O::cf )( &p, 1 )() == 2 );
  78. boost::shared_ptr<O> r( new O(3) );
  79. BOOST_TEST( ptr_to_mem_fun( &O::a )( r )() == 3 );
  80. BOOST_TEST( ptr_to_mem_fun( &O::cf )( r, 1 )() == 2 );
  81. BOOST_TEST( ptr_to_mem_fun( &O::f )( r, 1 )() == 5 );
  82. BOOST_TEST( ptr_to_mem_fun( &O::f )( r, 1 )() == 6 );
  83. BOOST_TEST( ptr_to_mem_fun( &O::cf )( r, 1 )() == 2 );
  84. boost::shared_ptr<const O> s( new O(3) );
  85. BOOST_TEST( ptr_to_mem_fun( &O::a )( s )() == 3 );
  86. BOOST_TEST( ptr_to_mem_fun( &O::cf )( s, 1 )() == 2 );
  87. return boost::report_errors();
  88. }