diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2010-08-07 23:11:44 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2010-08-07 23:11:44 +0000 |
commit | aab1fda91f93b5d863b1e4e61aff541199ab56fc (patch) | |
tree | 687bd2fe2ada06b4d797e3262d7e8d8570afb444 /clang | |
parent | f387dbde817e696dfdb0fee8feb90c03dfb5e8a7 (diff) | |
download | bcm5719-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.cpp | 2 | ||||
-rw-r--r-- | clang/test/SemaCXX/virtual-base-used.cpp | 16 |
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}} +} |