// Copyright (C) 2003, 2004, 2005 Laboratoire d'Informatique de Paris 6 (LIP6), // département Systèmes Répartis Coopératifs (SRC), Université Pierre // et Marie Curie. // // This file is part of Spot, a model checking library. // // Spot 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 2 of the License, or // (at your option) any later version. // // Spot 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 Spot; see the file COPYING. If not, write to the Free // Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA // 02111-1307, USA. #ifndef SPOT_MISC_HASH_HH # define SPOT_MISC_HASH_HH # include # include # include "hashfunc.hh" // See the G++ FAQ for details about the following. # ifdef __GNUC__ # if __GNUC__ < 3 # include # include namespace Sgi { // inherit globals using ::hash_map; using ::hash_set; using ::hash; }; # else # include # include # if __GNUC_MINOR__ == 0 namespace Sgi = std; // GCC 3.0 # else namespace Sgi = ::__gnu_cxx; // GCC 3.1 and later # endif # endif # else // ... there are other compilers, right? # include # include namespace Sgi = std; # endif namespace spot { /// \brief A hash function for pointers. /// \ingroup hash_funcs template struct ptr_hash : public std::unary_function { size_t operator()(const T* p) const { return knuth32_hash(reinterpret_cast(p) - static_cast(0)); } }; /// \brief A hash function for strings. /// \ingroup hash_funcs struct string_hash : public Sgi::hash, public std::unary_function { size_t operator()(const std::string& s) const { // We are living dangerously. Be sure to call operator() // from the super-class, not this one. return Sgi::hash::operator()(s.c_str()); } }; } #endif // SPOT_MISC_HASH_HH