hash_fwd_test.hpp 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. // Copyright 2006-2009 Daniel James.
  2. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  3. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  4. #include "./config.hpp"
  5. #if defined(BOOST_HASH_TEST_EXTENSIONS) && !defined(BOOST_HASH_TEST_STD_INCLUDES)
  6. #include <boost/container_hash/hash_fwd.hpp>
  7. #include <boost/config.hpp>
  8. #include <cstddef>
  9. #include <vector>
  10. namespace test {
  11. template <class T>
  12. struct test_type1
  13. {
  14. T value;
  15. test_type1(T const& x) : value(x) {}
  16. };
  17. #if !defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)
  18. template <class T>
  19. std::size_t hash_value(test_type1<T> const& x)
  20. {
  21. BOOST_HASH_TEST_NAMESPACE::hash<T> hasher;
  22. return hasher(x.value);
  23. }
  24. #endif
  25. template <class T>
  26. struct test_type2
  27. {
  28. T value1, value2;
  29. test_type2(T const& x, T const& y) : value1(x), value2(y) {}
  30. };
  31. #if !defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)
  32. template <class T>
  33. std::size_t hash_value(test_type2<T> const& x)
  34. {
  35. std::size_t seed = 0;
  36. BOOST_HASH_TEST_NAMESPACE::hash_combine(seed, x.value1);
  37. BOOST_HASH_TEST_NAMESPACE::hash_combine(seed, x.value2);
  38. return seed;
  39. }
  40. #endif
  41. template <class T>
  42. struct test_type3
  43. {
  44. std::vector<T> values;
  45. test_type3(typename std::vector<T>::iterator x,
  46. typename std::vector<T>::iterator y) : values(x, y) {}
  47. };
  48. #if !defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)
  49. template <class T>
  50. std::size_t hash_value(test_type3<T> const& x)
  51. {
  52. std::size_t seed =
  53. BOOST_HASH_TEST_NAMESPACE::hash_range(x.values.begin(), x.values.end());
  54. BOOST_HASH_TEST_NAMESPACE::hash_range(seed, x.values.begin(), x.values.end());
  55. return seed;
  56. }
  57. #endif
  58. }
  59. #if defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)
  60. namespace boost
  61. {
  62. template <class T>
  63. std::size_t hash_value(test::test_type1<T> const& x)
  64. {
  65. BOOST_HASH_TEST_NAMESPACE::hash<T> hasher;
  66. return hasher(x.value);
  67. }
  68. template <class T>
  69. std::size_t hash_value(test::test_type2<T> const& x)
  70. {
  71. std::size_t seed = 0;
  72. BOOST_HASH_TEST_NAMESPACE::hash_combine(seed, x.value1);
  73. BOOST_HASH_TEST_NAMESPACE::hash_combine(seed, x.value2);
  74. return seed;
  75. }
  76. template <class T>
  77. std::size_t hash_value(test::test_type3<T> const& x)
  78. {
  79. std::size_t seed =
  80. BOOST_HASH_TEST_NAMESPACE::hash_range(x.values.begin(), x.values.end());
  81. BOOST_HASH_TEST_NAMESPACE::hash_range(seed, x.values.begin(), x.values.end());
  82. return seed;
  83. }
  84. }
  85. #endif
  86. #endif