summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/new-delete.cpp
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2011-07-13 20:12:57 +0000
committerJohn McCall <rjmccall@apple.com>2011-07-13 20:12:57 +0000
commit928a25714e6d980e2eea215c24686d483015a8ac (patch)
tree8b66ce6ad95c60cd376d6333c81ccf6bcfc5ddc5 /clang/test/SemaCXX/new-delete.cpp
parent2371a3f14a9148ed341d27f3e256444c013c6c33 (diff)
downloadbcm5719-llvm-928a25714e6d980e2eea215c24686d483015a8ac.tar.gz
bcm5719-llvm-928a25714e6d980e2eea215c24686d483015a8ac.zip
Enforce access control for the destructor in a new[] expression and mark
it as used. Otherwise, we can fail to instantiate or validate the destructor, which can lead to crashes in IR gen like PR10351. llvm-svn: 135073
Diffstat (limited to 'clang/test/SemaCXX/new-delete.cpp')
-rw-r--r--clang/test/SemaCXX/new-delete.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/clang/test/SemaCXX/new-delete.cpp b/clang/test/SemaCXX/new-delete.cpp
index 13ef461e7c0..efdfa0f066d 100644
--- a/clang/test/SemaCXX/new-delete.cpp
+++ b/clang/test/SemaCXX/new-delete.cpp
@@ -389,3 +389,11 @@ namespace PR7702 {
new DoesNotExist; // expected-error {{expected a type}}
}
}
+
+namespace ArrayNewNeedsDtor {
+ struct A { A(); private: ~A(); }; // expected-note {{declared private here}}
+ struct B { B(); A a; }; // expected-error {{field of type 'ArrayNewNeedsDtor::A' has private destructor}}
+ B *test9() {
+ return new B[5]; // expected-note {{implicit default destructor for 'ArrayNewNeedsDtor::B' first required here}}
+ }
+}
OpenPOWER on IntegriCloud