mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-24 12:02:36 +08:00

Fixes MS issues 63, 64, and 65. test/std/utilities/any/any.class/any.cons/move.pass.cpp: * "Moves are always destructive" is not a portable assumption; check with LIBCPP_ASSERT. test/std/utilities/any/any.class/any.cons/value.pass.cpp: * The standard does not forbid initializing std::any from any pointer-to-function type. Remove the non-conforming "DecayTag" test. test/std/utilities/any/any.class/any.modifiers/swap.pass.cpp: * Self-swap is not specified to perform no moves; check with LIBCPP_ASSERT. Differential Revision: https://reviews.llvm.org/D26007 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@285234 91177308-0d34-0410-b5e6-96231b3b80d8
134 lines
2.7 KiB
C++
134 lines
2.7 KiB
C++
//===----------------------------------------------------------------------===//
|
|
//
|
|
// 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.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// UNSUPPORTED: c++98, c++03, c++11, c++14
|
|
|
|
// <any>
|
|
|
|
// any::swap(any &) noexcept
|
|
|
|
// Test swap(large, small) and swap(small, large)
|
|
|
|
#include <any>
|
|
#include <cassert>
|
|
|
|
#include "any_helpers.h"
|
|
|
|
using std::any;
|
|
using std::any_cast;
|
|
|
|
template <class LHS, class RHS>
|
|
void test_swap() {
|
|
assert(LHS::count == 0);
|
|
assert(RHS::count == 0);
|
|
{
|
|
any a1((LHS(1)));
|
|
any a2(RHS{2});
|
|
assert(LHS::count == 1);
|
|
assert(RHS::count == 1);
|
|
|
|
a1.swap(a2);
|
|
|
|
assert(LHS::count == 1);
|
|
assert(RHS::count == 1);
|
|
|
|
assertContains<RHS>(a1, 2);
|
|
assertContains<LHS>(a2, 1);
|
|
}
|
|
assert(LHS::count == 0);
|
|
assert(RHS::count == 0);
|
|
assert(LHS::copied == 0);
|
|
assert(RHS::copied == 0);
|
|
}
|
|
|
|
template <class Tp>
|
|
void test_swap_empty() {
|
|
assert(Tp::count == 0);
|
|
{
|
|
any a1((Tp(1)));
|
|
any a2;
|
|
assert(Tp::count == 1);
|
|
|
|
a1.swap(a2);
|
|
|
|
assert(Tp::count == 1);
|
|
|
|
assertContains<Tp>(a2, 1);
|
|
assertEmpty(a1);
|
|
}
|
|
assert(Tp::count == 0);
|
|
{
|
|
any a1((Tp(1)));
|
|
any a2;
|
|
assert(Tp::count == 1);
|
|
|
|
a2.swap(a1);
|
|
|
|
assert(Tp::count == 1);
|
|
|
|
assertContains<Tp>(a2, 1);
|
|
assertEmpty(a1);
|
|
}
|
|
assert(Tp::count == 0);
|
|
assert(Tp::copied == 0);
|
|
}
|
|
|
|
void test_noexcept()
|
|
{
|
|
any a1;
|
|
any a2;
|
|
static_assert(
|
|
noexcept(a1.swap(a2))
|
|
, "any::swap(any&) must be noexcept"
|
|
);
|
|
}
|
|
|
|
void test_self_swap() {
|
|
{
|
|
// empty
|
|
any a;
|
|
a.swap(a);
|
|
assertEmpty(a);
|
|
}
|
|
{ // small
|
|
using T = small;
|
|
any a{T{42}};
|
|
T::reset();
|
|
a.swap(a);
|
|
assertContains<T>(a, 42);
|
|
assert(T::count == 1);
|
|
assert(T::copied == 0);
|
|
LIBCPP_ASSERT(T::moved == 0);
|
|
}
|
|
assert(small::count == 0);
|
|
{ // large
|
|
using T = large;
|
|
any a{T{42}};
|
|
T::reset();
|
|
a.swap(a);
|
|
assertContains<T>(a, 42);
|
|
assert(T::count == 1);
|
|
assert(T::copied == 0);
|
|
LIBCPP_ASSERT(T::moved == 0);
|
|
}
|
|
assert(large::count == 0);
|
|
}
|
|
|
|
int main()
|
|
{
|
|
test_noexcept();
|
|
test_swap_empty<small>();
|
|
test_swap_empty<large>();
|
|
test_swap<small1, small2>();
|
|
test_swap<large1, large2>();
|
|
test_swap<small, large>();
|
|
test_swap<large, small>();
|
|
test_self_swap();
|
|
}
|