2009-12-16 04:14:24 +08:00
// RUN: %clang_cc1 -fsyntax-only -verify %s
2017-02-25 07:23:53 +08:00
// RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s
// RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s
2009-06-21 04:23:38 +08:00
struct X1 { // has no implicit default constructor
X1 ( int ) ;
} ;
2017-02-25 07:23:53 +08:00
struct X2 : X1 {
# if __cplusplus <= 199711L
// expected-note@-2 2 {{'X2' declared here}}
# endif
2009-06-21 04:23:38 +08:00
X2 ( int ) ;
} ;
2017-02-25 07:23:53 +08:00
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
2009-06-21 04:23:38 +08:00
} ;
2017-02-25 07:23:53 +08:00
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
2009-06-21 04:23:38 +08:00
} ;
2017-02-25 07:23:53 +08:00
X4 x4 ;
# if __cplusplus <= 199711L
// expected-note@-2 {{first required here}}
# else
// expected-error@-4 {{call to implicitly-deleted default constructor of 'X4'}}
# endif
2009-06-21 04:23:38 +08:00
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
2017-02-25 07:23:53 +08:00
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
2009-09-09 23:08:12 +08:00
volatile int v1 ;
2009-06-21 04:23:38 +08:00
} ;
2010-08-23 15:55:51 +08:00
// Test default initialization which *requires* a constructor call for non-POD.
2017-02-25 07:23:53 +08:00
Z1 z1 ;
# if __cplusplus <= 199711L
// expected-note@-2 {{first required here}}
# else
// expected-error@-4 {{call to implicitly-deleted default constructor of 'Z1'}}
# endif
2009-06-21 04:23:38 +08:00
2010-08-23 15:55:51 +08:00
// 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 } } ;
}
2011-05-17 08:19:05 +08:00
// This is valid
union U {
const int i ;
float f ;
} ;
U u ;