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
|
//===----------------------------------------------------------------------===//
//
// 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.
//
//===----------------------------------------------------------------------===//
// <functional>
// template <class T>
// struct hash
// : public unary_function<T, size_t>
// {
// size_t operator()(T val) const;
// };
// Not very portable
#include <functional>
#include <cassert>
#include <type_traits>
#include <limits>
#include <cmath>
template <class T>
void
test()
{
static_assert((std::is_base_of<std::unary_function<T, std::size_t>,
std::hash<T> >::value), "");
std::hash<T> h;
std::size_t t0 = h(0.);
std::size_t tn0 = h(-0.);
std::size_t tp1 = h(0.1);
std::size_t t1 = h(1);
std::size_t tn1 = h(-1);
std::size_t pinf = h(INFINITY);
std::size_t ninf = h(-INFINITY);
assert(t0 == tn0);
assert(t0 != tp1);
assert(t0 != t1);
assert(t0 != tn1);
assert(t0 != pinf);
assert(t0 != ninf);
assert(tp1 != t1);
assert(tp1 != tn1);
assert(tp1 != pinf);
assert(tp1 != ninf);
assert(t1 != tn1);
assert(t1 != pinf);
assert(t1 != ninf);
assert(tn1 != pinf);
assert(tn1 != ninf);
assert(pinf != ninf);
}
int main()
{
test<float>();
test<double>();
test<long double>();
}
|