|
|
|
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.
|