Fix memory leak.
authorDevang Patel <dpatel@apple.com>
Mon, 9 Jul 2007 20:52:39 +0000 (20:52 +0000)
committerDevang Patel <dpatel@apple.com>
Mon, 9 Jul 2007 20:52:39 +0000 (20:52 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@38469 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Pass.h
lib/VMCore/PassManager.cpp

index cee635bd8a5823748dd954d965e13b2ca1d760ba..a5a98f531312ba85128f6ccb102365c088845bee 100644 (file)
@@ -130,8 +130,14 @@ public:
   }
 
   // Access AnalysisResolver
-  inline void setResolver(AnalysisResolver *AR) { Resolver = AR; }
-  inline AnalysisResolver *getResolver() { return Resolver; }
+  inline void setResolver(AnalysisResolver *AR) { 
+    assert (!Resolver && "Resolver is already set");
+    Resolver = AR; 
+  }
+  inline AnalysisResolver *getResolver() { 
+    assert (Resolver && "Resolver is not set");
+    return Resolver; 
+  }
 
   /// getAnalysisUsage - This function should be overriden by passes that need
   /// analysis information to do their job.  If a pass specifies that it uses a
index 23e45c0b9583e01c30b0f4f7cbaad29fdd8b288d..af3cfb025dca290520a9ffbf6a2eb9b24c2b525a 100644 (file)
@@ -1380,9 +1380,6 @@ void PMStack::push(Pass *P) {
     PM->setTopLevelManager(TPM);
   }
 
-  AnalysisResolver *AR = new AnalysisResolver(*Top);
-  P->setResolver(AR);
-
   S.push_back(PM);
 }