hash.h
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018 #ifndef EQBASE_HASH_H
00019 #define EQBASE_HASH_H
00020
00021 #include <eq/base/base.h>
00022 #include <eq/base/refPtr.h>
00023 #include <eq/base/stdExt.h>
00024
00025 namespace eq
00026 {
00027 namespace base
00028 {
00030 template<class K, class T> class PtrHash
00031 #ifdef WIN32_VC
00032 : public stde::hash_map< K, T, stde::hash_compare< const void* > >
00033 #else
00034 : public stde::hash_map< K, T, stde::hash< const void* > >
00035 #endif
00036 {};
00037
00039 #ifdef WIN32_VC
00040 template< typename T >
00041 class hashRefPtr : public stde::hash_compare< RefPtr< T > >
00042 {
00043 public:
00044 size_t operator() ( const RefPtr< T >& key ) const
00045 {
00046 stde::hash_compare< const void* > comp;
00047 return comp( key.get( ));
00048 }
00049
00050 bool operator() ( const RefPtr< T >& k1, const RefPtr< T >& k2 ) const
00051 {
00052 return k1 < k2;
00053 }
00054 };
00055
00056 template< class K, class T > class RefPtrHash
00057 : public stde::hash_map< RefPtr< K >, T, hashRefPtr< K > >
00058 {};
00059
00060 #else
00061 template< typename T >
00062 struct hashRefPtr
00063 {
00064 size_t operator()( RefPtr< T > key ) const
00065 {
00066 return stde::hash< const void* >()( key.get() );
00067 }
00068 };
00069
00071 template< class K, class T > class RefPtrHash
00072 : public stde::hash_map< RefPtr< K >, T, hashRefPtr< K > >
00073 {};
00074 #endif
00075 }
00076
00077 }
00078 #endif // EQBASE_HASH_H