1 //===----------------------------------------------------------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // Copyright (C) 2011,2014 Vicente J. Botet Escriba
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)
15 // <boost/thread/future.hpp>
19 // void promise::set_value(R&& r);
21 #define BOOST_THREAD_VERSION 3
23 #include <boost/thread/future.hpp>
24 #include <boost/detail/lightweight_test.hpp>
25 #include <boost/static_assert.hpp>
37 BOOST_THREAD_MOVABLE_ONLY(A)
39 A(BOOST_THREAD_RV_REF(A) rhs)
49 A& operator=(BOOST_THREAD_RV_REF(A) rhs)
70 BOOST_THREAD_MOVABLE_ONLY(movable2)
71 movable2() : value_(1){}
72 movable2(int i) : value_(i){}
74 //Move constructor and assignment
75 movable2(BOOST_RV_REF(movable2) m)
76 { value_ = m.value_; m.value_ = 0; }
78 movable2 & operator=(BOOST_THREAD_RV_REF(movable2) m)
79 { value_ = m.value_; m.value_ = 0; return *this; }
81 bool moved() const //Observer
84 int value() const //Observer
89 movable2 move_return_function2(int i) {
95 #if defined BOOST_NO_CXX11_RVALUE_REFERENCES
96 BOOST_STATIC_ASSERT((boost::is_copy_constructible<movable2>::value == false));
97 BOOST_STATIC_ASSERT((boost::has_move_emulation_enabled<movable2>::value == true));
98 BOOST_STATIC_ASSERT((boost::is_copy_constructible<A>::value == false));
99 BOOST_STATIC_ASSERT((boost::has_move_emulation_enabled<A>::value == true));
106 boost::future<T> f = p.get_future();
109 p.set_value(boost::move(i));
125 boost::future<T> f = p.get_future();
144 boost::future<T> f = p.get_future();
145 p.set_value(boost::move(i));
146 BOOST_TEST(f.get().value == 3);
150 p.set_value(boost::move(j));
153 catch (const boost::future_error& e)
155 BOOST_TEST(e.code() == boost::system::make_error_code(boost::future_errc::promise_already_satisfied));
165 boost::promise<movable2> p;
166 boost::future<movable2> f = p.get_future();
167 p.set_value(move_return_function2(3));
168 BOOST_TEST(f.get().value_ == 3);
172 p.set_value(boost::move(j));
175 catch (const boost::future_error& e)
177 BOOST_TEST(e.code() == boost::system::make_error_code(boost::future_errc::promise_already_satisfied));
187 boost::future<A> f = p.get_future();
188 p.set_value(make(3));
189 BOOST_TEST(f.get().value == 3);
193 p.set_value(boost::move(j));
196 catch (const boost::future_error& e)
198 BOOST_TEST(e.code() == boost::system::make_error_code(boost::future_errc::promise_already_satisfied));
210 boost::future<T> f = p.get_future();
211 p.set_value(boost::move(i));
212 BOOST_TEST(i.value == 0);
213 boost::promise<T> p2(boost::move(p));
214 BOOST_TEST(f.get().value == 3);
221 boost::future<T> f = p.get_future();
222 p.set_value(boost::move(i));
223 BOOST_TEST(i.value == 0);
224 boost::promise<T> p2(boost::move(p));
225 boost::future<T> f2(boost::move(f));
226 BOOST_TEST(f2.get().value == 3);
233 p.set_value(boost::move(i));
234 BOOST_TEST(i.value == 0);
235 boost::promise<T> p2(boost::move(p));
236 boost::future<T> f = p2.get_future();
237 BOOST_TEST(f.get().value == 3);
242 typedef boost::future<int> T;
243 boost::promise<int> pi;
244 T fi=pi.get_future();
248 boost::future<T> f = p.get_future();
249 p.set_value(boost::move(fi));
250 boost::future<T> f2(boost::move(f));
251 BOOST_TEST(f2.get().get() == 3);
254 return boost::report_errors();