/* SSSD Service monitor Copyright (C) Stephen Gallagher 2008 This program 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 3 of the License, or (at your option) any later version. This program 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 this program. If not, see . */ #ifndef BTREEMAP_H_ #define BTREEMAP_H_ enum { BTREEMAP_EMPTY = -2, BTREEMAP_CREATE_LEFT, BTREEMAP_FOUND, BTREEMAP_CREATE_RIGHT }; typedef int (*btreemap_comparison_fn)(const void *first, const void *second); struct btreemap; int btreemap_search_key(struct btreemap *map, const void *key, struct btreemap **node); void *btreemap_get_value(struct btreemap *map, const void *key); int btreemap_set_value(TALLOC_CTX *mem_ctx, struct btreemap **map, const void *key, void *value, btreemap_comparison_fn comparator); int btreemap_get_keys(TALLOC_CTX *mem_ctx, struct btreemap *map, const void ***array, int *count); #endif /*BTREEMAP_H_*/