From 5acdf59ebc6839fc877604168eb96a76fdb51e77 Mon Sep 17 00:00:00 2001 From: Douglas Gregor Date: Thu, 17 Nov 2011 02:05:44 +0000 Subject: [PATCH] Actually free memory for the module maps llvm-svn: 144880 --- clang/include/clang/Lex/ModuleMap.h | 4 +++- clang/lib/Lex/ModuleMap.cpp | 15 +++++++++++++++ 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/clang/include/clang/Lex/ModuleMap.h b/clang/include/clang/Lex/ModuleMap.h index e9bf1b35c141..b1eaebddb20a 100644 --- a/clang/include/clang/Lex/ModuleMap.h +++ b/clang/include/clang/Lex/ModuleMap.h @@ -73,7 +73,9 @@ public: : Name(Name), DefinitionLoc(DefinitionLoc), Parent(Parent), UmbrellaHeader(0), IsExplicit(IsExplicit) { } - + + ~Module(); + /// \brief Determine whether this module is a submodule. bool isSubModule() const { return Parent != 0; } diff --git a/clang/lib/Lex/ModuleMap.cpp b/clang/lib/Lex/ModuleMap.cpp index 0c51659cab88..393118110aff 100644 --- a/clang/lib/Lex/ModuleMap.cpp +++ b/clang/lib/Lex/ModuleMap.cpp @@ -31,6 +31,15 @@ using namespace clang; // Module //----------------------------------------------------------------------------// +ModuleMap::Module::~Module() { + for (llvm::StringMap::iterator I = SubModules.begin(), + IEnd = SubModules.end(); + I != IEnd; ++I) { + delete I->getValue(); + } + +} + std::string ModuleMap::Module::getFullModuleName() const { llvm::SmallVector Names; @@ -72,6 +81,12 @@ ModuleMap::ModuleMap(FileManager &FileMgr, const DiagnosticConsumer &DC) { } ModuleMap::~ModuleMap() { + for (llvm::StringMap::iterator I = Modules.begin(), + IEnd = Modules.end(); + I != IEnd; ++I) { + delete I->getValue(); + } + delete SourceMgr; }