]>
git.saurik.com Git - wxWidgets.git/blob - include/wx/hashset.h
   1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     wxHashSet class 
   4 // Author:      Mattia Barbon 
   8 // Copyright:   (c) Mattia Barbon 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  12 #ifndef _WX_HASHSET_H_ 
  13 #define _WX_HASHSET_H_ 
  15 #include "wx/hashmap.h" 
  17 // this is a complex way of defining an easily inlineable identity function... 
  18 #define _WX_DECLARE_HASH_SET_KEY_EX( KEY_T, CLASSNAME, CLASSEXP )            \ 
  21     typedef KEY_T key_type;                                                  \ 
  22     typedef const key_type const_key_type;                                   \ 
  23     typedef const_key_type& const_key_reference;                             \ 
  26     const_key_reference operator()( const_key_reference key ) const          \ 
  29     /* the dummy assignment operator is needed to suppress compiler */       \ 
  30     /* warnings from hash table class' operator=(): gcc complains about */   \ 
  31     /* "statement with no effect" without it */                              \ 
  32     CLASSNAME& operator=(const CLASSNAME&) { return *this; }                 \ 
  35 #define _WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, CLASSEXP )\ 
  36 _WX_DECLARE_HASH_SET_KEY_EX( KEY_T, CLASSNAME##_wxImplementation_KeyEx, CLASSEXP ) \ 
  37 _WX_DECLARE_HASHTABLE( KEY_T, KEY_T, HASH_T, CLASSNAME##_wxImplementation_KeyEx, KEY_EQ_T, CLASSNAME##_wxImplementation_HashTable, CLASSEXP, grow_lf70, never_shrink ) \ 
  38 CLASSEXP CLASSNAME:public CLASSNAME##_wxImplementation_HashTable             \ 
  41     wxEXPLICIT CLASSNAME( size_type hint = 100, hasher hf = hasher(),        \ 
  42                           key_equal eq = key_equal() )                       \ 
  43         : CLASSNAME##_wxImplementation_HashTable( hint, hf, eq,              \ 
  44                       CLASSNAME##_wxImplementation_KeyEx() ) {}              \ 
  46     void insert( const key_type& key )                                       \ 
  48         GetOrCreateNode( key );                                              \ 
  51     const_iterator find( const const_key_type& key ) const                   \ 
  53         return const_iterator( GetNode( key ), this );                       \ 
  56     iterator find( const const_key_type& key )                               \ 
  58         return iterator( GetNode( key ), this );                             \ 
  61     size_type erase( const key_type& k )                                     \ 
  62         { return CLASSNAME##_wxImplementation_HashTable::erase( k ); }       \ 
  63     void erase( const iterator& it ) { erase( *it ); }                       \ 
  64     void erase( const const_iterator& it ) { erase( *it ); }                 \ 
  66     /* count() == 0 | 1 */                                                   \ 
  67     size_type count( const const_key_type& key )                             \ 
  68         { return GetNode( key ) ? 1 : 0; }                                   \ 
  71 // these macros are to be used in the user code 
  72 #define WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME) \ 
  73     _WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, class ) 
  75 // and these do exactly the same thing but should be used inside the 
  77 #define WX_DECLARE_HASH_SET_WITH_DECL( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, DECL) \ 
  78     _WX_DECLARE_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME, DECL ) 
  80 #define WX_DECLARE_EXPORTED_HASH_SET( KEY_T, HASH_T, KEY_EQ_T, CLASSNAME) \ 
  81     WX_DECLARE_HASH_SET_WITH_DECL( KEY_T, HASH_T, KEY_EQ_T, \ 
  82                                    CLASSNAME, class WXDLLEXPORT ) 
  84 // delete all hash elements 
  86 // NB: the class declaration of the hash elements must be visible from the 
  87 //     place where you use this macro, otherwise the proper destructor may not 
  88 //     be called (a decent compiler should give a warning about it, but don't 
  90 #define WX_CLEAR_HASH_SET(type, hashset)                                     \ 
  91     WX_CLEAR_HASH_MAP(type, hashset) 
  93 #endif // _WX_HASHSET_H_