1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
|
//===----------------------------------------------------------------------===//
//
// 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
//
//===----------------------------------------------------------------------===//
#ifndef MOVEONLY_H
#define MOVEONLY_H
#include "test_macros.h"
#include <cstddef>
#include <functional>
class MoveOnly
{
int data_;
public:
TEST_CONSTEXPR MoveOnly(int data = 1) : data_(data) {}
MoveOnly(const MoveOnly&) = delete;
MoveOnly& operator=(const MoveOnly&) = delete;
TEST_CONSTEXPR_CXX14 MoveOnly(MoveOnly&& x) TEST_NOEXCEPT
: data_(x.data_) {x.data_ = 0;}
TEST_CONSTEXPR_CXX14 MoveOnly& operator=(MoveOnly&& x)
{data_ = x.data_; x.data_ = 0; return *this;}
TEST_CONSTEXPR int get() const {return data_;}
friend TEST_CONSTEXPR bool operator==(const MoveOnly& x, const MoveOnly& y)
{ return x.data_ == y.data_; }
friend TEST_CONSTEXPR bool operator!=(const MoveOnly& x, const MoveOnly& y)
{ return x.data_ != y.data_; }
friend TEST_CONSTEXPR bool operator< (const MoveOnly& x, const MoveOnly& y)
{ return x.data_ < y.data_; }
friend TEST_CONSTEXPR bool operator<=(const MoveOnly& x, const MoveOnly& y)
{ return x.data_ <= y.data_; }
friend TEST_CONSTEXPR bool operator> (const MoveOnly& x, const MoveOnly& y)
{ return x.data_ > y.data_; }
friend TEST_CONSTEXPR bool operator>=(const MoveOnly& x, const MoveOnly& y)
{ return x.data_ >= y.data_; }
#if TEST_STD_VER > 17
friend constexpr auto operator<=>(const MoveOnly&, const MoveOnly&) = default;
#endif // TEST_STD_VER > 17
TEST_CONSTEXPR_CXX14 MoveOnly operator+(const MoveOnly& x) const
{ return MoveOnly(data_ + x.data_); }
TEST_CONSTEXPR_CXX14 MoveOnly operator*(const MoveOnly& x) const
{ return MoveOnly(data_ * x.data_); }
template<class T>
friend void operator,(MoveOnly const&, T) = delete;
template<class T>
friend void operator,(T, MoveOnly const&) = delete;
};
template <>
struct std::hash<MoveOnly>
{
typedef MoveOnly argument_type;
typedef std::size_t result_type;
TEST_CONSTEXPR std::size_t operator()(const MoveOnly& x) const {return static_cast<size_t>(x.get());}
};
class TrivialMoveOnly {
int data_;
public:
TEST_CONSTEXPR TrivialMoveOnly(int data = 1) : data_(data) {}
TrivialMoveOnly(const TrivialMoveOnly&) = delete;
TrivialMoveOnly& operator=(const TrivialMoveOnly&) = delete;
TrivialMoveOnly(TrivialMoveOnly&&) = default;
TrivialMoveOnly& operator=(TrivialMoveOnly&&) = default;
TEST_CONSTEXPR int get() const { return data_; }
friend TEST_CONSTEXPR bool operator==(const TrivialMoveOnly& x, const TrivialMoveOnly& y) {
return x.data_ == y.data_;
}
friend TEST_CONSTEXPR bool operator!=(const TrivialMoveOnly& x, const TrivialMoveOnly& y) {
return x.data_ != y.data_;
}
friend TEST_CONSTEXPR bool operator<(const TrivialMoveOnly& x, const TrivialMoveOnly& y) {
return x.data_ < y.data_;
}
friend TEST_CONSTEXPR bool operator<=(const TrivialMoveOnly& x, const TrivialMoveOnly& y) {
return x.data_ <= y.data_;
}
friend TEST_CONSTEXPR bool operator>(const TrivialMoveOnly& x, const TrivialMoveOnly& y) {
return x.data_ > y.data_;
}
friend TEST_CONSTEXPR bool operator>=(const TrivialMoveOnly& x, const TrivialMoveOnly& y) {
return x.data_ >= y.data_;
}
#if TEST_STD_VER > 17
friend constexpr auto operator<=>(const TrivialMoveOnly&, const TrivialMoveOnly&) = default;
#endif // TEST_STD_VER > 17
TEST_CONSTEXPR_CXX14 TrivialMoveOnly operator+(const TrivialMoveOnly& x) const {
return TrivialMoveOnly(data_ + x.data_);
}
TEST_CONSTEXPR_CXX14 TrivialMoveOnly operator*(const TrivialMoveOnly& x) const {
return TrivialMoveOnly(data_ * x.data_);
}
template<class T>
friend void operator,(TrivialMoveOnly const&, T) = delete;
template<class T>
friend void operator,(T, TrivialMoveOnly const&) = delete;
};
template <>
struct std::hash<TrivialMoveOnly> {
typedef TrivialMoveOnly argument_type;
typedef std::size_t result_type;
TEST_CONSTEXPR std::size_t operator()(const TrivialMoveOnly& x) const { return static_cast<size_t>(x.get()); }
};
#endif // MOVEONLY_H
|