blob: 1a31ddc40c4556b61134c3d7a8834c44a64c0358 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
/* Test for constant expressions: operands and casts not permitted in
integer constant expressions. */
/* Origin: Joseph Myers <joseph@codesourcery.com> */
/* { dg-do compile } */
/* { dg-options "-std=iso9899:1999 -pedantic-errors" } */
/* PR 29116. */
int n = 0, p[n * 0 + 1]; /* { dg-error "variabl" } */
/* PR 31871. */
extern int c[1 + ((__PTRDIFF_TYPE__) (void *) 0)]; /* { dg-error "variab" } */
/* Implicit conversions from floating-point constants are not OK,
although explicit ones are. */
extern int c1[1.0 ? 1 : 0]; /* { dg-error "variab" } */
extern int c2[(int)1.0 ? 1 : 0];
extern int c3[1.0 && 1]; /* { dg-error "variab" } */
extern int c4[(int)1.0 && 1];
extern int c5[1.0 || 1]; /* { dg-error "variab" } */
extern int c6[(int)1.0 || 1];
/* Similar with various other cases where integer constant expressions
are required. */
struct s {
int a : (n * 0 + 1); /* { dg-error "constant" } */
};
enum e {
E = (1 + ((__PTRDIFF_TYPE__) (void *) 0)), /* { dg-error "constant" } */
E2 = 0
};
enum f {
F = (1 ? 1 : n), /* { dg-error "constant" } */
F2 = 0
};
/* Presume that a compound literal, being a reference to an anonymous
variable, is not allowed in an integer constant expression
regardless of what initializers it contains. */
enum g {
G = (1 ? 1 : (int){0}), /* { dg-error "constant" } */
G2 = 0
};
int v[2] = { [(n * 0 + 1)] = 1 }; /* { dg-error "constant|near initialization" } */
void
f (int a)
{
switch (a)
{
case (n * 0 + 1): /* { dg-error "constant" } */
;
}
}
|