summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDJ Delorie <dj@delorie.com>2001-04-04 01:16:27 +0000
committerDJ Delorie <dj@delorie.com>2001-04-04 01:16:27 +0000
commitda534bef4f47238e3e3a00b54bb97718cdf302aa (patch)
treef6026e4549263e2c97d74cd88369017ea0cb2402
parent0d409dbffa686dc9fb5bc54d3ecbdb805178a9b2 (diff)
downloadgdb-da534bef4f47238e3e3a00b54bb97718cdf302aa.tar.gz
merge from gcc
-rw-r--r--include/ChangeLog4
-rw-r--r--include/ansidecl.h28
-rw-r--r--libiberty/ChangeLog4
-rw-r--r--libiberty/make-temp-file.c4
4 files changed, 38 insertions, 2 deletions
diff --git a/include/ChangeLog b/include/ChangeLog
index 550af2e9f98..3a37d1ac093 100644
--- a/include/ChangeLog
+++ b/include/ChangeLog
@@ -1,3 +1,7 @@
+2001-04-03 Zack Weinberg <zackw@stanford.edu>
+
+ * ansidecl.h: All logic from gcc/gansidecl.h moved here.
+
2001-03-31 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
* libiberty.h (alloca): Handle setting C_ALLOCA.
diff --git a/include/ansidecl.h b/include/ansidecl.h
index 545a62103a9..88187be6786 100644
--- a/include/ansidecl.h
+++ b/include/ansidecl.h
@@ -161,6 +161,15 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
#endif /* ANSI C. */
+/* This is for GCC, which has historically used typed null pointer
+ constants. It needs to be here so it is seen by headers included
+ by gcc's config.h.
+
+ FIXME: GCC probably doesn't need to use typed nulls anymore.
+ Clean it up, then remove this. Ware variable-argument functions. */
+#ifdef IN_GCC
+# define NULL_PTR ((PTR) 0)
+#endif
/* Using MACRO(x,y) in cpp #if conditionals does not work with some
older preprocessors. Thus we can't define something like this:
@@ -230,4 +239,23 @@ So instead we use the macro below and test it against specific values. */
#define __extension__
#endif
+/* Bootstrap support: Autoconf will possibly define the `inline' or
+ `const' keywords as macros, however this is only valid for the
+ stage1 compiler. If we detect a modern version of gcc,
+ unconditionally reset the values. This makes sure the right thing
+ happens in stage2 and later. We need to do this very early;
+ i.e. before any header files that might use these keywords.
+ Otherwise conflicts might occur. */
+
+#if (GCC_VERSION >= 2007)
+# ifdef __STDC__
+# undef const
+# endif
+# undef inline
+# define inline __inline__ /* __inline__ prevents -pedantic warnings */
+# ifndef HAVE_LONG_DOUBLE
+# define HAVE_LONG_DOUBLE 1
+# endif
+#endif /* GCC >= 2.7 */
+
#endif /* ansidecl.h */
diff --git a/libiberty/ChangeLog b/libiberty/ChangeLog
index a2b39ae80a1..79bef792c20 100644
--- a/libiberty/ChangeLog
+++ b/libiberty/ChangeLog
@@ -1,3 +1,7 @@
+2001-04-03 Zack Weinberg <zackw@stanford.edu>
+
+ * make-temp-file.c (try): Inline.
+
2001-02-28 Richard Henderson <rth@redhat.com>
* Makefile.in (make-temp-file.o): Depend on config.h.
diff --git a/libiberty/make-temp-file.c b/libiberty/make-temp-file.c
index 67efed16a58..f3e1d10e9a7 100644
--- a/libiberty/make-temp-file.c
+++ b/libiberty/make-temp-file.c
@@ -61,9 +61,9 @@ extern int mkstemps PARAMS ((char *, int));
If success, DIR is returned.
Otherwise NULL is returned. */
-static const char *try PARAMS ((const char *, const char *));
+static inline const char *try PARAMS ((const char *, const char *));
-static const char *
+static inline const char *
try (dir, base)
const char *dir, *base;
{