This is the mail archive of the gdb-cvs@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[binutils-gdb] gdb: Fix build breakage with GCC 4.1 and --disable-nls


https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=6679754127e51d9c3bd0e387fabbe4e71038c8ce

commit 6679754127e51d9c3bd0e387fabbe4e71038c8ce
Author: Pedro Alves <palves@redhat.com>
Date:   Mon Sep 19 16:55:35 2016 +0100

    gdb: Fix build breakage with GCC 4.1 and --disable-nls
    
    Ref: https://sourceware.org/ml/gdb-patches/2016-09/msg00203.html
    
    The std::{min,max} patch caused build failures when configuring GDB
    with with --disable-nls and using GCC 4.1.
    
    The reason is this bit in common/gdb_locale.h:
    
     #ifdef ENABLE_NLS
     ...
     #else
     # define gettext(Msgid) (Msgid)
     ...
     #endif
    
    This causes problems if the <libintl.h> header is first included at
    any point after "gdb_locale.h".
    
    Specifically, the gettext&co declarations in libintl.h:
    
     extern char *gettext (__const char *__msgid)
          __THROW __attribute_format_arg__ (1);
    
    end up broken after preprocessing:
    
     extern char *(__const char *__msgid)
          throw () __attribute__ ((__format_arg__ (1)));
    
    After the std::min/std::max change to include <algorithm>, this now
    happens with at least the GCC 4.1 copy of <algorithm>, which includes
    <libintl.h> via <bits/stl_algobase.h>, <iosfwd>, and
    <bits/c++locale.h>.
    
    The fix is to simply remove the troublesome *gettext and *textdomain
    macros, leaving only the _ and N_ ones.
    
    gdb/ChangeLog:
    2016-09-19  Pedro Alves  <palves@redhat.com>
    
    	* common/gdb_locale.h [!ENABLE_NLS] (gettext, dgettext, dcgettext,
    	textdomain, bindtextdomain): Delete macros.
    	* main.c (captured_main) [!ENABLE_NLS]: Skip bintextdomain and
    	textdomain calls.

Diff:
---
 gdb/ChangeLog           | 7 +++++++
 gdb/common/gdb_locale.h | 5 -----
 gdb/main.c              | 2 ++
 3 files changed, 9 insertions(+), 5 deletions(-)

diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 8b1f0bc..26b97e6 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,10 @@
+2016-09-19  Pedro Alves  <palves@redhat.com>
+
+	* common/gdb_locale.h [!ENABLE_NLS] (gettext, dgettext, dcgettext,
+	textdomain, bindtextdomain): Delete macros.
+	* main.c (captured_main) [!ENABLE_NLS]: Skip bintextdomain and
+	textdomain calls.
+
 2016-09-19  Sergio Durigan Junior  <sergiodj@redhat.com>
 
 	* darwin-nat.c (darwin_kill_inferior): Adjusting call to
diff --git a/gdb/common/gdb_locale.h b/gdb/common/gdb_locale.h
index 686260e..f9538a7 100644
--- a/gdb/common/gdb_locale.h
+++ b/gdb/common/gdb_locale.h
@@ -32,11 +32,6 @@
 #  define N_(String) (String)
 # endif
 #else
-# define gettext(Msgid) (Msgid)
-# define dgettext(Domainname, Msgid) (Msgid)
-# define dcgettext(Domainname, Msgid, Category) (Msgid)
-# define textdomain(Domainname) while (0) /* nothing */
-# define bindtextdomain(Domainname, Dirname) while (0) /* nothing */
 # define _(String) (String)
 # define N_(String) (String)
 #endif
diff --git a/gdb/main.c b/gdb/main.c
index 23d4ca0..2ea9466 100644
--- a/gdb/main.c
+++ b/gdb/main.c
@@ -501,8 +501,10 @@ captured_main (void *data)
 #if defined (HAVE_SETLOCALE)
   setlocale (LC_CTYPE, "");
 #endif
+#ifdef ENABLE_NLS
   bindtextdomain (PACKAGE, LOCALEDIR);
   textdomain (PACKAGE);
+#endif
 
   bfd_init ();
   notice_open_fds ();


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]