mirror of
https://github.com/boostorg/thread.git
synced 2026-01-24 06:22:12 +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]
147 lines
3.7 KiB
C++
147 lines
3.7 KiB
C++
// Copyright (C) 2007-8 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>
|
|
#include <boost/thread/mutex.hpp>
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
void do_nothing()
|
|
{}
|
|
|
|
void test_thread_move_from_lvalue_on_construction()
|
|
{
|
|
boost::thread src(do_nothing);
|
|
boost::thread::id src_id=src.get_id();
|
|
boost::thread dest(boost::move(src));
|
|
boost::thread::id dest_id=dest.get_id();
|
|
BOOST_CHECK(src_id==dest_id);
|
|
BOOST_CHECK(src.get_id()==boost::thread::id());
|
|
dest.join();
|
|
}
|
|
|
|
void test_thread_move_from_lvalue_on_assignment()
|
|
{
|
|
boost::thread src(do_nothing);
|
|
boost::thread::id src_id=src.get_id();
|
|
boost::thread dest;
|
|
dest=boost::move(src);
|
|
boost::thread::id dest_id=dest.get_id();
|
|
BOOST_CHECK(src_id==dest_id);
|
|
BOOST_CHECK(src.get_id()==boost::thread::id());
|
|
dest.join();
|
|
}
|
|
|
|
boost::thread start_thread()
|
|
{
|
|
return boost::thread(do_nothing);
|
|
}
|
|
|
|
void test_thread_move_from_rvalue_on_construction()
|
|
{
|
|
boost::thread x(start_thread());
|
|
BOOST_CHECK(x.get_id()!=boost::thread::id());
|
|
x.join();
|
|
}
|
|
|
|
void test_thread_move_from_rvalue_using_explicit_move()
|
|
{
|
|
//boost::thread x(boost::move(start_thread()));
|
|
boost::thread x=start_thread();
|
|
BOOST_CHECK(x.get_id()!=boost::thread::id());
|
|
x.join();
|
|
}
|
|
|
|
void test_unique_lock_move_from_lvalue_on_construction()
|
|
{
|
|
boost::mutex m;
|
|
boost::unique_lock<boost::mutex> l(m);
|
|
BOOST_CHECK(l.owns_lock());
|
|
BOOST_CHECK(l.mutex()==&m);
|
|
|
|
boost::unique_lock<boost::mutex> l2(boost::move(l));
|
|
BOOST_CHECK(!l.owns_lock());
|
|
BOOST_CHECK(!l.mutex());
|
|
BOOST_CHECK(l2.owns_lock());
|
|
BOOST_CHECK(l2.mutex()==&m);
|
|
}
|
|
|
|
boost::unique_lock<boost::mutex> get_lock(boost::mutex& m)
|
|
{
|
|
return boost::unique_lock<boost::mutex>(m);
|
|
}
|
|
|
|
|
|
void test_unique_lock_move_from_rvalue_on_construction()
|
|
{
|
|
boost::mutex m;
|
|
boost::unique_lock<boost::mutex> l(get_lock(m));
|
|
BOOST_CHECK(l.owns_lock());
|
|
BOOST_CHECK(l.mutex()==&m);
|
|
}
|
|
|
|
namespace user_test_ns
|
|
{
|
|
template<typename T>
|
|
T move(T& t)
|
|
{
|
|
return t.move();
|
|
}
|
|
|
|
bool move_called=false;
|
|
|
|
struct nc:
|
|
public boost::shared_ptr<int>
|
|
{
|
|
#ifndef BOOST_NO_RVALUE_REFERENCES
|
|
nc() {}
|
|
nc(nc&&)
|
|
{
|
|
move_called=true;
|
|
}
|
|
#endif
|
|
nc move()
|
|
{
|
|
move_called=true;
|
|
return nc();
|
|
}
|
|
};
|
|
}
|
|
|
|
#ifdef BOOST_NO_RVALUE_REFERENCES
|
|
namespace boost
|
|
{
|
|
template <>
|
|
struct has_move_emulation_enabled_aux<user_test_ns::nc>
|
|
: BOOST_MOVE_BOOST_NS::integral_constant<bool, true>
|
|
{};
|
|
}
|
|
#endif
|
|
|
|
void test_move_for_user_defined_type_unaffected()
|
|
{
|
|
user_test_ns::nc src;
|
|
#ifndef BOOST_NO_RVALUE_REFERENCES
|
|
user_test_ns::nc dest=boost::move(src);
|
|
#else
|
|
user_test_ns::nc dest=move(src);
|
|
#endif
|
|
BOOST_CHECK(user_test_ns::move_called);
|
|
}
|
|
|
|
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_thread_move_from_lvalue_on_construction));
|
|
test->add(BOOST_TEST_CASE(test_thread_move_from_rvalue_on_construction));
|
|
test->add(BOOST_TEST_CASE(test_thread_move_from_rvalue_using_explicit_move));
|
|
test->add(BOOST_TEST_CASE(test_thread_move_from_lvalue_on_assignment));
|
|
test->add(BOOST_TEST_CASE(test_unique_lock_move_from_lvalue_on_construction));
|
|
test->add(BOOST_TEST_CASE(test_unique_lock_move_from_rvalue_on_construction));
|
|
test->add(BOOST_TEST_CASE(test_move_for_user_defined_type_unaffected));
|
|
return test;
|
|
}
|