| Chris Lattner | 97e8b6f | 2007-10-07 06:04:32 +0000 | [diff] [blame] | 1 | //===--- ASTConsumers.h - ASTConsumer implementations -----------*- C++ -*-===// |
| Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| Chris Lattner | 0bc735f | 2007-12-29 19:59:25 +0000 | [diff] [blame] | 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | // |
| Chris Lattner | 97e8b6f | 2007-10-07 06:04:32 +0000 | [diff] [blame] | 10 | // AST Consumers. |
| Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 11 | // |
| 12 | //===----------------------------------------------------------------------===// |
| 13 | |
| Chris Lattner | 97e8b6f | 2007-10-07 06:04:32 +0000 | [diff] [blame] | 14 | #ifndef DRIVER_ASTCONSUMERS_H |
| 15 | #define DRIVER_ASTCONSUMERS_H |
| Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 16 | |
| Eli Friedman | 7df3d71 | 2008-02-16 23:17:23 +0000 | [diff] [blame] | 17 | #include <string> |
| Ted Kremenek | 1b5a4bd | 2007-11-27 21:46:50 +0000 | [diff] [blame] | 18 | |
| Chris Lattner | e66b65c | 2008-02-06 01:42:25 +0000 | [diff] [blame] | 19 | namespace llvm { |
| Chris Lattner | 0fa0daa | 2009-08-24 04:11:30 +0000 | [diff] [blame^] | 20 | class raw_ostream; |
| Chris Lattner | e66b65c | 2008-02-06 01:42:25 +0000 | [diff] [blame] | 21 | class Module; |
| Benjamin Kramer | f21efe9 | 2009-08-11 17:46:57 +0000 | [diff] [blame] | 22 | class LLVMContext; |
| Chris Lattner | e66b65c | 2008-02-06 01:42:25 +0000 | [diff] [blame] | 23 | namespace sys { class Path; } |
| 24 | } |
| Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 25 | namespace clang { |
| 26 | |
| Chris Lattner | 556beb7 | 2007-09-15 22:56:56 +0000 | [diff] [blame] | 27 | class ASTConsumer; |
| Chris Lattner | c0508f9 | 2007-09-15 23:21:08 +0000 | [diff] [blame] | 28 | class Diagnostic; |
| Ted Kremenek | dca2466 | 2007-12-05 00:26:13 +0000 | [diff] [blame] | 29 | class FileManager; |
| Chris Lattner | 3245a0a | 2008-04-16 06:11:58 +0000 | [diff] [blame] | 30 | class Preprocessor; |
| Ted Kremenek | 339b9c2 | 2008-04-17 22:31:54 +0000 | [diff] [blame] | 31 | class PreprocessorFactory; |
| Daniel Dunbar | eb19485 | 2009-07-12 23:52:11 +0000 | [diff] [blame] | 32 | class CompileOptions; |
| Cedric Venet | ea684e6 | 2009-02-14 16:15:20 +0000 | [diff] [blame] | 33 | class LangOptions; |
| Ted Kremenek | 339b9c2 | 2008-04-17 22:31:54 +0000 | [diff] [blame] | 34 | |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 35 | // AST pretty-printer: prints out the AST in a format that is close to the |
| 36 | // original C code. The output is intended to be in a format such that |
| 37 | // clang could re-parse the output back into the same AST, but the |
| 38 | // implementation is still incomplete. |
| Chris Lattner | 0fa0daa | 2009-08-24 04:11:30 +0000 | [diff] [blame^] | 39 | ASTConsumer *CreateASTPrinter(llvm::raw_ostream *OS); |
| Ted Kremenek | fdfc198 | 2007-12-19 22:24:34 +0000 | [diff] [blame] | 40 | |
| Douglas Gregor | ee75c05 | 2009-05-21 20:55:50 +0000 | [diff] [blame] | 41 | // AST XML-printer: prints out the AST in a XML format |
| 42 | // The output is intended to be in a format such that |
| 43 | // clang or any other tool could re-parse the output back into the same AST, |
| 44 | // but the implementation is still incomplete. |
| Chris Lattner | 0fa0daa | 2009-08-24 04:11:30 +0000 | [diff] [blame^] | 45 | ASTConsumer *CreateASTPrinterXML(llvm::raw_ostream *OS); |
| Douglas Gregor | ee75c05 | 2009-05-21 20:55:50 +0000 | [diff] [blame] | 46 | |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 47 | // AST dumper: dumps the raw AST in human-readable form to stderr; this is |
| Douglas Gregor | 4fe0c8e | 2009-05-30 00:08:05 +0000 | [diff] [blame] | 48 | // intended for debugging. |
| 49 | ASTConsumer *CreateASTDumper(); |
| Ted Kremenek | fdfc198 | 2007-12-19 22:24:34 +0000 | [diff] [blame] | 50 | |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 51 | // Graphical AST viewer: for each function definition, creates a graph of |
| 52 | // the AST and displays it with the graph viewer "dotty". Also outputs |
| 53 | // function declarations to stderr. |
| Ted Kremenek | 80de08f | 2007-09-19 21:29:43 +0000 | [diff] [blame] | 54 | ASTConsumer *CreateASTViewer(); |
| Ted Kremenek | fdfc198 | 2007-12-19 22:24:34 +0000 | [diff] [blame] | 55 | |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 56 | // DeclContext printer: prints out the DeclContext tree in human-readable form |
| 57 | // to stderr; this is intended for debugging. |
| Zhongxing Xu | 2d75d6f | 2009-01-13 01:29:24 +0000 | [diff] [blame] | 58 | ASTConsumer *CreateDeclContextPrinter(); |
| 59 | |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 60 | // ObjC rewriter: attempts tp rewrite ObjC constructs into pure C code. |
| 61 | // This is considered experimental, and only works with Apple's ObjC runtime. |
| Chris Lattner | 0fa0daa | 2009-08-24 04:11:30 +0000 | [diff] [blame^] | 62 | ASTConsumer *CreateObjCRewriter(const std::string &InFile, |
| 63 | llvm::raw_ostream *OS, |
| Eli Friedman | bce831b | 2009-05-18 22:29:17 +0000 | [diff] [blame] | 64 | Diagnostic &Diags, |
| Eli Friedman | c6d656e | 2009-05-18 22:39:16 +0000 | [diff] [blame] | 65 | const LangOptions &LOpts, |
| 66 | bool SilenceRewriteMacroWarning); |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 67 | |
| 68 | // LLVM code generator: uses the code generation backend to generate LLVM |
| 69 | // assembly. This runs optimizations depending on the CompileOptions |
| 70 | // parameter. The output depends on the Action parameter. |
| Daniel Dunbar | d69bacc | 2008-10-21 23:49:24 +0000 | [diff] [blame] | 71 | enum BackendAction { |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 72 | Backend_EmitAssembly, // Emit native assembly |
| 73 | Backend_EmitBC, // Emit LLVM bitcode file |
| 74 | Backend_EmitLL, // Emit human-readable LLVM assembly |
| 75 | Backend_EmitNothing // Don't emit anything (benchmarking mode) |
| Daniel Dunbar | d69bacc | 2008-10-21 23:49:24 +0000 | [diff] [blame] | 76 | }; |
| 77 | ASTConsumer *CreateBackendConsumer(BackendAction Action, |
| 78 | Diagnostic &Diags, |
| 79 | const LangOptions &Features, |
| Daniel Dunbar | 70f9243 | 2008-10-23 05:50:47 +0000 | [diff] [blame] | 80 | const CompileOptions &CompileOpts, |
| Eli Friedman | 66d6f04 | 2009-05-18 22:20:00 +0000 | [diff] [blame] | 81 | const std::string &ModuleID, |
| Owen Anderson | 42253cc | 2009-07-01 17:00:06 +0000 | [diff] [blame] | 82 | llvm::raw_ostream *OS, |
| Owen Anderson | 8f1ca78 | 2009-07-01 23:14:14 +0000 | [diff] [blame] | 83 | llvm::LLVMContext& C); |
| Ted Kremenek | fdfc198 | 2007-12-19 22:24:34 +0000 | [diff] [blame] | 84 | |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 85 | // HTML printer: uses the rewriter to convert source code to HTML with |
| 86 | // syntax highlighting suitable for viewing in a web-browser. |
| Eli Friedman | 66d6f04 | 2009-05-18 22:20:00 +0000 | [diff] [blame] | 87 | ASTConsumer* CreateHTMLPrinter(llvm::raw_ostream *OS, Diagnostic &D, |
| Chris Lattner | 0b1fb98 | 2009-04-10 17:15:23 +0000 | [diff] [blame] | 88 | Preprocessor *PP, PreprocessorFactory *PPF); |
| Ted Kremenek | 6a34083 | 2008-03-18 21:19:49 +0000 | [diff] [blame] | 89 | |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 90 | // PCH generator: generates a precompiled header file; this file can be |
| 91 | // used later with the PCHReader (clang-cc option -include-pch) |
| 92 | // to speed up compile times. |
| Chris Lattner | df961c2 | 2009-04-10 18:08:30 +0000 | [diff] [blame] | 93 | ASTConsumer *CreatePCHGenerator(const Preprocessor &PP, |
| Douglas Gregor | e650c8c | 2009-07-07 00:12:59 +0000 | [diff] [blame] | 94 | llvm::raw_ostream *OS, |
| 95 | const char *isysroot = 0); |
| Douglas Gregor | 2cf2634 | 2009-04-09 22:27:44 +0000 | [diff] [blame] | 96 | |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 97 | // Block rewriter: rewrites code using the Apple blocks extension to pure |
| Eli Friedman | 66d6f04 | 2009-05-18 22:20:00 +0000 | [diff] [blame] | 98 | // C code. Output is always sent to stdout. |
| Chris Lattner | 0b1fb98 | 2009-04-10 17:15:23 +0000 | [diff] [blame] | 99 | ASTConsumer *CreateBlockRewriter(const std::string &InFile, |
| Steve Naroff | 1c9f81b | 2008-09-17 00:13:27 +0000 | [diff] [blame] | 100 | Diagnostic &Diags, |
| 101 | const LangOptions &LangOpts); |
| Eli Friedman | 18d868f | 2009-05-18 01:16:21 +0000 | [diff] [blame] | 102 | |
| 103 | // Inheritance viewer: for C++ code, creates a graph of the inheritance |
| 104 | // tree for the given class and displays it with "dotty". |
| Ted Kremenek | 7cae2f6 | 2008-10-23 23:36:29 +0000 | [diff] [blame] | 105 | ASTConsumer *CreateInheritanceViewer(const std::string& clsname); |
| 106 | |
| Ted Kremenek | be1fe1e | 2009-02-17 04:27:41 +0000 | [diff] [blame] | 107 | } // end clang namespace |
| Ted Kremenek | f4381fd | 2008-07-02 00:03:09 +0000 | [diff] [blame] | 108 | |
| Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 109 | #endif |