
test/std/containers/Emplaceable.h test/std/containers/NotConstructible.h test/support/counting_predicates.hpp Replace unary_function/binary_function inheritance with typedefs. test/std/depr/depr.function.objects/depr.base/binary_function.pass.cpp test/std/depr/depr.function.objects/depr.base/unary_function.pass.cpp test/std/utilities/function.objects/func.require/binary_function.pass.cpp test/std/utilities/function.objects/func.require/unary_function.pass.cpp Mark these tests as requiring 98/03/11/14 because 17 removed unary_function/binary_function. test/std/thread/futures/futures.task/futures.task.members/ctor_func_alloc.pass.cpp test/std/thread/futures/futures.task/futures.task.nonmembers/uses_allocator.pass.cpp Mark these tests as requiring 11/14 because 17 removed packaged_task allocator support. test/std/utilities/function.objects/func.wrap/func.wrap.func/derive_from.pass.cpp This test doesn't need to be skipped in C++17 mode. Only the construction of std::function from an allocator needs to be skipped in C++17 mode. test/std/utilities/function.objects/refwrap/refwrap.access/conversion.pass.cpp test/std/utilities/function.objects/refwrap/refwrap.assign/copy_assign.pass.cpp test/std/utilities/function.objects/refwrap/refwrap.const/copy_ctor.pass.cpp test/std/utilities/function.objects/refwrap/refwrap.const/type_ctor.pass.cpp When testing these reference_wrapper features, unary_function inheritance is totally irrelevant. test/std/utilities/function.objects/refwrap/weak_result.pass.cpp Define and use my_unary_function/my_binary_function to test the weak result type machinery (which is still present in C++17, although deprecated). test/support/msvc_stdlib_force_include.hpp Now we can test C++17 strictly, without enabling removed features. Fixes D36503. llvm-svn: 311705
59 lines
1.5 KiB
C++
59 lines
1.5 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.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef EMPLACEABLE_H
|
|
#define EMPLACEABLE_H
|
|
|
|
#include <utility>
|
|
#include "test_macros.h"
|
|
|
|
#if TEST_STD_VER >= 11
|
|
|
|
class Emplaceable
|
|
{
|
|
Emplaceable(const Emplaceable&);
|
|
Emplaceable& operator=(const Emplaceable&);
|
|
|
|
int int_;
|
|
double double_;
|
|
public:
|
|
Emplaceable() : int_(0), double_(0) {}
|
|
Emplaceable(int i, double d) : int_(i), double_(d) {}
|
|
Emplaceable(Emplaceable&& x)
|
|
: int_(x.int_), double_(x.double_)
|
|
{x.int_ = 0; x.double_ = 0;}
|
|
Emplaceable& operator=(Emplaceable&& x)
|
|
{int_ = x.int_; x.int_ = 0;
|
|
double_ = x.double_; x.double_ = 0;
|
|
return *this;}
|
|
|
|
bool operator==(const Emplaceable& x) const
|
|
{return int_ == x.int_ && double_ == x.double_;}
|
|
bool operator<(const Emplaceable& x) const
|
|
{return int_ < x.int_ || (int_ == x.int_ && double_ < x.double_);}
|
|
|
|
int get() const {return int_;}
|
|
};
|
|
|
|
namespace std {
|
|
|
|
template <>
|
|
struct hash<Emplaceable>
|
|
{
|
|
typedef Emplaceable argument_type;
|
|
typedef std::size_t result_type;
|
|
|
|
std::size_t operator()(const Emplaceable& x) const {return x.get();}
|
|
};
|
|
|
|
}
|
|
|
|
#endif // TEST_STD_VER >= 11
|
|
#endif // EMPLACEABLE_H
|