CompilerInvocation.cpp 53 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412
  1. //===--- CompilerInvocation.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. #include "clang/Frontend/CompilerInvocation.h"
  10. #include "clang/Basic/Diagnostic.h"
  11. #include "clang/Basic/Version.h"
  12. #include "clang/Driver/Arg.h"
  13. #include "clang/Driver/ArgList.h"
  14. #include "clang/Driver/CC1Options.h"
  15. #include "clang/Driver/DriverDiagnostic.h"
  16. #include "clang/Driver/OptTable.h"
  17. #include "clang/Driver/Option.h"
  18. #include "clang/Frontend/CompilerInvocation.h"
  19. #include "clang/Frontend/LangStandard.h"
  20. #include "clang/Frontend/PCHReader.h"
  21. #include "llvm/ADT/OwningPtr.h"
  22. #include "llvm/ADT/SmallVector.h"
  23. #include "llvm/ADT/StringExtras.h"
  24. #include "llvm/ADT/StringSwitch.h"
  25. #include "llvm/Support/ErrorHandling.h"
  26. #include "llvm/System/Host.h"
  27. #include "llvm/System/Path.h"
  28. using namespace clang;
  29. static const char *getAnalysisName(Analyses Kind) {
  30. switch (Kind) {
  31. default:
  32. llvm_unreachable("Unknown analysis kind!");
  33. #define ANALYSIS(NAME, CMDFLAG, DESC, SCOPE)\
  34. case NAME: return "-" CMDFLAG;
  35. #include "clang/Frontend/Analyses.def"
  36. }
  37. }
  38. static const char *getAnalysisStoreName(AnalysisStores Kind) {
  39. switch (Kind) {
  40. default:
  41. llvm_unreachable("Unknown analysis store!");
  42. #define ANALYSIS_STORE(NAME, CMDFLAG, DESC, CREATFN) \
  43. case NAME##Model: return CMDFLAG;
  44. #include "clang/Frontend/Analyses.def"
  45. }
  46. }
  47. static const char *getAnalysisConstraintName(AnalysisConstraints Kind) {
  48. switch (Kind) {
  49. default:
  50. llvm_unreachable("Unknown analysis constraints!");
  51. #define ANALYSIS_CONSTRAINTS(NAME, CMDFLAG, DESC, CREATFN) \
  52. case NAME##Model: return CMDFLAG;
  53. #include "clang/Frontend/Analyses.def"
  54. }
  55. }
  56. static const char *getAnalysisDiagClientName(AnalysisDiagClients Kind) {
  57. switch (Kind) {
  58. default:
  59. llvm_unreachable("Unknown analysis client!");
  60. #define ANALYSIS_DIAGNOSTICS(NAME, CMDFLAG, DESC, CREATFN, AUTOCREATE) \
  61. case PD_##NAME: return CMDFLAG;
  62. #include "clang/Frontend/Analyses.def"
  63. }
  64. }
  65. //===----------------------------------------------------------------------===//
  66. // Serialization (to args)
  67. //===----------------------------------------------------------------------===//
  68. static void AnalyzerOptsToArgs(const AnalyzerOptions &Opts,
  69. std::vector<std::string> &Res) {
  70. for (unsigned i = 0, e = Opts.AnalysisList.size(); i != e; ++i)
  71. Res.push_back(getAnalysisName(Opts.AnalysisList[i]));
  72. if (Opts.AnalysisStoreOpt != BasicStoreModel) {
  73. Res.push_back("-analyzer-store");
  74. Res.push_back(getAnalysisStoreName(Opts.AnalysisStoreOpt));
  75. }
  76. if (Opts.AnalysisConstraintsOpt != RangeConstraintsModel) {
  77. Res.push_back("-analyzer-constraints");
  78. Res.push_back(getAnalysisConstraintName(Opts.AnalysisConstraintsOpt));
  79. }
  80. if (Opts.AnalysisDiagOpt != PD_HTML) {
  81. Res.push_back("-analyzer-output");
  82. Res.push_back(getAnalysisDiagClientName(Opts.AnalysisDiagOpt));
  83. }
  84. if (!Opts.AnalyzeSpecificFunction.empty()) {
  85. Res.push_back("-analyze-function");
  86. Res.push_back(Opts.AnalyzeSpecificFunction);
  87. }
  88. if (Opts.AnalyzeAll)
  89. Res.push_back("-analyzer-opt-analyze-headers");
  90. if (Opts.AnalyzerDisplayProgress)
  91. Res.push_back("-analyzer-display-progress");
  92. if (Opts.AnalyzeNestedBlocks)
  93. Res.push_back("-analyzer-opt-analyze-nested-blocks");
  94. if (Opts.EagerlyAssume)
  95. Res.push_back("-analyzer-eagerly-assume");
  96. if (!Opts.PurgeDead)
  97. Res.push_back("-analyzer-no-purge-dead");
  98. if (Opts.TrimGraph)
  99. Res.push_back("-trim-egraph");
  100. if (Opts.VisualizeEGDot)
  101. Res.push_back("-analyzer-viz-egraph-graphviz");
  102. if (Opts.VisualizeEGDot)
  103. Res.push_back("-analyzer-viz-egraph-ubigraph");
  104. if (Opts.EnableExperimentalChecks)
  105. Res.push_back("-analyzer-experimental-checks");
  106. if (Opts.EnableExperimentalInternalChecks)
  107. Res.push_back("-analyzer-experimental-internal-checks");
  108. }
  109. static void CodeGenOptsToArgs(const CodeGenOptions &Opts,
  110. std::vector<std::string> &Res) {
  111. if (Opts.DebugInfo)
  112. Res.push_back("-g");
  113. if (Opts.DisableLLVMOpts)
  114. Res.push_back("-disable-llvm-optzns");
  115. if (Opts.DisableRedZone)
  116. Res.push_back("-disable-red-zone");
  117. if (!Opts.DwarfDebugFlags.empty()) {
  118. Res.push_back("-dwarf-debug-flags");
  119. Res.push_back(Opts.DwarfDebugFlags);
  120. }
  121. if (!Opts.MergeAllConstants)
  122. Res.push_back("-fno-merge-all-constants");
  123. if (Opts.NoCommon)
  124. Res.push_back("-fno-common");
  125. if (Opts.NoImplicitFloat)
  126. Res.push_back("-no-implicit-float");
  127. if (Opts.OptimizeSize) {
  128. assert(Opts.OptimizationLevel == 2 && "Invalid options!");
  129. Res.push_back("-Os");
  130. } else if (Opts.OptimizationLevel != 0)
  131. Res.push_back("-O" + llvm::utostr(Opts.OptimizationLevel));
  132. if (!Opts.MainFileName.empty()) {
  133. Res.push_back("-main-file-name");
  134. Res.push_back(Opts.MainFileName);
  135. }
  136. // SimplifyLibCalls is only derived.
  137. // TimePasses is only derived.
  138. // UnitAtATime is unused.
  139. // UnrollLoops is only derived.
  140. // Inlining is only derived.
  141. if (Opts.DataSections)
  142. Res.push_back("-fdata-sections");
  143. if (Opts.FunctionSections)
  144. Res.push_back("-ffunction-sections");
  145. if (Opts.AsmVerbose)
  146. Res.push_back("-masm-verbose");
  147. if (!Opts.CodeModel.empty()) {
  148. Res.push_back("-mcode-model");
  149. Res.push_back(Opts.CodeModel);
  150. }
  151. if (!Opts.CXAAtExit)
  152. Res.push_back("-fno-use-cxa-atexit");
  153. if (Opts.CXXCtorDtorAliases)
  154. Res.push_back("-mconstructor-aliases");
  155. if (!Opts.DebugPass.empty()) {
  156. Res.push_back("-mdebug-pass");
  157. Res.push_back(Opts.DebugPass);
  158. }
  159. if (Opts.DisableFPElim)
  160. Res.push_back("-mdisable-fp-elim");
  161. if (!Opts.FloatABI.empty()) {
  162. Res.push_back("-mfloat-abi");
  163. Res.push_back(Opts.FloatABI);
  164. }
  165. if (!Opts.LimitFloatPrecision.empty()) {
  166. Res.push_back("-mlimit-float-precision");
  167. Res.push_back(Opts.LimitFloatPrecision);
  168. }
  169. if (Opts.NoZeroInitializedInBSS)
  170. Res.push_back("-mno-zero-initialized-bss");
  171. switch (Opts.getObjCDispatchMethod()) {
  172. case CodeGenOptions::Legacy:
  173. break;
  174. case CodeGenOptions::Mixed:
  175. Res.push_back("-fobjc-dispatch-method=mixed");
  176. break;
  177. case CodeGenOptions::NonLegacy:
  178. Res.push_back("-fobjc-dispatch-method=non-legacy");
  179. break;
  180. }
  181. if (Opts.RelaxAll)
  182. Res.push_back("-mrelax-all");
  183. if (Opts.SoftFloat)
  184. Res.push_back("-msoft-float");
  185. if (Opts.UnwindTables)
  186. Res.push_back("-munwind-tables");
  187. if (Opts.RelocationModel != "pic") {
  188. Res.push_back("-mrelocation-model");
  189. Res.push_back(Opts.RelocationModel);
  190. }
  191. if (!Opts.VerifyModule)
  192. Res.push_back("-disable-llvm-verifier");
  193. }
  194. static void DependencyOutputOptsToArgs(const DependencyOutputOptions &Opts,
  195. std::vector<std::string> &Res) {
  196. if (Opts.IncludeSystemHeaders)
  197. Res.push_back("-sys-header-deps");
  198. if (Opts.UsePhonyTargets)
  199. Res.push_back("-MP");
  200. if (!Opts.OutputFile.empty()) {
  201. Res.push_back("-dependency-file");
  202. Res.push_back(Opts.OutputFile);
  203. }
  204. for (unsigned i = 0, e = Opts.Targets.size(); i != e; ++i) {
  205. Res.push_back("-MT");
  206. Res.push_back(Opts.Targets[i]);
  207. }
  208. }
  209. static void DiagnosticOptsToArgs(const DiagnosticOptions &Opts,
  210. std::vector<std::string> &Res) {
  211. if (Opts.IgnoreWarnings)
  212. Res.push_back("-w");
  213. if (Opts.NoRewriteMacros)
  214. Res.push_back("-Wno-rewrite-macros");
  215. if (Opts.Pedantic)
  216. Res.push_back("-pedantic");
  217. if (Opts.PedanticErrors)
  218. Res.push_back("-pedantic-errors");
  219. if (!Opts.ShowColumn)
  220. Res.push_back("-fno-show-column");
  221. if (!Opts.ShowLocation)
  222. Res.push_back("-fno-show-source-location");
  223. if (!Opts.ShowCarets)
  224. Res.push_back("-fno-caret-diagnostics");
  225. if (!Opts.ShowFixits)
  226. Res.push_back("-fno-diagnostics-fixit-info");
  227. if (Opts.ShowSourceRanges)
  228. Res.push_back("-fdiagnostics-print-source-range-info");
  229. if (Opts.ShowColors)
  230. Res.push_back("-fcolor-diagnostics");
  231. if (Opts.VerifyDiagnostics)
  232. Res.push_back("-verify");
  233. if (Opts.BinaryOutput)
  234. Res.push_back("-fdiagnostics-binary");
  235. if (Opts.ShowOptionNames)
  236. Res.push_back("-fdiagnostics-show-option");
  237. if (Opts.ShowCategories == 1)
  238. Res.push_back("-fdiagnostics-show-category=id");
  239. else if (Opts.ShowCategories == 2)
  240. Res.push_back("-fdiagnostics-show-category=name");
  241. if (Opts.ErrorLimit) {
  242. Res.push_back("-ferror-limit");
  243. Res.push_back(llvm::utostr(Opts.ErrorLimit));
  244. }
  245. if (Opts.MacroBacktraceLimit
  246. != DiagnosticOptions::DefaultMacroBacktraceLimit) {
  247. Res.push_back("-fmacro-backtrace-limit");
  248. Res.push_back(llvm::utostr(Opts.MacroBacktraceLimit));
  249. }
  250. if (Opts.TemplateBacktraceLimit
  251. != DiagnosticOptions::DefaultTemplateBacktraceLimit) {
  252. Res.push_back("-ftemplate-backtrace-limit");
  253. Res.push_back(llvm::utostr(Opts.TemplateBacktraceLimit));
  254. }
  255. if (Opts.TabStop != DiagnosticOptions::DefaultTabStop) {
  256. Res.push_back("-ftabstop");
  257. Res.push_back(llvm::utostr(Opts.TabStop));
  258. }
  259. if (Opts.MessageLength) {
  260. Res.push_back("-fmessage-length");
  261. Res.push_back(llvm::utostr(Opts.MessageLength));
  262. }
  263. if (!Opts.DumpBuildInformation.empty()) {
  264. Res.push_back("-dump-build-information");
  265. Res.push_back(Opts.DumpBuildInformation);
  266. }
  267. for (unsigned i = 0, e = Opts.Warnings.size(); i != e; ++i)
  268. Res.push_back("-W" + Opts.Warnings[i]);
  269. }
  270. static const char *getInputKindName(InputKind Kind) {
  271. switch (Kind) {
  272. case IK_None: break;
  273. case IK_AST: return "ast";
  274. case IK_Asm: return "assembler-with-cpp";
  275. case IK_C: return "c";
  276. case IK_CXX: return "c++";
  277. case IK_LLVM_IR: return "ir";
  278. case IK_ObjC: return "objective-c";
  279. case IK_ObjCXX: return "objective-c++";
  280. case IK_OpenCL: return "cl";
  281. case IK_PreprocessedC: return "cpp-output";
  282. case IK_PreprocessedCXX: return "c++-cpp-output";
  283. case IK_PreprocessedObjC: return "objective-c-cpp-output";
  284. case IK_PreprocessedObjCXX:return "objective-c++-cpp-output";
  285. }
  286. llvm_unreachable("Unexpected language kind!");
  287. return 0;
  288. }
  289. static const char *getActionName(frontend::ActionKind Kind) {
  290. switch (Kind) {
  291. case frontend::PluginAction:
  292. case frontend::InheritanceView:
  293. llvm_unreachable("Invalid kind!");
  294. case frontend::ASTDump: return "-ast-dump";
  295. case frontend::ASTPrint: return "-ast-print";
  296. case frontend::ASTPrintXML: return "-ast-print-xml";
  297. case frontend::ASTView: return "-ast-view";
  298. case frontend::BoostCon: return "-boostcon";
  299. case frontend::DumpRawTokens: return "-dump-raw-tokens";
  300. case frontend::DumpTokens: return "-dump-tokens";
  301. case frontend::EmitAssembly: return "-S";
  302. case frontend::EmitBC: return "-emit-llvm-bc";
  303. case frontend::EmitHTML: return "-emit-html";
  304. case frontend::EmitLLVM: return "-emit-llvm";
  305. case frontend::EmitLLVMOnly: return "-emit-llvm-only";
  306. case frontend::EmitCodeGenOnly: return "-emit-codegen-only";
  307. case frontend::EmitObj: return "-emit-obj";
  308. case frontend::FixIt: return "-fixit";
  309. case frontend::GeneratePCH: return "-emit-pch";
  310. case frontend::GeneratePTH: return "-emit-pth";
  311. case frontend::InitOnly: return "-init-only";
  312. case frontend::ParseNoop: return "-parse-noop";
  313. case frontend::ParsePrintCallbacks: return "-parse-print-callbacks";
  314. case frontend::ParseSyntaxOnly: return "-fsyntax-only";
  315. case frontend::PrintDeclContext: return "-print-decl-contexts";
  316. case frontend::PrintPreprocessedInput: return "-E";
  317. case frontend::RewriteMacros: return "-rewrite-macros";
  318. case frontend::RewriteObjC: return "-rewrite-objc";
  319. case frontend::RewriteTest: return "-rewrite-test";
  320. case frontend::RunAnalysis: return "-analyze";
  321. case frontend::RunPreprocessorOnly: return "-Eonly";
  322. }
  323. llvm_unreachable("Unexpected language kind!");
  324. return 0;
  325. }
  326. static void FrontendOptsToArgs(const FrontendOptions &Opts,
  327. std::vector<std::string> &Res) {
  328. if (!Opts.DebugCodeCompletionPrinter)
  329. Res.push_back("-no-code-completion-debug-printer");
  330. if (Opts.DisableFree)
  331. Res.push_back("-disable-free");
  332. if (Opts.RelocatablePCH)
  333. Res.push_back("-relocatable-pch");
  334. if (Opts.ShowHelp)
  335. Res.push_back("-help");
  336. if (Opts.ShowMacrosInCodeCompletion)
  337. Res.push_back("-code-completion-macros");
  338. if (Opts.ShowCodePatternsInCodeCompletion)
  339. Res.push_back("-code-completion-patterns");
  340. if (Opts.ShowStats)
  341. Res.push_back("-print-stats");
  342. if (Opts.ShowTimers)
  343. Res.push_back("-ftime-report");
  344. if (Opts.ShowVersion)
  345. Res.push_back("-version");
  346. bool NeedLang = false;
  347. for (unsigned i = 0, e = Opts.Inputs.size(); i != e; ++i)
  348. if (FrontendOptions::getInputKindForExtension(Opts.Inputs[i].second) !=
  349. Opts.Inputs[i].first)
  350. NeedLang = true;
  351. if (NeedLang) {
  352. Res.push_back("-x");
  353. Res.push_back(getInputKindName(Opts.Inputs[0].first));
  354. }
  355. for (unsigned i = 0, e = Opts.Inputs.size(); i != e; ++i) {
  356. assert((!NeedLang || Opts.Inputs[i].first == Opts.Inputs[0].first) &&
  357. "Unable to represent this input vector!");
  358. Res.push_back(Opts.Inputs[i].second);
  359. }
  360. if (!Opts.OutputFile.empty()) {
  361. Res.push_back("-o");
  362. Res.push_back(Opts.OutputFile);
  363. }
  364. if (!Opts.ViewClassInheritance.empty()) {
  365. Res.push_back("-cxx-inheritance-view");
  366. Res.push_back(Opts.ViewClassInheritance);
  367. }
  368. if (!Opts.CodeCompletionAt.FileName.empty()) {
  369. Res.push_back("-code-completion-at");
  370. Res.push_back(Opts.CodeCompletionAt.FileName + ":" +
  371. llvm::utostr(Opts.CodeCompletionAt.Line) + ":" +
  372. llvm::utostr(Opts.CodeCompletionAt.Column));
  373. }
  374. if (Opts.ProgramAction != frontend::InheritanceView &&
  375. Opts.ProgramAction != frontend::PluginAction)
  376. Res.push_back(getActionName(Opts.ProgramAction));
  377. if (!Opts.ActionName.empty()) {
  378. Res.push_back("-plugin");
  379. Res.push_back(Opts.ActionName);
  380. }
  381. for (unsigned i = 0, e = Opts.Plugins.size(); i != e; ++i) {
  382. Res.push_back("-load");
  383. Res.push_back(Opts.Plugins[i]);
  384. }
  385. for (unsigned i = 0, e = Opts.ASTMergeFiles.size(); i != e; ++i) {
  386. Res.push_back("-ast-merge");
  387. Res.push_back(Opts.ASTMergeFiles[i]);
  388. }
  389. for (unsigned i = 0, e = Opts.LLVMArgs.size(); i != e; ++i) {
  390. Res.push_back("-mllvm");
  391. Res.push_back(Opts.LLVMArgs[i]);
  392. }
  393. }
  394. static void HeaderSearchOptsToArgs(const HeaderSearchOptions &Opts,
  395. std::vector<std::string> &Res) {
  396. if (Opts.Sysroot != "/") {
  397. Res.push_back("-isysroot");
  398. Res.push_back(Opts.Sysroot);
  399. }
  400. /// User specified include entries.
  401. for (unsigned i = 0, e = Opts.UserEntries.size(); i != e; ++i) {
  402. const HeaderSearchOptions::Entry &E = Opts.UserEntries[i];
  403. if (E.IsFramework && (E.Group != frontend::Angled || !E.IsUserSupplied))
  404. llvm::report_fatal_error("Invalid option set!");
  405. if (E.IsUserSupplied) {
  406. if (E.Group == frontend::After) {
  407. Res.push_back("-idirafter");
  408. } else if (E.Group == frontend::Quoted) {
  409. Res.push_back("-iquote");
  410. } else if (E.Group == frontend::System) {
  411. Res.push_back("-isystem");
  412. } else {
  413. assert(E.Group == frontend::Angled && "Invalid group!");
  414. Res.push_back(E.IsFramework ? "-F" : "-I");
  415. }
  416. } else {
  417. if (E.Group != frontend::Angled && E.Group != frontend::System)
  418. llvm::report_fatal_error("Invalid option set!");
  419. Res.push_back(E.Group == frontend::Angled ? "-iwithprefixbefore" :
  420. "-iwithprefix");
  421. }
  422. Res.push_back(E.Path);
  423. }
  424. if (!Opts.EnvIncPath.empty()) {
  425. // FIXME: Provide an option for this, and move env detection to driver.
  426. llvm::report_fatal_error("Not yet implemented!");
  427. }
  428. if (!Opts.CEnvIncPath.empty()) {
  429. // FIXME: Provide an option for this, and move env detection to driver.
  430. llvm::report_fatal_error("Not yet implemented!");
  431. }
  432. if (!Opts.ObjCEnvIncPath.empty()) {
  433. // FIXME: Provide an option for this, and move env detection to driver.
  434. llvm::report_fatal_error("Not yet implemented!");
  435. }
  436. if (!Opts.CXXEnvIncPath.empty()) {
  437. // FIXME: Provide an option for this, and move env detection to driver.
  438. llvm::report_fatal_error("Not yet implemented!");
  439. }
  440. if (!Opts.ObjCXXEnvIncPath.empty()) {
  441. // FIXME: Provide an option for this, and move env detection to driver.
  442. llvm::report_fatal_error("Not yet implemented!");
  443. }
  444. if (!Opts.ResourceDir.empty()) {
  445. Res.push_back("-resource-dir");
  446. Res.push_back(Opts.ResourceDir);
  447. }
  448. if (!Opts.UseStandardIncludes)
  449. Res.push_back("-nostdinc");
  450. if (!Opts.UseStandardCXXIncludes)
  451. Res.push_back("-nostdinc++");
  452. if (Opts.Verbose)
  453. Res.push_back("-v");
  454. }
  455. static void LangOptsToArgs(const LangOptions &Opts,
  456. std::vector<std::string> &Res) {
  457. LangOptions DefaultLangOpts;
  458. // FIXME: Need to set -std to get all the implicit options.
  459. // FIXME: We want to only pass options relative to the defaults, which
  460. // requires constructing a target. :(
  461. //
  462. // It would be better to push the all target specific choices into the driver,
  463. // so that everything below that was more uniform.
  464. if (Opts.Trigraphs)
  465. Res.push_back("-trigraphs");
  466. // Implicit based on the input kind:
  467. // AsmPreprocessor, CPlusPlus, ObjC1, ObjC2, OpenCL
  468. // Implicit based on the input language standard:
  469. // BCPLComment, C99, CPlusPlus0x, Digraphs, GNUInline, ImplicitInt, GNUMode
  470. if (Opts.DollarIdents)
  471. Res.push_back("-fdollars-in-identifiers");
  472. if (Opts.GNUMode && !Opts.GNUKeywords)
  473. Res.push_back("-fno-gnu-keywords");
  474. if (!Opts.GNUMode && Opts.GNUKeywords)
  475. Res.push_back("-fgnu-keywords");
  476. if (Opts.Microsoft)
  477. Res.push_back("-fms-extensions");
  478. if (Opts.ObjCNonFragileABI)
  479. Res.push_back("-fobjc-nonfragile-abi");
  480. if (Opts.ObjCNonFragileABI2)
  481. Res.push_back("-fobjc-nonfragile-abi2");
  482. // NoInline is implicit.
  483. if (!Opts.CXXOperatorNames)
  484. Res.push_back("-fno-operator-names");
  485. if (Opts.PascalStrings)
  486. Res.push_back("-fpascal-strings");
  487. if (Opts.CatchUndefined)
  488. Res.push_back("-fcatch-undefined-behavior");
  489. if (Opts.WritableStrings)
  490. Res.push_back("-fwritable-strings");
  491. if (Opts.ConstStrings)
  492. Res.push_back("-Wwrite-strings");
  493. if (!Opts.LaxVectorConversions)
  494. Res.push_back("-fno-lax-vector-conversions");
  495. if (Opts.AltiVec)
  496. Res.push_back("-faltivec");
  497. if (Opts.Exceptions)
  498. Res.push_back("-fexceptions");
  499. if (Opts.SjLjExceptions)
  500. Res.push_back("-fsjlj-exceptions");
  501. if (!Opts.RTTI)
  502. Res.push_back("-fno-rtti");
  503. if (!Opts.NeXTRuntime)
  504. Res.push_back("-fgnu-runtime");
  505. if (Opts.Freestanding)
  506. Res.push_back("-ffreestanding");
  507. if (Opts.NoBuiltin)
  508. Res.push_back("-fno-builtin");
  509. if (!Opts.AssumeSaneOperatorNew)
  510. Res.push_back("-fno-assume-sane-operator-new");
  511. if (!Opts.ThreadsafeStatics)
  512. Res.push_back("-fno-threadsafe-statics");
  513. if (Opts.POSIXThreads)
  514. Res.push_back("-pthread");
  515. if (Opts.Blocks)
  516. Res.push_back("-fblocks");
  517. if (Opts.EmitAllDecls)
  518. Res.push_back("-femit-all-decls");
  519. if (Opts.MathErrno)
  520. Res.push_back("-fmath-errno");
  521. if (Opts.OverflowChecking)
  522. Res.push_back("-ftrapv");
  523. if (Opts.HeinousExtensions)
  524. Res.push_back("-fheinous-gnu-extensions");
  525. // Optimize is implicit.
  526. // OptimizeSize is implicit.
  527. if (Opts.Static)
  528. Res.push_back("-static-define");
  529. if (Opts.DumpRecordLayouts)
  530. Res.push_back("-fdump-record-layouts");
  531. if (Opts.DumpVTableLayouts)
  532. Res.push_back("-fdump-vtable-layouts");
  533. if (Opts.NoBitFieldTypeAlign)
  534. Res.push_back("-fno-bitfield-type-alignment");
  535. if (Opts.SjLjExceptions)
  536. Res.push_back("-fsjlj-exceptions");
  537. if (Opts.PICLevel) {
  538. Res.push_back("-pic-level");
  539. Res.push_back(llvm::utostr(Opts.PICLevel));
  540. }
  541. if (Opts.ObjCGCBitmapPrint)
  542. Res.push_back("-print-ivar-layout");
  543. if (Opts.NoConstantCFStrings)
  544. Res.push_back("-fno-constant-cfstrings");
  545. if (!Opts.AccessControl)
  546. Res.push_back("-fno-access-control");
  547. if (!Opts.CharIsSigned)
  548. Res.push_back("-fno-signed-char");
  549. if (Opts.ShortWChar)
  550. Res.push_back("-fshort-wchar");
  551. if (!Opts.ElideConstructors)
  552. Res.push_back("-fno-elide-constructors");
  553. if (Opts.getGCMode() != LangOptions::NonGC) {
  554. if (Opts.getGCMode() == LangOptions::HybridGC) {
  555. Res.push_back("-fobjc-gc");
  556. } else {
  557. assert(Opts.getGCMode() == LangOptions::GCOnly && "Invalid GC mode!");
  558. Res.push_back("-fobjc-gc-only");
  559. }
  560. }
  561. if (Opts.getVisibilityMode() != LangOptions::Default) {
  562. Res.push_back("-fvisibility");
  563. if (Opts.getVisibilityMode() == LangOptions::Hidden) {
  564. Res.push_back("hidden");
  565. } else {
  566. assert(Opts.getVisibilityMode() == LangOptions::Protected &&
  567. "Invalid visibility!");
  568. Res.push_back("protected");
  569. }
  570. }
  571. if (Opts.getStackProtectorMode() != 0) {
  572. Res.push_back("-stack-protector");
  573. Res.push_back(llvm::utostr(Opts.getStackProtectorMode()));
  574. }
  575. if (Opts.InstantiationDepth != DefaultLangOpts.InstantiationDepth) {
  576. Res.push_back("-ftemplate-depth");
  577. Res.push_back(llvm::utostr(Opts.InstantiationDepth));
  578. }
  579. if (!Opts.ObjCConstantStringClass.empty()) {
  580. Res.push_back("-fconstant-string-class");
  581. Res.push_back(Opts.ObjCConstantStringClass);
  582. }
  583. }
  584. static void PreprocessorOptsToArgs(const PreprocessorOptions &Opts,
  585. std::vector<std::string> &Res) {
  586. for (unsigned i = 0, e = Opts.Macros.size(); i != e; ++i)
  587. Res.push_back(std::string(Opts.Macros[i].second ? "-U" : "-D") +
  588. Opts.Macros[i].first);
  589. for (unsigned i = 0, e = Opts.Includes.size(); i != e; ++i) {
  590. // FIXME: We need to avoid reincluding the implicit PCH and PTH includes.
  591. Res.push_back("-include");
  592. Res.push_back(Opts.Includes[i]);
  593. }
  594. for (unsigned i = 0, e = Opts.MacroIncludes.size(); i != e; ++i) {
  595. Res.push_back("-imacros");
  596. Res.push_back(Opts.MacroIncludes[i]);
  597. }
  598. if (!Opts.UsePredefines)
  599. Res.push_back("-undef");
  600. if (Opts.DetailedRecord)
  601. Res.push_back("-detailed-preprocessing-record");
  602. if (!Opts.ImplicitPCHInclude.empty()) {
  603. Res.push_back("-include-pch");
  604. Res.push_back(Opts.ImplicitPCHInclude);
  605. }
  606. if (!Opts.ImplicitPTHInclude.empty()) {
  607. Res.push_back("-include-pth");
  608. Res.push_back(Opts.ImplicitPTHInclude);
  609. }
  610. if (!Opts.TokenCache.empty()) {
  611. if (Opts.ImplicitPTHInclude.empty()) {
  612. Res.push_back("-token-cache");
  613. Res.push_back(Opts.TokenCache);
  614. } else
  615. assert(Opts.ImplicitPTHInclude == Opts.TokenCache &&
  616. "Unsupported option combination!");
  617. }
  618. for (unsigned i = 0, e = Opts.RemappedFiles.size(); i != e; ++i) {
  619. Res.push_back("-remap-file");
  620. Res.push_back(Opts.RemappedFiles[i].first + ";" +
  621. Opts.RemappedFiles[i].second);
  622. }
  623. }
  624. static void PreprocessorOutputOptsToArgs(const PreprocessorOutputOptions &Opts,
  625. std::vector<std::string> &Res) {
  626. if (!Opts.ShowCPP && !Opts.ShowMacros)
  627. llvm::report_fatal_error("Invalid option combination!");
  628. if (Opts.ShowCPP && Opts.ShowMacros)
  629. Res.push_back("-dD");
  630. else if (!Opts.ShowCPP && Opts.ShowMacros)
  631. Res.push_back("-dM");
  632. if (!Opts.ShowLineMarkers)
  633. Res.push_back("-P");
  634. if (Opts.ShowComments)
  635. Res.push_back("-C");
  636. if (Opts.ShowMacroComments)
  637. Res.push_back("-CC");
  638. }
  639. static void TargetOptsToArgs(const TargetOptions &Opts,
  640. std::vector<std::string> &Res) {
  641. Res.push_back("-triple");
  642. Res.push_back(Opts.Triple);
  643. if (!Opts.CPU.empty()) {
  644. Res.push_back("-target-cpu");
  645. Res.push_back(Opts.CPU);
  646. }
  647. if (!Opts.ABI.empty()) {
  648. Res.push_back("-target-abi");
  649. Res.push_back(Opts.ABI);
  650. }
  651. for (unsigned i = 0, e = Opts.Features.size(); i != e; ++i) {
  652. Res.push_back("-target-feature");
  653. Res.push_back(Opts.Features[i]);
  654. }
  655. }
  656. void CompilerInvocation::toArgs(std::vector<std::string> &Res) {
  657. AnalyzerOptsToArgs(getAnalyzerOpts(), Res);
  658. CodeGenOptsToArgs(getCodeGenOpts(), Res);
  659. DependencyOutputOptsToArgs(getDependencyOutputOpts(), Res);
  660. DiagnosticOptsToArgs(getDiagnosticOpts(), Res);
  661. FrontendOptsToArgs(getFrontendOpts(), Res);
  662. HeaderSearchOptsToArgs(getHeaderSearchOpts(), Res);
  663. LangOptsToArgs(getLangOpts(), Res);
  664. PreprocessorOptsToArgs(getPreprocessorOpts(), Res);
  665. PreprocessorOutputOptsToArgs(getPreprocessorOutputOpts(), Res);
  666. TargetOptsToArgs(getTargetOpts(), Res);
  667. }
  668. //===----------------------------------------------------------------------===//
  669. // Deserialization (to args)
  670. //===----------------------------------------------------------------------===//
  671. using namespace clang::driver;
  672. using namespace clang::driver::cc1options;
  673. //
  674. static void ParseAnalyzerArgs(AnalyzerOptions &Opts, ArgList &Args,
  675. Diagnostic &Diags) {
  676. using namespace cc1options;
  677. Opts.AnalysisList.clear();
  678. #define ANALYSIS(NAME, CMDFLAG, DESC, SCOPE) \
  679. if (Args.hasArg(OPT_analysis_##NAME)) Opts.AnalysisList.push_back(NAME);
  680. #include "clang/Frontend/Analyses.def"
  681. if (Arg *A = Args.getLastArg(OPT_analyzer_store)) {
  682. llvm::StringRef Name = A->getValue(Args);
  683. AnalysisStores Value = llvm::StringSwitch<AnalysisStores>(Name)
  684. #define ANALYSIS_STORE(NAME, CMDFLAG, DESC, CREATFN) \
  685. .Case(CMDFLAG, NAME##Model)
  686. #include "clang/Frontend/Analyses.def"
  687. .Default(NumStores);
  688. // FIXME: Error handling.
  689. if (Value == NumStores)
  690. Diags.Report(diag::err_drv_invalid_value)
  691. << Args.getLastArg(OPT_O)->getAsString(Args) << Name;
  692. else
  693. Opts.AnalysisStoreOpt = Value;
  694. }
  695. if (Arg *A = Args.getLastArg(OPT_analyzer_constraints)) {
  696. llvm::StringRef Name = A->getValue(Args);
  697. AnalysisConstraints Value = llvm::StringSwitch<AnalysisConstraints>(Name)
  698. #define ANALYSIS_CONSTRAINTS(NAME, CMDFLAG, DESC, CREATFN) \
  699. .Case(CMDFLAG, NAME##Model)
  700. #include "clang/Frontend/Analyses.def"
  701. .Default(NumConstraints);
  702. // FIXME: Error handling.
  703. if (Value == NumConstraints)
  704. Diags.Report(diag::err_drv_invalid_value)
  705. << Args.getLastArg(OPT_O)->getAsString(Args) << Name;
  706. else
  707. Opts.AnalysisConstraintsOpt = Value;
  708. }
  709. if (Arg *A = Args.getLastArg(OPT_analyzer_output)) {
  710. llvm::StringRef Name = A->getValue(Args);
  711. AnalysisDiagClients Value = llvm::StringSwitch<AnalysisDiagClients>(Name)
  712. #define ANALYSIS_DIAGNOSTICS(NAME, CMDFLAG, DESC, CREATFN, AUTOCREAT) \
  713. .Case(CMDFLAG, PD_##NAME)
  714. #include "clang/Frontend/Analyses.def"
  715. .Default(NUM_ANALYSIS_DIAG_CLIENTS);
  716. // FIXME: Error handling.
  717. if (Value == NUM_ANALYSIS_DIAG_CLIENTS)
  718. Diags.Report(diag::err_drv_invalid_value)
  719. << Args.getLastArg(OPT_O)->getAsString(Args) << Name;
  720. else
  721. Opts.AnalysisDiagOpt = Value;
  722. }
  723. Opts.VisualizeEGDot = Args.hasArg(OPT_analyzer_viz_egraph_graphviz);
  724. Opts.VisualizeEGUbi = Args.hasArg(OPT_analyzer_viz_egraph_ubigraph);
  725. Opts.AnalyzeAll = Args.hasArg(OPT_analyzer_opt_analyze_headers);
  726. Opts.AnalyzerDisplayProgress = Args.hasArg(OPT_analyzer_display_progress);
  727. Opts.AnalyzeNestedBlocks =
  728. Args.hasArg(OPT_analyzer_opt_analyze_nested_blocks);
  729. Opts.PurgeDead = !Args.hasArg(OPT_analyzer_no_purge_dead);
  730. Opts.EagerlyAssume = Args.hasArg(OPT_analyzer_eagerly_assume);
  731. Opts.AnalyzeSpecificFunction = Args.getLastArgValue(OPT_analyze_function);
  732. Opts.EnableExperimentalChecks = Args.hasArg(OPT_analyzer_experimental_checks);
  733. Opts.EnableExperimentalInternalChecks =
  734. Args.hasArg(OPT_analyzer_experimental_internal_checks);
  735. Opts.TrimGraph = Args.hasArg(OPT_trim_egraph);
  736. Opts.MaxNodes = Args.getLastArgIntValue(OPT_analyzer_max_nodes, 150000,Diags);
  737. Opts.MaxLoop = Args.getLastArgIntValue(OPT_analyzer_max_loop, 3, Diags);
  738. Opts.InlineCall = Args.hasArg(OPT_analyzer_inline_call);
  739. }
  740. static void ParseCodeGenArgs(CodeGenOptions &Opts, ArgList &Args,
  741. Diagnostic &Diags) {
  742. using namespace cc1options;
  743. // -Os implies -O2
  744. if (Args.hasArg(OPT_Os))
  745. Opts.OptimizationLevel = 2;
  746. else {
  747. Opts.OptimizationLevel = Args.getLastArgIntValue(OPT_O, 0, Diags);
  748. if (Opts.OptimizationLevel > 3) {
  749. Diags.Report(diag::err_drv_invalid_value)
  750. << Args.getLastArg(OPT_O)->getAsString(Args) << Opts.OptimizationLevel;
  751. Opts.OptimizationLevel = 3;
  752. }
  753. }
  754. // We must always run at least the always inlining pass.
  755. Opts.Inlining = (Opts.OptimizationLevel > 1) ? CodeGenOptions::NormalInlining
  756. : CodeGenOptions::OnlyAlwaysInlining;
  757. Opts.DebugInfo = Args.hasArg(OPT_g);
  758. Opts.DisableLLVMOpts = Args.hasArg(OPT_disable_llvm_optzns);
  759. Opts.DisableRedZone = Args.hasArg(OPT_disable_red_zone);
  760. Opts.DwarfDebugFlags = Args.getLastArgValue(OPT_dwarf_debug_flags);
  761. Opts.MergeAllConstants = !Args.hasArg(OPT_fno_merge_all_constants);
  762. Opts.NoCommon = Args.hasArg(OPT_fno_common);
  763. Opts.NoImplicitFloat = Args.hasArg(OPT_no_implicit_float);
  764. Opts.OptimizeSize = Args.hasArg(OPT_Os);
  765. Opts.SimplifyLibCalls = !(Args.hasArg(OPT_fno_builtin) ||
  766. Args.hasArg(OPT_ffreestanding));
  767. Opts.UnrollLoops = (Opts.OptimizationLevel > 1 && !Opts.OptimizeSize);
  768. Opts.AsmVerbose = Args.hasArg(OPT_masm_verbose);
  769. Opts.CXAAtExit = !Args.hasArg(OPT_fno_use_cxa_atexit);
  770. Opts.CXXCtorDtorAliases = Args.hasArg(OPT_mconstructor_aliases);
  771. Opts.CodeModel = Args.getLastArgValue(OPT_mcode_model);
  772. Opts.DebugPass = Args.getLastArgValue(OPT_mdebug_pass);
  773. Opts.DisableFPElim = Args.hasArg(OPT_mdisable_fp_elim);
  774. Opts.FloatABI = Args.getLastArgValue(OPT_mfloat_abi);
  775. Opts.LimitFloatPrecision = Args.getLastArgValue(OPT_mlimit_float_precision);
  776. Opts.NoZeroInitializedInBSS = Args.hasArg(OPT_mno_zero_initialized_in_bss);
  777. Opts.RelaxAll = Args.hasArg(OPT_mrelax_all);
  778. Opts.SoftFloat = Args.hasArg(OPT_msoft_float);
  779. Opts.UnwindTables = Args.hasArg(OPT_munwind_tables);
  780. Opts.RelocationModel = Args.getLastArgValue(OPT_mrelocation_model, "pic");
  781. Opts.FunctionSections = Args.hasArg(OPT_ffunction_sections);
  782. Opts.DataSections = Args.hasArg(OPT_fdata_sections);
  783. Opts.MainFileName = Args.getLastArgValue(OPT_main_file_name);
  784. Opts.VerifyModule = !Args.hasArg(OPT_disable_llvm_verifier);
  785. if (Arg *A = Args.getLastArg(OPT_fobjc_dispatch_method_EQ)) {
  786. llvm::StringRef Name = A->getValue(Args);
  787. unsigned Method = llvm::StringSwitch<unsigned>(Name)
  788. .Case("legacy", CodeGenOptions::Legacy)
  789. .Case("non-legacy", CodeGenOptions::NonLegacy)
  790. .Case("mixed", CodeGenOptions::Mixed)
  791. .Default(~0U);
  792. if (Method == ~0U)
  793. Diags.Report(diag::err_drv_invalid_value) << A->getAsString(Args) << Name;
  794. else
  795. Opts.ObjCDispatchMethod = Method;
  796. }
  797. }
  798. static void ParseDependencyOutputArgs(DependencyOutputOptions &Opts,
  799. ArgList &Args) {
  800. using namespace cc1options;
  801. Opts.OutputFile = Args.getLastArgValue(OPT_dependency_file);
  802. Opts.Targets = Args.getAllArgValues(OPT_MT);
  803. Opts.IncludeSystemHeaders = Args.hasArg(OPT_sys_header_deps);
  804. Opts.UsePhonyTargets = Args.hasArg(OPT_MP);
  805. }
  806. static void ParseDiagnosticArgs(DiagnosticOptions &Opts, ArgList &Args,
  807. Diagnostic &Diags) {
  808. using namespace cc1options;
  809. Opts.IgnoreWarnings = Args.hasArg(OPT_w);
  810. Opts.NoRewriteMacros = Args.hasArg(OPT_Wno_rewrite_macros);
  811. Opts.Pedantic = Args.hasArg(OPT_pedantic);
  812. Opts.PedanticErrors = Args.hasArg(OPT_pedantic_errors);
  813. Opts.ShowCarets = !Args.hasArg(OPT_fno_caret_diagnostics);
  814. Opts.ShowColors = Args.hasArg(OPT_fcolor_diagnostics);
  815. Opts.ShowColumn = !Args.hasArg(OPT_fno_show_column);
  816. Opts.ShowFixits = !Args.hasArg(OPT_fno_diagnostics_fixit_info);
  817. Opts.ShowLocation = !Args.hasArg(OPT_fno_show_source_location);
  818. Opts.ShowOptionNames = Args.hasArg(OPT_fdiagnostics_show_option);
  819. llvm::StringRef ShowCategory =
  820. Args.getLastArgValue(OPT_fdiagnostics_show_category, "none");
  821. if (ShowCategory == "none")
  822. Opts.ShowCategories = 0;
  823. else if (ShowCategory == "id")
  824. Opts.ShowCategories = 1;
  825. else if (ShowCategory == "name")
  826. Opts.ShowCategories = 2;
  827. else
  828. Diags.Report(diag::err_drv_invalid_value)
  829. << Args.getLastArg(OPT_fdiagnostics_show_category)->getAsString(Args)
  830. << ShowCategory;
  831. Opts.ShowSourceRanges = Args.hasArg(OPT_fdiagnostics_print_source_range_info);
  832. Opts.VerifyDiagnostics = Args.hasArg(OPT_verify);
  833. Opts.BinaryOutput = Args.hasArg(OPT_fdiagnostics_binary);
  834. Opts.ErrorLimit = Args.getLastArgIntValue(OPT_ferror_limit, 0, Diags);
  835. Opts.MacroBacktraceLimit
  836. = Args.getLastArgIntValue(OPT_fmacro_backtrace_limit,
  837. DiagnosticOptions::DefaultMacroBacktraceLimit, Diags);
  838. Opts.TemplateBacktraceLimit
  839. = Args.getLastArgIntValue(OPT_ftemplate_backtrace_limit,
  840. DiagnosticOptions::DefaultTemplateBacktraceLimit,
  841. Diags);
  842. Opts.TabStop = Args.getLastArgIntValue(OPT_ftabstop,
  843. DiagnosticOptions::DefaultTabStop, Diags);
  844. if (Opts.TabStop == 0 || Opts.TabStop > DiagnosticOptions::MaxTabStop) {
  845. Diags.Report(diag::warn_ignoring_ftabstop_value)
  846. << Opts.TabStop << DiagnosticOptions::DefaultTabStop;
  847. Opts.TabStop = DiagnosticOptions::DefaultTabStop;
  848. }
  849. Opts.MessageLength = Args.getLastArgIntValue(OPT_fmessage_length, 0, Diags);
  850. Opts.DumpBuildInformation = Args.getLastArgValue(OPT_dump_build_information);
  851. Opts.Warnings = Args.getAllArgValues(OPT_W);
  852. }
  853. static InputKind ParseFrontendArgs(FrontendOptions &Opts, ArgList &Args,
  854. Diagnostic &Diags) {
  855. using namespace cc1options;
  856. Opts.ProgramAction = frontend::ParseSyntaxOnly;
  857. if (const Arg *A = Args.getLastArg(OPT_Action_Group)) {
  858. switch (A->getOption().getID()) {
  859. default:
  860. assert(0 && "Invalid option in group!");
  861. case OPT_ast_dump:
  862. Opts.ProgramAction = frontend::ASTDump; break;
  863. case OPT_ast_print:
  864. Opts.ProgramAction = frontend::ASTPrint; break;
  865. case OPT_ast_print_xml:
  866. Opts.ProgramAction = frontend::ASTPrintXML; break;
  867. case OPT_ast_view:
  868. Opts.ProgramAction = frontend::ASTView; break;
  869. case OPT_boostcon:
  870. Opts.ProgramAction = frontend::BoostCon; break;
  871. case OPT_dump_raw_tokens:
  872. Opts.ProgramAction = frontend::DumpRawTokens; break;
  873. case OPT_dump_tokens:
  874. Opts.ProgramAction = frontend::DumpTokens; break;
  875. case OPT_S:
  876. Opts.ProgramAction = frontend::EmitAssembly; break;
  877. case OPT_emit_llvm_bc:
  878. Opts.ProgramAction = frontend::EmitBC; break;
  879. case OPT_emit_html:
  880. Opts.ProgramAction = frontend::EmitHTML; break;
  881. case OPT_emit_llvm:
  882. Opts.ProgramAction = frontend::EmitLLVM; break;
  883. case OPT_emit_llvm_only:
  884. Opts.ProgramAction = frontend::EmitLLVMOnly; break;
  885. case OPT_emit_codegen_only:
  886. Opts.ProgramAction = frontend::EmitCodeGenOnly; break;
  887. case OPT_emit_obj:
  888. Opts.ProgramAction = frontend::EmitObj; break;
  889. case OPT_fixit_EQ:
  890. Opts.FixItSuffix = A->getValue(Args);
  891. // fall-through!
  892. case OPT_fixit:
  893. Opts.ProgramAction = frontend::FixIt; break;
  894. case OPT_emit_pch:
  895. Opts.ProgramAction = frontend::GeneratePCH; break;
  896. case OPT_emit_pth:
  897. Opts.ProgramAction = frontend::GeneratePTH; break;
  898. case OPT_init_only:
  899. Opts.ProgramAction = frontend::InitOnly; break;
  900. case OPT_parse_noop:
  901. Opts.ProgramAction = frontend::ParseNoop; break;
  902. case OPT_parse_print_callbacks:
  903. Opts.ProgramAction = frontend::ParsePrintCallbacks; break;
  904. case OPT_fsyntax_only:
  905. Opts.ProgramAction = frontend::ParseSyntaxOnly; break;
  906. case OPT_print_decl_contexts:
  907. Opts.ProgramAction = frontend::PrintDeclContext; break;
  908. case OPT_E:
  909. Opts.ProgramAction = frontend::PrintPreprocessedInput; break;
  910. case OPT_rewrite_macros:
  911. Opts.ProgramAction = frontend::RewriteMacros; break;
  912. case OPT_rewrite_objc:
  913. Opts.ProgramAction = frontend::RewriteObjC; break;
  914. case OPT_rewrite_test:
  915. Opts.ProgramAction = frontend::RewriteTest; break;
  916. case OPT_analyze:
  917. Opts.ProgramAction = frontend::RunAnalysis; break;
  918. case OPT_Eonly:
  919. Opts.ProgramAction = frontend::RunPreprocessorOnly; break;
  920. }
  921. }
  922. if (const Arg *A = Args.getLastArg(OPT_plugin)) {
  923. Opts.ProgramAction = frontend::PluginAction;
  924. Opts.ActionName = A->getValue(Args);
  925. }
  926. if (const Arg *A = Args.getLastArg(OPT_code_completion_at)) {
  927. Opts.CodeCompletionAt =
  928. ParsedSourceLocation::FromString(A->getValue(Args));
  929. if (Opts.CodeCompletionAt.FileName.empty())
  930. Diags.Report(diag::err_drv_invalid_value)
  931. << A->getAsString(Args) << A->getValue(Args);
  932. }
  933. Opts.DebugCodeCompletionPrinter =
  934. !Args.hasArg(OPT_no_code_completion_debug_printer);
  935. Opts.DisableFree = Args.hasArg(OPT_disable_free);
  936. Opts.OutputFile = Args.getLastArgValue(OPT_o);
  937. Opts.Plugins = Args.getAllArgValues(OPT_load);
  938. Opts.RelocatablePCH = Args.hasArg(OPT_relocatable_pch);
  939. Opts.ShowHelp = Args.hasArg(OPT_help);
  940. Opts.ShowMacrosInCodeCompletion = Args.hasArg(OPT_code_completion_macros);
  941. Opts.ShowCodePatternsInCodeCompletion
  942. = Args.hasArg(OPT_code_completion_patterns);
  943. Opts.ShowStats = Args.hasArg(OPT_print_stats);
  944. Opts.ShowTimers = Args.hasArg(OPT_ftime_report);
  945. Opts.ShowVersion = Args.hasArg(OPT_version);
  946. Opts.ViewClassInheritance = Args.getLastArgValue(OPT_cxx_inheritance_view);
  947. Opts.ASTMergeFiles = Args.getAllArgValues(OPT_ast_merge);
  948. Opts.LLVMArgs = Args.getAllArgValues(OPT_mllvm);
  949. InputKind DashX = IK_None;
  950. if (const Arg *A = Args.getLastArg(OPT_x)) {
  951. DashX = llvm::StringSwitch<InputKind>(A->getValue(Args))
  952. .Case("c", IK_C)
  953. .Case("cl", IK_OpenCL)
  954. .Case("c", IK_C)
  955. .Case("cl", IK_OpenCL)
  956. .Case("c++", IK_CXX)
  957. .Case("objective-c", IK_ObjC)
  958. .Case("objective-c++", IK_ObjCXX)
  959. .Case("cpp-output", IK_PreprocessedC)
  960. .Case("assembler-with-cpp", IK_Asm)
  961. .Case("c++-cpp-output", IK_PreprocessedCXX)
  962. .Case("objective-c-cpp-output", IK_PreprocessedObjC)
  963. .Case("objective-c++-cpp-output", IK_PreprocessedObjCXX)
  964. .Case("c-header", IK_C)
  965. .Case("objective-c-header", IK_ObjC)
  966. .Case("c++-header", IK_CXX)
  967. .Case("objective-c++-header", IK_ObjCXX)
  968. .Case("ast", IK_AST)
  969. .Case("ir", IK_LLVM_IR)
  970. .Default(IK_None);
  971. if (DashX == IK_None)
  972. Diags.Report(diag::err_drv_invalid_value)
  973. << A->getAsString(Args) << A->getValue(Args);
  974. }
  975. // '-' is the default input if none is given.
  976. std::vector<std::string> Inputs = Args.getAllArgValues(OPT_INPUT);
  977. Opts.Inputs.clear();
  978. if (Inputs.empty())
  979. Inputs.push_back("-");
  980. for (unsigned i = 0, e = Inputs.size(); i != e; ++i) {
  981. InputKind IK = DashX;
  982. if (IK == IK_None) {
  983. IK = FrontendOptions::getInputKindForExtension(
  984. llvm::StringRef(Inputs[i]).rsplit('.').second);
  985. // FIXME: Remove this hack.
  986. if (i == 0)
  987. DashX = IK;
  988. }
  989. Opts.Inputs.push_back(std::make_pair(IK, Inputs[i]));
  990. }
  991. return DashX;
  992. }
  993. std::string CompilerInvocation::GetResourcesPath(const char *Argv0,
  994. void *MainAddr) {
  995. llvm::sys::Path P = llvm::sys::Path::GetMainExecutable(Argv0, MainAddr);
  996. if (!P.isEmpty()) {
  997. P.eraseComponent(); // Remove /clang from foo/bin/clang
  998. P.eraseComponent(); // Remove /bin from foo/bin
  999. // Get foo/lib/clang/<version>/include
  1000. P.appendComponent("lib");
  1001. P.appendComponent("clang");
  1002. P.appendComponent(CLANG_VERSION_STRING);
  1003. }
  1004. return P.str();
  1005. }
  1006. static void ParseHeaderSearchArgs(HeaderSearchOptions &Opts, ArgList &Args) {
  1007. using namespace cc1options;
  1008. Opts.Sysroot = Args.getLastArgValue(OPT_isysroot, "/");
  1009. Opts.Verbose = Args.hasArg(OPT_v);
  1010. Opts.UseBuiltinIncludes = !Args.hasArg(OPT_nobuiltininc);
  1011. Opts.UseStandardIncludes = !Args.hasArg(OPT_nostdinc);
  1012. Opts.UseStandardCXXIncludes = !Args.hasArg(OPT_nostdincxx);
  1013. Opts.ResourceDir = Args.getLastArgValue(OPT_resource_dir);
  1014. // Add -I... and -F... options in order.
  1015. for (arg_iterator it = Args.filtered_begin(OPT_I, OPT_F),
  1016. ie = Args.filtered_end(); it != ie; ++it)
  1017. Opts.AddPath(it->getValue(Args), frontend::Angled, true,
  1018. /*IsFramework=*/ it->getOption().matches(OPT_F));
  1019. // Add -iprefix/-iwith-prefix/-iwithprefixbefore options.
  1020. llvm::StringRef Prefix = ""; // FIXME: This isn't the correct default prefix.
  1021. for (arg_iterator it = Args.filtered_begin(OPT_iprefix, OPT_iwithprefix,
  1022. OPT_iwithprefixbefore),
  1023. ie = Args.filtered_end(); it != ie; ++it) {
  1024. if (it->getOption().matches(OPT_iprefix))
  1025. Prefix = it->getValue(Args);
  1026. else if (it->getOption().matches(OPT_iwithprefix))
  1027. Opts.AddPath(Prefix.str() + it->getValue(Args),
  1028. frontend::System, false, false);
  1029. else
  1030. Opts.AddPath(Prefix.str() + it->getValue(Args),
  1031. frontend::Angled, false, false);
  1032. }
  1033. for (arg_iterator it = Args.filtered_begin(OPT_idirafter),
  1034. ie = Args.filtered_end(); it != ie; ++it)
  1035. Opts.AddPath(it->getValue(Args), frontend::After, true, false);
  1036. for (arg_iterator it = Args.filtered_begin(OPT_iquote),
  1037. ie = Args.filtered_end(); it != ie; ++it)
  1038. Opts.AddPath(it->getValue(Args), frontend::Quoted, true, false);
  1039. for (arg_iterator it = Args.filtered_begin(OPT_isystem),
  1040. ie = Args.filtered_end(); it != ie; ++it)
  1041. Opts.AddPath(it->getValue(Args), frontend::System, true, false);
  1042. // FIXME: Need options for the various environment variables!
  1043. }
  1044. static void ParseLangArgs(LangOptions &Opts, ArgList &Args, InputKind IK,
  1045. Diagnostic &Diags) {
  1046. // FIXME: Cleanup per-file based stuff.
  1047. // Set some properties which depend soley on the input kind; it would be nice
  1048. // to move these to the language standard, and have the driver resolve the
  1049. // input kind + language standard.
  1050. if (IK == IK_Asm) {
  1051. Opts.AsmPreprocessor = 1;
  1052. } else if (IK == IK_ObjC ||
  1053. IK == IK_ObjCXX ||
  1054. IK == IK_PreprocessedObjC ||
  1055. IK == IK_PreprocessedObjCXX) {
  1056. Opts.ObjC1 = Opts.ObjC2 = 1;
  1057. }
  1058. LangStandard::Kind LangStd = LangStandard::lang_unspecified;
  1059. if (const Arg *A = Args.getLastArg(OPT_std_EQ)) {
  1060. LangStd = llvm::StringSwitch<LangStandard::Kind>(A->getValue(Args))
  1061. #define LANGSTANDARD(id, name, desc, features) \
  1062. .Case(name, LangStandard::lang_##id)
  1063. #include "clang/Frontend/LangStandards.def"
  1064. .Default(LangStandard::lang_unspecified);
  1065. if (LangStd == LangStandard::lang_unspecified)
  1066. Diags.Report(diag::err_drv_invalid_value)
  1067. << A->getAsString(Args) << A->getValue(Args);
  1068. }
  1069. if (LangStd == LangStandard::lang_unspecified) {
  1070. // Based on the base language, pick one.
  1071. switch (IK) {
  1072. case IK_None:
  1073. case IK_AST:
  1074. case IK_LLVM_IR:
  1075. assert(0 && "Invalid input kind!");
  1076. case IK_OpenCL:
  1077. LangStd = LangStandard::lang_opencl;
  1078. break;
  1079. case IK_Asm:
  1080. case IK_C:
  1081. case IK_PreprocessedC:
  1082. case IK_ObjC:
  1083. case IK_PreprocessedObjC:
  1084. LangStd = LangStandard::lang_gnu99;
  1085. break;
  1086. case IK_CXX:
  1087. case IK_PreprocessedCXX:
  1088. case IK_ObjCXX:
  1089. case IK_PreprocessedObjCXX:
  1090. LangStd = LangStandard::lang_gnucxx98;
  1091. break;
  1092. }
  1093. }
  1094. const LangStandard &Std = LangStandard::getLangStandardForKind(LangStd);
  1095. Opts.BCPLComment = Std.hasBCPLComments();
  1096. Opts.C99 = Std.isC99();
  1097. Opts.CPlusPlus = Std.isCPlusPlus();
  1098. Opts.CPlusPlus0x = Std.isCPlusPlus0x();
  1099. Opts.Digraphs = Std.hasDigraphs();
  1100. Opts.GNUMode = Std.isGNUMode();
  1101. Opts.GNUInline = !Std.isC99();
  1102. Opts.HexFloats = Std.hasHexFloats();
  1103. Opts.ImplicitInt = Std.hasImplicitInt();
  1104. // OpenCL has some additional defaults.
  1105. if (LangStd == LangStandard::lang_opencl) {
  1106. Opts.OpenCL = 1;
  1107. Opts.AltiVec = 1;
  1108. Opts.CXXOperatorNames = 1;
  1109. Opts.LaxVectorConversions = 1;
  1110. }
  1111. // OpenCL and C++ both have bool, true, false keywords.
  1112. Opts.Bool = Opts.OpenCL || Opts.CPlusPlus;
  1113. // We abuse '-f[no-]gnu-keywords' to force overriding all GNU-extension
  1114. // keywords. This behavior is provided by GCC's poorly named '-fasm' flag,
  1115. // while a subset (the non-C++ GNU keywords) is provided by GCC's
  1116. // '-fgnu-keywords'. Clang conflates the two for simplicity under the single
  1117. // name, as it doesn't seem a useful distinction.
  1118. Opts.GNUKeywords = Args.hasFlag(OPT_fgnu_keywords, OPT_fno_gnu_keywords,
  1119. Opts.GNUMode);
  1120. if (Opts.CPlusPlus)
  1121. Opts.CXXOperatorNames = !Args.hasArg(OPT_fno_operator_names);
  1122. if (Args.hasArg(OPT_fobjc_gc_only))
  1123. Opts.setGCMode(LangOptions::GCOnly);
  1124. else if (Args.hasArg(OPT_fobjc_gc))
  1125. Opts.setGCMode(LangOptions::HybridGC);
  1126. if (Args.hasArg(OPT_print_ivar_layout))
  1127. Opts.ObjCGCBitmapPrint = 1;
  1128. if (Args.hasArg(OPT_fno_constant_cfstrings))
  1129. Opts.NoConstantCFStrings = 1;
  1130. if (Args.hasArg(OPT_faltivec))
  1131. Opts.AltiVec = 1;
  1132. if (Args.hasArg(OPT_pthread))
  1133. Opts.POSIXThreads = 1;
  1134. llvm::StringRef Vis = Args.getLastArgValue(OPT_fvisibility, "default");
  1135. if (Vis == "default")
  1136. Opts.setVisibilityMode(LangOptions::Default);
  1137. else if (Vis == "hidden")
  1138. Opts.setVisibilityMode(LangOptions::Hidden);
  1139. else if (Vis == "protected")
  1140. Opts.setVisibilityMode(LangOptions::Protected);
  1141. else
  1142. Diags.Report(diag::err_drv_invalid_value)
  1143. << Args.getLastArg(OPT_fvisibility)->getAsString(Args) << Vis;
  1144. Opts.OverflowChecking = Args.hasArg(OPT_ftrapv);
  1145. // Mimicing gcc's behavior, trigraphs are only enabled if -trigraphs
  1146. // is specified, or -std is set to a conforming mode.
  1147. Opts.Trigraphs = !Opts.GNUMode;
  1148. if (Args.hasArg(OPT_trigraphs))
  1149. Opts.Trigraphs = 1;
  1150. Opts.DollarIdents = Args.hasFlag(OPT_fdollars_in_identifiers,
  1151. OPT_fno_dollars_in_identifiers,
  1152. !Opts.AsmPreprocessor);
  1153. Opts.PascalStrings = Args.hasArg(OPT_fpascal_strings);
  1154. Opts.Microsoft = Args.hasArg(OPT_fms_extensions);
  1155. Opts.WritableStrings = Args.hasArg(OPT_fwritable_strings);
  1156. Opts.ConstStrings = Args.hasArg(OPT_Wwrite_strings);
  1157. if (Args.hasArg(OPT_fno_lax_vector_conversions))
  1158. Opts.LaxVectorConversions = 0;
  1159. if (Args.hasArg(OPT_fno_threadsafe_statics))
  1160. Opts.ThreadsafeStatics = 0;
  1161. Opts.Exceptions = Args.hasArg(OPT_fexceptions);
  1162. Opts.RTTI = !Args.hasArg(OPT_fno_rtti);
  1163. Opts.Blocks = Args.hasArg(OPT_fblocks);
  1164. Opts.CharIsSigned = !Args.hasArg(OPT_fno_signed_char);
  1165. Opts.ShortWChar = Args.hasArg(OPT_fshort_wchar);
  1166. Opts.Freestanding = Args.hasArg(OPT_ffreestanding);
  1167. Opts.NoBuiltin = Args.hasArg(OPT_fno_builtin) || Opts.Freestanding;
  1168. Opts.AssumeSaneOperatorNew = !Args.hasArg(OPT_fno_assume_sane_operator_new);
  1169. Opts.HeinousExtensions = Args.hasArg(OPT_fheinous_gnu_extensions);
  1170. Opts.AccessControl = !Args.hasArg(OPT_fno_access_control);
  1171. Opts.ElideConstructors = !Args.hasArg(OPT_fno_elide_constructors);
  1172. Opts.MathErrno = Args.hasArg(OPT_fmath_errno);
  1173. Opts.InstantiationDepth = Args.getLastArgIntValue(OPT_ftemplate_depth, 1024,
  1174. Diags);
  1175. Opts.NeXTRuntime = !Args.hasArg(OPT_fgnu_runtime);
  1176. Opts.ObjCConstantStringClass =
  1177. Args.getLastArgValue(OPT_fconstant_string_class);
  1178. Opts.ObjCNonFragileABI = Args.hasArg(OPT_fobjc_nonfragile_abi);
  1179. Opts.ObjCNonFragileABI2 = Args.hasArg(OPT_fobjc_nonfragile_abi2);
  1180. if (Opts.ObjCNonFragileABI2)
  1181. Opts.ObjCNonFragileABI = true;
  1182. Opts.CatchUndefined = Args.hasArg(OPT_fcatch_undefined_behavior);
  1183. Opts.EmitAllDecls = Args.hasArg(OPT_femit_all_decls);
  1184. Opts.PICLevel = Args.getLastArgIntValue(OPT_pic_level, 0, Diags);
  1185. Opts.SjLjExceptions = Args.hasArg(OPT_fsjlj_exceptions);
  1186. Opts.Static = Args.hasArg(OPT_static_define);
  1187. Opts.DumpRecordLayouts = Args.hasArg(OPT_fdump_record_layouts);
  1188. Opts.DumpVTableLayouts = Args.hasArg(OPT_fdump_vtable_layouts);
  1189. Opts.NoBitFieldTypeAlign = Args.hasArg(OPT_fno_bitfield_type_align);
  1190. Opts.OptimizeSize = 0;
  1191. // FIXME: Eliminate this dependency.
  1192. unsigned Opt =
  1193. Args.hasArg(OPT_Os) ? 2 : Args.getLastArgIntValue(OPT_O, 0, Diags);
  1194. Opts.Optimize = Opt != 0;
  1195. // This is the __NO_INLINE__ define, which just depends on things like the
  1196. // optimization level and -fno-inline, not actually whether the backend has
  1197. // inlining enabled.
  1198. //
  1199. // FIXME: This is affected by other options (-fno-inline).
  1200. Opts.NoInline = !Opt;
  1201. unsigned SSP = Args.getLastArgIntValue(OPT_stack_protector, 0, Diags);
  1202. switch (SSP) {
  1203. default:
  1204. Diags.Report(diag::err_drv_invalid_value)
  1205. << Args.getLastArg(OPT_stack_protector)->getAsString(Args) << SSP;
  1206. break;
  1207. case 0: Opts.setStackProtectorMode(LangOptions::SSPOff); break;
  1208. case 1: Opts.setStackProtectorMode(LangOptions::SSPOn); break;
  1209. case 2: Opts.setStackProtectorMode(LangOptions::SSPReq); break;
  1210. }
  1211. }
  1212. static void ParsePreprocessorArgs(PreprocessorOptions &Opts, ArgList &Args,
  1213. Diagnostic &Diags) {
  1214. using namespace cc1options;
  1215. Opts.ImplicitPCHInclude = Args.getLastArgValue(OPT_include_pch);
  1216. Opts.ImplicitPTHInclude = Args.getLastArgValue(OPT_include_pth);
  1217. if (const Arg *A = Args.getLastArg(OPT_token_cache))
  1218. Opts.TokenCache = A->getValue(Args);
  1219. else
  1220. Opts.TokenCache = Opts.ImplicitPTHInclude;
  1221. Opts.UsePredefines = !Args.hasArg(OPT_undef);
  1222. Opts.DetailedRecord = Args.hasArg(OPT_detailed_preprocessing_record);
  1223. // Add macros from the command line.
  1224. for (arg_iterator it = Args.filtered_begin(OPT_D, OPT_U),
  1225. ie = Args.filtered_end(); it != ie; ++it) {
  1226. if (it->getOption().matches(OPT_D))
  1227. Opts.addMacroDef(it->getValue(Args));
  1228. else
  1229. Opts.addMacroUndef(it->getValue(Args));
  1230. }
  1231. Opts.MacroIncludes = Args.getAllArgValues(OPT_imacros);
  1232. // Add the ordered list of -includes.
  1233. for (arg_iterator it = Args.filtered_begin(OPT_include, OPT_include_pch,
  1234. OPT_include_pth),
  1235. ie = Args.filtered_end(); it != ie; ++it) {
  1236. // PCH is handled specially, we need to extra the original include path.
  1237. if (it->getOption().matches(OPT_include_pch)) {
  1238. std::string OriginalFile =
  1239. PCHReader::getOriginalSourceFile(it->getValue(Args), Diags);
  1240. if (OriginalFile.empty())
  1241. continue;
  1242. Opts.Includes.push_back(OriginalFile);
  1243. } else
  1244. Opts.Includes.push_back(it->getValue(Args));
  1245. }
  1246. // Include 'altivec.h' if -faltivec option present
  1247. if (Args.hasArg(OPT_faltivec))
  1248. Opts.Includes.push_back("altivec.h");
  1249. for (arg_iterator it = Args.filtered_begin(OPT_remap_file),
  1250. ie = Args.filtered_end(); it != ie; ++it) {
  1251. std::pair<llvm::StringRef,llvm::StringRef> Split =
  1252. llvm::StringRef(it->getValue(Args)).split(';');
  1253. if (Split.second.empty()) {
  1254. Diags.Report(diag::err_drv_invalid_remap_file) << it->getAsString(Args);
  1255. continue;
  1256. }
  1257. Opts.addRemappedFile(Split.first, Split.second);
  1258. }
  1259. }
  1260. static void ParsePreprocessorOutputArgs(PreprocessorOutputOptions &Opts,
  1261. ArgList &Args) {
  1262. using namespace cc1options;
  1263. Opts.ShowCPP = !Args.hasArg(OPT_dM);
  1264. Opts.ShowMacros = Args.hasArg(OPT_dM) || Args.hasArg(OPT_dD);
  1265. Opts.ShowLineMarkers = !Args.hasArg(OPT_P);
  1266. Opts.ShowComments = Args.hasArg(OPT_C);
  1267. Opts.ShowMacroComments = Args.hasArg(OPT_CC);
  1268. }
  1269. static void ParseTargetArgs(TargetOptions &Opts, ArgList &Args) {
  1270. using namespace cc1options;
  1271. Opts.ABI = Args.getLastArgValue(OPT_target_abi);
  1272. Opts.CPU = Args.getLastArgValue(OPT_target_cpu);
  1273. Opts.Triple = Args.getLastArgValue(OPT_triple);
  1274. Opts.Features = Args.getAllArgValues(OPT_target_feature);
  1275. // Use the host triple if unspecified.
  1276. if (Opts.Triple.empty())
  1277. Opts.Triple = llvm::sys::getHostTriple();
  1278. }
  1279. //
  1280. void CompilerInvocation::CreateFromArgs(CompilerInvocation &Res,
  1281. const char **ArgBegin,
  1282. const char **ArgEnd,
  1283. Diagnostic &Diags) {
  1284. // Parse the arguments.
  1285. llvm::OwningPtr<OptTable> Opts(createCC1OptTable());
  1286. unsigned MissingArgIndex, MissingArgCount;
  1287. llvm::OwningPtr<InputArgList> Args(
  1288. Opts->ParseArgs(ArgBegin, ArgEnd,MissingArgIndex, MissingArgCount));
  1289. // Check for missing argument error.
  1290. if (MissingArgCount)
  1291. Diags.Report(diag::err_drv_missing_argument)
  1292. << Args->getArgString(MissingArgIndex) << MissingArgCount;
  1293. // Issue errors on unknown arguments.
  1294. for (arg_iterator it = Args->filtered_begin(OPT_UNKNOWN),
  1295. ie = Args->filtered_end(); it != ie; ++it)
  1296. Diags.Report(diag::err_drv_unknown_argument) << it->getAsString(*Args);
  1297. ParseAnalyzerArgs(Res.getAnalyzerOpts(), *Args, Diags);
  1298. ParseCodeGenArgs(Res.getCodeGenOpts(), *Args, Diags);
  1299. ParseDependencyOutputArgs(Res.getDependencyOutputOpts(), *Args);
  1300. ParseDiagnosticArgs(Res.getDiagnosticOpts(), *Args, Diags);
  1301. InputKind DashX = ParseFrontendArgs(Res.getFrontendOpts(), *Args, Diags);
  1302. ParseHeaderSearchArgs(Res.getHeaderSearchOpts(), *Args);
  1303. if (DashX != IK_AST && DashX != IK_LLVM_IR)
  1304. ParseLangArgs(Res.getLangOpts(), *Args, DashX, Diags);
  1305. ParsePreprocessorArgs(Res.getPreprocessorOpts(), *Args, Diags);
  1306. ParsePreprocessorOutputArgs(Res.getPreprocessorOutputOpts(), *Args);
  1307. ParseTargetArgs(Res.getTargetOpts(), *Args);
  1308. }