Commit 7f311f63 by Neil Booth Committed by Neil Booth

* gcc.dg/decl-1.c: Update, new test.

From-SVN: r49804
parent 8d6e459d
2002-02-16 Neil Booth <neil@daikokuya.demon.co.uk>
* gcc.dg/decl-1.c: Update, new test.
2002-02-15 Nathan Sidwell <nathan@codesourcery.com>
* g++.dg/abi/bitfield1.C: New test.
......
......@@ -2,16 +2,28 @@
Source: Neil Booth, 12 Feb 2002.
In the declaration of proc, x must be parsed as a typedef name
(6.7.5.3 p11). */
In the declaration of proc, x must be parsed as a typedef name (C99
6.7.5.3 p11. Also see C89 DR #009, which was erroneously ommitted
from C99, and resubmitted as DR #249: if in a parameter
declaration, an identifier can be read as a typedef name or a
paramter name, it is read as a typedef name). */
/* { dg-do compile } */
typedef int x;
typedef int y;
int proc(int (x)); /* x is a typedef, param to proc is a function. */
int proc2(int x); /* x is an identifier, param is an int. */
/* Parameter to proc3 is unnamed, with type a function that returns
int and takes a single argument of type function with one int
parameter returning int. In particular, proc3 is not a function
that takes a parameter y that is a function with one int parameter
returning int. 8-) */
int proc3(int (y (x)));
int main ()
{
return proc (proc2); /* { dg-bogus "integer from pointer" } */
proc (proc2); /* { dg-bogus "integer from pointer" } */
return proc3 (proc); /* { dg-bogus "incompatible pointer type" } */
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment