ExecuteCompilerInvocation.cpp 8.5 KB

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