- wxHashTableBase( wxKeyType keyType = wxKEY_INTEGER,
- size_t size = wxHASH_SIZE_DEFAULT )
- : m_map( size, wxHashTableHash( keyType ),
- wxHashTableEqual( keyType ) ),
- m_keyType( keyType ) { }
-
- ~wxHashTableBase() { Clear(); }
-
- size_t GetCount() const { return m_map.size(); }
-
- void Clear()
- {
- if( m_keyType == wxKEY_STRING )
- {
- for( wxHashTableBaseBase::iterator it = m_map.begin(),
- en = m_map.end();
- it != en; )
- {
- wxChar* tmp = it->first.string;
- ++it;
- delete[] tmp; // used in operator++
- }
- }
- m_map.clear();
- }
-protected:
- void DoPut( long key, void* data )
- {
- wxASSERT( m_keyType == wxKEY_INTEGER );
-
- wxHashKeyValue k; k.integer = key;
- m_map[k] = data;
- }
-
- void DoPut( const wxChar* key, void* data )
- {
- wxASSERT( m_keyType == wxKEY_STRING );
-
- wxHashKeyValue k;
- k.string = (wxChar*)key;
- wxHashTableBaseBase::iterator it = m_map.find(k);
-
- if( it == m_map.end() )
- {
- k.string = new wxChar[wxStrlen(key) + 1];
- wxStrcpy(k.string, key);
- m_map[k] = data;
- }
- else
- it->second = data;
- }
-
- void* DoGet( long key ) const
- {
- wxASSERT( m_keyType == wxKEY_INTEGER );
-
- wxHashKeyValue k; k.integer = key;
- wxHashTableBaseBase::const_iterator it = m_map.find( k );
-
- return it != m_map.end() ? it->second : NULL;
- }
-
- void* DoGet( const wxChar* key ) const
- {
- wxASSERT( m_keyType == wxKEY_STRING );
+ wxHashTableBase_Node( long key, void* value,
+ wxHashTableBase* table );
+ wxHashTableBase_Node( const wxChar* key, void* value,
+ wxHashTableBase* table );
+ ~wxHashTableBase_Node();