From: Chris Lattner Date: Mon, 29 Jul 2002 23:02:25 +0000 (+0000) Subject: Use a module analysis X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=1ad4436cc249e7b426085a97fbc94dc23efb6600;p=oota-llvm.git Use a module analysis git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3133 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/tools/analyze/analyze.cpp b/tools/analyze/analyze.cpp index cc3a4780824..79bcc4c5bdc 100644 --- a/tools/analyze/analyze.cpp +++ b/tools/analyze/analyze.cpp @@ -19,17 +19,22 @@ struct ModulePassPrinter : public Pass { - Pass *PassToPrint; - ModulePassPrinter(Pass *PI) : PassToPrint(PI) {} + const PassInfo *PassToPrint; + ModulePassPrinter(const PassInfo *PI) : PassToPrint(PI) {} virtual bool run(Module &M) { std::cout << "Printing Analysis info for Pass " << PassToPrint->getPassName() << ":\n"; - PassToPrint->print(std::cout, &M); + getAnalysis(PassToPrint).print(std::cout, &M); // Get and print pass... return false; } + + virtual void getAnalysisUsage(AnalysisUsage &AU) const { + AU.addRequired(PassToPrint); + AU.setPreservesAll(); + } }; struct FunctionPassPrinter : public FunctionPass { @@ -122,7 +127,7 @@ int main(int argc, char **argv) { else if (FunctionPass *FP = dynamic_cast(P)) Passes.add(new FunctionPassPrinter(Analysis)); else - Passes.add(new ModulePassPrinter(P)); + Passes.add(new ModulePassPrinter(Analysis)); } else cerr << "Cannot create pass: " << Analysis->getPassName() << "\n";