diff options
Diffstat (limited to 'include/llvm')
-rw-r--r-- | include/llvm/ADT/HashExtras.h | 1 | ||||
-rw-r--r-- | include/llvm/ADT/hash_map.cmake | 150 | ||||
-rw-r--r-- | include/llvm/ADT/hash_map.h.in | 150 | ||||
-rw-r--r-- | include/llvm/ADT/hash_set.cmake | 111 | ||||
-rw-r--r-- | include/llvm/ADT/hash_set.h.in | 111 |
5 files changed, 0 insertions, 523 deletions
diff --git a/include/llvm/ADT/HashExtras.h b/include/llvm/ADT/HashExtras.h index fcc50c8..85abf91 100644 --- a/include/llvm/ADT/HashExtras.h +++ b/include/llvm/ADT/HashExtras.h @@ -17,7 +17,6 @@ #ifndef LLVM_ADT_HASHEXTRAS_H #define LLVM_ADT_HASHEXTRAS_H -#include "llvm/ADT/hash_map.h" #include <string> // Cannot specialize hash template from outside of the std namespace. diff --git a/include/llvm/ADT/hash_map.cmake b/include/llvm/ADT/hash_map.cmake deleted file mode 100644 index b5d2aa8..0000000 --- a/include/llvm/ADT/hash_map.cmake +++ /dev/null @@ -1,150 +0,0 @@ -//===-- llvm/ADT/hash_map - "Portable" wrapper around hash_map --*- C++ -*-===// -// -// The LLVM Compiler Infrastructure -// -// This file was developed by the LLVM research group and is distributed under -// the University of Illinois Open Source License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// -// This file provides a wrapper around the mysterious <hash_map> header file -// that seems to move around between GCC releases into and out of namespaces at -// will. #including this header will cause hash_map to be available in the -// global namespace. -// -//===----------------------------------------------------------------------===// - -#ifndef LLVM_ADT_HASH_MAP -#define LLVM_ADT_HASH_MAP - -// Compiler Support Matrix -// -// Version Namespace Header File -// 2.95.x :: hash_map -// 3.0.4 std ext/hash_map -// 3.1 __gnu_cxx ext/hash_map -// HP aCC6 std stdex/rw/hashm*ap.h -// MS VC++ stdext hash_map - -#cmakedefine HAVE_GNU_EXT_HASH_MAP -#cmakedefine HAVE_STD_EXT_HASH_MAP -#cmakedefine HAVE_GLOBAL_HASH_MAP -#cmakedefine HAVE_RW_STDEX_HASH_MAP_H - -#if defined(HAVE_GNU_EXT_HASH_MAP) -// This is for GCC-3.1+ which puts hash in ext/hash_map -# include <ext/hash_map> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE __gnu_cxx -# endif - -// GCC 3.0.x puts hash_map in <ext/hash_map> and in the std namespace. -#elif defined(HAVE_STD_EXT_HASH_MAP) -# include <ext/hash_map> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// Older compilers such as GCC before version 3.0 do not keep -// extensions in the `ext' directory, and ignore the `std' namespace. -#elif defined(HAVE_GLOBAL_HASH_MAP) -# include <hash_map> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// HP aCC doesn't include an SGI-like hash_map. For this platform (or -// any others using Rogue Wave Software's Tools.h++ library), we wrap -// around them in std:: -#elif defined(HAVE_RW_STDEX_HASH_MAP_H) -# include <rw/stdex/hashmap.h> -# include <rw/stdex/hashmmap.h> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// Support Microsoft VC++. -#elif defined(_MSC_VER) -# include <hash_map> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE stdext - using std::_Distance; -# endif - -// Give a warning if we couldn't find it, instead of (or in addition to) -// randomly doing something dumb. -#else -# warning "Autoconfiguration failed to find the hash_map header file." -#endif - -// we wrap Rogue Wave Tools.h++ rw_hashmap into something SGI-looking, here: -#ifdef HAVE_RW_STDEX_HASH_MAP_H -namespace HASH_NAMESPACE { - -template <class DataType> struct hash { - unsigned int operator()(const unsigned int& x) const { - return x; - } -}; - -template <typename KeyType, - typename ValueType, - class _HashFcn = hash<KeyType>, - class _EqualKey = equal_to<KeyType>, - class _A = allocator <ValueType> > -class hash_map : public rw_hashmap<KeyType, ValueType, class _HashFcn, - class _EqualKey, class _A> { -}; - -template <typename KeyType, - typename ValueType, - class _HashFcn = hash<KeyType>, - class _EqualKey = equal_to<KeyType>, - class _A = allocator <ValueType> > -class hash_multimap : public rw_hashmultimap<KeyType, ValueType, class _HashFcn, - class _EqualKey, class _A> { -}; - -} // end HASH_NAMESPACE; -#endif - -// Include vector because ext/hash_map includes stl_vector.h and leaves -// out specializations like stl_bvector.h, causing link conflicts. -#include <vector> - -#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<class Key> struct hash; - - // Provide a hash function for unsigned ints... - template<> struct hash<unsigned int> { - inline size_t operator()(unsigned int Val) const { - return Val; - } - }; - - template<class Key> class hash_compare<Key, std::less<Key> > { - std::less<Key> comp; - public: - enum { bucket_size = 4 }; - enum { min_buckets = 8 }; - hash_compare() {} - hash_compare(std::less<Key> pred) : comp(pred) {} - size_t operator()(const Key& key) const { return hash<Key>()(key); } - bool operator()(const Key& k1, const Key& k2) const { return comp(k1, k2); } - }; -} - -#endif - -using HASH_NAMESPACE::hash_map; -using HASH_NAMESPACE::hash_multimap; -using HASH_NAMESPACE::hash; - -#include "llvm/ADT/HashExtras.h" - -#endif diff --git a/include/llvm/ADT/hash_map.h.in b/include/llvm/ADT/hash_map.h.in deleted file mode 100644 index 7267c39..0000000 --- a/include/llvm/ADT/hash_map.h.in +++ /dev/null @@ -1,150 +0,0 @@ -//==-- llvm/ADT/hash_map.h - "Portable" wrapper around hash_map --*- C++ -*-==// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// -// This file provides a wrapper around the mysterious <hash_map> header file -// that seems to move around between GCC releases into and out of namespaces at -// will. #including this header will cause hash_map to be available in the -// global namespace. -// -//===----------------------------------------------------------------------===// - -#ifndef LLVM_ADT_HASH_MAP_H -#define LLVM_ADT_HASH_MAP_H - -// Compiler Support Matrix -// -// Version Namespace Header File -// 2.95.x :: hash_map -// 3.0.4 std ext/hash_map -// 3.1 __gnu_cxx ext/hash_map -// HP aCC6 std stdex/rw/hashm*ap.h -// MS VC++ stdext hash_map - -#undef HAVE_GNU_EXT_HASH_MAP -#undef HAVE_STD_EXT_HASH_MAP -#undef HAVE_GLOBAL_HASH_MAP -#undef HAVE_RW_STDEX_HASH_MAP_H - -#if HAVE_GNU_EXT_HASH_MAP -// This is for GCC-3.1+ which puts hash in ext/hash_map -# include <ext/hash_map> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE __gnu_cxx -# endif - -// GCC 3.0.x puts hash_map in <ext/hash_map> and in the std namespace. -#elif HAVE_STD_EXT_HASH_MAP -# include <ext/hash_map> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// Older compilers such as GCC before version 3.0 do not keep -// extensions in the `ext' directory, and ignore the `std' namespace. -#elif HAVE_GLOBAL_HASH_MAP -# include <hash_map> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// HP aCC doesn't include an SGI-like hash_map. For this platform (or -// any others using Rogue Wave Software's Tools.h++ library), we wrap -// around them in std:: -#elif HAVE_RW_STDEX_HASH_MAP_H -# include <rw/stdex/hashmap.h> -# include <rw/stdex/hashmmap.h> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// Support Microsoft VC++. -#elif defined(_MSC_VER) -# include <hash_map> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE stdext - using std::_Distance; -# endif - -// Give a warning if we couldn't find it, instead of (or in addition to) -// randomly doing something dumb. -#else -# warning "Autoconfiguration failed to find the hash_map header file." -#endif - -// we wrap Rogue Wave Tools.h++ rw_hashmap into something SGI-looking, here: -#ifdef HAVE_RW_STDEX_HASH_MAP_H -namespace HASH_NAMESPACE { - -template <class DataType> struct hash { - unsigned int operator()(const unsigned int& x) const { - return x; - } -}; - -template <typename KeyType, - typename ValueType, - class _HashFcn = hash<KeyType>, - class _EqualKey = equal_to<KeyType>, - class _A = allocator <ValueType> > -class hash_map : public rw_hashmap<KeyType, ValueType, class _HashFcn, - class _EqualKey, class _A> { -}; - -template <typename KeyType, - typename ValueType, - class _HashFcn = hash<KeyType>, - class _EqualKey = equal_to<KeyType>, - class _A = allocator <ValueType> > -class hash_multimap : public rw_hashmultimap<KeyType, ValueType, class _HashFcn, - class _EqualKey, class _A> { -}; - -} // end HASH_NAMESPACE; -#endif - -// Include vector because ext/hash_map includes stl_vector.h and leaves -// out specializations like stl_bvector.h, causing link conflicts. -#include <vector> - -#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<class Key> struct hash; - - // Provide a hash function for unsigned ints... - template<> struct hash<unsigned int> { - inline size_t operator()(unsigned int Val) const { - return Val; - } - }; - - template<class Key> class hash_compare<Key, std::less<Key> > { - std::less<Key> comp; - public: - enum { bucket_size = 4 }; - enum { min_buckets = 8 }; - hash_compare() {} - hash_compare(std::less<Key> pred) : comp(pred) {} - size_t operator()(const Key& key) const { return hash<Key>()(key); } - bool operator()(const Key& k1, const Key& k2) const { return comp(k1, k2); } - }; -} - -#endif - -using HASH_NAMESPACE::hash_map; -using HASH_NAMESPACE::hash_multimap; -using HASH_NAMESPACE::hash; - -#include "llvm/ADT/HashExtras.h" - -#endif // LLVM_ADT_HASH_MAP_H diff --git a/include/llvm/ADT/hash_set.cmake b/include/llvm/ADT/hash_set.cmake deleted file mode 100644 index 5a2ffae..0000000 --- a/include/llvm/ADT/hash_set.cmake +++ /dev/null @@ -1,111 +0,0 @@ -//===-- llvm/ADT/hash_set - "Portable" wrapper around hash_set --*- C++ -*-===// -// -// The LLVM Compiler Infrastructure -// -// This file was developed by the LLVM research group and is distributed under -// the University of Illinois Open Source License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// vim:ft=cpp -// -// This file provides a wrapper around the mysterious <hash_set> header file -// that seems to move around between GCC releases into and out of namespaces at -// will. #including this header will cause hash_set to be available in the -// global namespace. -// -//===----------------------------------------------------------------------===// - -#ifndef LLVM_ADT_HASH_SET -#define LLVM_ADT_HASH_SET - -// Compiler Support Matrix -// -// Version Namespace Header File -// 2.95.x :: hash_set -// 3.0.4 std ext/hash_set -// 3.1 __gnu_cxx ext/hash_set -// HP aCC6 std stdex/rw/hashset.h -// MS VC++ stdext hash_set - -#cmakedefine HAVE_GNU_EXT_HASH_SET -#cmakedefine HAVE_STD_EXT_HASH_SET -#cmakedefine HAVE_GLOBAL_HASH_SET -#cmakedefine HAVE_RW_STDEX_HASH_SET_H - -// GCC versions 3.1 and later put hash_set in <ext/hash_set> and in -// the __gnu_cxx namespace. -#if defined(HAVE_GNU_EXT_HASH_SET) -# include <ext/hash_set> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE __gnu_cxx -# endif - -// GCC 3.0.x puts hash_set in <ext/hash_set> and in the std namespace. -#elif defined(HAVE_STD_EXT_HASH_SET) -# include <ext/hash_set> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// Older compilers such as GCC before version 3.0 do not keep -// extensions in the `ext' directory, and ignore the `std' namespace. -#elif defined(HAVE_GLOBAL_HASH_SET) -# include <hash_set> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// HP aCC doesn't include an SGI-like hash_set. For this platform (or -// any others using Rogue Wave Software's Tools.h++ library), we wrap -// around them in std:: -#elif defined(HAVE_RW_STDEX_HASH_SET_H) -# include <rw/stdex/hashset.h> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// Support Microsoft VC++. -#elif defined(_MSC_VER) -# include <hash_set> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE stdext -# endif - -// Give a warning if we couldn't find it, instead of (or in addition to) -// randomly doing something dumb. -#else -# warning "Autoconfiguration failed to find the hash_set header file." -#endif - -// we wrap Rogue Wave Tools.h++ rw_hashset into something SGI-looking, here: -#ifdef HAVE_RW_STDEX_HASH_SET_H -namespace HASH_NAMESPACE { - -/* -template <class DataType> struct hash { - unsigned int operator()(const unsigned int& x) const { - return x; - } -}; -*/ - -template <typename ValueType, - class _HashFcn = hash<ValueType>, - class _EqualKey = equal_to<ValueType>, - class _A = allocator <ValueType> > -class hash_set : - public rw_hashset<ValueType, class _HashFcn, class _EqualKey, class _A> { -}; - -} // end HASH_NAMESPACE; -#endif - -using HASH_NAMESPACE::hash_set; - -// Include vector because ext/hash_set includes stl_vector.h and leaves -// out specializations like stl_bvector.h, causing link conflicts. -#include <vector> - -#include "llvm/ADT/HashExtras.h" - -#endif diff --git a/include/llvm/ADT/hash_set.h.in b/include/llvm/ADT/hash_set.h.in deleted file mode 100644 index e0c3e8c..0000000 --- a/include/llvm/ADT/hash_set.h.in +++ /dev/null @@ -1,111 +0,0 @@ -//==-- llvm/ADT/hash_set.h - "Portable" wrapper around hash_set --*- C++ -*-==// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// vim:ft=cpp -// -// This file provides a wrapper around the mysterious <hash_set> header file -// that seems to move around between GCC releases into and out of namespaces at -// will. #including this header will cause hash_set to be available in the -// global namespace. -// -//===----------------------------------------------------------------------===// - -#ifndef LLVM_ADT_HASH_SET_H -#define LLVM_ADT_HASH_SET_H - -// Compiler Support Matrix -// -// Version Namespace Header File -// 2.95.x :: hash_set -// 3.0.4 std ext/hash_set -// 3.1 __gnu_cxx ext/hash_set -// HP aCC6 std stdex/rw/hashset.h -// MS VC++ stdext hash_set - -#undef HAVE_GNU_EXT_HASH_SET -#undef HAVE_STD_EXT_HASH_SET -#undef HAVE_GLOBAL_HASH_SET -#undef HAVE_RW_STDEX_HASH_SET_H - -// GCC versions 3.1 and later put hash_set in <ext/hash_set> and in -// the __gnu_cxx namespace. -#if HAVE_GNU_EXT_HASH_SET -# include <ext/hash_set> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE __gnu_cxx -# endif - -// GCC 3.0.x puts hash_set in <ext/hash_set> and in the std namespace. -#elif HAVE_STD_EXT_HASH_SET -# include <ext/hash_set> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// Older compilers such as GCC before version 3.0 do not keep -// extensions in the `ext' directory, and ignore the `std' namespace. -#elif HAVE_GLOBAL_HASH_SET -# include <hash_set> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// HP aCC doesn't include an SGI-like hash_set. For this platform (or -// any others using Rogue Wave Software's Tools.h++ library), we wrap -// around them in std:: -#elif HAVE_RW_STDEX_HASH_SET_H -# include <rw/stdex/hashset.h> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE std -# endif - -// Support Microsoft VC++. -#elif defined(_MSC_VER) -# include <hash_set> -# ifndef HASH_NAMESPACE -# define HASH_NAMESPACE stdext -# endif - -// Give a warning if we couldn't find it, instead of (or in addition to) -// randomly doing something dumb. -#else -# warning "Autoconfiguration failed to find the hash_set header file." -#endif - -// we wrap Rogue Wave Tools.h++ rw_hashset into something SGI-looking, here: -#ifdef HAVE_RW_STDEX_HASH_SET_H -namespace HASH_NAMESPACE { - -/* -template <class DataType> struct hash { - unsigned int operator()(const unsigned int& x) const { - return x; - } -}; -*/ - -template <typename ValueType, - class _HashFcn = hash<ValueType>, - class _EqualKey = equal_to<ValueType>, - class _A = allocator <ValueType> > -class hash_set : - public rw_hashset<ValueType, class _HashFcn, class _EqualKey, class _A> { -}; - -} // end HASH_NAMESPACE; -#endif - -using HASH_NAMESPACE::hash_set; - -// Include vector because ext/hash_set includes stl_vector.h and leaves -// out specializations like stl_bvector.h, causing link conflicts. -#include <vector> - -#include "llvm/ADT/HashExtras.h" - -#endif // LLVM_ADT_HASH_SET_H |