aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorAndrew Burgess <aburgess@redhat.com>2022-02-21 14:07:45 +0000
committerAndrew Burgess <aburgess@redhat.com>2022-02-25 17:50:22 +0000
commit820ed8af6a757408873d8955a2db03b0989fdaeb (patch)
tree702c8ff17e87f29eba4bd4db307ee026694bdfba /gdb
parente8b4efc3cf3d5d2c475b3e5c31439aa5bcd277ae (diff)
downloadbinutils-820ed8af6a757408873d8955a2db03b0989fdaeb.zip
binutils-820ed8af6a757408873d8955a2db03b0989fdaeb.tar.gz
binutils-820ed8af6a757408873d8955a2db03b0989fdaeb.tar.bz2
gdb: add operator+= and operator+ overload for std::string
This commit adds operator+= and operator+ overloads for adding gdb::unique_xmalloc_ptr<char> to a std::string. I could only find 3 places in GDB where this was useful right now, and these all make use of operator+=. I've also added a self test for gdb::unique_xmalloc_ptr<char>, which makes use of both operator+= and operator+, so they are both getting used/tested. There should be no user visible changes after this commit, except when running 'maint selftest', where the new self test is visible.
Diffstat (limited to 'gdb')
-rw-r--r--gdb/Makefile.in1
-rw-r--r--gdb/symfile.c6
-rw-r--r--gdb/unittests/unique_xmalloc_ptr_char.c57
3 files changed, 61 insertions, 3 deletions
diff --git a/gdb/Makefile.in b/gdb/Makefile.in
index 70cef6e..6cbbc32 100644
--- a/gdb/Makefile.in
+++ b/gdb/Makefile.in
@@ -478,6 +478,7 @@ SELFTESTS_SRCS = \
unittests/tracepoint-selftests.c \
unittests/tui-selftests.c \
unittests/ui-file-selftests.c \
+ unittests/unique_xmalloc_ptr_char.c \
unittests/unpack-selftests.c \
unittests/utils-selftests.c \
unittests/vec-utils-selftests.c \
diff --git a/gdb/symfile.c b/gdb/symfile.c
index 1a64fc7..0c8d574 100644
--- a/gdb/symfile.c
+++ b/gdb/symfile.c
@@ -1438,7 +1438,7 @@ find_separate_debug_file (const char *dir,
for (const gdb::unique_xmalloc_ptr<char> &debugdir : debugdir_vec)
{
debugfile = target_prefix ? "target:" : "";
- debugfile += debugdir.get ();
+ debugfile += debugdir;
debugfile += "/";
debugfile += drive;
debugfile += dir_notarget;
@@ -1460,7 +1460,7 @@ find_separate_debug_file (const char *dir,
/* If the file is in the sysroot, try using its base path in
the global debugfile directory. */
debugfile = target_prefix ? "target:" : "";
- debugfile += debugdir.get ();
+ debugfile += debugdir;
debugfile += "/";
debugfile += base_path;
debugfile += "/";
@@ -1473,7 +1473,7 @@ find_separate_debug_file (const char *dir,
the sysroot's global debugfile directory. */
debugfile = target_prefix ? "target:" : "";
debugfile += gdb_sysroot;
- debugfile += debugdir.get ();
+ debugfile += debugdir;
debugfile += "/";
debugfile += base_path;
debugfile += "/";
diff --git a/gdb/unittests/unique_xmalloc_ptr_char.c b/gdb/unittests/unique_xmalloc_ptr_char.c
new file mode 100644
index 0000000..3eb1b7b
--- /dev/null
+++ b/gdb/unittests/unique_xmalloc_ptr_char.c
@@ -0,0 +1,57 @@
+/* Self tests for gdb::unique_xmalloc_ptr<char>.
+
+ Copyright (C) 2022 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/>. */
+
+#include "defs.h"
+#include "gdbsupport/selftest.h"
+#include "selftest-arch.h"
+#include "gdbsupport/gdb_unique_ptr.h"
+
+namespace selftests {
+namespace unpack {
+
+static void
+unique_xmalloc_ptr_char ()
+{
+ gdb::unique_xmalloc_ptr<char> a = make_unique_xstrdup ("abc");
+ gdb::unique_xmalloc_ptr<char> b = make_unique_xstrndup ("defghi", 3);
+
+ SELF_CHECK (strcmp (a.get (), "abc") == 0);
+ SELF_CHECK (strcmp (b.get (), "def") == 0);
+
+ std::string str = "xxx";
+
+ /* Check the operator+= overload. */
+ str += a;
+ SELF_CHECK (str == "xxxabc");
+
+ /* Check the operator+ overload. */
+ str = str + b;
+ SELF_CHECK (str == "xxxabcdef");
+}
+
+}
+}
+
+void _initialize_unique_xmalloc_ptr_char ();
+void
+_initialize_unique_xmalloc_ptr_char ()
+{
+ selftests::register_test ("unique_xmalloc_ptr_char",
+ selftests::unpack::unique_xmalloc_ptr_char);
+}