]> granicus.if.org Git - clang/commitdiff
PR7800: both virtual and non-virtual bases must be marked as used for VTTs.
authorEli Friedman <eli.friedman@gmail.com>
Sat, 7 Aug 2010 23:11:44 +0000 (23:11 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Sat, 7 Aug 2010 23:11:44 +0000 (23:11 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@110526 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaDeclCXX.cpp
test/SemaCXX/virtual-base-used.cpp [new file with mode: 0644]

index 08fa97b5e2ca2f8ddd12b844c91d23d4e33340d8..94ca031c2a3155685a29d2cbb71fedb1cd0972ce 100644 (file)
@@ -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/test/SemaCXX/virtual-base-used.cpp b/test/SemaCXX/virtual-base-used.cpp
new file mode 100644 (file)
index 0000000..c9e3d2f
--- /dev/null
@@ -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}}
+}