Jeff Thompson | a28eed8 | 2013-08-22 16:21:10 -0700 | [diff] [blame^] | 1 | |
| 2 | // Copyright 2005-2009 Daniel James. |
| 3 | // Distributed under the Boost Software License, Version 1.0. (See accompanying |
| 4 | // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) |
| 5 | |
| 6 | #if !defined(CONTAINER_TYPE) |
| 7 | #error "CONTAINER_TYPE not defined" |
| 8 | #else |
| 9 | |
| 10 | #include <boost/preprocessor/cat.hpp> |
| 11 | |
| 12 | #if defined(BOOST_MSVC) |
| 13 | #pragma warning(push) |
| 14 | #pragma warning(disable:4244) // conversion from 'int' to 'float' |
| 15 | #pragma warning(disable:4245) // signed/unsigned mismatch |
| 16 | #endif |
| 17 | |
| 18 | namespace BOOST_PP_CAT(CONTAINER_TYPE, _tests) |
| 19 | { |
| 20 | template <class T> |
| 21 | void integer_tests(T* = 0) |
| 22 | { |
| 23 | const int number_of_containers = 10; |
| 24 | T containers[number_of_containers]; |
| 25 | typedef BOOST_DEDUCED_TYPENAME T::value_type pair; |
| 26 | typedef BOOST_DEDUCED_TYPENAME T::key_type key; |
| 27 | typedef BOOST_DEDUCED_TYPENAME T::mapped_type value; |
| 28 | |
| 29 | for(int i = 0; i < 5; ++i) { |
| 30 | for(int j = 0; j < i; ++j) |
| 31 | containers[i].insert(pair(key(0), value(0))); |
| 32 | } |
| 33 | |
| 34 | containers[6].insert(pair(key(1),value(0))); |
| 35 | containers[7].insert(pair(key(1),value(0))); |
| 36 | containers[7].insert(pair(key(1),value(0))); |
| 37 | containers[8].insert(pair(key(-1),value(1))); |
| 38 | containers[9].insert(pair(key(-1),value(3))); |
| 39 | containers[9].insert(pair(key(-1),value(3))); |
| 40 | |
| 41 | BOOST_HASH_TEST_NAMESPACE::hash<T> hasher; |
| 42 | |
| 43 | for(int i2 = 0; i2 < number_of_containers; ++i2) { |
| 44 | BOOST_TEST(hasher(containers[i2]) == hasher(containers[i2])); |
| 45 | |
| 46 | BOOST_TEST(hasher(containers[i2]) == |
| 47 | BOOST_HASH_TEST_NAMESPACE::hash_value(containers[i2])); |
| 48 | |
| 49 | BOOST_TEST(hasher(containers[i2]) |
| 50 | == BOOST_HASH_TEST_NAMESPACE::hash_range( |
| 51 | containers[i2].begin(), containers[i2].end())); |
| 52 | |
| 53 | for(int j2 = i2 + 1; j2 < number_of_containers; ++j2) { |
| 54 | BOOST_TEST( |
| 55 | (containers[i2] == containers[j2]) == |
| 56 | (hasher(containers[i2]) == hasher(containers[j2])) |
| 57 | ); |
| 58 | } |
| 59 | } |
| 60 | } |
| 61 | |
| 62 | void BOOST_PP_CAT(CONTAINER_TYPE, _hash_integer_tests()) |
| 63 | { |
| 64 | integer_tests((CONTAINER_TYPE<char, unsigned char>*) 0); |
| 65 | integer_tests((CONTAINER_TYPE<int, float>*) 0); |
| 66 | integer_tests((CONTAINER_TYPE<unsigned long, unsigned long>*) 0); |
| 67 | integer_tests((CONTAINER_TYPE<double, short>*) 0); |
| 68 | } |
| 69 | } |
| 70 | |
| 71 | #if defined(BOOST_MSVC) |
| 72 | #pragma warning(pop) |
| 73 | #endif |
| 74 | |
| 75 | #undef CONTAINER_TYPE |
| 76 | #endif |