mirror of git://sourceware.org/git/glibc.git
stdio: Suppress %Z format for clang
clang does not handle %Z on print, and just suppressing -Wformat-invalid-specifier might trigger another warning for extra arguments (since %Z is ignored). So suppress -Wformat-extra-args as well. For tst-fphex.c a heavy hammer is used since the printf is more complex and clang throws a more generic warning. Reviewed-by: Sam James <sam@gentoo.org>
This commit is contained in:
parent
69c181f2b3
commit
77c1128bd3
|
|
@ -1,6 +1,7 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <libc-diag.h>
|
||||||
|
|
||||||
int
|
int
|
||||||
main (void)
|
main (void)
|
||||||
|
|
@ -13,12 +14,22 @@ main (void)
|
||||||
stream = open_memstream (&bp, &size);
|
stream = open_memstream (&bp, &size);
|
||||||
fprintf (stream, "hello");
|
fprintf (stream, "hello");
|
||||||
fflush (stream);
|
fflush (stream);
|
||||||
|
/* clang do not handle %Z format. */
|
||||||
|
DIAG_PUSH_NEEDS_COMMENT_CLANG;
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-invalid-specifier");
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-extra-args");
|
||||||
printf ("buf = %s, size = %Zu\n", bp, size);
|
printf ("buf = %s, size = %Zu\n", bp, size);
|
||||||
|
DIAG_POP_NEEDS_COMMENT_CLANG;
|
||||||
lose |= size != 5;
|
lose |= size != 5;
|
||||||
lose |= strncmp (bp, "hello", size);
|
lose |= strncmp (bp, "hello", size);
|
||||||
fprintf (stream, ", world");
|
fprintf (stream, ", world");
|
||||||
fclose (stream);
|
fclose (stream);
|
||||||
|
/* clang do not handle %Z format. */
|
||||||
|
DIAG_PUSH_NEEDS_COMMENT_CLANG;
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-invalid-specifier");
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-extra-args");
|
||||||
printf ("buf = %s, size = %Zu\n", bp, size);
|
printf ("buf = %s, size = %Zu\n", bp, size);
|
||||||
|
DIAG_POP_NEEDS_COMMENT_CLANG;
|
||||||
lose |= size != 12;
|
lose |= size != 12;
|
||||||
lose |= strncmp (bp, "hello, world", 12);
|
lose |= strncmp (bp, "hello, world", 12);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,7 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <libc-diag.h>
|
||||||
|
|
||||||
#include <support/support.h>
|
#include <support/support.h>
|
||||||
|
|
||||||
|
|
@ -30,7 +31,12 @@ main (void)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
for (i = 0; i < 1000; ++i)
|
for (i = 0; i < 1000; ++i)
|
||||||
|
/* clang do not handle %Z format. */
|
||||||
|
DIAG_PUSH_NEEDS_COMMENT_CLANG;
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-invalid-specifier");
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-extra-args");
|
||||||
fprintf (in, "%Zu\n", i);
|
fprintf (in, "%Zu\n", i);
|
||||||
|
DIAG_POP_NEEDS_COMMENT_CLANG;
|
||||||
|
|
||||||
out = fopen (outname, "w");
|
out = fopen (outname, "w");
|
||||||
if (out == NULL)
|
if (out == NULL)
|
||||||
|
|
|
||||||
|
|
@ -19,6 +19,7 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <libc-diag.h>
|
||||||
|
|
||||||
#include <support/xstdio.h>
|
#include <support/xstdio.h>
|
||||||
|
|
||||||
|
|
@ -54,6 +55,11 @@ main (int argc, char **argv)
|
||||||
rewind (f);
|
rewind (f);
|
||||||
(void) fputs (buf, f);
|
(void) fputs (buf, f);
|
||||||
rewind (f);
|
rewind (f);
|
||||||
|
|
||||||
|
/* clang do not handle %Z format. */
|
||||||
|
DIAG_PUSH_NEEDS_COMMENT_CLANG;
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-invalid-specifier");
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-extra-args");
|
||||||
{
|
{
|
||||||
size_t i;
|
size_t i;
|
||||||
for (i = 0; i < replace_from; ++i)
|
for (i = 0; i < replace_from; ++i)
|
||||||
|
|
@ -101,6 +107,7 @@ main (int argc, char **argv)
|
||||||
lose = 1;
|
lose = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
DIAG_POP_NEEDS_COMMENT_CLANG;
|
||||||
|
|
||||||
if (!lose)
|
if (!lose)
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
#include <array_length.h>
|
#include <array_length.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <libc-diag.h>
|
||||||
|
|
||||||
#ifndef WIDE
|
#ifndef WIDE
|
||||||
# define STR_LEN strlen
|
# define STR_LEN strlen
|
||||||
|
|
@ -56,10 +57,14 @@ do_test (void)
|
||||||
int n = SPRINT (buf, array_length (buf), t->fmt, t->value);
|
int n = SPRINT (buf, array_length (buf), t->fmt, t->value);
|
||||||
if (n != STR_LEN (t->expect) || STR_CMP (buf, t->expect) != 0)
|
if (n != STR_LEN (t->expect) || STR_CMP (buf, t->expect) != 0)
|
||||||
{
|
{
|
||||||
|
/* clang do not handle %Z format. */
|
||||||
|
DIAG_PUSH_NEEDS_COMMENT_CLANG;
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat");
|
||||||
PRINT (L_("" S "\tExpected \"" S "\" (%Zu)\n\tGot \""
|
PRINT (L_("" S "\tExpected \"" S "\" (%Zu)\n\tGot \""
|
||||||
S "\" (%d, %Zu)\n"),
|
S "\" (%d, %Zu)\n"),
|
||||||
t->fmt, t->expect, STR_LEN (t->expect),
|
t->fmt, t->expect, STR_LEN (t->expect),
|
||||||
buf, n, STR_LEN (buf));
|
buf, n, STR_LEN (buf));
|
||||||
|
DIAG_POP_NEEDS_COMMENT_CLANG;
|
||||||
result = 1;
|
result = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -16,6 +16,7 @@
|
||||||
<https://www.gnu.org/licenses/>. */
|
<https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <libc-diag.h>
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char *argv[])
|
main (int argc, char *argv[])
|
||||||
|
|
@ -26,7 +27,12 @@ main (int argc, char *argv[])
|
||||||
|
|
||||||
while ((len = getline (&buf, &size, stdin)) != -1)
|
while ((len = getline (&buf, &size, stdin)) != -1)
|
||||||
{
|
{
|
||||||
|
/* clang do not handle %Z format. */
|
||||||
|
DIAG_PUSH_NEEDS_COMMENT_CLANG;
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-invalid-specifier");
|
||||||
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wformat-extra-args");
|
||||||
printf ("bufsize %Zu; read %Zd: ", size, len);
|
printf ("bufsize %Zu; read %Zd: ", size, len);
|
||||||
|
DIAG_POP_NEEDS_COMMENT_CLANG;
|
||||||
if (fwrite (buf, len, 1, stdout) != 1)
|
if (fwrite (buf, len, 1, stdout) != 1)
|
||||||
{
|
{
|
||||||
perror ("fwrite");
|
perror ("fwrite");
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue