//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // template // typename conditional // < // !is_nothrow_move_constructible::value && is_copy_constructible::value, // const T&, // T&& // >::type // move_if_noexcept(T& x); #include #include "test_macros.h" class A { A(const A&); A& operator=(const A&); public: A() {} #if TEST_STD_VER >= 11 A(A&&) {} #endif }; struct legacy { legacy() {} legacy(const legacy&); }; int main() { int i = 0; const int ci = 0; legacy l; A a; const A ca; #if TEST_STD_VER >= 11 static_assert((std::is_same::value), ""); static_assert((std::is_same::value), ""); static_assert((std::is_same::value), ""); static_assert((std::is_same::value), ""); static_assert((std::is_same::value), ""); #else // C++ < 11 // In C++03 libc++ #define's decltype to be __decltype on clang and // __typeof__ for other compilers. __typeof__ does not deduce the reference // qualifiers and will cause this test to fail. static_assert((std::is_same::value), ""); static_assert((std::is_same::value), ""); static_assert((std::is_same::value), ""); static_assert((std::is_same::value), ""); static_assert((std::is_same::value), ""); #endif #if TEST_STD_VER > 11 constexpr int i1 = 23; constexpr int i2 = std::move_if_noexcept(i1); static_assert(i2 == 23, "" ); #endif }