From: David Malcolm Date: Mon, 23 Oct 2017 20:25:58 +0000 (+0000) Subject: Add INCLUDE_UNIQUE_PTR and use it (PR bootstrap/82610) X-Git-Tag: upstream/12.2.0~36115 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b367de5dc31371f88b59e165aa6b8be4ed9ee070;p=platform%2Fupstream%2Fgcc.git Add INCLUDE_UNIQUE_PTR and use it (PR bootstrap/82610) gcc/ChangeLog: PR bootstrap/82610 * system.h: Conditionally include "unique-ptr.h" if INCLUDE_UNIQUE_PTR is defined. * unique-ptr-tests.cc: Remove include of "unique-ptr.h" in favor of defining INCLUDE_UNIQUE_PTR before including "system.h". include/ChangeLog: * unique-ptr.h: Make include of conditional on C++11 or later. From-SVN: r254024 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index bed397c..8aa652d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2017-10-23 David Malcolm + + PR bootstrap/82610 + * system.h: Conditionally include "unique-ptr.h" if + INCLUDE_UNIQUE_PTR is defined. + * unique-ptr-tests.cc: Remove include of "unique-ptr.h" in favor + of defining INCLUDE_UNIQUE_PTR before including "system.h". + 2017-10-23 Sebastian Perta * config/rl78/rl78.md: New define_expand "subdi3". diff --git a/gcc/system.h b/gcc/system.h index 01bc134..cd46454 100644 --- a/gcc/system.h +++ b/gcc/system.h @@ -720,6 +720,16 @@ extern int vsnprintf (char *, size_t, const char *, va_list); #define __builtin_expect(a, b) (a) #endif +/* Some of the headers included by can use "abort" within a + namespace, e.g. "_VSTD::abort();", which fails after we use the + preprocessor to redefine "abort" as "fancy_abort" below. + Given that unique-ptr.h can use "free", we need to do this after "free" + is declared but before "abort" is overridden. */ + +#ifdef INCLUDE_UNIQUE_PTR +# include "unique-ptr.h" +#endif + /* Redefine abort to report an internal error w/o coredump, and reporting the location of the error in the source file. */ extern void fancy_abort (const char *, int, const char *) diff --git a/gcc/unique-ptr-tests.cc b/gcc/unique-ptr-tests.cc index f5b72a8..d275694 100644 --- a/gcc/unique-ptr-tests.cc +++ b/gcc/unique-ptr-tests.cc @@ -18,9 +18,9 @@ along with GCC; see the file COPYING3. If not see . */ #include "config.h" +#define INCLUDE_UNIQUE_PTR #include "system.h" #include "coretypes.h" -#include "unique-ptr.h" #include "selftest.h" #if CHECKING_P diff --git a/include/ChangeLog b/include/ChangeLog index 805e81c..8ccc57a 100644 --- a/include/ChangeLog +++ b/include/ChangeLog @@ -1,3 +1,8 @@ +2017-10-23 David Malcolm + + * unique-ptr.h: Make include of conditional on C++11 or + later. + 2017-10-16 Trevor Saunders David Malcolm diff --git a/include/unique-ptr.h b/include/unique-ptr.h index c5ca031..0b6f11a 100644 --- a/include/unique-ptr.h +++ b/include/unique-ptr.h @@ -74,7 +74,9 @@ #ifndef GNU_UNIQUE_PTR_H #define GNU_UNIQUE_PTR_H 1 -#include +#if __cplusplus >= 201103 +# include +#endif namespace gnu {