2013-02-04 09:42:39 +00:00
|
|
|
#ifndef SPROUT_FUNCTIONAL_HASH_HASH_COMBINE_HPP
|
|
|
|
#define SPROUT_FUNCTIONAL_HASH_HASH_COMBINE_HPP
|
|
|
|
|
|
|
|
#include <cstddef>
|
|
|
|
#include <sprout/config.hpp>
|
|
|
|
#include <sprout/functional/hash/hash_fwd.hpp>
|
|
|
|
#include <sprout/functional/hash/to_hash.hpp>
|
|
|
|
|
|
|
|
namespace sprout {
|
2013-02-04 13:13:27 +00:00
|
|
|
namespace detail {
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR std::size_t
|
|
|
|
hash_combine_impl(std::size_t seed) {
|
|
|
|
return seed;
|
|
|
|
}
|
|
|
|
template<typename T>
|
|
|
|
inline SPROUT_CONSTEXPR std::size_t
|
|
|
|
hash_combine_impl(std::size_t seed, T const& v) {
|
|
|
|
return seed ^ (sprout::to_hash(v) + 0x9e3779b9 + (seed << 6) + (seed >> 2));
|
|
|
|
}
|
|
|
|
template<typename Head, typename... Tail>
|
|
|
|
inline SPROUT_CONSTEXPR std::size_t
|
|
|
|
hash_combine_impl(std::size_t seed, Head const& head, Tail const&... tail) {
|
|
|
|
return sprout::detail::hash_combine_impl(sprout::detail::hash_combine_impl(seed, head), tail...);
|
|
|
|
}
|
|
|
|
} // namespace detail
|
2013-02-04 09:42:39 +00:00
|
|
|
//
|
|
|
|
// hash_combine
|
|
|
|
//
|
2013-02-04 13:13:27 +00:00
|
|
|
template<typename... Args>
|
2013-02-04 09:42:39 +00:00
|
|
|
inline SPROUT_CONSTEXPR std::size_t
|
2013-02-04 13:13:27 +00:00
|
|
|
hash_combine(std::size_t seed, Args const&... args) {
|
|
|
|
return sprout::detail::hash_combine_impl(seed, args...);
|
2013-02-04 09:42:39 +00:00
|
|
|
}
|
|
|
|
} // namespace sprout
|
|
|
|
|
|
|
|
#endif // #ifndef SPROUT_FUNCTIONAL_HASH_HASH_COMBINE_HPP
|