X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=lib%2FIR%2FIRPrintingPasses.cpp;h=13336ba55b3e3d39390ec6f93695ae64091812e0;hb=a59525786d39de4af8d7ee65531c220348ec48b6;hp=4398a9cfd2aaee8a5373b5e7c3d378db3c56e713;hpb=2ad3b87c4e1dfb8a49537ef51be5a13ea244f867;p=oota-llvm.git diff --git a/lib/IR/IRPrintingPasses.cpp b/lib/IR/IRPrintingPasses.cpp index 4398a9cfd2a..13336ba55b3 100644 --- a/lib/IR/IRPrintingPasses.cpp +++ b/lib/IR/IRPrintingPasses.cpp @@ -14,31 +14,43 @@ #include "llvm/IR/IRPrintingPasses.h" #include "llvm/IR/Function.h" #include "llvm/IR/Module.h" +#include "llvm/IR/PassManager.h" #include "llvm/Pass.h" #include "llvm/Support/Debug.h" #include "llvm/Support/raw_ostream.h" using namespace llvm; +PrintModulePass::PrintModulePass() : OS(dbgs()) {} +PrintModulePass::PrintModulePass(raw_ostream &OS, const std::string &Banner) + : OS(OS), Banner(Banner) {} + +PreservedAnalyses PrintModulePass::run(Module *M) { + OS << Banner << *M; + return PreservedAnalyses::all(); +} + +PrintFunctionPass::PrintFunctionPass() : OS(dbgs()) {} +PrintFunctionPass::PrintFunctionPass(raw_ostream &OS, const std::string &Banner) + : OS(OS), Banner(Banner) {} + +PreservedAnalyses PrintFunctionPass::run(Function *F) { + OS << Banner << static_cast(*F); + return PreservedAnalyses::all(); +} + namespace { -class PrintModulePass : public ModulePass { - std::string Banner; - raw_ostream *Out; - bool DeleteStream; +class PrintModulePassWrapper : public ModulePass { + PrintModulePass P; public: static char ID; - PrintModulePass() : ModulePass(ID), Out(&dbgs()), DeleteStream(false) {} - PrintModulePass(const std::string &B, raw_ostream *o, bool DS) - : ModulePass(ID), Banner(B), Out(o), DeleteStream(DS) {} - - ~PrintModulePass() { - if (DeleteStream) - delete Out; - } + PrintModulePassWrapper() : ModulePass(ID) {} + PrintModulePassWrapper(raw_ostream &OS, const std::string &Banner) + : ModulePass(ID), P(OS, Banner) {} bool runOnModule(Module &M) { - (*Out) << Banner << M; + P.run(&M); return false; } @@ -47,26 +59,18 @@ public: } }; -class PrintFunctionPass : public FunctionPass { - std::string Banner; - raw_ostream *Out; - bool DeleteStream; +class PrintFunctionPassWrapper : public FunctionPass { + PrintFunctionPass P; public: static char ID; - PrintFunctionPass() - : FunctionPass(ID), Banner(""), Out(&dbgs()), DeleteStream(false) {} - PrintFunctionPass(const std::string &B, raw_ostream *o, bool DS) - : FunctionPass(ID), Banner(B), Out(o), DeleteStream(DS) {} - - ~PrintFunctionPass() { - if (DeleteStream) - delete Out; - } + PrintFunctionPassWrapper() : FunctionPass(ID) {} + PrintFunctionPassWrapper(raw_ostream &OS, const std::string &Banner) + : FunctionPass(ID), P(OS, Banner) {} // This pass just prints a banner followed by the function as it's processed. bool runOnFunction(Function &F) { - (*Out) << Banner << static_cast(F); + P.run(&F); return false; } @@ -76,24 +80,17 @@ public: }; class PrintBasicBlockPass : public BasicBlockPass { + raw_ostream &Out; std::string Banner; - raw_ostream *Out; - bool DeleteStream; public: static char ID; - PrintBasicBlockPass() - : BasicBlockPass(ID), Out(&dbgs()), DeleteStream(false) {} - PrintBasicBlockPass(const std::string &B, raw_ostream *o, bool DS) - : BasicBlockPass(ID), Banner(B), Out(o), DeleteStream(DS) {} - - ~PrintBasicBlockPass() { - if (DeleteStream) - delete Out; - } + PrintBasicBlockPass() : BasicBlockPass(ID), Out(dbgs()) {} + PrintBasicBlockPass(raw_ostream &Out, const std::string &Banner) + : BasicBlockPass(ID), Out(Out), Banner(Banner) {} bool runOnBasicBlock(BasicBlock &BB) { - (*Out) << Banner << BB; + Out << Banner << BB; return false; } @@ -101,32 +98,30 @@ public: AU.setPreservesAll(); } }; + } -char PrintModulePass::ID = 0; -INITIALIZE_PASS(PrintModulePass, "print-module", "Print module to stderr", - false, false) -char PrintFunctionPass::ID = 0; -INITIALIZE_PASS(PrintFunctionPass, "print-function", "Print function to stderr", - false, false) +char PrintModulePassWrapper::ID = 0; +INITIALIZE_PASS(PrintModulePassWrapper, "print-module", + "Print module to stderr", false, false) +char PrintFunctionPassWrapper::ID = 0; +INITIALIZE_PASS(PrintFunctionPassWrapper, "print-function", + "Print function to stderr", false, false) char PrintBasicBlockPass::ID = 0; INITIALIZE_PASS(PrintBasicBlockPass, "print-bb", "Print BB to stderr", false, false) -ModulePass *llvm::createPrintModulePass(llvm::raw_ostream *OS, - bool DeleteStream, +ModulePass *llvm::createPrintModulePass(llvm::raw_ostream &OS, const std::string &Banner) { - return new PrintModulePass(Banner, OS, DeleteStream); + return new PrintModulePassWrapper(OS, Banner); } -FunctionPass *llvm::createPrintFunctionPass(const std::string &Banner, - llvm::raw_ostream *OS, - bool DeleteStream) { - return new PrintFunctionPass(Banner, OS, DeleteStream); +FunctionPass *llvm::createPrintFunctionPass(llvm::raw_ostream &OS, + const std::string &Banner) { + return new PrintFunctionPassWrapper(OS, Banner); } -BasicBlockPass *llvm::createPrintBasicBlockPass(llvm::raw_ostream *OS, - bool DeleteStream, +BasicBlockPass *llvm::createPrintBasicBlockPass(llvm::raw_ostream &OS, const std::string &Banner) { - return new PrintBasicBlockPass(Banner, OS, DeleteStream); + return new PrintBasicBlockPass(OS, Banner); }