|  | hash API | 
|  | ======== | 
|  |  | 
|  | The hash API is a collection of simple hash table functions. Users are expected | 
|  | to implement their own hashing. | 
|  |  | 
|  | Data Structures | 
|  | --------------- | 
|  |  | 
|  | `struct hash_table`:: | 
|  |  | 
|  | The hash table structure. The `array` member points to the hash table | 
|  | entries. The `size` member counts the total number of valid and invalid | 
|  | entries in the table. The `nr` member keeps track of the number of | 
|  | valid entries. | 
|  |  | 
|  | `struct hash_table_entry`:: | 
|  |  | 
|  | An opaque structure representing an entry in the hash table. The `hash` | 
|  | member is the entry's hash key and the `ptr` member is the entry's | 
|  | value. | 
|  |  | 
|  | Functions | 
|  | --------- | 
|  |  | 
|  | `init_hash`:: | 
|  |  | 
|  | Initialize the hash table. | 
|  |  | 
|  | `free_hash`:: | 
|  |  | 
|  | Release memory associated with the hash table. | 
|  |  | 
|  | `insert_hash`:: | 
|  |  | 
|  | Insert a pointer into the hash table. If an entry with that hash | 
|  | already exists, a pointer to the existing entry's value is returned. | 
|  | Otherwise NULL is returned.  This allows callers to implement | 
|  | chaining, etc. | 
|  |  | 
|  | `lookup_hash`:: | 
|  |  | 
|  | Lookup an entry in the hash table. If an entry with that hash exists | 
|  | the entry's value is returned. Otherwise NULL is returned. | 
|  |  | 
|  | `for_each_hash`:: | 
|  |  | 
|  | Call a function for each entry in the hash table. The function is | 
|  | expected to take the entry's value as its only argument and return an | 
|  | int. If the function returns a negative int the loop is aborted | 
|  | immediately.  Otherwise, the return value is accumulated and the sum | 
|  | returned upon completion of the loop. |