mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-22 16:37:40 +08:00

These functions are key to allowing the use of rvalues and variadics in C++03 mode. Everything works the same as in C++11, except for one tangentially related case: struct T { T(T &&) = default; }; In C++11, T has a deleted copy constructor. But in C++03 Clang gives it both a move and a copy constructor. This seems reasonable enough given the extensions it's using. The other changes in this patch were the minimal set required to keep the tests passing after the move/forward change. Most notably the removal of the `__rv<unique_ptr>` hack that was present in an attempt to make unique_ptr move only without language support. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@364063 91177308-0d34-0410-b5e6-96231b3b80d8
73 lines
2.1 KiB
C++
73 lines
2.1 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// <utility>
|
|
|
|
// template <class T>
|
|
// typename conditional
|
|
// <
|
|
// !is_nothrow_move_constructible<T>::value && is_copy_constructible<T>::value,
|
|
// const T&,
|
|
// T&&
|
|
// >::type
|
|
// move_if_noexcept(T& x);
|
|
|
|
#include <utility>
|
|
|
|
#include "test_macros.h"
|
|
|
|
class A
|
|
{
|
|
A(const A&);
|
|
A& operator=(const A&);
|
|
public:
|
|
|
|
A() {}
|
|
A(A&&) {}
|
|
};
|
|
|
|
struct legacy
|
|
{
|
|
legacy() {}
|
|
legacy(const legacy&);
|
|
};
|
|
|
|
int main(int, char**)
|
|
{
|
|
int i = 0;
|
|
const int ci = 0;
|
|
|
|
legacy l;
|
|
A a;
|
|
const A ca;
|
|
|
|
#if TEST_STD_VER >= 11
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(i)), int&&>::value), "");
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(ci)), const int&&>::value), "");
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(a)), A&&>::value), "");
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(ca)), const A&&>::value), "");
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(l)), const legacy&>::value), "");
|
|
#else // C++ < 11
|
|
// In C++03 we don't have noexcept so we can never move :-(
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(i)), const int&>::value), "");
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(ci)), const int&>::value), "");
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(a)), const A&>::value), "");
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(ca)), const A&>::value), "");
|
|
static_assert((std::is_same<decltype(std::move_if_noexcept(l)), const legacy&>::value), "");
|
|
#endif
|
|
|
|
#if TEST_STD_VER > 11
|
|
constexpr int i1 = 23;
|
|
constexpr int i2 = std::move_if_noexcept(i1);
|
|
static_assert(i2 == 23, "" );
|
|
#endif
|
|
|
|
|
|
return 0;
|
|
}
|