From patchwork Mon Jul 25 14:30:14 2011 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: Allow Tru64 UNIX bootstrap with C++ Date: Mon, 25 Jul 2011 04:30:14 -0000 From: Rainer Orth X-Patchwork-Id: 106680 Message-Id: To: Ian Lance Taylor Cc: gcc-patches@gcc.gnu.org Ian Lance Taylor writes: > I'll preapprove a similar patch to libcpp/system.h if you want to take a > look at that. Sure. The following patch has been bootstrapped successfully on i386-pc-solaris2.11, installed on mainline. Rainer 2011-07-22 Rainer Orth * system.h [__cplusplus]: Wrap C function declarations in extern "C". diff --git a/libcpp/system.h b/libcpp/system.h --- a/libcpp/system.h +++ b/libcpp/system.h @@ -84,6 +84,10 @@ along with GCC; see the file COPYING3. # define fputc(C, Stream) fputc_unlocked (C, Stream) # endif +#ifdef __cplusplus +extern "C" { +#endif + # ifdef HAVE_CLEARERR_UNLOCKED # undef clearerr # define clearerr(Stream) clearerr_unlocked (Stream) @@ -164,6 +168,10 @@ extern int fprintf_unlocked (FILE *, con # endif # endif +#ifdef __cplusplus +} +#endif + #endif /* ??? Glibc's fwrite/fread_unlocked macros cause @@ -286,10 +294,18 @@ extern int errno; here. These checks will be in the undefined state while configure is running so be careful to test "defined (HAVE_DECL_*)". */ +#ifdef __cplusplus +extern "C" { +#endif + #if defined (HAVE_DECL_ABORT) && !HAVE_DECL_ABORT extern void abort (void); #endif +#ifdef __cplusplus +} +#endif + #if HAVE_SYS_STAT_H # include #endif