From a68941b2d461a9c8827caf69af1050526b5dd167 Mon Sep 17 00:00:00 2001 From: Devang Patel Date: Tue, 19 Dec 2006 20:12:38 +0000 Subject: [PATCH] Now, there is additional layer, referred in the comment, in place to handle this correctly. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32684 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/VMCore/PassManager.cpp | 11 ----------- 1 file changed, 11 deletions(-) diff --git a/lib/VMCore/PassManager.cpp b/lib/VMCore/PassManager.cpp index 1a5276f14dc..620d4da9631 100644 --- a/lib/VMCore/PassManager.cpp +++ b/lib/VMCore/PassManager.cpp @@ -153,10 +153,6 @@ public: /// then return NULL. Pass *findAnalysisPass(AnalysisID AID); - inline void clearManagers() { - PassManagers.clear(); - } - virtual ~PMTopLevelManager() { for (std::vector::iterator I = PassManagers.begin(), E = PassManagers.end(); I != E; ++I) @@ -1150,13 +1146,6 @@ FunctionPassManager::FunctionPassManager(ModuleProvider *P) { } FunctionPassManager::~FunctionPassManager() { - // Note : FPM maintains one entry in PassManagers vector. - // This one entry is FPM itself. This is not ideal. One - // alternative is have one additional layer between - // FunctionPassManager and FunctionPassManagerImpl. - // Meanwhile, to avoid going into infinte loop, first - // remove FPM from its PassMangers vector. - FPM->clearManagers(); delete FPM; }