diff options
author | Hans Wennborg <hans@hanshq.net> | 2012-03-09 10:10:54 +0000 |
---|---|---|
committer | Hans Wennborg <hans@hanshq.net> | 2012-03-09 10:10:54 +0000 |
commit | aa8c61cf94b75946087799fad85e23ac38e8b18f (patch) | |
tree | 8f84e59a50c07d899bc45ad363f1764565f898c2 /clang/test/Sema | |
parent | 29e9595bd783b032c96f60a8602bb2b7d136e735 (diff) | |
download | bcm5719-llvm-aa8c61cf94b75946087799fad85e23ac38e8b18f.tar.gz bcm5719-llvm-aa8c61cf94b75946087799fad85e23ac38e8b18f.zip |
-Wformat-non-iso: warn about positional arguments (pr12017)
This renames the -Wformat-non-standard flag to -Wformat-non-iso,
rewords the current warnings a bit (pointing out that a format string
is not supported by ISO C rather than being "non standard"),
and adds a warning about positional arguments.
llvm-svn: 152403
Diffstat (limited to 'clang/test/Sema')
-rw-r--r-- | clang/test/Sema/format-strings-c90.c | 12 | ||||
-rw-r--r-- | clang/test/Sema/format-strings-fixit.c | 6 | ||||
-rw-r--r-- | clang/test/Sema/format-strings-non-iso.c | 29 | ||||
-rw-r--r-- | clang/test/Sema/format-strings-non-standard.c | 26 |
4 files changed, 41 insertions, 32 deletions
diff --git a/clang/test/Sema/format-strings-c90.c b/clang/test/Sema/format-strings-c90.c index 63d58532cb8..66ca5073475 100644 --- a/clang/test/Sema/format-strings-c90.c +++ b/clang/test/Sema/format-strings-c90.c @@ -5,8 +5,8 @@ int scanf(const char * restrict, ...); int printf(const char *restrict, ...); void foo(char **sp, float *fp, int *ip) { - scanf("%as", sp); /* expected-warning{{'a' is a non-standard length modifier}} */ - scanf("%a[abc]", sp); /* expected-warning{{'a' is a non-standard length modifier}} */ + scanf("%as", sp); /* expected-warning{{'a' length modifier is not supported by ISO C}} */ + scanf("%a[abc]", sp); /* expected-warning{{'a' length modifier is not supported by ISO C}} */ /* TODO: Warn that the 'a' conversion specifier is a C99 feature. */ scanf("%a", fp); @@ -21,10 +21,10 @@ void foo(char **sp, float *fp, int *ip) { /* Test argument type check for the 'a' length modifier. */ scanf("%as", fp); /* expected-warning{{format specifies type 'char **' but the argument has type 'float *'}} - expected-warning{{'a' is a non-standard length modifier}} */ + expected-warning{{'a' length modifier is not supported by ISO C}} */ scanf("%aS", fp); /* expected-warning{{format specifies type 'wchar_t **' (aka 'int **') but the argument has type 'float *'}} - expected-warning{{'a' is a non-standard length modifier}} - expected-warning{{'S' is a non-standard conversion specifier}} */ + expected-warning{{'a' length modifier is not supported by ISO C}} + expected-warning{{'S' conversion specifier is not supported by ISO C}} */ scanf("%a[abc]", fp); /* expected-warning{{format specifies type 'char **' but the argument has type 'float *'}} - expected-warning{{'a' is a non-standard length modifier}} */ + expected-warning{{'a' length modifier is not supported by ISO C}} */ } diff --git a/clang/test/Sema/format-strings-fixit.c b/clang/test/Sema/format-strings-fixit.c index 80b1be05787..800691ecc8c 100644 --- a/clang/test/Sema/format-strings-fixit.c +++ b/clang/test/Sema/format-strings-fixit.c @@ -35,7 +35,10 @@ void test() { printf("%0-f", 1.23); // - flag should stay // Positional arguments +#pragma clang diagnostic push // Don't warn about using positional arguments. +#pragma clang diagnostic ignored "-Wformat-non-iso" printf("%1$f:%2$.*3$f:%4$.*3$f\n", 1, 2, 3, 4); +#pragma clang diagnostic pop // Precision printf("%10.5d", 1l); // (bug 7394) @@ -46,7 +49,10 @@ void test() { // Bad length modifiers printf("%hhs", "foo"); +#pragma clang diagnostic push // Don't warn about using positional arguments. +#pragma clang diagnostic ignored "-Wformat-non-iso" printf("%1$zp", (void *)0); +#pragma clang diagnostic pop // Preserve the original formatting for unsigned integers. unsigned long val = 42; diff --git a/clang/test/Sema/format-strings-non-iso.c b/clang/test/Sema/format-strings-non-iso.c new file mode 100644 index 00000000000..ed8095f10a4 --- /dev/null +++ b/clang/test/Sema/format-strings-non-iso.c @@ -0,0 +1,29 @@ +// RUN: %clang_cc1 -fsyntax-only -verify -std=c99 -pedantic %s + +int printf(const char *restrict, ...); +int scanf(const char * restrict, ...); + +void f(void) { + char *cp; + + // The 'q' length modifier. + printf("%qd", (long long)42); // expected-warning{{'q' length modifier is not supported by ISO C}} + scanf("%qd", (long long *)0); // expected-warning{{'q' length modifier is not supported by ISO C}} + + // The 'm' length modifier. + scanf("%ms", &cp); // expected-warning{{'m' length modifier is not supported by ISO C}} + + // The 'S' and 'C' conversion specifiers. + printf("%S", L"foo"); // expected-warning{{'S' conversion specifier is not supported by ISO C}} + printf("%C", L'x'); // expected-warning{{'C' conversion specifier is not supported by ISO C}} + + // Combining 'L' with an integer conversion specifier. + printf("%Li", (long long)42); // expected-warning{{using length modifier 'L' with conversion specifier 'i' is not supported by ISO C}} + printf("%Lo", (long long)42); // expected-warning{{using length modifier 'L' with conversion specifier 'o' is not supported by ISO C}} + printf("%Lu", (long long)42); // expected-warning{{using length modifier 'L' with conversion specifier 'u' is not supported by ISO C}} + printf("%Lx", (long long)42); // expected-warning{{using length modifier 'L' with conversion specifier 'x' is not supported by ISO C}} + printf("%LX", (long long)42); // expected-warning{{using length modifier 'L' with conversion specifier 'X' is not supported by ISO C}} + + // Positional arguments. + printf("%1$d", 42); // expected-warning{{positional arguments are not supported by ISO C}} +} diff --git a/clang/test/Sema/format-strings-non-standard.c b/clang/test/Sema/format-strings-non-standard.c deleted file mode 100644 index a24d43a6e1d..00000000000 --- a/clang/test/Sema/format-strings-non-standard.c +++ /dev/null @@ -1,26 +0,0 @@ -// RUN: %clang_cc1 -fsyntax-only -verify -std=c99 -pedantic %s - -int printf(const char *restrict, ...); -int scanf(const char * restrict, ...); - -void f(void) { - char *cp; - - // The 'q' length modifier. - printf("%qd", (long long)42); // expected-warning{{'q' is a non-standard length modifier}} - scanf("%qd", (long long *)0); // expected-warning{{'q' is a non-standard length modifier}} - - // The 'm' length modifier. - scanf("%ms", &cp); // expected-warning{{'m' is a non-standard length modifier}} - - // The 'S' and 'C' conversion specifiers. - printf("%S", L"foo"); // expected-warning{{'S' is a non-standard conversion specifier}} - printf("%C", L'x'); // expected-warning{{'C' is a non-standard conversion specifier}} - - // Combining 'L' with an integer conversion specifier. - printf("%Li", (long long)42); // expected-warning{{using the length modifier 'L' with the conversion specifier 'i' is non-standard}} - printf("%Lo", (long long)42); // expected-warning{{using the length modifier 'L' with the conversion specifier 'o' is non-standard}} - printf("%Lu", (long long)42); // expected-warning{{using the length modifier 'L' with the conversion specifier 'u' is non-standard}} - printf("%Lx", (long long)42); // expected-warning{{using the length modifier 'L' with the conversion specifier 'x' is non-standard}} - printf("%LX", (long long)42); // expected-warning{{using the length modifier 'L' with the conversion specifier 'X' is non-standard}} -} |