mirror of
https://github.com/boostorg/thread.git
synced 2026-01-24 18:32:32 +00:00
* [@http://svn.boost.org/trac/boost/ticket/6195 #6195] c++11 compliance: Provide the standard time related interface using Boost.Chrono. * [@http://svn.boost.org/trac/boost/ticket/6224 #6224] c++11 compliance: Add the use of standard noexcept on compilers supporting them. * [@http://svn.boost.org/trac/boost/ticket/6226 #6226] c++11 compliance: Add explicit bool conversion from locks. * [@http://svn.boost.org/trac/boost/ticket/6230 #6230] c++11 compliance: Follows the exception reporting mechanism as defined in the c++11. * [@http://svn.boost.org/trac/boost/ticket/6272 #6272] c++11 compliance: Add thread::id hash specialization. * [@http://svn.boost.org/trac/boost/ticket/6273 #6273] c++11 compliance: Add cv_status enum class and use it on the conditions wait functions. * [@http://svn.boost.org/trac/boost/ticket/6194 #6194] Adapt to Boost.Move. Fixed Bugs: * [@http://svn.boost.org/trac/boost/ticket/2575 #2575] Bug- Boost 1.36.0 on Itanium platform. * [@http://svn.boost.org/trac/boost/ticket/4921 #4921] BOOST_THREAD_USE_DLL and BOOST_THREAD_USE_LIB are crucial and need to be documented. * [@http://svn.boost.org/trac/boost/ticket/5013 #5013] documentation: boost:🧵 pthreas_exit causes terminate(). * [@http://svn.boost.org/trac/boost/ticket/5351 #5351] interrupt a future get boost::unknown_exception. * [@http://svn.boost.org/trac/boost/ticket/5516 #5516] Upgrade lock is not acquired when previous upgrade lock releases if another read lock is present. * [@http://svn.boost.org/trac/boost/ticket/5990 #5990] shared_future<T>::get() has wrong return type. * [@http://svn.boost.org/trac/boost/ticket/6174 #6174] packaged_task doesn't correctly handle moving results. [SVN r76543]
57 lines
1.4 KiB
C++
57 lines
1.4 KiB
C++
// Copyright (C) 2007-9 Anthony Williams
|
|
//
|
|
// 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/thread/thread.hpp>
|
|
#include <boost/test/unit_test.hpp>
|
|
|
|
void do_nothing(boost::thread::id* my_id)
|
|
{
|
|
*my_id=boost::this_thread::get_id();
|
|
}
|
|
|
|
void test_move_on_construction()
|
|
{
|
|
boost::thread::id the_id;
|
|
boost::thread x=boost::thread(do_nothing,&the_id);
|
|
boost::thread::id x_id=x.get_id();
|
|
x.join();
|
|
BOOST_CHECK_EQUAL(the_id,x_id);
|
|
}
|
|
|
|
boost::thread make_thread(boost::thread::id* the_id)
|
|
{
|
|
return boost::thread(do_nothing,the_id);
|
|
}
|
|
|
|
void test_move_from_function_return()
|
|
{
|
|
boost::thread::id the_id;
|
|
boost::thread x=make_thread(&the_id);
|
|
boost::thread::id x_id=x.get_id();
|
|
x.join();
|
|
BOOST_CHECK_EQUAL(the_id,x_id);
|
|
}
|
|
|
|
void test_move_assign()
|
|
{
|
|
boost::thread::id the_id;
|
|
boost::thread x(do_nothing,&the_id);
|
|
boost::thread y;
|
|
y=boost::move(x);
|
|
boost::thread::id y_id=y.get_id();
|
|
y.join();
|
|
BOOST_CHECK_EQUAL(the_id,y_id);
|
|
}
|
|
|
|
boost::unit_test::test_suite* init_unit_test_suite(int, char*[])
|
|
{
|
|
boost::unit_test::test_suite* test =
|
|
BOOST_TEST_SUITE("Boost.Threads: thread move test suite");
|
|
|
|
test->add(BOOST_TEST_CASE(test_move_on_construction));
|
|
test->add(BOOST_TEST_CASE(test_move_from_function_return));
|
|
test->add(BOOST_TEST_CASE(test_move_assign));
|
|
return test;
|
|
}
|