//////////////////////////////////////////////////////////////////////////////// /// DISCLAIMER /// /// Copyright 2016 by EMC Corporation, All Rights Reserved /// /// Licensed under the Apache License, Version 2.0 (the "License"); /// you may not use this file except in compliance with the License. /// You may obtain a copy of the License at /// /// http://www.apache.org/licenses/LICENSE-2.0 /// /// Unless required by applicable law or agreed to in writing, software /// distributed under the License is distributed on an "AS IS" BASIS, /// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. /// See the License for the specific language governing permissions and /// limitations under the License. /// /// Copyright holder is EMC Corporation /// /// @author Andrey Abramov /// @author Vasiliy Nabatchikov //////////////////////////////////////////////////////////////////////////////// #ifndef IRESEARCH_HASH_UTILS_H #define IRESEARCH_HASH_UTILS_H #include "shared.hpp" #include "string.hpp" // ----------------------------------------------------------------------------- // --SECTION-- hash utils // ----------------------------------------------------------------------------- NS_ROOT FORCE_INLINE size_t hash_combine(size_t seed, size_t v) NOEXCEPT { return seed ^ (v + 0x9e3779b9 + (seed<<6) + (seed>>2)); } template FORCE_INLINE size_t hash_combine(size_t seed, T const& v) { return hash_combine(seed, std::hash()(v)); } template class IRESEARCH_API_TEMPLATE hashed_basic_string_ref : public basic_string_ref { public: typedef basic_string_ref base_t; hashed_basic_string_ref(size_t hash, const base_t& ref) : base_t(ref), hash_(hash) { } hashed_basic_string_ref(size_t hash, const base_t& ref, size_t size) : base_t(ref, size), hash_(hash) { } hashed_basic_string_ref(size_t hash, const typename base_t::char_type* ptr) : base_t(ptr), hash_(hash) { } hashed_basic_string_ref(size_t hash, const typename base_t::char_type* ptr, size_t size) : base_t(ptr, size), hash_(hash) { } hashed_basic_string_ref(size_t hash, const std::basic_string& str) : base_t(str), hash_(hash) { } hashed_basic_string_ref(size_t hash, const std::basic_string& str, size_t size) : base_t(str, size), hash_(hash) { } inline size_t hash() const { return hash_; } private: size_t hash_; }; // hashed_basic_string_ref template hashed_basic_string_ref make_hashed_ref(const basic_string_ref& ref, const Hasher& hasher = Hasher()) { return hashed_basic_string_ref(hasher(ref), ref); } template hashed_basic_string_ref make_hashed_ref(const basic_string_ref& ref, size_t size, const Hasher& hasher = Hasher()) { return hashed_basic_string_ref(hasher(ref), ref, size); } typedef hashed_basic_string_ref hashed_bytes_ref; typedef hashed_basic_string_ref hashed_string_ref; NS_END // ----------------------------------------------------------------------------- // --SECTION-- std extensions // ----------------------------------------------------------------------------- NS_BEGIN(std) template<> struct hash<::iresearch::hashed_bytes_ref> { size_t operator()(const ::iresearch::hashed_bytes_ref& value) const { return value.hash(); } }; template<> struct hash<::iresearch::hashed_string_ref> { size_t operator()(const ::iresearch::hashed_string_ref& value) const { return value.hash(); } }; NS_END // std #endif