diff options
| author | Anders Carlsson <andersca@mac.com> | 2009-12-07 04:35:11 +0000 | 
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2009-12-07 04:35:11 +0000 | 
| commit | 5ebf8b44e925c79fbdfb11aac9cb14522036f849 (patch) | |
| tree | 6240fc3156e8d204cca414891b36a92384b2aeb9 /clang/lib/AST | |
| parent | 92c310cb7984bb3336725939dbb71709d473648e (diff) | |
| download | bcm5719-llvm-5ebf8b44e925c79fbdfb11aac9cb14522036f849.tar.gz bcm5719-llvm-5ebf8b44e925c79fbdfb11aac9cb14522036f849.zip | |
Move key functions to a separate map.
llvm-svn: 90745
Diffstat (limited to 'clang/lib/AST')
| -rw-r--r-- | clang/lib/AST/ASTContext.cpp | 14 | ||||
| -rw-r--r-- | clang/lib/AST/RecordLayoutBuilder.cpp | 68 | ||||
| -rw-r--r-- | clang/lib/AST/RecordLayoutBuilder.h | 1 | 
3 files changed, 50 insertions, 33 deletions
| diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp index cc96a5dc0e2..490f338d38f 100644 --- a/clang/lib/AST/ASTContext.cpp +++ b/clang/lib/AST/ASTContext.cpp @@ -1104,6 +1104,20 @@ const ASTRecordLayout &ASTContext::getASTRecordLayout(const RecordDecl *D) {    return *NewEntry;  } +const CXXMethodDecl *ASTContext::getKeyFunction(const CXXRecordDecl *RD) { +  RD = cast<CXXRecordDecl>(RD->getDefinition(*this)); +  assert(RD && "Cannot get key function for forward declarations!"); +   +  const CXXMethodDecl *&Entry = KeyFunctions[RD]; +  if (!Entry)  +    Entry = ASTRecordLayoutBuilder::ComputeKeyFunction(RD); +  else +    assert(Entry == ASTRecordLayoutBuilder::ComputeKeyFunction(RD) && +           "Key function changed!"); +   +  return Entry; +} +  //===----------------------------------------------------------------------===//  //                   Type creation/memoization methods  //===----------------------------------------------------------------------===// diff --git a/clang/lib/AST/RecordLayoutBuilder.cpp b/clang/lib/AST/RecordLayoutBuilder.cpp index 088673916f8..550a32b0d05 100644 --- a/clang/lib/AST/RecordLayoutBuilder.cpp +++ b/clang/lib/AST/RecordLayoutBuilder.cpp @@ -663,35 +663,6 @@ void ASTRecordLayoutBuilder::UpdateAlignment(unsigned NewAlignment) {    Alignment = NewAlignment;  } -static const CXXMethodDecl *GetKeyFunction(const CXXRecordDecl *RD) { -  if (!RD->isDynamicClass()) -    return 0; -   -  for (CXXRecordDecl::method_iterator I = RD->method_begin(),  -       E = RD->method_end(); I != E; ++I) { -    const CXXMethodDecl *MD = *I; -     -    if (!MD->isVirtual()) -      continue; -     -    if (MD->isPure()) -      continue; -     -    // Ignore implicit member functions, they are always marked as inline, but -    // they don't have a body until they're defined. -    if (MD->isImplicit()) -      continue; - -    if (MD->hasInlineBody()) -      continue; -     -    // We found it. -    return MD; -  } -   -  return 0; -} -  const ASTRecordLayout *  ASTRecordLayoutBuilder::ComputeLayout(ASTContext &Ctx,                                        const RecordDecl *D) { @@ -715,8 +686,6 @@ ASTRecordLayoutBuilder::ComputeLayout(ASTContext &Ctx,    uint64_t NonVirtualSize =      IsPODForThePurposeOfLayout ? DataSize : Builder.NonVirtualSize; -  const CXXMethodDecl *KeyFunction = GetKeyFunction(cast<CXXRecordDecl>(D)); -      return new ASTRecordLayout(Builder.Size, Builder.Alignment, DataSize,                               Builder.FieldOffsets.data(),                               Builder.FieldOffsets.size(), @@ -726,8 +695,7 @@ ASTRecordLayoutBuilder::ComputeLayout(ASTContext &Ctx,                               Builder.Bases.data(),                               Builder.Bases.size(),                               Builder.VBases.data(), -                             Builder.VBases.size(), -                             KeyFunction); +                             Builder.VBases.size());  }  const ASTRecordLayout * @@ -743,3 +711,37 @@ ASTRecordLayoutBuilder::ComputeLayout(ASTContext &Ctx,                               Builder.FieldOffsets.data(),                               Builder.FieldOffsets.size());  } + +const CXXMethodDecl * +ASTRecordLayoutBuilder::ComputeKeyFunction(const CXXRecordDecl *RD) { +  assert(RD->isDynamicClass() && "Class does not have any virtual methods!"); + +  // If a class isnt' polymorphic it doesn't have a key function. +  if (!RD->isPolymorphic()) +    return 0; +   +  for (CXXRecordDecl::method_iterator I = RD->method_begin(),  +       E = RD->method_end(); I != E; ++I) { +    const CXXMethodDecl *MD = *I; +     +    if (!MD->isVirtual()) +      continue; +     +    if (MD->isPure()) +      continue; +     +    // Ignore implicit member functions, they are always marked as inline, but +    // they don't have a body until they're defined. +    if (MD->isImplicit()) +      continue; + +    if (MD->hasInlineBody()) +      continue; +     +    // We found it. +    return MD; +  } +   +  return 0; +} + diff --git a/clang/lib/AST/RecordLayoutBuilder.h b/clang/lib/AST/RecordLayoutBuilder.h index 69e0498917c..d4171d3cc9a 100644 --- a/clang/lib/AST/RecordLayoutBuilder.h +++ b/clang/lib/AST/RecordLayoutBuilder.h @@ -151,6 +151,7 @@ public:    static const ASTRecordLayout *ComputeLayout(ASTContext &Ctx,                                                const ObjCInterfaceDecl *D,                                              const ObjCImplementationDecl *Impl); +  static const CXXMethodDecl *ComputeKeyFunction(const CXXRecordDecl *RD);  };  } // end namespace clang | 

