/*** This file is part of eudev, forked from systemd. Copyright 2010 Lennart Poettering systemd 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. 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 Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with systemd; If not, see . ***/ #include #include "set.h" #include "hashmap.h" #define MAKE_SET(h) ((Set*) (h)) #define MAKE_HASHMAP(s) ((Hashmap*) (s)) /* For now this is not much more than a wrapper around a hashmap */ Set *set_new(const struct hash_ops *hash_ops) { return MAKE_SET(hashmap_new(hash_ops)); } void set_free(Set* s) { hashmap_free(MAKE_HASHMAP(s)); } int set_put(Set *s, void *value) { return hashmap_put(MAKE_HASHMAP(s), value, value); } void *set_get(Set *s, void *value) { return hashmap_get(MAKE_HASHMAP(s), value); } bool set_contains(Set *s, void *value) { return hashmap_contains(MAKE_HASHMAP(s), value); } void *set_iterate(Set *s, Iterator *i) { return hashmap_iterate(MAKE_HASHMAP(s), i, NULL); } int set_reserve(Set *s, unsigned entries_add) { return hashmap_reserve(MAKE_HASHMAP(s), entries_add); }