From 1467e7ae92ebb0c2430d593138967715258dc351 Mon Sep 17 00:00:00 2001 From: Jeff Cohen Date: Wed, 16 Mar 2005 05:25:09 +0000 Subject: [PATCH] Add adapter class to let VC++ hash_map use GCC's hash struct. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@20637 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/ADT/hash_map.in | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/include/llvm/ADT/hash_map.in b/include/llvm/ADT/hash_map.in index ca609804396..1681b9c3bcc 100644 --- a/include/llvm/ADT/hash_map.in +++ b/include/llvm/ADT/hash_map.in @@ -108,4 +108,30 @@ using HASH_NAMESPACE::hash; #include "llvm/ADT/HashExtras.h" +#ifdef _MSC_VER + +// GCC and VC++ have differing ways of implementing hash_maps. As it's not +// standardized, that's to be expected. This adapter class allows VC++ +// hash_map to use GCC's hash classes. +namespace stdext { + template struct hash { + inline size_t operator()(const Key &) const { + return 0; + } + }; + + template class hash_compare > { + std::less comp; + public: + enum { bucket_size = 4 }; + enum { min_buckets = 8 }; + hash_compare() {} + hash_compare(std::less pred) : comp(pred) {} + size_t operator()(const Key& key) const { return hash()(key); } + bool operator()(const Key& k1, const Key& k2) const { return comp(k1, k2); } + }; +} + +#endif + #endif