[llvm-commits] CVS: llvm/tools/analyze/AnalysisWrappers.cpp 
    Chris Lattner 
    lattner at cs.uiuc.edu
       
    Thu Dec 22 11:26:18 PST 2005
    
    
  
Changes in directory llvm/tools/analyze:
AnalysisWrappers.cpp updated: 1.16 -> 1.17
---
Log message:
Fix test/Regression/Other/2002-01-31-CallGraph.ll after the recent callgraph
rework.
---
Diffs of the changes:  (+17 -3)
 AnalysisWrappers.cpp |   20 +++++++++++++++++---
 1 files changed, 17 insertions(+), 3 deletions(-)
Index: llvm/tools/analyze/AnalysisWrappers.cpp
diff -u llvm/tools/analyze/AnalysisWrappers.cpp:1.16 llvm/tools/analyze/AnalysisWrappers.cpp:1.17
--- llvm/tools/analyze/AnalysisWrappers.cpp:1.16	Thu Apr 21 18:59:21 2005
+++ llvm/tools/analyze/AnalysisWrappers.cpp	Thu Dec 22 13:26:06 2005
@@ -20,6 +20,7 @@
 #include "llvm/Module.h"
 #include "llvm/Pass.h"
 #include "llvm/Support/CallSite.h"
+#include "llvm/Analysis/CallGraph.h"
 #include <iostream>
 using namespace llvm;
 
@@ -55,13 +56,26 @@
       return false;
     }
 
-    void print(std::ostream &OS) const {}
-
     virtual void getAnalysisUsage(AnalysisUsage &AU) const {
       AU.setPreservesAll();
     }
   };
 
   RegisterAnalysis<ExternalFunctionsPassedConstants>
-  P2("externalfnconstants", "Print external fn callsites passed constants");
+  P1("externalfnconstants", "Print external fn callsites passed constants");
+  
+  struct CallGraphPrinter : public ModulePass {
+    virtual void getAnalysisUsage(AnalysisUsage &AU) const {
+      AU.setPreservesAll();
+      AU.addRequired<CallGraph>();
+    }
+    virtual bool runOnModule(Module &M) { return false; }
+
+    void print(std::ostream &OS, Module *M) const {
+      getAnalysis<CallGraph>().print(OS, M);
+    }
+  };
+  
+  RegisterAnalysis<CallGraphPrinter>
+    P2("callgraph", "Print a call graph");
 }
    
    
More information about the llvm-commits
mailing list