2001-07-23 17:46:59 +00:00
|
|
|
//===-- HashExtras.h - Useful functions for STL hash containers --*- C++ -*--=//
|
|
|
|
//
|
|
|
|
// This file contains some templates that are useful if you are working with the
|
|
|
|
// STL Hashed containers.
|
|
|
|
//
|
|
|
|
// No library is required when using these functinons.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2003-06-17 00:35:55 +00:00
|
|
|
#ifndef SUPPORT_HASHEXTRAS_H
|
|
|
|
#define SUPPORT_HASHEXTRAS_H
|
2001-07-23 17:46:59 +00:00
|
|
|
|
|
|
|
#include <string>
|
2002-10-28 02:11:53 +00:00
|
|
|
#include "Support/hash_map"
|
2002-01-20 22:54:45 +00:00
|
|
|
|
|
|
|
// Cannot specialize hash template from outside of the std namespace.
|
2002-07-24 22:20:00 +00:00
|
|
|
namespace HASH_NAMESPACE {
|
2001-07-23 17:46:59 +00:00
|
|
|
|
2002-07-24 22:20:00 +00:00
|
|
|
template <> struct hash<std::string> {
|
|
|
|
size_t operator()(std::string const &str) const {
|
2001-07-23 17:46:59 +00:00
|
|
|
return hash<char const *>()(str.c_str());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2001-07-28 04:41:10 +00:00
|
|
|
// Provide a hash function for arbitrary pointers...
|
|
|
|
template <class T> struct hash<T *> {
|
|
|
|
inline size_t operator()(const T *Val) const { return (size_t)Val; }
|
|
|
|
};
|
|
|
|
|
2002-01-20 22:54:45 +00:00
|
|
|
} // End namespace std
|
|
|
|
|
2001-07-23 17:46:59 +00:00
|
|
|
#endif
|