summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/copy-initialization.cpp
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2012-02-11 19:22:50 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2012-02-11 19:22:50 +0000
commitb24f06780ce2f437e0cf5da6d2e71ba2ed207759 (patch)
tree57f6f8f76a646231748c0f6c8cc6f6e01ed561a8 /clang/test/SemaCXX/copy-initialization.cpp
parent4c7b490d1921dd93685be9da9033101f99997025 (diff)
downloadbcm5719-llvm-b24f06780ce2f437e0cf5da6d2e71ba2ed207759.tar.gz
bcm5719-llvm-b24f06780ce2f437e0cf5da6d2e71ba2ed207759.zip
Implement core issue 5: a temporary created for copy-initialization has a
cv-unqualified type. This is essential in order to allow move-only objects of const-qualified types to be copy-initialized via a converting constructor. llvm-svn: 150309
Diffstat (limited to 'clang/test/SemaCXX/copy-initialization.cpp')
-rw-r--r--clang/test/SemaCXX/copy-initialization.cpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/copy-initialization.cpp b/clang/test/SemaCXX/copy-initialization.cpp
index fb83dcfbd01..ea2db0c68e8 100644
--- a/clang/test/SemaCXX/copy-initialization.cpp
+++ b/clang/test/SemaCXX/copy-initialization.cpp
@@ -42,3 +42,26 @@ namespace PR6757 {
f(foo);
}
}
+
+namespace DR5 {
+ // Core issue 5: if a temporary is created in copy-initialization, it is of
+ // the cv-unqualified version of the destination type.
+ namespace Ex1 {
+ struct C { };
+ C c;
+ struct A {
+ A(const A&);
+ A(const C&);
+ };
+ const volatile A a = c; // ok
+ }
+
+ namespace Ex2 {
+ struct S {
+ S(S&&); // expected-warning {{C++11}}
+ S(int);
+ };
+ const S a(0);
+ const S b = 0;
+ }
+}
OpenPOWER on IntegriCloud