189 lines
4.9 KiB
Markdown
189 lines
4.9 KiB
Markdown
|
<!--
|
||
|
Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
|
||
|
|
||
|
SPDX-License-Identifier: curl
|
||
|
-->
|
||
|
|
||
|
# `hash`
|
||
|
|
||
|
#include "hash.h"
|
||
|
|
||
|
This is the internal module for doing hash tables. A hash table uses a hash
|
||
|
function to compute an index. On each index there is a separate linked list of
|
||
|
entries.
|
||
|
|
||
|
Create a hash table. Add items. Retrieve items. Remove items. Destroy table.
|
||
|
|
||
|
## `Curl_hash_init`
|
||
|
|
||
|
~~~c
|
||
|
void Curl_hash_init(struct Curl_hash *h,
|
||
|
size_t slots,
|
||
|
hash_function hfunc,
|
||
|
comp_function comparator,
|
||
|
Curl_hash_dtor dtor);
|
||
|
~~~
|
||
|
|
||
|
The call initializes a `struct Curl_hash`.
|
||
|
|
||
|
- `slots` is the number of entries to create in the hash table. Larger is
|
||
|
better (faster lookups) but also uses more memory.
|
||
|
- `hfunc` is a function pointer to a function that returns a `size_t` value as
|
||
|
a checksum for an entry in this hash table. Ideally, it returns a unique
|
||
|
value for every entry ever added to the hash table, but hash collisions are
|
||
|
handled.
|
||
|
- `comparator` is a function pointer to a function that compares two hash
|
||
|
table entries. It should return non-zero if the compared items are
|
||
|
identical.
|
||
|
- `dtor` is a function pointer to a destructor called when an entry is removed
|
||
|
from the table
|
||
|
|
||
|
## `Curl_hash_add`
|
||
|
|
||
|
~~~c
|
||
|
void *
|
||
|
Curl_hash_add(struct Curl_hash *h, void *key, size_t key_len, void *p)
|
||
|
~~~
|
||
|
|
||
|
This call adds an entry to the hash. `key` points to the hash key and
|
||
|
`key_len` is the length of the hash key. `p` is a custom pointer.
|
||
|
|
||
|
If there already was a match in the hash, that data is replaced with this new
|
||
|
entry.
|
||
|
|
||
|
This function also lazily allocates the table if needed, as it is not done in
|
||
|
the `Curl_hash_init` function.
|
||
|
|
||
|
Returns NULL on error, otherwise it returns a pointer to `p`.
|
||
|
|
||
|
## `Curl_hash_add2`
|
||
|
|
||
|
~~~c
|
||
|
void *Curl_hash_add2(struct Curl_hash *h, void *key, size_t key_len, void *p,
|
||
|
Curl_hash_elem_dtor dtor)
|
||
|
~~~
|
||
|
|
||
|
This works like `Curl_hash_add` but has an extra argument: `dtor`, which is a
|
||
|
destructor call for this specific entry. When this entry is removed, this
|
||
|
function is called instead of the function stored for the whole hash table.
|
||
|
|
||
|
## `Curl_hash_delete`
|
||
|
|
||
|
~~~c
|
||
|
int Curl_hash_delete(struct Curl_hash *h, void *key, size_t key_len);
|
||
|
~~~
|
||
|
|
||
|
This function removes an entry from the hash table. If successful, it returns
|
||
|
zero. If the entry was not found, it returns 1.
|
||
|
|
||
|
## `Curl_hash_pick`
|
||
|
|
||
|
~~~c
|
||
|
void *Curl_hash_pick(struct Curl_hash *h, void *key, size_t key_len);
|
||
|
~~~
|
||
|
|
||
|
If there is an entry in the hash that matches the given `key` with size of
|
||
|
`key_len`, that its custom pointer is returned. The pointer that was called
|
||
|
`p` when the entry was added.
|
||
|
|
||
|
It returns NULL if there is no matching entry in the hash.
|
||
|
|
||
|
## `Curl_hash_destroy`
|
||
|
|
||
|
~~~c
|
||
|
void Curl_hash_destroy(struct Curl_hash *h);
|
||
|
~~~
|
||
|
|
||
|
This function destroys a hash and cleanups up all its related data. Calling it
|
||
|
multiple times is fine.
|
||
|
|
||
|
## `Curl_hash_clean`
|
||
|
|
||
|
~~~c
|
||
|
void Curl_hash_clean(struct Curl_hash *h);
|
||
|
~~~
|
||
|
|
||
|
This function removes all the entries in the given hash.
|
||
|
|
||
|
## `Curl_hash_clean_with_criterium`
|
||
|
|
||
|
~~~c
|
||
|
void
|
||
|
Curl_hash_clean_with_criterium(struct Curl_hash *h, void *user,
|
||
|
int (*comp)(void *, void *))
|
||
|
~~~
|
||
|
|
||
|
This function removes all the entries in the given hash that matches the
|
||
|
criterion. The provided `comp` function determines if the criteria is met by
|
||
|
returning non-zero.
|
||
|
|
||
|
## `Curl_hash_count`
|
||
|
|
||
|
~~~c
|
||
|
size_t Curl_hash_count(struct Curl_hash *h)
|
||
|
~~~
|
||
|
|
||
|
Returns the number of entries stored in the hash.
|
||
|
|
||
|
## `Curl_hash_start_iterate`
|
||
|
|
||
|
~~~c
|
||
|
void Curl_hash_start_iterate(struct Curl_hash *hash,
|
||
|
struct Curl_hash_iterator *iter):
|
||
|
~~~
|
||
|
|
||
|
This function initializes a `struct Curl_hash_iterator` that `iter` points to.
|
||
|
It can then be used to iterate over all the entries in the hash.
|
||
|
|
||
|
## `Curl_hash_next_element`
|
||
|
|
||
|
~~~c
|
||
|
struct Curl_hash_element *
|
||
|
Curl_hash_next_element(struct Curl_hash_iterator *iter);
|
||
|
~~~
|
||
|
|
||
|
Given the iterator `iter`, this function returns a pointer to the next hash
|
||
|
entry if there is one, or NULL if there is no more entries.
|
||
|
|
||
|
Called repeatedly, it iterates over all the entries in the hash table.
|
||
|
|
||
|
Note: it only guarantees functionality if the hash table remains untouched
|
||
|
during its iteration.
|
||
|
|
||
|
# `curl_off_t` dedicated hash functions
|
||
|
|
||
|
## `Curl_hash_offt_init`
|
||
|
|
||
|
~~~c
|
||
|
void Curl_hash_offt_init(struct Curl_hash *h,
|
||
|
size_t slots,
|
||
|
Curl_hash_dtor dtor);
|
||
|
~~~
|
||
|
|
||
|
Initializes a hash table for `curl_off_t` values. Pass in desired number of
|
||
|
`slots` and `dtor` function.
|
||
|
|
||
|
## `Curl_hash_offt_set`
|
||
|
|
||
|
~~~c
|
||
|
void *Curl_hash_offt_set(struct Curl_hash *h, curl_off_t id, void *elem);
|
||
|
~~~
|
||
|
|
||
|
Associate a custom `elem` pointer with the given `id`.
|
||
|
|
||
|
## `Curl_hash_offt_remove`
|
||
|
|
||
|
~~~c
|
||
|
int Curl_hash_offt_remove(struct Curl_hash *h, curl_off_t id);
|
||
|
~~~
|
||
|
|
||
|
Remove the `id` from the hash.
|
||
|
|
||
|
## `Curl_hash_offt_get`
|
||
|
|
||
|
~~~c
|
||
|
void *Curl_hash_offt_get(struct Curl_hash *h, curl_off_t id);
|
||
|
~~~
|
||
|
|
||
|
Get the pointer associated with the specified `id`.
|