| //======================================================================== |
| // |
| // GooHash.h |
| // |
| // Copyright 2001-2003 Glyph & Cog, LLC |
| // |
| //======================================================================== |
| |
| #ifndef GHASH_H |
| #define GHASH_H |
| |
| #ifdef USE_GCC_PRAGMAS |
| #pragma interface |
| #endif |
| |
| #include "gtypes.h" |
| |
| class GooString; |
| struct GooHashBucket; |
| struct GooHashIter; |
| |
| //------------------------------------------------------------------------ |
| |
| class GooHash { |
| public: |
| |
| GooHash(GBool deleteKeysA = gFalse); |
| ~GooHash(); |
| void add(GooString *key, void *val); |
| void add(GooString *key, int val); |
| void replace(GooString *key, void *val); |
| void replace(GooString *key, int val); |
| void *lookup(GooString *key); |
| int lookupInt(GooString *key); |
| void *lookup(char *key); |
| int lookupInt(char *key); |
| void *remove(GooString *key); |
| int removeInt(GooString *key); |
| void *remove(char *key); |
| int removeInt(char *key); |
| int getLength() { return len; } |
| void startIter(GooHashIter **iter); |
| GBool getNext(GooHashIter **iter, GooString **key, void **val); |
| GBool getNext(GooHashIter **iter, GooString **key, int *val); |
| void killIter(GooHashIter **iter); |
| |
| private: |
| |
| void expand(); |
| GooHashBucket *find(GooString *key, int *h); |
| GooHashBucket *find(char *key, int *h); |
| int hash(GooString *key); |
| int hash(char *key); |
| |
| GBool deleteKeys; // set if key strings should be deleted |
| int size; // number of buckets |
| int len; // number of entries |
| GooHashBucket **tab; |
| }; |
| |
| #define deleteGooHash(hash, T) \ |
| do { \ |
| GooHash *_hash = (hash); \ |
| { \ |
| GooHashIter *_iter; \ |
| GooString *_key; \ |
| void *_p; \ |
| _hash->startIter(&_iter); \ |
| while (_hash->getNext(&_iter, &_key, &_p)) { \ |
| delete (T*)_p; \ |
| } \ |
| delete _hash; \ |
| } \ |
| } while(0) |
| |
| #endif |