A HashTable specialization for hashing pointers. More...
Public Types | |
typedef HashTable< T *, Key, Hash >::iterator | iterator |
typedef HashTable< T *, Key, Hash >::const_iterator | const_iterator |
Public Types inherited from HashTable< T *, Key, Hash > | |
typedef T * | value_type |
Type of values the HashTable contains. More... | |
typedef T *& | reference |
Type that can be used for storing into HashTable::value_type. More... | |
typedef const T *& | const_reference |
Type that can be used for storing into constant. More... | |
typedef label | size_type |
The type that can represent the size of a HashTable. More... | |
Public Member Functions | |
HashPtrTable (const label size=128) | |
Construct given initial table size. More... | |
template<class INew > | |
HashPtrTable (Istream &, const INew &) | |
Construct from Istream using given Istream constructor class. More... | |
HashPtrTable (Istream &) | |
Construct from Istream using default Istream constructor class. More... | |
HashPtrTable (const dictionary &) | |
Construct from dictionary using default dictionary constructor. More... | |
HashPtrTable (const HashPtrTable< T, Key, Hash > &) | |
Construct as copy. More... | |
~HashPtrTable () | |
Destructor. More... | |
T * | remove (iterator &) |
Remove and return the pointer specified by given iterator. More... | |
bool | erase (iterator &) |
Erase an hashedEntry specified by given iterator. More... | |
void | clear () |
Clear all entries from table. More... | |
void | write (Ostream &os) const |
Write. More... | |
void | operator= (const HashPtrTable< T, Key, Hash > &) |
Public Member Functions inherited from HashTable< T *, Key, Hash > | |
bool | set (const Key &, const T *&newElmt) |
Assign a new hashedEntry, overwriting existing entries. More... | |
HashTable (const label size=128) | |
Construct given initial table size. More... | |
HashTable (Istream &, const label size=128) | |
Construct from Istream. More... | |
HashTable (const HashTable< T *, Key, Hash > &) | |
Construct as copy. More... | |
HashTable (const Xfer< HashTable< T *, Key, Hash >> &) | |
Construct by transferring the parameter contents. More... | |
~HashTable () | |
Destructor. More... | |
label | capacity () const |
The size of the underlying table. More... | |
label | size () const |
Return number of elements in table. More... | |
bool | empty () const |
Return true if the hash table is empty. More... | |
bool | found (const Key &) const |
Return true if hashedEntry is found in table. More... | |
iterator | find (const Key &) |
Find and return an iterator set at the hashedEntry. More... | |
const_iterator | find (const Key &) const |
Find and return an const_iterator set at the hashedEntry. More... | |
List< Key > | toc () const |
Return the table of contents. More... | |
List< Key > | sortedToc () const |
Return the table of contents as a sorted list. More... | |
Ostream & | printInfo (Ostream &) const |
Print information. More... | |
bool | insert (const Key &, const T *&newElmt) |
Insert a new hashedEntry. More... | |
bool | erase (const iterator &) |
Erase a hashedEntry specified by given iterator. More... | |
bool | erase (const Key &) |
Erase a hashedEntry specified by the given key. More... | |
label | erase (const UList< Key > &) |
Remove entries given by the listed keys from this HashTable. More... | |
label | erase (const HashTable< AnyType, Key, AnyHash > &) |
Remove entries given by the given keys from this HashTable. More... | |
void | resize (const label newSize) |
Resize the hash table for efficiency. More... | |
void | clear () |
Clear all entries from table. More... | |
void | clearStorage () |
Clear the table entries and the table itself. More... | |
void | shrink () |
Shrink the allocated table to approx. twice number of elements. More... | |
void | transfer (HashTable< T *, Key, Hash > &) |
Transfer the contents of the argument table into this table. More... | |
Xfer< HashTable< T *, Key, Hash > > | xfer () |
Transfer contents to the Xfer container. More... | |
T *& | operator[] (const Key &) |
Find and return a hashedEntry. More... | |
const T *& | operator[] (const Key &) const |
Find and return a hashedEntry. More... | |
T *& | operator() (const Key &) |
Find and return a hashedEntry, create it null if not present. More... | |
void | operator= (const HashTable< T *, Key, Hash > &) |
Assignment. More... | |
bool | operator== (const HashTable< T *, Key, Hash > &) const |
Equality. Hash tables are equal if the keys and values are equal. More... | |
bool | operator!= (const HashTable< T *, Key, Hash > &) const |
The opposite of the equality operation. Takes linear time. More... | |
iterator | begin () |
Iterator set to the beginning of the HashTable. More... | |
const_iterator | begin () const |
const_iterator set to the beginning of the HashTable More... | |
const_iterator | cbegin () const |
const_iterator set to the beginning of the HashTable More... | |
Public Member Functions inherited from HashTableCore | |
HashTableCore () | |
Construct null. More... | |
ClassName ("HashTable") | |
Define template name and debug. More... | |
Friends | |
Istream & | operator>> (Istream &, HashPtrTable< T, Key, Hash > &) |
Ostream & | operator (Ostream &, const HashPtrTable< T, Key, Hash > &) |
Additional Inherited Members | |
Static Public Member Functions inherited from HashTableCore | |
static label | canonicalSize (const label) |
Return a canonical (power-of-two) size. More... | |
static iteratorEnd | cend () |
iteratorEnd set to beyond the end of any HashTable More... | |
static iteratorEnd | end () |
iteratorEnd set to beyond the end of any HashTable More... | |
Static Public Attributes inherited from HashTableCore | |
static const label | maxTableSize |
Maximum allowable table size. More... | |
A HashTable specialization for hashing pointers.
Definition at line 50 of file HashPtrTable.H.
typedef HashTable<T*, Key, Hash>::const_iterator const_iterator |
Definition at line 83 of file HashPtrTable.H.
HashPtrTable | ( | const label | size = 128 | ) |
Construct given initial table size.
Definition at line 32 of file HashPtrTable.C.
HashPtrTable | ( | Istream & | is, |
const INew & | inewt | ||
) |
Construct from Istream using given Istream constructor class.
Definition at line 179 of file HashPtrTableIO.C.
References Foam::read().
HashPtrTable | ( | Istream & | is | ) |
Construct from Istream using default Istream constructor class.
Definition at line 186 of file HashPtrTableIO.C.
References Foam::read().
HashPtrTable | ( | const dictionary & | dict | ) |
Construct from dictionary using default dictionary constructor.
class
Definition at line 193 of file HashPtrTableIO.C.
References HashTable< T *, Key, Hash >::begin(), HashPtrTable< T, Key, Hash >::clear(), HashTableCore::end(), Foam::nl, Foam::operator>>(), Foam::read(), and HashTable< T *, Key, Hash >::size().
HashPtrTable | ( | const HashPtrTable< T, Key, Hash > & | ht | ) |
Construct as copy.
Definition at line 40 of file HashPtrTable.C.
References HashTable< T *, Key, Hash >::begin(), HashTableCore::end(), HashTable< T *, Key, Hash >::insert(), and Foam::T().
~HashPtrTable | ( | ) |
Destructor.
Definition at line 56 of file HashPtrTable.C.
References HashPtrTable< T, Key, Hash >::clear().
Remove and return the pointer specified by given iterator.
Definition at line 65 of file HashPtrTable.C.
References HashTable< T, Key, Hash >::erase(), and Foam::T().
bool erase | ( | iterator & | it | ) |
Erase an hashedEntry specified by given iterator.
Definition at line 74 of file HashPtrTable.C.
References Foam::T().
void clear | ( | ) |
Clear all entries from table.
Definition at line 95 of file HashPtrTable.C.
References HashTable< T *, Key, Hash >::begin(), HashTable< T, Key, Hash >::clear(), and HashTableCore::end().
Referenced by HashPtrTable< T, Key, Hash >::HashPtrTable(), HashPtrTable< T, Key, Hash >::operator=(), and HashPtrTable< T, Key, Hash >::~HashPtrTable().
void write | ( | Ostream & | os | ) | const |
void operator= | ( | const HashPtrTable< T, Key, Hash > & | rhs | ) |
Definition at line 115 of file HashPtrTable.C.
References Foam::abort(), HashPtrTable< T, Key, Hash >::clear(), Foam::FatalError, FatalErrorInFunction, HashTable< T *, Key, Hash >::insert(), and Foam::T().
|
friend |