blob: c532c8323d11ffd0208708d5a22407e3baaa4576 [file] [log] [blame]
// Copyright (C) 2015-2023 Free Software Foundation, Inc.
//
// This file is part of the GNU ISO C++ Library. This library is free
// software; you can redistribute it and/or modify it under the
// terms of the GNU General Public License as published by the
// Free Software Foundation; either version 3, or (at your option)
// any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this library; see the file COPYING3. If not see
// <http://www.gnu.org/licenses/>.
#include <type_traits>
#include <testsuite_tr1.h>
#include <utility>
#include <array>
#include <tuple>
#include <queue>
#include <stack>
#if defined(test_std_is_swappable)
# ifndef __cpp_lib_is_swappable
# error "Feature-test macro for is_swappable missing"
# elif __cpp_lib_is_swappable != 201603
# error "Feature-test macro for is_swappable has wrong value"
# endif
// Test std::is_swappable:
template<class T>
using is_swappable = std::is_swappable<T>;
#elif defined(test_std_is_swappable_ext)
// Test our __is_swappable extension:
template<class T>
using is_swappable = std::__is_swappable<T>;
#else
# error "Either test_std_is_swappable or test_std_is_swappable_ext" \
"need to be defined"
#endif
namespace funny {
struct F {};
void swap(F&, F&) = delete;
void swap(F(&)[5], F(&)[5]);
struct F2
{
friend void swap(F2&, F2&) = delete;
};
struct F3
{
friend void swap(F3&, F3) {}
};
struct DummyCmp
{
template<class T>
bool operator()(const T&, const T&) const
{ return false; }
};
}
void test01()
{
using namespace __gnu_test;
// Positive tests.
static_assert(test_property<is_swappable, int>(true), "");
static_assert(test_property<is_swappable, bool>(true), "");
static_assert(test_property<is_swappable, decltype(nullptr)>(true), "");
static_assert(test_property<is_swappable, int&>(true), "");
static_assert(test_property<is_swappable, int&&>(true), "");
static_assert(test_property<is_swappable, int[1]>(true), "");
static_assert(test_property<is_swappable, int[1][2]>(true), "");
static_assert(test_property<is_swappable, int[1][2][3]>(true), "");
static_assert(test_property<is_swappable, int(&)[1]>(true), "");
static_assert(test_property<is_swappable, funny::F[5]>(true), "");
static_assert(test_property<is_swappable, funny::F3>(true), "");
static_assert(test_property<is_swappable, funny::F3[1]>(true), "");
static_assert(test_property<is_swappable, funny::F3[1][2]>(true), "");
static_assert(test_property<is_swappable, funny::F3[1][2][3]>(true), "");
static_assert(test_property<is_swappable,
ThrowCopyConsClass>(true), "");
static_assert(test_property<is_swappable, EnumType>(true), "");
static_assert(test_property<is_swappable, PODType>(true), "");
static_assert(test_property<is_swappable, UnionType>(true), "");
static_assert(test_property<is_swappable, construct::SE>(true), "");
static_assert(test_property<is_swappable, construct::Empty>(true), "");
static_assert(test_property<is_swappable, void*>(true), "");
static_assert(test_property<is_swappable, int const*>(true), "");
static_assert(test_property<is_swappable, ClassType*>(true), "");
static_assert(test_property<is_swappable, int ClassType::*>(true), "");
static_assert(test_property<is_swappable,
void (ClassType::*)()>(true), "");
static_assert(test_property<is_swappable,
construct::Nontrivial>(true), "");
static_assert(test_property<is_swappable, construct::Any>(true), "");
static_assert(test_property<is_swappable, construct::nAny>(true), "");
static_assert(test_property<is_swappable,
std::pair<int, int>>(true), "");
static_assert(test_property<is_swappable,
std::pair<int, int>[1]>(true), "");
static_assert(test_property<is_swappable,
std::pair<int, int>[1][2]>(true), "");
static_assert(test_property<is_swappable,
std::pair<int, int>[1][2][3]>(true), "");
static_assert(test_property<is_swappable,
std::pair<construct::Nontrivial, construct::Nontrivial>>(true), "");
static_assert(test_property<is_swappable,
std::tuple<int>>(true), "");
static_assert(test_property<is_swappable,
std::tuple<int>[1]>(true), "");
static_assert(test_property<is_swappable,
std::tuple<int>[1][2]>(true), "");
static_assert(test_property<is_swappable,
std::tuple<int>[1][2][3]>(true), "");
static_assert(test_property<is_swappable,
std::tuple<>>(true), "");
static_assert(test_property<is_swappable,
std::tuple<>[1]>(true), "");
static_assert(test_property<is_swappable,
std::tuple<>[1][2]>(true), "");
static_assert(test_property<is_swappable,
std::tuple<>[1][2][3]>(true), "");
static_assert(test_property<is_swappable,
std::tuple<construct::Nontrivial>>(true), "");
static_assert(test_property<is_swappable,
std::array<int, 1>>(true), "");
static_assert(test_property<is_swappable,
std::array<int, 1>[1]>(true), "");
static_assert(test_property<is_swappable,
std::array<int, 1>[1][2]>(true), "");
static_assert(test_property<is_swappable,
std::array<int, 1>[1][2][3]>(true), "");
static_assert(test_property<is_swappable,
std::array<construct::Nontrivial, 1>>(true), "");
static_assert(test_property<is_swappable,
std::array<int, 0>>(true), "");
static_assert(test_property<is_swappable,
std::array<construct::DelCopy, 0>>(true), "");
static_assert(test_property<is_swappable,
std::queue<int>>(true), "");
static_assert(test_property<is_swappable,
std::queue<int>[1]>(true), "");
static_assert(test_property<is_swappable,
std::queue<int>[1][2]>(true), "");
static_assert(test_property<is_swappable,
std::queue<int>[1][2][3]>(true), "");
static_assert(test_property<is_swappable,
std::queue<construct::Nontrivial>>(true), "");
static_assert(test_property<is_swappable,
std::priority_queue<int>>(true), "");
static_assert(test_property<is_swappable,
std::priority_queue<int>[1]>(true), "");
static_assert(test_property<is_swappable,
std::priority_queue<int>[1][2]>(true), "");
static_assert(test_property<is_swappable,
std::priority_queue<int>[1][2][3]>(true), "");
static_assert(test_property<is_swappable,
std::priority_queue<construct::Nontrivial,
std::vector<construct::Nontrivial>,
funny::DummyCmp>>(true), "");
static_assert(test_property<is_swappable,
std::stack<int>>(true), "");
static_assert(test_property<is_swappable,
std::stack<int>[1]>(true), "");
static_assert(test_property<is_swappable,
std::stack<int>[1][2]>(true), "");
static_assert(test_property<is_swappable,
std::stack<int>[1][2][3]>(true), "");
static_assert(test_property<is_swappable,
std::stack<construct::Nontrivial>>(true), "");
// Negative tests.
static_assert(test_property<is_swappable, void>(false), "");
static_assert(test_property<is_swappable, const void>(false), "");
static_assert(test_property<is_swappable, void()>(false), "");
static_assert(test_property<is_swappable, void() const>(false), "");
static_assert(test_property<is_swappable, void() volatile>(false), "");
static_assert(test_property<is_swappable,
void() const volatile>(false), "");
static_assert(test_property<is_swappable, const int>(false), "");
static_assert(test_property<is_swappable, const bool>(false), "");
static_assert(test_property<is_swappable, int[]>(false), "");
static_assert(test_property<is_swappable, const int[]>(false), "");
static_assert(test_property<is_swappable, int[][1]>(false), "");
static_assert(test_property<is_swappable, const int[1]>(false), "");
static_assert(test_property<is_swappable, const int[1][2]>(false), "");
static_assert(test_property<is_swappable, const int[1][2][3]>(false), "");
static_assert(test_property<is_swappable, construct::DelCopy>(false), "");
static_assert(test_property<is_swappable,
construct::Abstract>(false), "");
static_assert(test_property<is_swappable,
construct::NontrivialUnion>(false), "");
static_assert(test_property<is_swappable, funny::F>(false), "");
static_assert(test_property<is_swappable, funny::F[1]>(false), "");
static_assert(test_property<is_swappable, funny::F[1][2]>(false), "");
static_assert(test_property<is_swappable, funny::F[1][2][3]>(false), "");
static_assert(test_property<is_swappable, funny::F[4]>(false), "");
static_assert(test_property<is_swappable, construct::DelCopy>(false), "");
static_assert(test_property<is_swappable,
DeletedCopyAssignClass>(false), "");
static_assert(test_property<is_swappable,
DeletedMoveAssignClass>(false), "");
static_assert(test_property<is_swappable, funny::F2>(false), "");
static_assert(test_property<is_swappable, funny::F2[1]>(false), "");
static_assert(test_property<is_swappable, funny::F2[1][2]>(false), "");
static_assert(test_property<is_swappable, funny::F2[1][2][3]>(false), "");
static_assert(test_property<is_swappable, funny::F2[4]>(false), "");
static_assert(test_property<is_swappable, funny::F2[5]>(false), "");
}