Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 9 Jan 2018 22:08:45 +0000 (UTC)
From:      Dimitry Andric <dim@FreeBSD.org>
To:        ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org
Subject:   svn commit: r458581 - in head/lang: gcc48 gcc49 gcc5 gcc5/files
Message-ID:  <201801092208.w09M8jeq029512@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: dim (src committer)
Date: Tue Jan  9 22:08:45 2018
New Revision: 458581
URL: https://svnweb.freebsd.org/changeset/ports/458581

Log:
  Fix builds of lang/gcc{48,49,5} with clang 6.0.0
  
  Since clang++ 6.0.0 now defaults to -std=gnu++14 (similar to g++ 6 and
  higher), building gcc48, gcc49 or gcc5 produce quite a number of
  "invalid suffix on literal; C++11 requires a space between literal and
  identifier" errors.  This is because in many places, double quotes are
  directly followed by printf helper macros like HOST_WIDE_INT_PRINT.
  
  In gcc 6 and later, spaces were added between the double quotes and the
  macros, to fix this issue, but for earlier versions, use a combination
  of find, grep and sed to add them mechanically throughout the respective
  source trees.
  
  In addition, gcc5 needs a regular patch to fix an incorrect call to
  error(), which should have been error_at().  (This was a mismerge by
  upstream.)
  
  Approved by:	gerald (maintainer)
  PR:		224927
  MFH:		2018Q1

Added:
  head/lang/gcc5/files/patch-gcc_toplev.c   (contents, props changed)
Modified:
  head/lang/gcc48/Makefile
  head/lang/gcc49/Makefile
  head/lang/gcc5/Makefile

Modified: head/lang/gcc48/Makefile
==============================================================================
--- head/lang/gcc48/Makefile	Tue Jan  9 22:07:43 2018	(r458580)
+++ head/lang/gcc48/Makefile	Tue Jan  9 22:08:45 2018	(r458581)
@@ -120,6 +120,11 @@ SUB_LIST+=	TARGLIB=${TARGLIB}
 pre-everything::
 	@${ECHO_MSG} "Making GCC ${PORTVERSION} for ${CONFIGURE_TARGET} [${LANGUAGES}]"
 
+post-patch:
+	@${FIND} ${WRKSRC} -type f -name '*.[ch]' | \
+	    ${XARGS} ${EGREP} -l '"(HOST_WIDE|PLUGIN_COND)' | \
+	    ${XARGS} ${REINPLACE_CMD} -E -e 's/"(HOST_WIDE|PLUGIN_COND)/" \1/g'
+
 pre-configure:
 	cd ${WRKSRC} ; contrib/gcc_update --touch
 	@${RM} ${WRKSRC}/gcc/*/*.info*

Modified: head/lang/gcc49/Makefile
==============================================================================
--- head/lang/gcc49/Makefile	Tue Jan  9 22:07:43 2018	(r458580)
+++ head/lang/gcc49/Makefile	Tue Jan  9 22:08:45 2018	(r458581)
@@ -120,6 +120,11 @@ SUB_LIST+=	TARGLIB=${TARGLIB}
 pre-everything::
 	@${ECHO_MSG} "Making GCC ${PORTVERSION} for ${CONFIGURE_TARGET} [${LANGUAGES}]"
 
+post-patch:
+	@${FIND} ${WRKSRC} -type f -name '*.[ch]' | \
+	    ${XARGS} ${EGREP} -l '"(HOST_WIDE|PLUGIN_COND)' | \
+	    ${XARGS} ${REINPLACE_CMD} -E -e 's/"(HOST_WIDE|PLUGIN_COND)/" \1/g'
+
 pre-configure:
 	cd ${WRKSRC} ; contrib/gcc_update --touch
 	@${RM} ${WRKSRC}/gcc/*/*.info*

Modified: head/lang/gcc5/Makefile
==============================================================================
--- head/lang/gcc5/Makefile	Tue Jan  9 22:07:43 2018	(r458580)
+++ head/lang/gcc5/Makefile	Tue Jan  9 22:08:45 2018	(r458581)
@@ -117,6 +117,11 @@ CONFIGURE_ARGS+=--enable-languages=${LANGUAGES}
 pre-everything::
 	@${ECHO_MSG} "Making GCC ${PORTVERSION} for ${CONFIGURE_TARGET} [${LANGUAGES}]"
 
+post-patch:
+	@${FIND} ${WRKSRC} -type f \( -name '*.[ch]' -o -name '*.cc' \) | \
+	    ${XARGS} ${EGREP} -l '"(HOST_WIDE|PLUGIN_COND|PRId64)' | \
+	    ${XARGS} ${REINPLACE_CMD} -E -e 's/"(HOST_WIDE|PLUGIN_COND|PRId64)/" \1/g'
+
 pre-configure:
 	cd ${WRKSRC} ; contrib/gcc_update --touch
 	@${RM} ${WRKSRC}/gcc/*/*.info*

Added: head/lang/gcc5/files/patch-gcc_toplev.c
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/lang/gcc5/files/patch-gcc_toplev.c	Tue Jan  9 22:08:45 2018	(r458581)
@@ -0,0 +1,11 @@
+--- gcc/toplev.c.orig	2018-01-04 15:22:21 UTC
++++ gcc/toplev.c
+@@ -1386,7 +1386,7 @@ process_options (void)
+ 
+       if (flag_sanitize & SANITIZE_THREAD)
+ 	{
+-	  error (UNKNOWN_LOCATION,
++	  error_at (UNKNOWN_LOCATION,
+ 		 "%<-fcheck-pointer-bounds%> is not supported with "
+ 		 "Thread Sanitizer");
+ 



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201801092208.w09M8jeq029512>