1 /* Test for various situations where a new declaration of an
2    identifier conflicts with an earlier declaration which isn't in the
3    same scope.  These are all undefined behavior per C89 sections
4    6.1.2.2p7, 6.1.2.6p2, and 6.3.2.2p2/footnote 38 (C99 6.2.2p7 and
5    6.2.7p2 - implicit declarations are invalid in C99).  */
6 
7 /* { dg-do compile } */
8 /* { dg-options "-std=c89 -pedantic -Wall -Wno-unused" } */
9 
10 /* Extern at function scope, clashing with extern at file scope */
11 
12 extern int foo1;		/* { dg-message "note: previous" } */
13 extern int bar1(int);		/* { dg-message "note: previous" } */
14 
test1(void)15 void test1(void)
16 {
17   extern double foo1;		/* { dg-error "conflict" } */
18   extern double bar1(double);	/* { dg-error "conflict" } */
19 }
20 
21 /* Extern at file scope, clashing with extern at function scope */
22 
test2(void)23 void test2(void)
24 {
25   extern double foo2;		/* { dg-message "note: previous" } */
26   extern double bar2(double);	/* { dg-message "note: previous" } */
27 }
28 
29 extern int foo2;		/* { dg-error "conflict" } */
30 extern int bar2(int);		/* { dg-error "conflict" } */
31 
32 /* Extern at function scope, clashing with extern at earlier function
33    scope.  Also, don't be fooled by a typedef at file scope.  */
34 
35 typedef float baz3;		/* { dg-bogus } */
36 
prime3(void)37 void prime3(void)
38 {
39   extern int foo3;		/* { dg-message "note: previous" } */
40   extern int bar3(int);		/* { dg-message "note: previous" } */
41   extern int baz3;		/* { dg-message "note: previous" } */
42 }
43 
test3(void)44 void test3(void)
45 {
46   extern double foo3;		/* { dg-error "conflict" } */
47   extern double bar3(double);	/* { dg-error "conflict" } */
48   extern double baz3;		/* { dg-error "conflict" } */
49 }
50 
51 /* Extern at function scope, clashing with previous implicit decl.  */
52 
prime4(void)53 void prime4(void)
54 {
55   bar4(); /* { dg-line implicit_bar4 } */
56   /* { dg-warning "implicit declaration of function" "implicit" { target *-*-* } implicit_bar4 } */
57 }
58 
test4(void)59 void test4(void)
60 {
61   extern double bar4(double);	/* { dg-error "conflict" } */
62 /* { dg-message "note: previous implicit declaration" "previous" { target *-*-* } implicit_bar4 } */
63 }
64 
65 /* Implicit decl, clashing with extern at previous function scope.  */
66 
prime5(void)67 void prime5(void)
68 {
69   extern double bar5(double);	/* { dg-message "note: previous declaration" "previous 1" } */
70 } /* { dg-message "note: previous implicit declaration" "previous 2" { target *-*-* } .-1 } */
71 
test5(void)72 void test5(void)
73 {
74   bar5(1);			/* { dg-warning "implicit declaration of function" } */
75 } /* { dg-error "incompatible implicit declaration" "" { target *-*-* } .-1 } */
76 
77 /* Extern then static, both at file scope.  */
78 
79 extern int test6(int);		/* { dg-message "note: previous" } */
test6(int x)80 static int test6(int x)		/* { dg-error "follows non-static" } */
81 { return x; }
82 
83 
84 /* Extern then static, extern at previous function scope.  */
85 
prime7(void)86 void prime7(void)
87 {
88   extern int test7(int);	/* { dg-message "note: previous" } */
89 }
90 
test7(int x)91 static int test7(int x)		/* { dg-error "follows non-static" } */
92 { return x; }
93 
94 /* Implicit decl then static.  */
95 
prime8(void)96 void prime8(void)
97 {
98   test8();			/* { dg-message "note: previous" } */
99                                 /* { dg-warning "implicit" "implicit" { target *-*-* } .-1 } */
100 }
101 
test8(int x)102 static int test8(int x)		/* { dg-error "follows non-static" } */
103 { return x; }
104