1 //===- IRPrintingPasses.h - Passes to print out IR constructs ---*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
11 /// This file defines passes to print out IR in various granularities. The
12 /// PrintModulePass pass simply prints out the entire module when it is
13 /// executed. The PrintFunctionPass class is designed to be pipelined with
14 /// other FunctionPass's, and prints out the functions of the module as they
17 //===----------------------------------------------------------------------===//
19 #ifndef LLVM_IR_IRPRINTINGPASSES_H
20 #define LLVM_IR_IRPRINTINGPASSES_H
22 #include "llvm/ADT/StringRef.h"
31 class PreservedAnalyses;
34 /// \brief Create and return a pass that writes the module to the specified
36 ModulePass *createPrintModulePass(raw_ostream &OS,
37 const std::string &Banner = "",
38 bool ShouldPreserveUseListOrder = false);
40 /// \brief Create and return a pass that prints functions to the specified
41 /// \c raw_ostream as they are processed.
42 FunctionPass *createPrintFunctionPass(raw_ostream &OS,
43 const std::string &Banner = "");
45 /// \brief Create and return a pass that writes the BB to the specified
47 BasicBlockPass *createPrintBasicBlockPass(raw_ostream &OS,
48 const std::string &Banner = "");
50 /// \brief Pass for printing a Module as LLVM's text IR assembly.
52 /// Note: This pass is for use with the new pass manager. Use the create...Pass
53 /// functions above to create passes for use with the legacy pass manager.
54 class PrintModulePass {
57 bool ShouldPreserveUseListOrder;
61 PrintModulePass(raw_ostream &OS, const std::string &Banner = "",
62 bool ShouldPreserveUseListOrder = false);
64 PreservedAnalyses run(Module &M);
66 static StringRef name() { return "PrintModulePass"; }
69 /// \brief Pass for printing a Function as LLVM's text IR assembly.
71 /// Note: This pass is for use with the new pass manager. Use the create...Pass
72 /// functions above to create passes for use with the legacy pass manager.
73 class PrintFunctionPass {
79 PrintFunctionPass(raw_ostream &OS, const std::string &Banner = "");
81 PreservedAnalyses run(Function &F);
83 static StringRef name() { return "PrintFunctionPass"; }
86 } // End llvm namespace