From 554fd8c5195424bdbcabf5de30fdc183aba391bd Mon Sep 17 00:00:00 2001 From: upstream source tree Date: Sun, 15 Mar 2015 20:14:05 -0400 Subject: obtained gcc-4.6.4.tar.bz2 from upstream website; verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository. --- gcc/testsuite/gcc.dg/wtr-aggr-init-1.c | 48 ++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 gcc/testsuite/gcc.dg/wtr-aggr-init-1.c (limited to 'gcc/testsuite/gcc.dg/wtr-aggr-init-1.c') diff --git a/gcc/testsuite/gcc.dg/wtr-aggr-init-1.c b/gcc/testsuite/gcc.dg/wtr-aggr-init-1.c new file mode 100644 index 000000000..f17531e8f --- /dev/null +++ b/gcc/testsuite/gcc.dg/wtr-aggr-init-1.c @@ -0,0 +1,48 @@ +/* Test for -Wtraditional warnings on automatic aggregate initialization. + Note, gcc should omit these warnings in system header files. + By Kaveh R. Ghazi 8/22/2000. */ +/* { dg-do compile } */ +/* { dg-options "-Wtraditional" } */ + +struct foo +{ + int i; + long l; +}; + +struct foo f0 = { 0, 0 }; +static struct foo f1 = { 0, 0 }; + +void +testfunc1 () +{ + struct foo f3 = { 0, 0 }; /* { dg-warning "traditional C rejects automatic" "automatic aggregate initialization" } */ + static struct foo f4 = { 0, 0 }; + + f3 = f4; + + __extension__ ({ + struct foo f5 = { 0, 0 }; /* { dg-bogus "traditional C rejects automatic" "__extension__ disables warnings" } */ + f5.i = 0; + }); + + { + struct foo f6 = { 0, 0 }; /* { dg-warning "traditional C rejects automatic" "__extension__ reenables warnings" } */ + f6.i = 0; + } +} + +# 35 "sys-header.h" 3 +/* We are in system headers now, no -Wtraditional warnings should issue. */ + +struct foo f7 = { 0, 0 }; +static struct foo f8 = { 0, 0 }; + +void +testfunc2 () +{ + struct foo f9 = { 0, 0 }; + static struct foo f10 = { 0, 0 }; + + f9 = f10; +} -- cgit v1.2.3