2010-08-17 05:33:07 +04:00
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2009-11-18 02:42:52 +03:00
# ifndef foohashmaphfoo
# define foohashmaphfoo
2010-02-03 15:03:47 +03:00
/***
This file is part of systemd .
Copyright 2010 Lennart Poettering
systemd is free software ; you can redistribute it and / or modify it
under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
systemd is distributed in the hope that it will be useful , but
WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
General Public License for more details .
You should have received a copy of the GNU General Public License
along with systemd ; If not , see < http : //www.gnu.org/licenses/>.
* * */
2009-11-18 02:42:52 +03:00
# include <stdbool.h>
/* Pretty straightforward hash table implementation. As a minor
* optimization a NULL hashmap object will be treated as empty hashmap
* for all read operations . That way it is not necessary to
* instantiate an object for each Hashmap use . */
typedef struct Hashmap Hashmap ;
2010-01-26 06:18:44 +03:00
typedef struct _IteratorStruct _IteratorStruct ;
typedef _IteratorStruct * Iterator ;
# define ITERATOR_FIRST ((Iterator) 0)
# define ITERATOR_LAST ((Iterator) -1)
2009-11-18 02:42:52 +03:00
typedef unsigned ( * hash_func_t ) ( const void * p ) ;
typedef int ( * compare_func_t ) ( const void * a , const void * b ) ;
unsigned string_hash_func ( const void * p ) ;
int string_compare_func ( const void * a , const void * b ) ;
unsigned trivial_hash_func ( const void * p ) ;
int trivial_compare_func ( const void * a , const void * b ) ;
Hashmap * hashmap_new ( hash_func_t hash_func , compare_func_t compare_func ) ;
2010-01-19 01:49:49 +03:00
void hashmap_free ( Hashmap * h ) ;
2010-08-20 05:26:15 +04:00
void hashmap_free_free ( Hashmap * h ) ;
2010-01-19 01:49:49 +03:00
Hashmap * hashmap_copy ( Hashmap * h ) ;
2010-01-26 06:18:44 +03:00
int hashmap_ensure_allocated ( Hashmap * * h , hash_func_t hash_func , compare_func_t compare_func ) ;
2009-11-18 02:42:52 +03:00
int hashmap_put ( Hashmap * h , const void * key , void * value ) ;
2010-01-20 04:12:12 +03:00
int hashmap_replace ( Hashmap * h , const void * key , void * value ) ;
2009-11-18 02:42:52 +03:00
void * hashmap_get ( Hashmap * h , const void * key ) ;
void * hashmap_remove ( Hashmap * h , const void * key ) ;
2010-01-20 04:12:12 +03:00
void * hashmap_remove_value ( Hashmap * h , const void * key , void * value ) ;
2010-04-06 04:38:43 +04:00
int hashmap_remove_and_put ( Hashmap * h , const void * old_key , const void * new_key , void * value ) ;
2010-07-20 22:33:19 +04:00
int hashmap_remove_and_replace ( Hashmap * h , const void * old_key , const void * new_key , void * value ) ;
2009-11-18 02:42:52 +03:00
2010-01-19 01:49:49 +03:00
int hashmap_merge ( Hashmap * h , Hashmap * other ) ;
2010-04-06 04:38:43 +04:00
void hashmap_move ( Hashmap * h , Hashmap * other ) ;
int hashmap_move_one ( Hashmap * h , Hashmap * other , const void * key ) ;
2010-01-19 01:49:49 +03:00
2009-11-18 02:42:52 +03:00
unsigned hashmap_size ( Hashmap * h ) ;
bool hashmap_isempty ( Hashmap * h ) ;
2010-01-26 06:18:44 +03:00
void * hashmap_iterate ( Hashmap * h , Iterator * i , const void * * key ) ;
void * hashmap_iterate_backwards ( Hashmap * h , Iterator * i , const void * * key ) ;
void * hashmap_iterate_skip ( Hashmap * h , const void * key , Iterator * i ) ;
2009-11-18 02:42:52 +03:00
2010-01-19 06:15:20 +03:00
void hashmap_clear ( Hashmap * h ) ;
2009-11-18 02:42:52 +03:00
void * hashmap_steal_first ( Hashmap * h ) ;
2010-09-23 17:01:41 +04:00
void * hashmap_steal_first_key ( Hashmap * h ) ;
2009-11-18 02:42:52 +03:00
void * hashmap_first ( Hashmap * h ) ;
void * hashmap_last ( Hashmap * h ) ;
2011-04-25 22:41:47 +04:00
char * * hashmap_get_strv ( Hashmap * h ) ;
2010-01-26 06:18:44 +03:00
# define HASHMAP_FOREACH(e, h, i) \
2010-09-27 22:13:21 +04:00
for ( ( i ) = ITERATOR_FIRST , ( e ) = hashmap_iterate ( ( h ) , & ( i ) , NULL ) ; ( e ) ; ( e ) = hashmap_iterate ( ( h ) , & ( i ) , NULL ) )
2009-11-18 02:42:52 +03:00
2010-01-26 06:18:44 +03:00
# define HASHMAP_FOREACH_KEY(e, k, h, i) \
2010-09-27 22:13:21 +04:00
for ( ( i ) = ITERATOR_FIRST , ( e ) = hashmap_iterate ( ( h ) , & ( i ) , ( const void * * ) & ( k ) ) ; ( e ) ; ( e ) = hashmap_iterate ( ( h ) , & ( i ) , ( const void * * ) & ( k ) ) )
2010-01-19 06:15:20 +03:00
2010-01-26 06:18:44 +03:00
# define HASHMAP_FOREACH_BACKWARDS(e, h, i) \
2010-09-27 22:13:21 +04:00
for ( ( i ) = ITERATOR_LAST , ( e ) = hashmap_iterate_backwards ( ( h ) , & ( i ) , NULL ) ; ( e ) ; ( e ) = hashmap_iterate_backwards ( ( h ) , & ( i ) , NULL ) )
2009-11-18 02:42:52 +03:00
# endif