ExecuteCompilerInvocation.cpp 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. //===--- ExecuteCompilerInvocation.cpp ------------------------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is distributed under the University of Illinois Open Source
  6. // License. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. //
  10. // This file holds ExecuteCompilerInvocation(). It is split into its own file to
  11. // minimize the impact of pulling in essentially everything else in Clang.
  12. //
  13. //===----------------------------------------------------------------------===//
  14. #include "clang/FrontendTool/Utils.h"
  15. #include "clang/ARCMigrate/ARCMTActions.h"
  16. #include "clang/CodeGen/CodeGenAction.h"
  17. #include "clang/Driver/Options.h"
  18. #include "clang/Frontend/CompilerInstance.h"
  19. #include "clang/Frontend/CompilerInvocation.h"
  20. #include "clang/Frontend/FrontendActions.h"
  21. #include "clang/Frontend/FrontendDiagnostic.h"
  22. #include "clang/Frontend/FrontendPluginRegistry.h"
  23. #include "clang/Frontend/Utils.h"
  24. #include "clang/Rewrite/Frontend/FrontendActions.h"
  25. #include "clang/StaticAnalyzer/Frontend/FrontendActions.h"
  26. #include "llvm/Option/OptTable.h"
  27. #include "llvm/Option/Option.h"
  28. #include "llvm/Support/DynamicLibrary.h"
  29. #include "llvm/Support/ErrorHandling.h"
  30. using namespace clang;
  31. using namespace llvm::opt;
  32. static FrontendAction *CreateFrontendBaseAction(CompilerInstance &CI) {
  33. using namespace clang::frontend;
  34. StringRef Action("unknown");
  35. (void)Action;
  36. switch (CI.getFrontendOpts().ProgramAction) {
  37. case ASTDeclList: return new ASTDeclListAction();
  38. case ASTDump: return new ASTDumpAction();
  39. case ASTPrint: return new ASTPrintAction();
  40. case ASTView: return new ASTViewAction();
  41. case DumpRawTokens: return new DumpRawTokensAction();
  42. case DumpTokens: return new DumpTokensAction();
  43. case EmitAssembly: return new EmitAssemblyAction();
  44. case EmitBC: return new EmitBCAction();
  45. #ifdef CLANG_ENABLE_REWRITER
  46. case EmitHTML: return new HTMLPrintAction();
  47. #else
  48. case EmitHTML: Action = "EmitHTML"; break;
  49. #endif
  50. case EmitLLVM: return new EmitLLVMAction();
  51. case EmitLLVMOnly: return new EmitLLVMOnlyAction();
  52. case EmitCodeGenOnly: return new EmitCodeGenOnlyAction();
  53. case EmitObj: return new EmitObjAction();
  54. #ifdef CLANG_ENABLE_REWRITER
  55. case FixIt: return new FixItAction();
  56. #else
  57. case FixIt: Action = "FixIt"; break;
  58. #endif
  59. case GenerateModule: return new GenerateModuleAction;
  60. case GeneratePCH: return new GeneratePCHAction;
  61. case GeneratePTH: return new GeneratePTHAction();
  62. case InitOnly: return new InitOnlyAction();
  63. case ParseSyntaxOnly: return new SyntaxOnlyAction();
  64. case ModuleFileInfo: return new DumpModuleInfoAction();
  65. case PluginAction: {
  66. for (FrontendPluginRegistry::iterator it =
  67. FrontendPluginRegistry::begin(), ie = FrontendPluginRegistry::end();
  68. it != ie; ++it) {
  69. if (it->getName() == CI.getFrontendOpts().ActionName) {
  70. OwningPtr<PluginASTAction> P(it->instantiate());
  71. if (!P->ParseArgs(CI, CI.getFrontendOpts().PluginArgs))
  72. return 0;
  73. return P.take();
  74. }
  75. }
  76. CI.getDiagnostics().Report(diag::err_fe_invalid_plugin_name)
  77. << CI.getFrontendOpts().ActionName;
  78. return 0;
  79. }
  80. case PrintDeclContext: return new DeclContextPrintAction();
  81. case PrintPreamble: return new PrintPreambleAction();
  82. case PrintPreprocessedInput: {
  83. if (CI.getPreprocessorOutputOpts().RewriteIncludes) {
  84. #ifdef CLANG_ENABLE_REWRITER
  85. return new RewriteIncludesAction();
  86. #else
  87. Action = "RewriteIncludesAction";
  88. break;
  89. #endif
  90. }
  91. return new PrintPreprocessedAction();
  92. }
  93. #ifdef CLANG_ENABLE_REWRITER
  94. case RewriteMacros: return new RewriteMacrosAction();
  95. case RewriteObjC: return new RewriteObjCAction();
  96. case RewriteTest: return new RewriteTestAction();
  97. #else
  98. case RewriteMacros: Action = "RewriteMacros"; break;
  99. case RewriteObjC: Action = "RewriteObjC"; break;
  100. case RewriteTest: Action = "RewriteTest"; break;
  101. #endif
  102. #ifdef CLANG_ENABLE_ARCMT
  103. case MigrateSource: return new arcmt::MigrateSourceAction();
  104. #else
  105. case MigrateSource: Action = "MigrateSource"; break;
  106. #endif
  107. #ifdef CLANG_ENABLE_STATIC_ANALYZER
  108. case RunAnalysis: return new ento::AnalysisAction();
  109. #else
  110. case RunAnalysis: Action = "RunAnalysis"; break;
  111. #endif
  112. case RunPreprocessorOnly: return new PreprocessOnlyAction();
  113. }
  114. #if !defined(CLANG_ENABLE_ARCMT) || !defined(CLANG_ENABLE_STATIC_ANALYZER) \
  115. || !defined(CLANG_ENABLE_REWRITER)
  116. CI.getDiagnostics().Report(diag::err_fe_action_not_available) << Action;
  117. return 0;
  118. #else
  119. llvm_unreachable("Invalid program action!");
  120. #endif
  121. }
  122. static FrontendAction *CreateFrontendAction(CompilerInstance &CI) {
  123. // Create the underlying action.
  124. FrontendAction *Act = CreateFrontendBaseAction(CI);
  125. if (!Act)
  126. return 0;
  127. const FrontendOptions &FEOpts = CI.getFrontendOpts();
  128. #ifdef CLANG_ENABLE_REWRITER
  129. if (FEOpts.FixAndRecompile) {
  130. Act = new FixItRecompile(Act);
  131. }
  132. #endif
  133. #ifdef CLANG_ENABLE_ARCMT
  134. if (CI.getFrontendOpts().ProgramAction != frontend::MigrateSource) {
  135. // Potentially wrap the base FE action in an ARC Migrate Tool action.
  136. switch (FEOpts.ARCMTAction) {
  137. case FrontendOptions::ARCMT_None:
  138. break;
  139. case FrontendOptions::ARCMT_Check:
  140. Act = new arcmt::CheckAction(Act);
  141. break;
  142. case FrontendOptions::ARCMT_Modify:
  143. Act = new arcmt::ModifyAction(Act);
  144. break;
  145. case FrontendOptions::ARCMT_Migrate:
  146. Act = new arcmt::MigrateAction(Act,
  147. FEOpts.MTMigrateDir,
  148. FEOpts.ARCMTMigrateReportOut,
  149. FEOpts.ARCMTMigrateEmitARCErrors);
  150. break;
  151. }
  152. if (FEOpts.ObjCMTAction != FrontendOptions::ObjCMT_None) {
  153. Act = new arcmt::ObjCMigrateAction(Act, FEOpts.MTMigrateDir,
  154. FEOpts.ObjCMTAction);
  155. }
  156. }
  157. #endif
  158. // If there are any AST files to merge, create a frontend action
  159. // adaptor to perform the merge.
  160. if (!FEOpts.ASTMergeFiles.empty())
  161. Act = new ASTMergeAction(Act, FEOpts.ASTMergeFiles);
  162. return Act;
  163. }
  164. bool clang::ExecuteCompilerInvocation(CompilerInstance *Clang) {
  165. // Honor -help.
  166. if (Clang->getFrontendOpts().ShowHelp) {
  167. OwningPtr<OptTable> Opts(driver::createDriverOptTable());
  168. Opts->PrintHelp(llvm::outs(), "clang -cc1",
  169. "LLVM 'Clang' Compiler: http://clang.llvm.org",
  170. /*Include=*/ driver::options::CC1Option, /*Exclude=*/ 0);
  171. return true;
  172. }
  173. // Honor -version.
  174. //
  175. // FIXME: Use a better -version message?
  176. if (Clang->getFrontendOpts().ShowVersion) {
  177. llvm::cl::PrintVersionMessage();
  178. return true;
  179. }
  180. // Load any requested plugins.
  181. for (unsigned i = 0,
  182. e = Clang->getFrontendOpts().Plugins.size(); i != e; ++i) {
  183. const std::string &Path = Clang->getFrontendOpts().Plugins[i];
  184. std::string Error;
  185. if (llvm::sys::DynamicLibrary::LoadLibraryPermanently(Path.c_str(), &Error))
  186. Clang->getDiagnostics().Report(diag::err_fe_unable_to_load_plugin)
  187. << Path << Error;
  188. }
  189. // Honor -mllvm.
  190. //
  191. // FIXME: Remove this, one day.
  192. // This should happen AFTER plugins have been loaded!
  193. if (!Clang->getFrontendOpts().LLVMArgs.empty()) {
  194. unsigned NumArgs = Clang->getFrontendOpts().LLVMArgs.size();
  195. const char **Args = new const char*[NumArgs + 2];
  196. Args[0] = "clang (LLVM option parsing)";
  197. for (unsigned i = 0; i != NumArgs; ++i)
  198. Args[i + 1] = Clang->getFrontendOpts().LLVMArgs[i].c_str();
  199. Args[NumArgs + 1] = 0;
  200. llvm::cl::ParseCommandLineOptions(NumArgs + 1, Args);
  201. }
  202. #ifdef CLANG_ENABLE_STATIC_ANALYZER
  203. // Honor -analyzer-checker-help.
  204. // This should happen AFTER plugins have been loaded!
  205. if (Clang->getAnalyzerOpts()->ShowCheckerHelp) {
  206. ento::printCheckerHelp(llvm::outs(), Clang->getFrontendOpts().Plugins);
  207. return true;
  208. }
  209. #endif
  210. // If there were errors in processing arguments, don't do anything else.
  211. if (Clang->getDiagnostics().hasErrorOccurred())
  212. return false;
  213. // Create and execute the frontend action.
  214. OwningPtr<FrontendAction> Act(CreateFrontendAction(*Clang));
  215. if (!Act)
  216. return false;
  217. bool Success = Clang->ExecuteAction(*Act);
  218. if (Clang->getFrontendOpts().DisableFree)
  219. BuryPointer(Act.take());
  220. return Success;
  221. }