]> sjero.net Git - wget/blob - src/hash.h
[svn] Merge of fix for bugs 20341 and 20410.
[wget] / src / hash.h
1 /* Hash table declarations.
2    Copyright (C) 2000 Free Software Foundation, Inc.
3
4 This file is part of GNU Wget.
5
6 GNU Wget is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
10
11 GNU Wget is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with Wget.  If not, see <http://www.gnu.org/licenses/>.
18
19 In addition, as a special exception, the Free Software Foundation
20 gives permission to link the code of its release of Wget with the
21 OpenSSL project's "OpenSSL" library (or with modified versions of it
22 that use the same license as the "OpenSSL" library), and distribute
23 the linked executables.  You must obey the GNU General Public License
24 in all respects for all of the code used other than "OpenSSL".  If you
25 modify this file, you may extend this exception to your version of the
26 file, but you are not obligated to do so.  If you do not wish to do
27 so, delete this exception statement from your version.  */
28
29 #ifndef HASH_H
30 #define HASH_H
31
32 struct hash_table;
33
34 struct hash_table *hash_table_new (int, unsigned long (*) (const void *),
35                                    int (*) (const void *, const void *));
36 void hash_table_destroy (struct hash_table *);
37
38 void *hash_table_get (const struct hash_table *, const void *);
39 int hash_table_get_pair (const struct hash_table *, const void *,
40                          void *, void *);
41 int hash_table_contains (const struct hash_table *, const void *);
42
43 void hash_table_put (struct hash_table *, const void *, void *);
44 int hash_table_remove (struct hash_table *, const void *);
45 void hash_table_clear (struct hash_table *);
46
47 void hash_table_for_each (struct hash_table *,
48                           int (*) (void *, void *, void *), void *);
49
50 typedef struct {
51   void *key, *value;            /* public members */
52   void *pos, *end;              /* private members */
53 } hash_table_iterator;
54 void hash_table_iterate (struct hash_table *, hash_table_iterator *);
55 int hash_table_iter_next (hash_table_iterator *);
56
57 int hash_table_count (const struct hash_table *);
58
59 struct hash_table *make_string_hash_table (int);
60 struct hash_table *make_nocase_string_hash_table (int);
61
62 unsigned long hash_pointer (const void *);
63
64 #endif /* HASH_H */