diff options
author | Joseph Myers <joseph@codesourcery.com> | 2005-07-30 02:34:58 +0100 |
---|---|---|
committer | Joseph Myers <jsm28@gcc.gnu.org> | 2005-07-30 02:34:58 +0100 |
commit | 91d975b88eee06af82847fdb48c58e230506c72c (patch) | |
tree | 5b5a77889165a1437cae84a1933af1e14db1f0fd /gcc/testsuite | |
parent | 94ad79eaf5616f25f3edb2d2212742359603ce67 (diff) | |
download | gcc-91d975b88eee06af82847fdb48c58e230506c72c.tar.gz |
re PR c/23143 (parameter forward declarations broken)
PR c/23143
* c-parser.c (c_parser_parms_list_declarator): Call
mark_forward_parm_decls.
* c-decl.c (merge_decls): Only check DECL_IN_SYSTEM_HEADER for
decls with visibility structure.
testsuite:
* gcc.dg/parm-forwdecl-1.c, gcc.dg/parm-forwdecl-2.c,
gcc.dg/parm-forwdecl-3.c, gcc.dg/parm-forwdecl-4.c: New tests.
From-SVN: r102581
Diffstat (limited to 'gcc/testsuite')
-rw-r--r-- | gcc/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/parm-forwdecl-1.c | 26 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/parm-forwdecl-2.c | 8 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/parm-forwdecl-3.c | 8 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/parm-forwdecl-4.c | 10 |
5 files changed, 58 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 6e1004c67ef..27b1a3ce920 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2005-07-30 Joseph S. Myers <joseph@codesourcery.com> + + PR c/23143 + * gcc.dg/parm-forwdecl-1.c, gcc.dg/parm-forwdecl-2.c, + gcc.dg/parm-forwdecl-3.c, gcc.dg/parm-forwdecl-4.c: New tests. + 2005-07-29 Joseph S. Myers <joseph@codesourcery.com> PR c/529 diff --git a/gcc/testsuite/gcc.dg/parm-forwdecl-1.c b/gcc/testsuite/gcc.dg/parm-forwdecl-1.c new file mode 100644 index 00000000000..470636de95c --- /dev/null +++ b/gcc/testsuite/gcc.dg/parm-forwdecl-1.c @@ -0,0 +1,26 @@ +/* Test GNU parameter forward declarations. */ +/* Origin: Joseph Myers <joseph@codesourcery.com> */ +/* { dg-do compile } */ +/* { dg-options "" } */ + +/* Valid uses. */ +int f1(int a; int a); +int f2(int a; int a) { return 0; } +int f3(int a; int a; int a); +int f4(int a; int a; int a) { return 0; } +int f5(int a; int (*x)[a], int a); +int f6(int a; int (*x)[a], int a) { return 0; } +int f7(int a; int (*x)[a]; int (*y)[x[1][2]], int (*x)[a], int a); +int f8(int a; int (*x)[a]; int (*y)[x[1][2]], int (*x)[a], int a) { return 0; } + +/* Strange uses accepted by GCC 4.0 but not by 3.4 and probably not + desirable to accept. */ +int g1(int a;); /* { dg-error "just a forward declaration" "no parms" { xfail *-*-* } } */ +int g2(int a; __attribute__((unused))); /* { dg-error "just a forward declaration" "no parms" { xfail *-*-* } } */ +int g3(int;); /* { dg-error "just a forward declaration" "no parms" { xfail *-*-* } } */ +int g4(int, long;); /* { dg-error "just a forward declaration" "no parms" { xfail *-*-* } } */ + +/* Invalid uses. */ +int h1(int a; int b); /* { dg-error "just a forward declaration" } */ +int h2(int; int b); /* { dg-error "just a forward declaration" } */ +int h3(int a; long a); /* { dg-error "conflicting types|previous definition|just a forward declaration" } */ diff --git a/gcc/testsuite/gcc.dg/parm-forwdecl-2.c b/gcc/testsuite/gcc.dg/parm-forwdecl-2.c new file mode 100644 index 00000000000..cecedf2515c --- /dev/null +++ b/gcc/testsuite/gcc.dg/parm-forwdecl-2.c @@ -0,0 +1,8 @@ +/* Test GNU parameter forward declarations. Warning with + -pedantic. */ +/* Origin: Joseph Myers <joseph@codesourcery.com> */ +/* { dg-do compile } */ +/* { dg-options "-pedantic" } */ + +int f1(int a; int a); /* { dg-warning "warning: ISO C forbids forward parameter declarations" } */ +int f2(int a; int a) { return 0; } /* { dg-warning "warning: ISO C forbids forward parameter declarations" } */ diff --git a/gcc/testsuite/gcc.dg/parm-forwdecl-3.c b/gcc/testsuite/gcc.dg/parm-forwdecl-3.c new file mode 100644 index 00000000000..d99188a0bd4 --- /dev/null +++ b/gcc/testsuite/gcc.dg/parm-forwdecl-3.c @@ -0,0 +1,8 @@ +/* Test GNU parameter forward declarations. Error with + -pedantic-errors. */ +/* Origin: Joseph Myers <joseph@codesourcery.com> */ +/* { dg-do compile } */ +/* { dg-options "-pedantic-errors" } */ + +int f1(int a; int a); /* { dg-error "error: ISO C forbids forward parameter declarations" } */ +int f2(int a; int a) { return 0; } /* { dg-error "error: ISO C forbids forward parameter declarations" } */ diff --git a/gcc/testsuite/gcc.dg/parm-forwdecl-4.c b/gcc/testsuite/gcc.dg/parm-forwdecl-4.c new file mode 100644 index 00000000000..a210092e1d5 --- /dev/null +++ b/gcc/testsuite/gcc.dg/parm-forwdecl-4.c @@ -0,0 +1,10 @@ +/* Test GNU parameter forward declarations. OK with + -Wredundant-decls. */ +/* Origin: Joseph Myers <joseph@codesourcery.com> */ +/* { dg-do compile } */ +/* { dg-options "-Wredundant-decls" } */ + +int f1(int a; int a); +int f2(int a; int a) { return 0; } +int f3(int a; int a; int a); +int f4(int a; int a; int a) { return 0; } |