summaryrefslogtreecommitdiff
path: root/lib/gl_avltree_omap.c
diff options
context:
space:
mode:
authorBruno Haible <bruno@clisp.org>2018-12-11 20:56:25 +0100
committerBruno Haible <bruno@clisp.org>2018-12-11 20:56:25 +0100
commiteaf9a78f20bdb8e805ae7501bba020272b1f91cf (patch)
treefa5eebbed9b64de48cecc455166125617dc8d94a /lib/gl_avltree_omap.c
parent83ac717e2c236cb1734b8f9eeab6d70b5fb7e6dd (diff)
downloadgnulib-eaf9a78f20bdb8e805ae7501bba020272b1f91cf.tar.gz
avltree-omap: New module.
* lib/gl_avltree_omap.h: New file. * lib/gl_avltree_omap.c: New file. * lib/gl_avltree_ordered.h: Code moved to here from lib/gl_avltree_oset.c. Parameterize. * lib/gl_avltree_oset.c: Include gl_avltree_ordered.h. * lib/gl_anytree_omap.h: New file. * modules/avltree-omap: New file. * modules/avltree-oset (Files): Add lib/gl_avltree_ordered.h. (Makefile.am): Add gl_avltree_ordered.h to lib_SOURCES.
Diffstat (limited to 'lib/gl_avltree_omap.c')
-rw-r--r--lib/gl_avltree_omap.c75
1 files changed, 75 insertions, 0 deletions
diff --git a/lib/gl_avltree_omap.c b/lib/gl_avltree_omap.c
new file mode 100644
index 0000000000..f205eb5e7c
--- /dev/null
+++ b/lib/gl_avltree_omap.c
@@ -0,0 +1,75 @@
+/* Ordered map data type implemented by a binary tree.
+ Copyright (C) 2006-2007, 2009-2018 Free Software Foundation, Inc.
+ Written by Bruno Haible <bruno@clisp.org>, 2018.
+
+ 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 <https://www.gnu.org/licenses/>. */
+
+#include <config.h>
+
+/* Specification. */
+#include "gl_avltree_omap.h"
+
+#include <stdlib.h>
+
+/* -------------------------- gl_omap_t Data Type -------------------------- */
+
+/* Parameterization of gl_avltree_ordered.h. */
+#define CONTAINER_T gl_omap_t
+#define CONTAINER_IMPL gl_omap_impl
+#define CONTAINER_IMPL_BASE gl_omap_impl_base
+#define NODE_IMPL gl_omap_node_impl
+#define NODE_T gl_omap_node_t
+#define NODE_PAYLOAD_FIELDS \
+ const void *key; \
+ const void *value;
+#define NODE_PAYLOAD_PARAMS \
+ const void *key, const void *value
+#define NODE_PAYLOAD_ASSIGN(node) \
+ node->key = key; \
+ node->value = value;
+#define NODE_PAYLOAD_DISPOSE \
+ if (container->base.vdispose_fn != NULL) \
+ container->base.vdispose_fn (node->value); \
+ if (container->base.kdispose_fn != NULL) \
+ container->base.kdispose_fn (node->key);
+
+#include "gl_avltree_ordered.h"
+
+/* Generic binary tree code. */
+#include "gl_anytree_omap.h"
+
+/* For debugging. */
+void
+gl_avltree_omap_check_invariants (gl_omap_t map)
+{
+ size_t counter = 0;
+ if (map->root != NULL)
+ check_invariants (map->root, NULL, &counter);
+ if (!(map->count == counter))
+ abort ();
+}
+
+const struct gl_omap_implementation gl_avltree_omap_implementation =
+ {
+ gl_tree_nx_create_empty,
+ gl_tree_size,
+ gl_tree_search,
+ gl_tree_search_atleast,
+ gl_tree_nx_getput,
+ gl_tree_getremove,
+ gl_tree_omap_free,
+ gl_tree_iterator,
+ gl_tree_iterator_next,
+ gl_tree_iterator_free
+ };