diff options
| author | Ted Kremenek <kremenek@apple.com> | 2010-06-08 23:00:58 +0000 | 
|---|---|---|
| committer | Ted Kremenek <kremenek@apple.com> | 2010-06-08 23:00:58 +0000 | 
| commit | 076baeb03eabececd2249e2fa5f69a0199c624c4 (patch) | |
| tree | 47360777fe7794a144a5b0feff87a424422b9c87 | |
| parent | dea66e3e4c80f6e31762e4db3fa9141fa010c975 (diff) | |
| download | bcm5719-llvm-076baeb03eabececd2249e2fa5f69a0199c624c4.tar.gz bcm5719-llvm-076baeb03eabececd2249e2fa5f69a0199c624c4.zip | |
Fix memory leak in ASTContext where ASTRecordLayout objects involving C++ structures wouldn't have
their associated memory destroyed when using a BumpPtrAllocator.  These objects internally use
a DenseMap.
llvm-svn: 105659
| -rw-r--r-- | clang/lib/AST/ASTContext.cpp | 17 | 
1 files changed, 10 insertions, 7 deletions
| diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp index 9aa8781592c..75af89ee96a 100644 --- a/clang/lib/AST/ASTContext.cpp +++ b/clang/lib/AST/ASTContext.cpp @@ -89,13 +89,6 @@ ASTContext::~ASTContext() {        Deallocate(&*I++);      } -    for (llvm::DenseMap<const RecordDecl*, const ASTRecordLayout*>::iterator -         I = ASTRecordLayouts.begin(), E = ASTRecordLayouts.end(); I != E; ) { -      // Increment in loop to prevent using deallocated memory. -      if (ASTRecordLayout *R = const_cast<ASTRecordLayout*>((I++)->second)) -        R->Destroy(*this); -    } -      for (llvm::DenseMap<const ObjCContainerDecl*,           const ASTRecordLayout*>::iterator           I = ObjCLayouts.begin(), E = ObjCLayouts.end(); I != E; ) { @@ -105,6 +98,16 @@ ASTContext::~ASTContext() {      }    } +  // ASTRecordLayout objects in ASTRecordLayouts must always be destroyed +  // even when using the BumpPtrAllocator because they can contain +  // DenseMaps. +  for (llvm::DenseMap<const RecordDecl*, const ASTRecordLayout*>::iterator +       I = ASTRecordLayouts.begin(), E = ASTRecordLayouts.end(); I != E; ) { +    // Increment in loop to prevent using deallocated memory. +    if (ASTRecordLayout *R = const_cast<ASTRecordLayout*>((I++)->second)) +      R->Destroy(*this); +  } +    // Destroy nested-name-specifiers.    for (llvm::FoldingSet<NestedNameSpecifier>::iterator           NNS = NestedNameSpecifiers.begin(), | 

