2001-09-28 13:08:44 +00:00
/*
* Copyright ( C ) 2001 Sistina Software
*
* This file is released under the GPL .
*/
2001-10-01 15:14:39 +00:00
# ifndef _LVM_HASH_H
# define _LVM_HASH_H
2001-09-28 13:08:44 +00:00
struct hash_table ;
2001-10-03 11:06:31 +00:00
struct hash_node ;
2002-12-19 23:25:55 +00:00
typedef void ( * iterate_fn ) ( void * data ) ;
2001-09-28 13:08:44 +00:00
2001-10-03 11:06:31 +00:00
struct hash_table * hash_create ( unsigned size_hint ) ;
void hash_destroy ( struct hash_table * t ) ;
2001-10-24 17:53:50 +00:00
void hash_wipe ( struct hash_table * t ) ;
2001-09-28 13:08:44 +00:00
2001-10-22 14:14:00 +00:00
void * hash_lookup ( struct hash_table * t , const char * key ) ;
2002-11-18 14:01:16 +00:00
void * hash_lookup_fixed ( struct hash_table * t , const char * key , uint32_t len ) ;
2001-10-04 10:13:07 +00:00
int hash_insert ( struct hash_table * t , const char * key , void * data ) ;
2001-09-28 13:08:44 +00:00
void hash_remove ( struct hash_table * t , const char * key ) ;
unsigned hash_get_num_entries ( struct hash_table * t ) ;
2002-02-25 11:52:58 +00:00
void hash_iter ( struct hash_table * t , iterate_fn f ) ;
2001-09-28 13:08:44 +00:00
2001-10-22 14:14:00 +00:00
char * hash_get_key ( struct hash_table * t , struct hash_node * n ) ;
2001-10-03 11:06:31 +00:00
void * hash_get_data ( struct hash_table * t , struct hash_node * n ) ;
struct hash_node * hash_get_first ( struct hash_table * t ) ;
struct hash_node * hash_get_next ( struct hash_table * t , struct hash_node * n ) ;
2002-02-25 11:52:58 +00:00
# define hash_iterate(v, h) \
for ( v = hash_get_first ( h ) ; v ; \
v = hash_get_next ( h , v ) )
2001-09-28 13:08:44 +00:00
# endif