summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2010-08-07 23:11:44 +0000
committerEli Friedman <eli.friedman@gmail.com>2010-08-07 23:11:44 +0000
commitaab1fda91f93b5d863b1e4e61aff541199ab56fc (patch)
tree687bd2fe2ada06b4d797e3262d7e8d8570afb444 /clang
parentf387dbde817e696dfdb0fee8feb90c03dfb5e8a7 (diff)
downloadbcm5719-llvm-aab1fda91f93b5d863b1e4e61aff541199ab56fc.tar.gz
bcm5719-llvm-aab1fda91f93b5d863b1e4e61aff541199ab56fc.zip
PR7800: both virtual and non-virtual bases must be marked as used for VTTs.
llvm-svn: 110526
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Sema/SemaDeclCXX.cpp2
-rw-r--r--clang/test/SemaCXX/virtual-base-used.cpp16
2 files changed, 16 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp
index 08fa97b5e2c..94ca031c2a3 100644
--- a/clang/lib/Sema/SemaDeclCXX.cpp
+++ b/clang/lib/Sema/SemaDeclCXX.cpp
@@ -6797,8 +6797,6 @@ void Sema::MarkVirtualMembersReferenced(SourceLocation Loc,
e = RD->bases_end(); i != e; ++i) {
const CXXRecordDecl *Base =
cast<CXXRecordDecl>(i->getType()->getAs<RecordType>()->getDecl());
- if (i->isVirtual())
- continue;
if (Base->getNumVBases() == 0)
continue;
MarkVirtualMembersReferenced(Loc, Base);
diff --git a/clang/test/SemaCXX/virtual-base-used.cpp b/clang/test/SemaCXX/virtual-base-used.cpp
new file mode 100644
index 00000000000..c9e3d2f802b
--- /dev/null
+++ b/clang/test/SemaCXX/virtual-base-used.cpp
@@ -0,0 +1,16 @@
+// RUN: %clang_cc1 -fsyntax-only -verify %s
+// PR7800
+
+class NoDestroy { ~NoDestroy(); }; // expected-note {{declared private here}}
+struct A {
+ virtual ~A();
+};
+struct B : public virtual A {
+ NoDestroy x; // expected-error {{field of type 'NoDestroy' has private destructor}}
+};
+struct D : public virtual B {
+ virtual void foo();
+ ~D();
+};
+void D::foo() { // expected-note {{implicit default destructor for 'B' first required here}}
+}
OpenPOWER on IntegriCloud