From: Simon Marchi Date: Tue, 8 May 2018 20:45:02 +0000 (-0400) Subject: Define GNULIB_NAMESPACE in unittests/string_view-selftests.c X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7402fbcae1c282e27aafd5c5c90aca7eabbdf45c;p=binutils-gdb.git Define GNULIB_NAMESPACE in unittests/string_view-selftests.c When building with x86_64-w64-mingw32-g++ (to test cross-compiling for Windows), I get this error: unittests/string_view-selftests.o: In function `selftests::string_view::inserters_2::test05(unsigned long long)': /home/emaisin/src/binutils-gdb/gdb/unittests/basic_string_view/inserters/char/2.cc:60: undefined reference to `std::basic_ofstream >::rpl_close()' This is caused by gnulib redefining "close" as "rpl_close", and therefore messing up the declaration of basic_ofstream in the libstdc++ header. The solution would be to use gnulib namespaces [1]. Until we use them across GDB, we can use them locally in files that are problematic, like this one. gdb/ChangeLog: * unittests/string_view-selftests.c: Define GNULIB_NAMESPACE. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 8314945f1c7..a1059aef8d7 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,7 @@ +2018-05-08 Simon Marchi + + * unittests/string_view-selftests.c: Define GNULIB_NAMESPACE. + 2018-05-08 Andrew Burgess * common/x86-xstate.h (I387_FCTRL_INIT_VAL): New constant. diff --git a/gdb/unittests/string_view-selftests.c b/gdb/unittests/string_view-selftests.c index 182a5df9e4d..55ffe640bf6 100644 --- a/gdb/unittests/string_view-selftests.c +++ b/gdb/unittests/string_view-selftests.c @@ -21,6 +21,8 @@ the "real" version. */ #if __cplusplus < 201703L +#define GNULIB_NAMESPACE gnulib + #include "defs.h" #include "selftest.h" #include "common/gdb_string_view.h"