llvm-project/libcxx/test/std/containers/Emplaceable.h

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

58 lines
1.5 KiB
C
Raw Normal View History

//===----------------------------------------------------------------------===//
//
// 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
//
//===----------------------------------------------------------------------===//
2010-05-12 03:42:16 +08:00
#ifndef EMPLACEABLE_H
#define EMPLACEABLE_H
#include <functional>
#include "test_macros.h"
#if TEST_STD_VER >= 11
2010-05-12 03:42:16 +08:00
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_);}
2010-05-12 03:42:16 +08:00
int get() const {return int_;}
};
namespace std {
template <>
struct hash<Emplaceable>
{
[libcxx] [test] Update for C++17 feature removals. 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
2017-08-25 05:24:08 +08:00
typedef Emplaceable argument_type;
typedef std::size_t result_type;
2010-05-12 03:42:16 +08:00
std::size_t operator()(const Emplaceable& x) const {return x.get();}
};
}
#endif // TEST_STD_VER >= 11
#endif // EMPLACEABLE_H