Arthur de Jong

Open Source / Free Software developer

summaryrefslogtreecommitdiffstats
path: root/common
diff options
context:
space:
mode:
authorArthur de Jong <arthur@arthurdejong.org>2008-04-19 12:26:44 +0200
committerArthur de Jong <arthur@arthurdejong.org>2008-04-19 12:26:44 +0200
commitd3ed555ef3e65601f3b952036914eafc10b01d9c (patch)
treeb74838b7d85931c225dbd6a8bab0275e52bb5857 /common
parent953a00fd4b8463f9b6ba8616a507746fe8bc56af (diff)
implement a set that uses the dict module as back-end
git-svn-id: http://arthurdejong.org/svn/nss-pam-ldapd/nss-ldapd@681 ef36b2f9-881f-0410-afb5-c4e39611909c
Diffstat (limited to 'common')
-rw-r--r--common/Makefile.am5
-rw-r--r--common/set.c64
-rw-r--r--common/set.h65
3 files changed, 132 insertions, 2 deletions
diff --git a/common/Makefile.am b/common/Makefile.am
index 42f20a0..a813da5 100644
--- a/common/Makefile.am
+++ b/common/Makefile.am
@@ -1,6 +1,6 @@
# Makefile.am - use automake to generate Makefile.in
#
-# Copyright (C) 2007 Arthur de Jong
+# Copyright (C) 2007, 2008 Arthur de Jong
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
@@ -24,4 +24,5 @@ AM_CFLAGS = -fPIC
libtio_a_SOURCES = tio.c tio.h
-libdict_a_SOURCES = dict.c dict.h
+libdict_a_SOURCES = dict.c dict.h \
+ set.c set.h
diff --git a/common/set.c b/common/set.c
new file mode 100644
index 0000000..9efc582
--- /dev/null
+++ b/common/set.c
@@ -0,0 +1,64 @@
+/*
+ set.c - set functions
+ This file is part of the nss-ldapd library.
+
+ Copyright (C) 2008 Arthur de Jong
+
+ This library is free software; you can redistribute it and/or
+ modify it 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 (at your option) any later version.
+
+ This library 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
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with this library; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ 02110-1301 USA
+*/
+
+#include "config.h"
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <strings.h>
+
+#include "set.h"
+#include "dict.h"
+
+SET *set_new(void)
+{
+ return (SET *)dict_new();
+}
+
+int set_add(SET *set,const char *value)
+{
+ return dict_put((DICT *)set,value,set);
+}
+
+int set_contains(SET *set,const char *value)
+{
+ return dict_get((DICT *)set,value)!=NULL;
+}
+
+void set_free(SET *set)
+{
+ dict_free((DICT *)set);
+}
+
+void set_loop_first(SET *set)
+{
+ dict_loop_first((DICT *)set);
+}
+
+const char *set_loop_next(SET *set)
+{
+ const char *value=NULL;
+ if (dict_loop_next((DICT *)set,&value,NULL)==NULL)
+ return NULL;
+ return value;
+}
diff --git a/common/set.h b/common/set.h
new file mode 100644
index 0000000..f867815
--- /dev/null
+++ b/common/set.h
@@ -0,0 +1,65 @@
+/*
+ set.h - set functions
+ This file is part of the nss-ldapd library.
+
+ Copyright (C) 2008 Arthur de Jong
+
+ This library is free software; you can redistribute it and/or
+ modify it 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 (at your option) any later version.
+
+ This library 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
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with this library; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ 02110-1301 USA
+*/
+
+#ifndef _SET_H
+#define _SET_H
+
+#include "compat/attrs.h"
+
+/*
+ These functions provide a set of string in an unordered
+ collection.
+*/
+typedef struct set SET;
+
+/* Create a new instance of a set. Returns NULL
+ in case of memory allocation errors. */
+SET *set_new(void)
+ LIKE_MALLOC MUST_USE;
+
+/* Add a string in the set. The value is duplicated
+ and can be reused by the caller.
+ This function returns non-0 in case of memory allocation
+ errors. All value comparisons are case insensitive. */
+int set_add(SET *set,const char *value);
+
+/* Return non-zero if the value is in the set.
+ All value comparisons are case insensitive. */
+int set_contains(SET *set,const char *value)
+ MUST_USE;
+
+/* Remove the set from memory. All allocated storage
+ for the set and the values is freed. */
+void set_free(SET *set);
+
+/* Function for looping over all set values.
+ This resets the search to the beginning of the set.
+ This is required before calling set_loop_next(); */
+void set_loop_first(SET *set);
+
+/* Function for looping over all set values.
+ This returns a stored value. NULL is returned when all
+ values have been returned. */
+const char *set_loop_next(SET *set)
+ MUST_USE;
+
+#endif /* _SET_H */