]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Fix string/bug-strncat1.c build with GCC 8.
authorJoseph Myers <joseph@codesourcery.com>
Tue, 14 Nov 2017 17:50:36 +0000 (17:50 +0000)
committerJoseph Myers <joseph@codesourcery.com>
Tue, 14 Nov 2017 17:50:36 +0000 (17:50 +0000)
GCC 8 warns about strncat calls with truncated output.
string/bug-strncat1.c tests such a call; this patch disables the
warning for it.

Tested (compilation) with GCC 8 for x86_64-linux-gnu with
build-many-glibcs.py (in conjunction with Martin's patch to allow
glibc to build).

* string/bug-strncat1.c: Include <libc-diag.h>.
(main): Disable -Wstringop-truncation for strncat call for GCC 8.

ChangeLog
string/bug-strncat1.c

index bc5ff140819494d63976b25cb75a6f4ed16e35c6..579185d23e821bab4364ac41086ac6203e12a4ec 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2017-11-14  Joseph Myers  <joseph@codesourcery.com>
+
+       * string/bug-strncat1.c: Include <libc-diag.h>.
+       (main): Disable -Wstringop-truncation for strncat call for GCC 8.
+
 2017-11-13  Claude Paroz <claude@2xlibre.net>
 
        [BZ #22387]
index f1b5c37c5cd14b96fbb9672486700de22e0a7720..b22beba4d3d672b88ae6ae8c84b96f8de86d5454 100644 (file)
@@ -4,13 +4,21 @@
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
+#include <libc-diag.h>
 
 char d[3] = "\0\1\2";
 
 int
 main (void)
 {
+  DIAG_PUSH_NEEDS_COMMENT;
+#if __GNUC_PREREQ (8, 0)
+  /* GCC 8 warns about strncat truncating output; this is deliberately
+     tested here.  */
+  DIAG_IGNORE_NEEDS_COMMENT (8, "-Wstringop-truncation");
+#endif
   strncat (d, "\5\6", 1);
+  DIAG_POP_NEEDS_COMMENT;
   if (d[0] != '\5')
     {
       puts ("d[0] != '\\5'");