diff options
author | Joseph Myers <jsm28@cam.ac.uk> | 2000-12-09 21:26:56 +0000 |
---|---|---|
committer | Joseph Myers <jsm28@gcc.gnu.org> | 2000-12-09 21:26:56 +0000 |
commit | e45046aeda064dac8461f0037eb221cca677c9d0 (patch) | |
tree | 8a5eb4e052f246c02d053a731de53400bfee8a98 | |
parent | d82a33c6bd3f83bb032bef6a23f29cc72b17ceb0 (diff) | |
download | gcc-e45046aeda064dac8461f0037eb221cca677c9d0.zip gcc-e45046aeda064dac8461f0037eb221cca677c9d0.tar.gz gcc-e45046aeda064dac8461f0037eb221cca677c9d0.tar.bz2 |
c-common.c (check_function_format): Don't suggest adding format attributes to functions with no parameter to which...
* c-common.c (check_function_format): Don't suggest adding format
attributes to functions with no parameter to which to add them.
testsuite:
* gcc.dg/format-miss-2.c: New test.
From-SVN: r38163
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/c-common.c | 21 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/format-miss-2.c | 18 |
4 files changed, 46 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e8bc306..ea745cd 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2000-12-09 Joseph S. Myers <jsm28@cam.ac.uk> + + * c-common.c (check_function_format): Don't suggest adding format + attributes to functions with no parameter to which to add them. + 2000-12-09 Nick Clifton <nickc@redhat.com> * config/arm/arm.c (arm_expand_prologue): Mark the generated diff --git a/gcc/c-common.c b/gcc/c-common.c index 2baba02..1e766e6 100644 --- a/gcc/c-common.c +++ b/gcc/c-common.c @@ -2047,8 +2047,25 @@ check_function_format (status, name, assembler_name, params) && info2->format_type == info->format_type) break; if (info2 == NULL) - warning ("function might be possible candidate for `%s' format attribute", - format_types[info->format_type].name); + { + /* Check if the current function has a parameter to which + the format attribute could be attached; if not, it + can't be a candidate for a format attribute, despite + the vprintf-like or vscanf-like call. */ + tree args; + for (args = DECL_ARGUMENTS (current_function_decl); + args != 0; + args = TREE_CHAIN (args)) + { + if (TREE_CODE (TREE_TYPE (args)) == POINTER_TYPE + && (TYPE_MAIN_VARIANT (TREE_TYPE (TREE_TYPE (args))) + == char_type_node)) + break; + } + if (args != 0) + warning ("function might be possible candidate for `%s' format attribute", + format_types[info->format_type].name); + } } break; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5282938..de2e47a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2000-12-09 Joseph S. Myers <jsm28@cam.ac.uk> + + * gcc.dg/format-miss-2.c: New test. + 2000-12-09 Neil Booth <neilb@earthling.net> * gcc.dg/cpp/lineflags.c: New tests. diff --git a/gcc/testsuite/gcc.dg/format-miss-2.c b/gcc/testsuite/gcc.dg/format-miss-2.c new file mode 100644 index 0000000..b7c5501 --- /dev/null +++ b/gcc/testsuite/gcc.dg/format-miss-2.c @@ -0,0 +1,18 @@ +/* Test for warnings for missing format attributes. Don't warn if no + relevant parameters for a format attribute; see c/1017. */ +/* Origin: Joseph Myers <jsm28@cam.ac.uk> */ +/* { dg-do compile } */ +/* { dg-options "-std=gnu99 -Wformat -Wmissing-format-attribute" } */ + +#include <stdarg.h> + +extern int vprintf (const char *restrict, va_list); + +void +foo (int i, ...) +{ + va_list ap; + va_start (ap, i); + vprintf ("Foo %s bar %s", ap); /* { dg-bogus "candidate" "bogus printf attribute warning" } */ + va_end (ap); +} |