--- /dev/null
+/* GDB wrapper for splay trees.
+
+ Copyright (C) 2017 Free Software Foundation, Inc.
+
+ This file is part of GDB.
+
+ 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 <http://www.gnu.org/licenses/>. */
+
+#ifndef GDB_SPLAY_TREE_H
+#define GDB_SPLAY_TREE_H
+
+#include "splay-tree.h"
+
+namespace gdb {
+
+struct splay_tree_deleter
+{
+ void operator() (splay_tree tree) const
+ {
+ splay_tree_delete (tree);
+ }
+};
+
+} /* namespace gdb */
+
+/* A unique pointer to a splay tree. */
+
+typedef std::unique_ptr<splay_tree_s, gdb::splay_tree_deleter>
+ gdb_splay_tree_up;
+
+#endif /* ! GDB_SPLAY_TREE_H */
#include "valprint.h"
#include "inferior.h"
#include "osdata.h"
-#include "splay-tree.h"
+#include "common/gdb_splay_tree.h"
#include "tracepoint.h"
#include "ctf.h"
#include "ada-lang.h"
return a - b;
}
-static void
-free_splay_tree (void *xt)
-{
- splay_tree t = (splay_tree) xt;
- splay_tree_delete (t);
-}
-
static void
list_available_thread_groups (const std::set<int> &ids, int recurse)
{
The vector contains information about all threads for the given pid.
This is assigned an initial value to avoid "may be used uninitialized"
warning from gcc. */
- splay_tree tree = NULL;
+ gdb_splay_tree_up tree;
/* get_osdata will throw if it cannot return data. */
data = get_osdata ("processes");
struct osdata *threads = get_osdata ("threads");
make_cleanup_osdata_free (threads);
- tree = splay_tree_new (splay_tree_int_comparator,
- NULL,
- free_vector_of_osdata_items);
- make_cleanup (free_splay_tree, tree);
+ tree.reset (splay_tree_new (splay_tree_int_comparator,
+ NULL,
+ free_vector_of_osdata_items));
for (ix_items = 0;
VEC_iterate (osdata_item_s, threads->items,
int pid_i = strtoul (pid, NULL, 0);
VEC (osdata_item_s) *vec = 0;
- splay_tree_node n = splay_tree_lookup (tree, pid_i);
+ splay_tree_node n = splay_tree_lookup (tree.get (), pid_i);
if (!n)
{
VEC_safe_push (osdata_item_s, vec, item);
- splay_tree_insert (tree, pid_i, (splay_tree_value)vec);
+ splay_tree_insert (tree.get (), pid_i, (splay_tree_value)vec);
}
else
{
if (recurse)
{
- splay_tree_node n = splay_tree_lookup (tree, pid_i);
+ splay_tree_node n = splay_tree_lookup (tree.get (), pid_i);
if (n)
{
VEC (osdata_item_s) *children = (VEC (osdata_item_s) *) n->value;