diff options
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/Sema/Sema.h | 3 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 18 | 
2 files changed, 19 insertions, 2 deletions
diff --git a/clang/lib/Sema/Sema.h b/clang/lib/Sema/Sema.h index 5986b479cdd..2ccc41f2875 100644 --- a/clang/lib/Sema/Sema.h +++ b/clang/lib/Sema/Sema.h @@ -2486,7 +2486,8 @@ public:    /// MarkVirtualMembersReferenced - Will mark all virtual members of the given    /// CXXRecordDecl referenced. -  void MarkVirtualMembersReferenced(SourceLocation Loc, CXXRecordDecl *RD); +  void MarkVirtualMembersReferenced(SourceLocation Loc, +                                    const CXXRecordDecl *RD);    /// ProcessPendingClassesWithUnmarkedVirtualMembers - Will process classes     /// that might need to have their virtual members marked as referenced. diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index 9a68f472e67..1f6630e3436 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -5944,7 +5944,8 @@ bool Sema::ProcessPendingClassesWithUnmarkedVirtualMembers() {    return true;  } -void Sema::MarkVirtualMembersReferenced(SourceLocation Loc, CXXRecordDecl *RD) { +void Sema::MarkVirtualMembersReferenced(SourceLocation Loc, +                                        const CXXRecordDecl *RD) {    for (CXXRecordDecl::method_iterator i = RD->method_begin(),          e = RD->method_end(); i != e; ++i) {      CXXMethodDecl *MD = *i; @@ -5954,4 +5955,19 @@ void Sema::MarkVirtualMembersReferenced(SourceLocation Loc, CXXRecordDecl *RD) {      if (MD->isVirtual() && !MD->isPure())        MarkDeclarationReferenced(Loc, MD);    } + +  // Only classes that have virtual bases need a VTT. +  if (RD->getNumVBases() == 0) +    return; + +  for (CXXRecordDecl::base_class_const_iterator i = RD->bases_begin(), +           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); +  }  }  | 

