virhash.h 6.1 KB
Newer Older
D
Daniel Veillard 已提交
1
/*
2 3 4
 * Summary: Chained hash tables and domain/connections handling
 * Description: This module implements the hash table and allocation and
 *              deallocation of domains and connections
D
Daniel Veillard 已提交
5
 *
E
Eric Blake 已提交
6
 * Copyright (C) 2005-2014 Red Hat, Inc.
7
 * Copyright (C) 2000 Bjorn Reese and Daniel Veillard.
D
Daniel Veillard 已提交
8 9
 *
 * Author: Bjorn Reese <bjorn.reese@systematic.dk>
10
 *         Daniel Veillard <veillard@redhat.com>
D
Daniel Veillard 已提交
11 12
 */

13
#ifndef __VIR_HASH_H__
14
# define __VIR_HASH_H__
D
Daniel Veillard 已提交
15

16
# include <stdint.h>
17
# include <stdbool.h>
18

D
Daniel Veillard 已提交
19 20 21
/*
 * The hash table.
 */
22 23
typedef struct _virHashTable virHashTable;
typedef virHashTable *virHashTablePtr;
D
Daniel Veillard 已提交
24

J
Jiri Denemark 已提交
25 26 27
typedef struct _virHashAtomic virHashAtomic;
typedef virHashAtomic *virHashAtomicPtr;

D
Daniel Veillard 已提交
28 29 30
/*
 * function types:
 */
31

D
Daniel Veillard 已提交
32
/**
33
 * virHashDataFree:
D
Daniel Veillard 已提交
34 35 36 37 38
 * @payload:  the data in the hash
 * @name:  the name associated
 *
 * Callback to free data from a hash.
 */
39
typedef void (*virHashDataFree) (void *payload, const void *name);
40 41 42
/**
 * virHashIterator:
 * @payload: the data in the hash
43
 * @name: the hash key
44 45 46
 * @data: user supplied data blob
 *
 * Callback to process a hash entry during iteration
47 48
 *
 * Returns -1 to stop the iteration, e.g. in case of an error
49
 */
50
typedef int (*virHashIterator) (void *payload, const void *name, void *data);
51
/**
52
 * virHashSearcher:
53
 * @payload: the data in the hash
54
 * @name: the hash key
55 56 57 58 59 60
 * @data: user supplied data blob
 *
 * Callback to identify hash entry desired
 * Returns 1 if the hash entry is desired, 0 to move
 * to next entry
 */
61
typedef int (*virHashSearcher) (const void *payload, const void *name,
62
                                const void *data);
D
Daniel Veillard 已提交
63

64 65 66
/**
 * virHashKeyCode:
 * @name: the hash key
67
 * @seed: random seed
68
 *
69 70
 * Compute the hash code corresponding to the key @name, using
 * @seed to perturb the hashing algorithm
71 72 73
 *
 * Returns the hash code
 */
74 75
typedef uint32_t (*virHashKeyCode)(const void *name,
                                   uint32_t seed);
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
/**
 * virHashKeyEqual:
 * @namea: the first hash key
 * @nameb: the second hash key
 *
 * Compare two hash keys for equality
 *
 * Returns true if the keys are equal, false otherwise
 */
typedef bool (*virHashKeyEqual)(const void *namea, const void *nameb);
/**
 * virHashKeyCopy:
 * @name: the hash key
 *
 * Create a copy of the hash key, duplicating
 * memory allocation where applicable
 *
 * Returns a newly allocated copy of @name
 */
typedef void *(*virHashKeyCopy)(const void *name);
/**
 * virHashKeyFree:
 * @name: the hash key
 *
 * Free any memory associated with the hash
 * key @name
 */
typedef void (*virHashKeyFree)(void *name);

D
Daniel Veillard 已提交
105 106 107
/*
 * Constructor and destructor.
 */
108
virHashTablePtr virHashCreate(ssize_t size,
109
                              virHashDataFree dataFree);
J
Jiri Denemark 已提交
110 111
virHashAtomicPtr virHashAtomicNew(ssize_t size,
                                  virHashDataFree dataFree);
