|  | // RUN: %clang_cc1 -fsyntax-only -verify %s | 
|  | // RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s | 
|  | // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s | 
|  |  | 
|  | struct X1 { // has no implicit default constructor | 
|  | X1(int); | 
|  | }; | 
|  |  | 
|  | struct X2  : X1 { | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-note@-2 2 {{'X2' declared here}} | 
|  | #endif | 
|  |  | 
|  | X2(int); | 
|  | }; | 
|  |  | 
|  | struct X3 : public X2 { | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-error@-2 {{implicit default constructor for 'X3' must explicitly initialize the base class 'X2' which does not have a default constructor}} | 
|  | #else | 
|  | // expected-note@-4 {{default constructor of 'X3' is implicitly deleted because base class 'X2' has no default constructor}} | 
|  | #endif | 
|  | }; | 
|  |  | 
|  | X3 x3; | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-note@-2 {{first required here}} | 
|  | #else | 
|  | // expected-error@-4 {{call to implicitly-deleted default constructor of 'X3'}} | 
|  | #endif | 
|  |  | 
|  | struct X4 { | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-error@-2 {{must explicitly initialize the member 'x2'}} | 
|  | // expected-error@-3 {{must explicitly initialize the reference member 'rx2'}} | 
|  | #endif | 
|  |  | 
|  | X2 x2; | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-note@-2 {{member is declared here}} | 
|  | #else | 
|  | // expected-note@-4 {{default constructor of 'X4' is implicitly deleted because field 'x2' has no default constructor}} | 
|  | #endif | 
|  |  | 
|  | X2 & rx2; | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-note@-2 {{declared here}} | 
|  | #endif | 
|  | }; | 
|  |  | 
|  | X4 x4; | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-note@-2 {{first required here}} | 
|  | #else | 
|  | // expected-error@-4 {{call to implicitly-deleted default constructor of 'X4'}} | 
|  | #endif | 
|  |  | 
|  | struct Y1 { // has no implicit default constructor | 
|  | Y1(int); | 
|  | }; | 
|  |  | 
|  | struct Y2  : Y1 { | 
|  | Y2(int); | 
|  | Y2(); | 
|  | }; | 
|  |  | 
|  | struct Y3 : public Y2 { | 
|  | }; | 
|  | Y3 y3; | 
|  |  | 
|  | struct Y4 { | 
|  | Y2 y2; | 
|  | }; | 
|  |  | 
|  | Y4 y4; | 
|  |  | 
|  | // More tests | 
|  |  | 
|  | struct Z1 { | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-error@-2 {{must explicitly initialize the reference member 'z'}} | 
|  | // expected-error@-3 {{must explicitly initialize the const member 'c1'}} | 
|  | #endif | 
|  |  | 
|  | int& z; | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-note@-2 {{declared here}} | 
|  | #else | 
|  | // expected-note@-4 {{default constructor of 'Z1' is implicitly deleted because field 'z' of reference type 'int &' would not be initialized}} | 
|  | #endif | 
|  |  | 
|  | const int c1; | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-note@-2 {{declared here}} | 
|  | #endif | 
|  | volatile int v1; | 
|  | }; | 
|  |  | 
|  | // Test default initialization which *requires* a constructor call for non-POD. | 
|  | Z1 z1; | 
|  | #if __cplusplus <= 199711L | 
|  | // expected-note@-2 {{first required here}} | 
|  | #else | 
|  | // expected-error@-4 {{call to implicitly-deleted default constructor of 'Z1'}} | 
|  | #endif | 
|  |  | 
|  | // Ensure that value initialization doesn't use trivial implicit constructors. | 
|  | namespace PR7948 { | 
|  | // Note that this is also non-POD to ensure we don't just special case PODs. | 
|  | struct S { const int x; ~S(); }; | 
|  | const S arr[2] = { { 42 } }; | 
|  | } | 
|  |  | 
|  | // This is valid | 
|  | union U { | 
|  | const int i; | 
|  | float f; | 
|  | }; | 
|  | U u; |