1*67e74705SXin Li // RUN: %clang_cc1 -fsyntax-only -std=c++03 -verify -ast-dump %s > %t-03
2*67e74705SXin Li // RUN: FileCheck --input-file=%t-03 %s
3*67e74705SXin Li // RUN: %clang_cc1 -fsyntax-only -std=c++11 -verify -ast-dump %s > %t-11
4*67e74705SXin Li // RUN: FileCheck --input-file=%t-11 %s
5*67e74705SXin Li // RUN: FileCheck --input-file=%t-11 %s --check-prefix=CHECK-CXX11
6*67e74705SXin Li
7*67e74705SXin Li // http://llvm.org/PR7905
8*67e74705SXin Li namespace PR7905 {
9*67e74705SXin Li struct S; // expected-note {{forward declaration}}
foo1()10*67e74705SXin Li void foo1() {
11*67e74705SXin Li (void)(S[]) {{3}}; // expected-error {{array has incomplete element type}}
12*67e74705SXin Li }
13*67e74705SXin Li
14*67e74705SXin Li template <typename T> struct M { T m; };
foo2()15*67e74705SXin Li void foo2() {
16*67e74705SXin Li (void)(M<short> []) {{3}};
17*67e74705SXin Li }
18*67e74705SXin Li }
19*67e74705SXin Li
20*67e74705SXin Li // Check compound literals mixed with C++11 list-initialization.
21*67e74705SXin Li namespace brace_initializers {
22*67e74705SXin Li struct POD {
23*67e74705SXin Li int x, y;
24*67e74705SXin Li };
25*67e74705SXin Li struct HasCtor {
26*67e74705SXin Li HasCtor(int x, int y);
27*67e74705SXin Li };
28*67e74705SXin Li struct HasDtor {
29*67e74705SXin Li int x, y;
30*67e74705SXin Li ~HasDtor();
31*67e74705SXin Li };
32*67e74705SXin Li struct HasCtorDtor {
33*67e74705SXin Li HasCtorDtor(int x, int y);
34*67e74705SXin Li ~HasCtorDtor();
35*67e74705SXin Li };
36*67e74705SXin Li
test()37*67e74705SXin Li void test() {
38*67e74705SXin Li (void)(POD){1, 2};
39*67e74705SXin Li // CHECK-NOT: CXXBindTemporaryExpr {{.*}} 'struct brace_initializers::POD'
40*67e74705SXin Li // CHECK: CompoundLiteralExpr {{.*}} 'struct brace_initializers::POD'
41*67e74705SXin Li // CHECK-NEXT: InitListExpr {{.*}} 'struct brace_initializers::POD'
42*67e74705SXin Li // CHECK-NEXT: IntegerLiteral {{.*}} 1{{$}}
43*67e74705SXin Li // CHECK-NEXT: IntegerLiteral {{.*}} 2{{$}}
44*67e74705SXin Li
45*67e74705SXin Li (void)(HasDtor){1, 2};
46*67e74705SXin Li // CHECK: CXXBindTemporaryExpr {{.*}} 'struct brace_initializers::HasDtor'
47*67e74705SXin Li // CHECK-NEXT: CompoundLiteralExpr {{.*}} 'struct brace_initializers::HasDtor'
48*67e74705SXin Li // CHECK-NEXT: InitListExpr {{.*}} 'struct brace_initializers::HasDtor'
49*67e74705SXin Li // CHECK-NEXT: IntegerLiteral {{.*}} 1{{$}}
50*67e74705SXin Li // CHECK-NEXT: IntegerLiteral {{.*}} 2{{$}}
51*67e74705SXin Li
52*67e74705SXin Li #if __cplusplus >= 201103L
53*67e74705SXin Li (void)(HasCtor){1, 2};
54*67e74705SXin Li // CHECK-CXX11-NOT: CXXBindTemporaryExpr {{.*}} 'struct brace_initializers::HasCtor'
55*67e74705SXin Li // CHECK-CXX11: CompoundLiteralExpr {{.*}} 'struct brace_initializers::HasCtor'
56*67e74705SXin Li // CHECK-CXX11-NEXT: CXXTemporaryObjectExpr {{.*}} 'struct brace_initializers::HasCtor'
57*67e74705SXin Li // CHECK-CXX11-NEXT: IntegerLiteral {{.*}} 1{{$}}
58*67e74705SXin Li // CHECK-CXX11-NEXT: IntegerLiteral {{.*}} 2{{$}}
59*67e74705SXin Li
60*67e74705SXin Li (void)(HasCtorDtor){1, 2};
61*67e74705SXin Li // CHECK-CXX11: CXXBindTemporaryExpr {{.*}} 'struct brace_initializers::HasCtorDtor'
62*67e74705SXin Li // CHECK-CXX11-NEXT: CompoundLiteralExpr {{.*}} 'struct brace_initializers::HasCtorDtor'
63*67e74705SXin Li // CHECK-CXX11-NEXT: CXXTemporaryObjectExpr {{.*}} 'struct brace_initializers::HasCtorDtor'
64*67e74705SXin Li // CHECK-CXX11-NEXT: IntegerLiteral {{.*}} 1{{$}}
65*67e74705SXin Li // CHECK-CXX11-NEXT: IntegerLiteral {{.*}} 2{{$}}
66*67e74705SXin Li #endif
67*67e74705SXin Li }
68*67e74705SXin Li
69*67e74705SXin Li struct PrivateDtor {
70*67e74705SXin Li int x, y;
71*67e74705SXin Li private:
72*67e74705SXin Li ~PrivateDtor(); // expected-note {{declared private here}}
73*67e74705SXin Li };
74*67e74705SXin Li
testPrivateDtor()75*67e74705SXin Li void testPrivateDtor() {
76*67e74705SXin Li (void)(PrivateDtor){1, 2}; // expected-error {{temporary of type 'brace_initializers::PrivateDtor' has private destructor}}
77*67e74705SXin Li }
78*67e74705SXin Li }
79*67e74705SXin Li
80*67e74705SXin Li // This doesn't necessarily need to be an error, but CodeGen can't handle it
81*67e74705SXin Li // at the moment.
82*67e74705SXin Li int PR17415 = (int){PR17415}; // expected-error {{initializer element is not a compile-time constant}}
83*67e74705SXin Li
84*67e74705SXin Li // Make sure we accept this. (Not sure if we actually should... but we do
85*67e74705SXin Li // at the moment.)
86*67e74705SXin Li template<unsigned> struct Value { };
87*67e74705SXin Li template<typename T>
88*67e74705SXin Li int &check_narrowed(Value<sizeof((T){1.1})>);
89