1
0
Fork 0
mirror of https://github.com/bolero-MURAKAMI/Sprout synced 2024-11-12 21:09:01 +00:00
Sprout/sprout/functional/hash/hash_combine.hpp
bolero-MURAKAMI 6e5f4c5606 rename hash_values_combine -> hash_combine
fix hash_range
2013-02-04 22:13:27 +09:00

37 lines
1.2 KiB
C++

#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 {
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
//
// hash_combine
//
template<typename... Args>
inline SPROUT_CONSTEXPR std::size_t
hash_combine(std::size_t seed, Args const&... args) {
return sprout::detail::hash_combine_impl(seed, args...);
}
} // namespace sprout
#endif // #ifndef SPROUT_FUNCTIONAL_HASH_HASH_COMBINE_HPP