112
virHashTablePtr virHashCreateFull(ssize_t size,
113 114 115 116 117
                                  virHashDataFree dataFree,
                                  virHashKeyCode keyCode,
                                  virHashKeyEqual keyEqual,
                                  virHashKeyCopy keyCopy,
                                  virHashKeyFree keyFree);
118
void virHashFree(virHashTablePtr table);
E
Eric Blake 已提交
119 120
ssize_t virHashSize(const virHashTable *table);
ssize_t virHashTableSize(const virHashTable *table);
D
Daniel Veillard 已提交
121 122 123 124

/*
 * Add a new entry to the hash table.
 */
125
int virHashAddEntry(virHashTablePtr table,
126
                    const void *name, void *userdata);
127
int virHashUpdateEntry(virHashTablePtr table,
128
                       const void *name,
129
                       void *userdata);
J
Jiri Denemark 已提交
130 131 132
int virHashAtomicUpdate(virHashAtomicPtr table,
                        const void *name,
                        void *userdata);
D
Daniel Veillard 已提交
133 134 135 136

/*
 * Remove an entry from the hash table.
 */
137
int virHashRemoveEntry(virHashTablePtr table,
138
                       const void *name);
139

140 141 142 143 144
/*
 * Remove all entries from the hash table.
 */
ssize_t virHashRemoveAll(virHashTablePtr table);

D
Daniel Veillard 已提交
145 146 147
/*
 * Retrieve the userdata.
 */
E
Eric Blake 已提交
148
void *virHashLookup(const virHashTable *table, const void *name);
D
Daniel Veillard 已提交
149

150 151 152
/*
 * Retrieve & remove the userdata.
 */
153
void *virHashSteal(virHashTablePtr table, const void *name);
J
Jiri Denemark 已提交
154 155
void *virHashAtomicSteal(virHashAtomicPtr table,
                         const void *name);
156

157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174
/*
 * Get the hash table's key/value pairs and have them optionally sorted.
 * The returned array contains virHashSize() elements. Additionally,
 * an empty element has been added to the end of the array (with key == NULL)
 * to indicate the end of the array.
 * The key/value pairs are only valid as long as the underlying hash
 * table is not modified, i.e., no keys are removed or inserted, and
 * the hash table is not deleted.
 * The caller must only free the returned array using VIR_FREE().
 * The caller must make copies of all returned keys and values if they are
 * to be used somewhere else.
 */
typedef struct _virHashKeyValuePair virHashKeyValuePair;
typedef virHashKeyValuePair *virHashKeyValuePairPtr;
struct _virHashKeyValuePair {
    const void *key;
    const void *value;
};
E
Eric Blake 已提交
175 176
typedef int (*virHashKeyComparator)(const virHashKeyValuePair *,
                                    const virHashKeyValuePair *);
177 178
virHashKeyValuePairPtr virHashGetItems(virHashTablePtr table,
                                       virHashKeyComparator compar);
179

180 181 182 183 184 185 186
/*
 * Compare two tables for equality: the lookup of a key's value in
 * both tables must result in an equivalent value.
 * The caller must pass in a comparator function for comparing the values
 * of two keys.
 */
typedef int (*virHashValueComparator)(const void *value1, const void *value2);
E
Eric Blake 已提交
187 188
bool virHashEqual(const virHashTable *table1,
                  const virHashTable *table2,
189 190 191
                  virHashValueComparator compar);


192 193 194
/*
 * Iterators
 */
195
int virHashForEach(virHashTablePtr table, virHashIterator iter, void *data);
196
ssize_t virHashRemoveSet(virHashTablePtr table, virHashSearcher iter, const void *data);
E
Eric Blake 已提交
197
void *virHashSearch(const virHashTable *table, virHashSearcher iter,
198
                    const void *data, void **name);
199

E
Eric Blake 已提交
200 201 202
/* Convenience for when VIR_FREE(value) is sufficient as a data freer.  */
void virHashValueFree(void *value, const void *name);

203
#endif                          /* ! __VIR_HASH_H__ */