//===----------------------------------------------------------------------===//
//
// 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
#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
class Emplaceable
{
#if !defined(__clang__)
// GCC 4.8 when compile ccontainers/unord/unord.map/unorder.map.modifiers/emplace_hint.pass.cpp, etc,
// complains about the following being private
public:
Emplaceable(const Emplaceable&) {}
#else
Emplaceable(const Emplaceable&);
#endif
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>
: public std::unary_function<Emplaceable, std::size_t>
{
std::size_t operator()(const Emplaceable& x) const {return x.get();}
};
}
#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
#endif // EMPLACEABLE_H