Mercurial > hg > CbC > CbC_gcc
view gcc/testsuite/gcc.dg/format/no-exargs-2.c @ 158:494b0b89df80 default tip
...
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Mon, 25 May 2020 18:13:55 +0900 |
parents | 04ced10e8804 |
children |
line wrap: on
line source
/* Test for warnings for extra format arguments being disabled by -Wno-format-extra-args. Test which warnings still apply with $ operand numbers. */ /* Origin: Joseph Myers <jsm28@cam.ac.uk> */ /* { dg-do compile } */ /* { dg-options "-std=gnu99 -Wformat -Wno-format-extra-args" } */ #include "format.h" void foo (int i, int *ip, va_list va) { printf ("%3$d%1$d", i, i, i); /* { dg-warning "before used" "unused $ operand" } */ printf ("%2$d%1$d", i, i, i); vprintf ("%3$d%1$d", va); /* { dg-warning "before used" "unused $ operand" } */ /* With scanf formats, gaps in the used arguments are allowed only if the arguments are all pointers. In such a case, should only give the lesser warning about unused arguments rather than the more serious one about argument gaps. */ scanf ("%3$d%1$d", ip, ip, ip); /* If there are non-pointer arguments unused at the end, this is also OK. */ scanf ("%3$d%1$d", ip, ip, ip, i); scanf ("%3$d%1$d", ip, i, ip); /* { dg-warning "before used" "unused $ scanf non-pointer operand" } */ /* Can't check the arguments in the vscanf case, so should suppose the lesser problem. */ vscanf ("%3$d%1$d", va); }