2005-11-30 13:36:58 +00:00
|
|
|
/*
|
2006-04-09 13:11:22 +00:00
|
|
|
* Summary: Chained hash tables and domain/connections handling
|
|
|
|
* Description: This module implements the hash table and allocation and
|
|
|
|
* deallocation of domains and connections
|
2005-11-30 13:36:58 +00:00
|
|
|
*
|
2005-12-19 16:34:11 +00:00
|
|
|
* Copy: Copyright (C) 2005 Red Hat, Inc.
|
2005-11-30 13:36:58 +00:00
|
|
|
*
|
|
|
|
* Author: Bjorn Reese <bjorn.reese@systematic.dk>
|
2006-04-09 13:11:22 +00:00
|
|
|
* Daniel Veillard <veillard@redhat.com>
|
2005-11-30 13:36:58 +00:00
|
|
|
*/
|
|
|
|
|
2005-12-05 11:16:07 +00:00
|
|
|
#ifndef __VIR_HASH_H__
|
2010-03-09 19:22:22 +01:00
|
|
|
# define __VIR_HASH_H__
|
2005-11-30 13:36:58 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The hash table.
|
|
|
|
*/
|
2006-04-09 13:11:22 +00:00
|
|
|
typedef struct _virHashTable virHashTable;
|
|
|
|
typedef virHashTable *virHashTablePtr;
|
2005-11-30 13:36:58 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* function types:
|
|
|
|
*/
|
2006-03-15 12:13:25 +00:00
|
|
|
|
2005-11-30 13:36:58 +00:00
|
|
|
/**
|
2005-12-05 11:16:07 +00:00
|
|
|
* virHashDeallocator:
|
2005-11-30 13:36:58 +00:00
|
|
|
* @payload: the data in the hash
|
|
|
|
* @name: the name associated
|
|
|
|
*
|
|
|
|
* Callback to free data from a hash.
|
|
|
|
*/
|
2006-11-15 20:11:56 +00:00
|
|
|
typedef void (*virHashDeallocator) (void *payload, const char *name);
|
|
|
|
/**
|
|
|
|
* virHashIterator:
|
|
|
|
* @payload: the data in the hash
|
|
|
|
* @name: the name associated
|
|
|
|
* @data: user supplied data blob
|
|
|
|
*
|
|
|
|
* Callback to process a hash entry during iteration
|
|
|
|
*/
|
2009-10-14 11:17:24 +01:00
|
|
|
typedef void (*virHashIterator) (void *payload, const char *name, void *data);
|
2006-11-15 20:11:56 +00:00
|
|
|
/**
|
|
|
|
* virHashSearcher
|
|
|
|
* @payload: the data in the hash
|
|
|
|
* @name: the name associated
|
|
|
|
* @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
|
|
|
|
*/
|
|
|
|
typedef int (*virHashSearcher) (const void *payload, const char *name, const void *data);
|
2005-11-30 13:36:58 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Constructor and destructor.
|
|
|
|
*/
|
2006-04-09 13:11:22 +00:00
|
|
|
virHashTablePtr virHashCreate(int size);
|
|
|
|
void virHashFree(virHashTablePtr table, virHashDeallocator f);
|
|
|
|
int virHashSize(virHashTablePtr table);
|
2005-11-30 13:36:58 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Add a new entry to the hash table.
|
|
|
|
*/
|
2006-04-09 13:11:22 +00:00
|
|
|
int virHashAddEntry(virHashTablePtr table,
|
2008-04-10 16:54:54 +00:00
|
|
|
const char *name, void *userdata);
|
2006-04-09 13:11:22 +00:00
|
|
|
int virHashUpdateEntry(virHashTablePtr table,
|
2008-04-10 16:54:54 +00:00
|
|
|
const char *name,
|
|
|
|
void *userdata, virHashDeallocator f);
|
2005-11-30 13:36:58 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Remove an entry from the hash table.
|
|
|
|
*/
|
2006-04-09 13:11:22 +00:00
|
|
|
int virHashRemoveEntry(virHashTablePtr table,
|
2008-04-10 16:54:54 +00:00
|
|
|
const char *name, virHashDeallocator f);
|
2006-03-15 12:13:25 +00:00
|
|
|
|
2005-11-30 13:36:58 +00:00
|
|
|
/*
|
|
|
|
* Retrieve the userdata.
|
|
|
|
*/
|
2006-04-09 13:11:22 +00:00
|
|
|
void *virHashLookup(virHashTablePtr table, const char *name);
|
2005-11-30 13:36:58 +00:00
|
|
|
|
2006-11-15 20:11:56 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Iterators
|
|
|
|
*/
|
2009-10-14 11:17:24 +01:00
|
|
|
int virHashForEach(virHashTablePtr table, virHashIterator iter, void *data);
|
2006-11-15 20:11:56 +00:00
|
|
|
int virHashRemoveSet(virHashTablePtr table, virHashSearcher iter, virHashDeallocator f, const void *data);
|
|
|
|
void *virHashSearch(virHashTablePtr table, virHashSearcher iter, const void *data);
|
|
|
|
|
2006-03-15 12:13:25 +00:00
|
|
|
#endif /* ! __VIR_HASH_H__ */
|