then_pass.cpp 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. // Copyright (C) 2012-2013 Vicente Botet
  2. //
  3. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. // <boost/thread/future.hpp>
  6. // class future<R>
  7. // template<typename F>
  8. // auto then(F&& func) -> future<decltype(func(*this))>;
  9. #define BOOST_THREAD_VERSION 4
  10. //#define BOOST_THREAD_USES_LOG
  11. #define BOOST_THREAD_USES_LOG_THREAD_ID
  12. #include <boost/thread/detail/log.hpp>
  13. #include <boost/thread/future.hpp>
  14. #include <boost/detail/lightweight_test.hpp>
  15. #if defined BOOST_THREAD_PROVIDES_FUTURE_CONTINUATION
  16. #ifdef BOOST_MSVC
  17. #pragma warning(disable: 4127) // conditional expression is constant
  18. #endif
  19. int p1()
  20. {
  21. BOOST_THREAD_LOG << "p1 < " << BOOST_THREAD_END_LOG;
  22. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  23. BOOST_THREAD_LOG << "p1 >" << BOOST_THREAD_END_LOG;
  24. return 1;
  25. }
  26. int p2(boost::future<int> f)
  27. {
  28. BOOST_THREAD_LOG << "p2 <" << &f << BOOST_THREAD_END_LOG;
  29. BOOST_TEST(f.valid());
  30. int i = f.get();
  31. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  32. BOOST_THREAD_LOG << "p2 <" << &f << BOOST_THREAD_END_LOG;
  33. return 2 * i;
  34. }
  35. void p3(boost::future<int> f)
  36. {
  37. BOOST_THREAD_LOG << "p3 <" << &f << BOOST_THREAD_END_LOG;
  38. BOOST_TEST(f.valid());
  39. int i = f.get();
  40. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  41. BOOST_THREAD_LOG << "p3 <" << &f << " " <<i << BOOST_THREAD_END_LOG;
  42. return;
  43. }
  44. int main()
  45. {
  46. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  47. {
  48. boost::future<int> f1 = boost::async(boost::launch::async, &p1);
  49. BOOST_TEST(f1.valid());
  50. boost::future<int> f2 = f1.then(&p2);
  51. BOOST_TEST(f2.valid());
  52. BOOST_TEST(! f1.valid());
  53. try
  54. {
  55. BOOST_TEST(f2.get()==2);
  56. }
  57. catch (std::exception& ex)
  58. {
  59. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  60. BOOST_TEST(false);
  61. }
  62. catch (...)
  63. {
  64. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  65. BOOST_TEST(false);
  66. }
  67. }
  68. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  69. {
  70. boost::future<int> f1 = boost::async(boost::launch::async, &p1);
  71. BOOST_TEST(f1.valid());
  72. boost::future<void> f2 = f1.then(&p3);
  73. BOOST_TEST(f2.valid());
  74. try
  75. {
  76. f2.wait();
  77. }
  78. catch (std::exception& ex)
  79. {
  80. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  81. BOOST_TEST(false);
  82. }
  83. catch (...)
  84. {
  85. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  86. BOOST_TEST(false);
  87. }
  88. }
  89. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  90. {
  91. boost::future<int> f2 = boost::async(p1).then(&p2);
  92. BOOST_TEST(f2.get()==2);
  93. }
  94. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  95. {
  96. boost::future<int> f1 = boost::async(p1);
  97. boost::future<int> f21 = f1.then(&p2);
  98. boost::future<int> f2= f21.then(&p2);
  99. BOOST_TEST(f2.get()==4);
  100. }
  101. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  102. {
  103. boost::future<int> f1 = boost::async(p1);
  104. boost::future<int> f2= f1.then(&p2).then(&p2);
  105. BOOST_TEST(f2.get()==4);
  106. }
  107. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  108. {
  109. boost::future<int> f2 = boost::async(p1).then(&p2).then(&p2);
  110. BOOST_TEST(f2.get()==4);
  111. }
  112. return boost::report_errors();
  113. }
  114. #else
  115. int main()
  116. {
  117. return 0;
  118. }
  119. #endif