/*---------------------------------------------------------------------------*\ ========= | \\ / F ield | OpenFOAM: The Open Source CFD Toolbox \\ / O peration | \\ / A nd | www.openfoam.com \\/ M anipulation | ------------------------------------------------------------------------------- Copyright (C) 2021-2025 OpenCFD Ltd. ------------------------------------------------------------------------------- License This file is part of OpenFOAM. OpenFOAM is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. OpenFOAM is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenFOAM. If not, see . Class Foam::HashFunction Description Hash function class. Verify that template overloads are properly resolved Note The second template parameter (bool) is used for SFINAE overloading, \*---------------------------------------------------------------------------*/ #ifndef HashFunction_H #define HashFunction_H #include "Hash.H" #ifdef FULLDEBUG #define HashTypeInfo(Name) \ static constexpr const char* name() noexcept { return Name; } \ void info() const { std::cerr<< name() << " hashing\n"; } #else #define HashTypeInfo(Name) void info() const {} #endif // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // namespace Foam { /*---------------------------------------------------------------------------*\ Class HashFunc Declaration \*---------------------------------------------------------------------------*/ template struct HashFun { void info() const { #ifdef FULLDEBUG if constexpr (std::is_base_of_v) { std::cerr<< "std::string hashing\n"; } else { std::cerr<< "default hashing\n"; } #endif } unsigned operator()(const T& obj, unsigned seed=0) const { if constexpr (std::is_base_of_v) { return Foam::Hasher(obj.data(), obj.size(), seed); } else { return Foam::Hasher(&obj, sizeof(obj), seed); } } }; // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // //- Hashing for label template<> struct HashFun : Hash