aboutsummaryrefslogtreecommitdiff
path: root/test/SemaCXX/value-initialization.cpp
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2009-10-27 16:51:19 +0000
committerFariborz Jahanian <fjahanian@apple.com>2009-10-27 16:51:19 +0000
commit6c813e1cb719a328f01619c3d44910be4e79e4d5 (patch)
treed16946911c9302726f09829cbf862da3e6275349 /test/SemaCXX/value-initialization.cpp
parent7d5ba55f58c070e5b9f8cee3a172e2da1fcd02af (diff)
Generate constructor for value-initialization cases, even if the
implementation technique doesn't call the constructor at that point. DR302. Fixes pr5296. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@85249 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/SemaCXX/value-initialization.cpp')
-rw-r--r--test/SemaCXX/value-initialization.cpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/test/SemaCXX/value-initialization.cpp b/test/SemaCXX/value-initialization.cpp
new file mode 100644
index 0000000000..6b99297361
--- /dev/null
+++ b/test/SemaCXX/value-initialization.cpp
@@ -0,0 +1,23 @@
+// RUN: clang-cc -fsyntax-only -verify %s -std=c++0x
+
+struct A {
+ ~A();
+ const int i; // expected-note {{declared at}}
+};
+
+struct B {
+ // B is a non-POD with no user-written constructor.
+ // It has a nontrivial generated constructor.
+ const int i[12]; // expected-note {{declared at}}
+ A a;
+};
+
+int main () {
+ // Value-initializing a "B" doesn't call the default constructor for
+ // "B"; it value-initializes the members of B. Therefore it shouldn't
+ // cause an error on generation of the default constructor for the
+ // following:
+ new B(); // expected-error {{cannot define the implicit default constructor for 'struct B', because const member 'i'}}
+ (void)B();
+ (void)A(); // expected-error {{cannot define the implicit default constructor for 'struct A', because const member 'i'}}
+}