]>
git.proxmox.com Git - ceph.git/blob - ceph/src/boost/libs/thread/example/future_then.cpp
86ee1970c2f8f1e252ee1c3246e6ce43c0f48d26
1 // Copyright (C) 2012-2013 Vicente Botet
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)
6 #include <boost/config.hpp>
7 #if ! defined BOOST_NO_CXX11_DECLTYPE
8 #define BOOST_RESULT_OF_USE_DECLTYPE
12 #define BOOST_THREAD_VERSION 4
13 //#define BOOST_THREAD_USES_LOG
14 #define BOOST_THREAD_USES_LOG_THREAD_ID
16 #include <boost/thread/detail/log.hpp>
17 #include <boost/thread/future.hpp>
18 #include <boost/assert.hpp>
20 #if defined BOOST_THREAD_PROVIDES_FUTURE_CONTINUATION
24 BOOST_THREAD_LOG
<< "P1" << BOOST_THREAD_END_LOG
;
28 int p2(boost::future
<int> f
)
30 BOOST_THREAD_LOG
<< "P2<" << BOOST_THREAD_END_LOG
;
35 catch (std::exception
& ex
)
37 std::cout
<< "ERRORRRRR "<<ex
.what() << "" << std::endl
;
38 BOOST_THREAD_LOG
<< "ERRORRRRR "<<ex
.what() << "" << BOOST_THREAD_END_LOG
;
43 BOOST_THREAD_LOG
<< " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG
;
46 BOOST_THREAD_LOG
<< "P2>" << BOOST_THREAD_END_LOG
;
49 int p2s(boost::shared_future
<int> f
)
51 BOOST_THREAD_LOG
<< "<P2S" << BOOST_THREAD_END_LOG
;
56 catch (std::exception
& ex
)
58 std::cout
<< "ERRORRRRR "<<ex
.what() << "" << std::endl
;
59 BOOST_THREAD_LOG
<< "ERRORRRRR "<<ex
.what() << "" << BOOST_THREAD_END_LOG
;
64 BOOST_THREAD_LOG
<< " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG
;
67 BOOST_THREAD_LOG
<< "P2S>" << BOOST_THREAD_END_LOG
;
73 const int number_of_tests
= 100;
74 BOOST_THREAD_LOG
<< "<MAIN" << BOOST_THREAD_END_LOG
;
76 for (int i
=0; i
< number_of_tests
; i
++)
79 BOOST_THREAD_LOG
<< "" << BOOST_THREAD_END_LOG
;
80 boost::future
<int> f1
= boost::async(&p1
);
81 BOOST_THREAD_LOG
<< "" << BOOST_THREAD_END_LOG
;
82 boost::future
<int> f2
= f1
.then(&p2
);
83 BOOST_THREAD_LOG
<< "" << BOOST_THREAD_END_LOG
;
85 BOOST_THREAD_LOG
<< "" << BOOST_THREAD_END_LOG
;
87 catch (std::exception
& ex
)
89 std::cout
<< "ERRORRRRR "<<ex
.what() << "" << std::endl
;
90 BOOST_THREAD_LOG
<< "ERRORRRRR "<<ex
.what() << "" << BOOST_THREAD_END_LOG
;
95 BOOST_THREAD_LOG
<< " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG
;
100 for (int i
=0; i
< number_of_tests
; i
++)
103 BOOST_THREAD_LOG
<< "" << BOOST_THREAD_END_LOG
;
104 boost::shared_future
<int> f1
= boost::async(&p1
).share();
105 BOOST_THREAD_LOG
<< "" << BOOST_THREAD_END_LOG
;
106 boost::future
<int> f2
= f1
.then(&p2s
);
107 BOOST_THREAD_LOG
<< "" << BOOST_THREAD_END_LOG
;
109 BOOST_THREAD_LOG
<< "" << BOOST_THREAD_END_LOG
;
111 catch (std::exception
& ex
)
113 std::cout
<< "ERRORRRRR "<<ex
.what() << "" << std::endl
;
114 BOOST_THREAD_LOG
<< "ERRORRRRR "<<ex
.what() << "" << BOOST_THREAD_END_LOG
;
119 BOOST_THREAD_LOG
<< " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG
;
123 BOOST_THREAD_LOG
<< "MAIN>" << BOOST_THREAD_END_LOG
;