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
2012-07-18 21:07:51 +04:00
# pragma once
2009-11-18 02:42:52 +03:00
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
2012-04-12 02:20:58 +04:00
under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation ; either version 2.1 of the License , or
2010-02-03 15:03:47 +03:00
( 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
2012-04-12 02:20:58 +04:00
Lesser General Public License for more details .
2010-02-03 15:03:47 +03:00
2012-04-12 02:20:58 +04:00
You should have received a copy of the GNU Lesser General Public License
2010-02-03 15:03:47 +03:00
along with systemd ; If not , see < http : //www.gnu.org/licenses/>.
* * */
2009-11-18 02:42:52 +03:00
/* Pretty straightforward set implementation. Internally based on the
* hashmap . That means that as a minor optimization a NULL set
* object will be treated as empty set for all read
* operations . That way it is not necessary to instantiate an object
* for each set use . */
# include "hashmap.h"
typedef struct Set Set ;
Set * set_new ( hash_func_t hash_func , compare_func_t compare_func ) ;
2010-01-19 01:49:49 +03:00
void set_free ( Set * s ) ;
2013-03-06 17:44:51 +04:00
static inline void set_freep ( Set * * s ) {
set_free ( * s ) ;
}
2010-06-15 04:45:26 +04:00
void set_free_free ( Set * s ) ;
2013-03-06 17:44:51 +04:00
static inline void set_free_freep ( Set * * s ) {
set_free_free ( * s ) ;
}
2010-01-26 06:18:44 +03:00
Set * set_copy ( Set * s ) ;
int set_ensure_allocated ( Set * * s , hash_func_t hash_func , compare_func_t compare_func ) ;
2009-11-18 02:42:52 +03:00
int set_put ( Set * s , void * value ) ;
2013-04-23 07:12:15 +04:00
int set_consume ( Set * s , void * value ) ;
2010-01-20 04:12:36 +03:00
int set_replace ( Set * s , void * value ) ;
2009-11-18 02:42:52 +03:00
void * set_get ( Set * s , void * value ) ;
2012-08-13 15:58:01 +04:00
bool set_contains ( Set * s , void * value ) ;
2009-11-18 02:42:52 +03:00
void * set_remove ( Set * s , void * value ) ;
2010-04-06 04:38:43 +04:00
int set_remove_and_put ( Set * s , void * old_value , void * new_value ) ;
2009-11-18 02:42:52 +03:00
2010-01-19 01:49:49 +03:00
int set_merge ( Set * s , Set * other ) ;
2010-04-06 04:38:43 +04:00
void set_move ( Set * s , Set * other ) ;
int set_move_one ( Set * s , Set * other , void * value ) ;
2010-01-19 01:49:49 +03:00
2009-11-18 02:42:52 +03:00
unsigned set_size ( Set * s ) ;
bool set_isempty ( Set * s ) ;
2010-01-26 06:18:44 +03:00
void * set_iterate ( Set * s , Iterator * i ) ;
void * set_iterate_backwards ( Set * s , Iterator * i ) ;
void * set_iterate_skip ( Set * s , void * value , Iterator * i ) ;
2009-11-18 02:42:52 +03:00
2010-01-19 06:15:20 +03:00
void set_clear ( Set * s ) ;
2012-07-03 18:09:36 +04:00
void set_clear_free ( Set * s ) ;
2010-01-19 01:49:49 +03:00
void * set_steal_first ( Set * s ) ;
void * set_first ( Set * s ) ;
void * set_last ( Set * s ) ;
2009-11-18 02:42:52 +03:00
2012-10-19 06:52:14 +04:00
char * * set_get_strv ( Set * s ) ;
2010-01-26 06:18:44 +03:00
# define SET_FOREACH(e, s, i) \
for ( ( i ) = ITERATOR_FIRST , ( e ) = set_iterate ( ( s ) , & ( i ) ) ; ( e ) ; ( e ) = set_iterate ( ( s ) , & ( i ) ) )
2009-11-18 02:42:52 +03:00
2010-01-26 06:18:44 +03:00
# define SET_FOREACH_BACKWARDS(e, s, i) \
for ( ( i ) = ITERATOR_LAST , ( e ) = set_iterate_backwards ( ( s ) , & ( i ) ) ; ( e ) ; ( e ) = set_iterate_backwards ( ( s ) , & ( i ) ) )
2013-04-16 07:25:57 +04:00
# define _cleanup_set_free_ _cleanup_(set_freep)
# define _cleanup_set_free_free_ _cleanup_(set_free_freep)