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 10 #include "clang/Frontend/CompilerInvocation.h" 11 #include "clang/Basic/Diagnostic.h" 12 #include "clang/Basic/Version.h" 13 #include "clang/Basic/FileManager.h" 14 #include "clang/Driver/Arg.h" 15 #include "clang/Driver/ArgList.h" 16 #include "clang/Driver/CC1Options.h" 17 #include "clang/Driver/DriverDiagnostic.h" 18 #include "clang/Driver/OptTable.h" 19 #include "clang/Driver/Option.h" 20 #include "clang/Frontend/CompilerInvocation.h" 21 #include "clang/Frontend/LangStandard.h" 22 #include "clang/Serialization/ASTReader.h" 23 #include "llvm/ADT/OwningPtr.h" 24 #include "llvm/ADT/SmallVector.h" 25 #include "llvm/ADT/StringExtras.h" 26 #include "llvm/ADT/StringSwitch.h" 27 #include "llvm/ADT/Triple.h" 28 #include "llvm/Support/ErrorHandling.h" 29 #include "llvm/Support/Host.h" 30 #include "llvm/Support/Path.h" 31 using namespace clang; 32 33 //===----------------------------------------------------------------------===// 34 // Initialization. 35 //===----------------------------------------------------------------------===// 36 37 CompilerInvocationBase::CompilerInvocationBase() 38 : LangOpts(new LangOptions()) {} 39 40 CompilerInvocationBase::CompilerInvocationBase(const CompilerInvocationBase &X) 41 : llvm::RefCountedBase<CompilerInvocation>(), 42 LangOpts(new LangOptions(*X.getLangOpts())) {} 43 44 //===----------------------------------------------------------------------===// 45 // Utility functions. 46 //===----------------------------------------------------------------------===// 47 48 static const char *getAnalysisStoreName(AnalysisStores Kind) { 49 switch (Kind) { 50 default: 51 llvm_unreachable("Unknown analysis store!"); 52 #define ANALYSIS_STORE(NAME, CMDFLAG, DESC, CREATFN) \ 53 case NAME##Model: return CMDFLAG; 54 #include "clang/Frontend/Analyses.def" 55 } 56 } 57 58 static const char *getAnalysisConstraintName(AnalysisConstraints Kind) { 59 switch (Kind) { 60 default: 61 llvm_unreachable("Unknown analysis constraints!"); 62 #define ANALYSIS_CONSTRAINTS(NAME, CMDFLAG, DESC, CREATFN) \ 63 case NAME##Model: return CMDFLAG; 64 #include "clang/Frontend/Analyses.def" 65 } 66 } 67 68 static const char *getAnalysisDiagClientName(AnalysisDiagClients Kind) { 69 switch (Kind) { 70 default: 71 llvm_unreachable("Unknown analysis client!"); 72 #define ANALYSIS_DIAGNOSTICS(NAME, CMDFLAG, DESC, CREATFN, AUTOCREATE) \ 73 case PD_##NAME: return CMDFLAG; 74 #include "clang/Frontend/Analyses.def" 75 } 76 } 77 78 static const char *getAnalysisPurgeModeName(AnalysisPurgeMode Kind) { 79 switch (Kind) { 80 default: 81 llvm_unreachable("Unknown analysis client!"); 82 #define ANALYSIS_PURGE(NAME, CMDFLAG, DESC) \ 83 case NAME: return CMDFLAG; 84 #include "clang/Frontend/Analyses.def" 85 } 86 } 87 88 //===----------------------------------------------------------------------===// 89 // Serialization (to args) 90 //===----------------------------------------------------------------------===// 91 92 static void AnalyzerOptsToArgs(const AnalyzerOptions &Opts, 93 std::vector<std::string> &Res) { 94 if (Opts.ShowCheckerHelp) 95 Res.push_back("-analyzer-checker-help"); 96 if (Opts.AnalysisStoreOpt != RegionStoreModel) { 97 Res.push_back("-analyzer-store"); 98 Res.push_back(getAnalysisStoreName(Opts.AnalysisStoreOpt)); 99 } 100 if (Opts.AnalysisConstraintsOpt != RangeConstraintsModel) { 101 Res.push_back("-analyzer-constraints"); 102 Res.push_back(getAnalysisConstraintName(Opts.AnalysisConstraintsOpt)); 103 } 104 if (Opts.AnalysisDiagOpt != PD_HTML) { 105 Res.push_back("-analyzer-output"); 106 Res.push_back(getAnalysisDiagClientName(Opts.AnalysisDiagOpt)); 107 } 108 if (Opts.AnalysisPurgeOpt != PurgeStmt) { 109 Res.push_back("-analyzer-purge"); 110 Res.push_back(getAnalysisPurgeModeName(Opts.AnalysisPurgeOpt)); 111 } 112 if (!Opts.AnalyzeSpecificFunction.empty()) { 113 Res.push_back("-analyze-function"); 114 Res.push_back(Opts.AnalyzeSpecificFunction); 115 } 116 if (Opts.AnalyzeAll) 117 Res.push_back("-analyzer-opt-analyze-headers"); 118 if (Opts.AnalyzerDisplayProgress) 119 Res.push_back("-analyzer-display-progress"); 120 if (Opts.AnalyzeNestedBlocks) 121 Res.push_back("-analyzer-opt-analyze-nested-blocks"); 122 if (Opts.EagerlyAssume) 123 Res.push_back("-analyzer-eagerly-assume"); 124 if (Opts.TrimGraph) 125 Res.push_back("-trim-egraph"); 126 if (Opts.VisualizeEGDot) 127 Res.push_back("-analyzer-viz-egraph-graphviz"); 128 if (Opts.VisualizeEGUbi) 129 Res.push_back("-analyzer-viz-egraph-ubigraph"); 130 131 for (unsigned i = 0, e = Opts.CheckersControlList.size(); i != e; ++i) { 132 const std::pair<std::string, bool> &opt = Opts.CheckersControlList[i]; 133 if (opt.second) 134 Res.push_back("-analyzer-disable-checker"); 135 else 136 Res.push_back("-analyzer-checker"); 137 Res.push_back(opt.first); 138 } 139 } 140 141 static void CodeGenOptsToArgs(const CodeGenOptions &Opts, 142 std::vector<std::string> &Res) { 143 if (Opts.DebugInfo) 144 Res.push_back("-g"); 145 if (Opts.DisableLLVMOpts) 146 Res.push_back("-disable-llvm-optzns"); 147 if (Opts.DisableRedZone) 148 Res.push_back("-disable-red-zone"); 149 if (Opts.DisableTailCalls) 150 Res.push_back("-mdisable-tail-calls"); 151 if (!Opts.DebugCompilationDir.empty()) { 152 Res.push_back("-fdebug-compilation-dir"); 153 Res.push_back(Opts.DebugCompilationDir); 154 } 155 if (!Opts.DwarfDebugFlags.empty()) { 156 Res.push_back("-dwarf-debug-flags"); 157 Res.push_back(Opts.DwarfDebugFlags); 158 } 159 if (Opts.ObjCRuntimeHasARC) 160 Res.push_back("-fobjc-runtime-has-arc"); 161 if (Opts.ObjCRuntimeHasTerminate) 162 Res.push_back("-fobjc-runtime-has-terminate"); 163 if (Opts.EmitGcovArcs) 164 Res.push_back("-femit-coverage-data"); 165 if (Opts.EmitGcovNotes) 166 Res.push_back("-femit-coverage-notes"); 167 if (!Opts.MergeAllConstants) 168 Res.push_back("-fno-merge-all-constants"); 169 if (Opts.NoCommon) 170 Res.push_back("-fno-common"); 171 if (Opts.ForbidGuardVariables) 172 Res.push_back("-fforbid-guard-variables"); 173 if (Opts.UseRegisterSizedBitfieldAccess) 174 Res.push_back("-fuse-register-sized-bitfield-access"); 175 if (Opts.NoImplicitFloat) 176 Res.push_back("-no-implicit-float"); 177 if (Opts.OmitLeafFramePointer) 178 Res.push_back("-momit-leaf-frame-pointer"); 179 if (Opts.OptimizeSize) { 180 assert(Opts.OptimizationLevel == 2 && "Invalid options!"); 181 Opts.OptimizeSize == 1 ? Res.push_back("-Os") : Res.push_back("-Oz"); 182 } else if (Opts.OptimizationLevel != 0) 183 Res.push_back("-O" + llvm::utostr(Opts.OptimizationLevel)); 184 if (!Opts.MainFileName.empty()) { 185 Res.push_back("-main-file-name"); 186 Res.push_back(Opts.MainFileName); 187 } 188 if (Opts.NoInfsFPMath) 189 Res.push_back("-menable-no-infinities"); 190 if (Opts.NoNaNsFPMath) 191 Res.push_back("-menable-no-nans"); 192 // SimplifyLibCalls is only derived. 193 // TimePasses is only derived. 194 // UnitAtATime is unused. 195 // Inlining is only derived. 196 197 // UnrollLoops is derived, but also accepts an option, no 198 // harm in pushing it back here. 199 if (Opts.UnrollLoops) 200 Res.push_back("-funroll-loops"); 201 if (Opts.DataSections) 202 Res.push_back("-fdata-sections"); 203 if (Opts.FunctionSections) 204 Res.push_back("-ffunction-sections"); 205 if (Opts.AsmVerbose) 206 Res.push_back("-masm-verbose"); 207 if (!Opts.CodeModel.empty()) { 208 Res.push_back("-mcode-model"); 209 Res.push_back(Opts.CodeModel); 210 } 211 if (Opts.CUDAIsDevice) 212 Res.push_back("-fcuda-is-device"); 213 if (!Opts.CXAAtExit) 214 Res.push_back("-fno-use-cxa-atexit"); 215 if (Opts.CXXCtorDtorAliases) 216 Res.push_back("-mconstructor-aliases"); 217 if (Opts.ObjCAutoRefCountExceptions) 218 Res.push_back("-fobjc-arc-eh"); 219 if (!Opts.DebugPass.empty()) { 220 Res.push_back("-mdebug-pass"); 221 Res.push_back(Opts.DebugPass); 222 } 223 if (Opts.DisableFPElim) 224 Res.push_back("-mdisable-fp-elim"); 225 if (!Opts.FloatABI.empty()) { 226 Res.push_back("-mfloat-abi"); 227 Res.push_back(Opts.FloatABI); 228 } 229 if (!Opts.LimitFloatPrecision.empty()) { 230 Res.push_back("-mlimit-float-precision"); 231 Res.push_back(Opts.LimitFloatPrecision); 232 } 233 if (Opts.NoZeroInitializedInBSS) 234 Res.push_back("-mno-zero-initialized-bss"); 235 switch (Opts.getObjCDispatchMethod()) { 236 case CodeGenOptions::Legacy: 237 break; 238 case CodeGenOptions::Mixed: 239 Res.push_back("-fobjc-dispatch-method=mixed"); 240 break; 241 case CodeGenOptions::NonLegacy: 242 Res.push_back("-fobjc-dispatch-method=non-legacy"); 243 break; 244 } 245 if (Opts.NumRegisterParameters) { 246 Res.push_back("-mregparm"); 247 Res.push_back(llvm::utostr(Opts.NumRegisterParameters)); 248 } 249 if (Opts.NoGlobalMerge) 250 Res.push_back("-mno-global-merge"); 251 if (Opts.NoExecStack) 252 Res.push_back("-mnoexecstack"); 253 if (Opts.RelaxAll) 254 Res.push_back("-mrelax-all"); 255 if (Opts.SaveTempLabels) 256 Res.push_back("-msave-temp-labels"); 257 if (Opts.NoDwarf2CFIAsm) 258 Res.push_back("-fno-dwarf2-cfi-asm"); 259 if (Opts.NoDwarfDirectoryAsm) 260 Res.push_back("-fno-dwarf-directory-asm"); 261 if (Opts.SoftFloat) 262 Res.push_back("-msoft-float"); 263 if (Opts.UnwindTables) 264 Res.push_back("-munwind-tables"); 265 if (Opts.RelocationModel != "pic") { 266 Res.push_back("-mrelocation-model"); 267 Res.push_back(Opts.RelocationModel); 268 } 269 if (!Opts.VerifyModule) 270 Res.push_back("-disable-llvm-verifier"); 271 for (unsigned i = 0, e = Opts.BackendOptions.size(); i != e; ++i) { 272 Res.push_back("-backend-option"); 273 Res.push_back(Opts.BackendOptions[i]); 274 } 275 } 276 277 static void DependencyOutputOptsToArgs(const DependencyOutputOptions &Opts, 278 std::vector<std::string> &Res) { 279 if (Opts.IncludeSystemHeaders) 280 Res.push_back("-sys-header-deps"); 281 if (Opts.ShowHeaderIncludes) 282 Res.push_back("-H"); 283 if (!Opts.HeaderIncludeOutputFile.empty()) { 284 Res.push_back("-header-include-file"); 285 Res.push_back(Opts.HeaderIncludeOutputFile); 286 } 287 if (Opts.UsePhonyTargets) 288 Res.push_back("-MP"); 289 if (!Opts.OutputFile.empty()) { 290 Res.push_back("-dependency-file"); 291 Res.push_back(Opts.OutputFile); 292 } 293 for (unsigned i = 0, e = Opts.Targets.size(); i != e; ++i) { 294 Res.push_back("-MT"); 295 Res.push_back(Opts.Targets[i]); 296 } 297 } 298 299 static void DiagnosticOptsToArgs(const DiagnosticOptions &Opts, 300 std::vector<std::string> &Res) { 301 if (Opts.IgnoreWarnings) 302 Res.push_back("-w"); 303 if (Opts.NoRewriteMacros) 304 Res.push_back("-Wno-rewrite-macros"); 305 if (Opts.Pedantic) 306 Res.push_back("-pedantic"); 307 if (Opts.PedanticErrors) 308 Res.push_back("-pedantic-errors"); 309 if (!Opts.ShowColumn) 310 Res.push_back("-fno-show-column"); 311 if (!Opts.ShowLocation) 312 Res.push_back("-fno-show-source-location"); 313 if (!Opts.ShowCarets) 314 Res.push_back("-fno-caret-diagnostics"); 315 if (!Opts.ShowFixits) 316 Res.push_back("-fno-diagnostics-fixit-info"); 317 if (Opts.ShowSourceRanges) 318 Res.push_back("-fdiagnostics-print-source-range-info"); 319 if (Opts.ShowParseableFixits) 320 Res.push_back("-fdiagnostics-parseable-fixits"); 321 if (Opts.ShowColors) 322 Res.push_back("-fcolor-diagnostics"); 323 if (Opts.VerifyDiagnostics) 324 Res.push_back("-verify"); 325 if (Opts.ShowNames) 326 Res.push_back("-fdiagnostics-show-name"); 327 if (Opts.ShowOptionNames) 328 Res.push_back("-fdiagnostics-show-option"); 329 if (Opts.ShowCategories == 1) 330 Res.push_back("-fdiagnostics-show-category=id"); 331 else if (Opts.ShowCategories == 2) 332 Res.push_back("-fdiagnostics-show-category=name"); 333 switch (Opts.Format) { 334 case DiagnosticOptions::Clang: 335 Res.push_back("-fdiagnostics-format=clang"); break; 336 case DiagnosticOptions::Msvc: 337 Res.push_back("-fdiagnostics-format=msvc"); break; 338 case DiagnosticOptions::Vi: 339 Res.push_back("-fdiagnostics-format=vi"); break; 340 } 341 if (Opts.ErrorLimit) { 342 Res.push_back("-ferror-limit"); 343 Res.push_back(llvm::utostr(Opts.ErrorLimit)); 344 } 345 if (!Opts.DiagnosticLogFile.empty()) { 346 Res.push_back("-diagnostic-log-file"); 347 Res.push_back(Opts.DiagnosticLogFile); 348 } 349 if (Opts.MacroBacktraceLimit 350 != DiagnosticOptions::DefaultMacroBacktraceLimit) { 351 Res.push_back("-fmacro-backtrace-limit"); 352 Res.push_back(llvm::utostr(Opts.MacroBacktraceLimit)); 353 } 354 if (Opts.TemplateBacktraceLimit 355 != DiagnosticOptions::DefaultTemplateBacktraceLimit) { 356 Res.push_back("-ftemplate-backtrace-limit"); 357 Res.push_back(llvm::utostr(Opts.TemplateBacktraceLimit)); 358 } 359 if (Opts.ConstexprBacktraceLimit 360 != DiagnosticOptions::DefaultConstexprBacktraceLimit) { 361 Res.push_back("-fconstexpr-backtrace-limit"); 362 Res.push_back(llvm::utostr(Opts.ConstexprBacktraceLimit)); 363 } 364 365 if (Opts.TabStop != DiagnosticOptions::DefaultTabStop) { 366 Res.push_back("-ftabstop"); 367 Res.push_back(llvm::utostr(Opts.TabStop)); 368 } 369 if (Opts.MessageLength) { 370 Res.push_back("-fmessage-length"); 371 Res.push_back(llvm::utostr(Opts.MessageLength)); 372 } 373 if (!Opts.DumpBuildInformation.empty()) { 374 Res.push_back("-dump-build-information"); 375 Res.push_back(Opts.DumpBuildInformation); 376 } 377 for (unsigned i = 0, e = Opts.Warnings.size(); i != e; ++i) 378 Res.push_back("-W" + Opts.Warnings[i]); 379 } 380 381 static const char *getInputKindName(InputKind Kind) { 382 switch (Kind) { 383 case IK_None: break; 384 case IK_AST: return "ast"; 385 case IK_Asm: return "assembler-with-cpp"; 386 case IK_C: return "c"; 387 case IK_CXX: return "c++"; 388 case IK_LLVM_IR: return "ir"; 389 case IK_ObjC: return "objective-c"; 390 case IK_ObjCXX: return "objective-c++"; 391 case IK_OpenCL: return "cl"; 392 case IK_CUDA: return "cuda"; 393 case IK_PreprocessedC: return "cpp-output"; 394 case IK_PreprocessedCXX: return "c++-cpp-output"; 395 case IK_PreprocessedObjC: return "objective-c-cpp-output"; 396 case IK_PreprocessedObjCXX:return "objective-c++-cpp-output"; 397 } 398 399 llvm_unreachable("Unexpected language kind!"); 400 } 401 402 static const char *getActionName(frontend::ActionKind Kind) { 403 switch (Kind) { 404 case frontend::PluginAction: 405 llvm_unreachable("Invalid kind!"); 406 407 case frontend::ASTDump: return "-ast-dump"; 408 case frontend::ASTDumpXML: return "-ast-dump-xml"; 409 case frontend::ASTPrint: return "-ast-print"; 410 case frontend::ASTView: return "-ast-view"; 411 case frontend::DumpRawTokens: return "-dump-raw-tokens"; 412 case frontend::DumpTokens: return "-dump-tokens"; 413 case frontend::EmitAssembly: return "-S"; 414 case frontend::EmitBC: return "-emit-llvm-bc"; 415 case frontend::EmitHTML: return "-emit-html"; 416 case frontend::EmitLLVM: return "-emit-llvm"; 417 case frontend::EmitLLVMOnly: return "-emit-llvm-only"; 418 case frontend::EmitCodeGenOnly: return "-emit-codegen-only"; 419 case frontend::EmitObj: return "-emit-obj"; 420 case frontend::FixIt: return "-fixit"; 421 case frontend::GenerateModule: return "-emit-module"; 422 case frontend::GeneratePCH: return "-emit-pch"; 423 case frontend::GeneratePTH: return "-emit-pth"; 424 case frontend::InitOnly: return "-init-only"; 425 case frontend::ParseSyntaxOnly: return "-fsyntax-only"; 426 case frontend::PrintDeclContext: return "-print-decl-contexts"; 427 case frontend::PrintPreamble: return "-print-preamble"; 428 case frontend::PrintPreprocessedInput: return "-E"; 429 case frontend::RewriteMacros: return "-rewrite-macros"; 430 case frontend::RewriteObjC: return "-rewrite-objc"; 431 case frontend::RewriteTest: return "-rewrite-test"; 432 case frontend::RunAnalysis: return "-analyze"; 433 case frontend::RunPreprocessorOnly: return "-Eonly"; 434 } 435 436 llvm_unreachable("Unexpected language kind!"); 437 } 438 439 static void FileSystemOptsToArgs(const FileSystemOptions &Opts, 440 std::vector<std::string> &Res) { 441 if (!Opts.WorkingDir.empty()) { 442 Res.push_back("-working-directory"); 443 Res.push_back(Opts.WorkingDir); 444 } 445 } 446 447 static void FrontendOptsToArgs(const FrontendOptions &Opts, 448 std::vector<std::string> &Res) { 449 if (Opts.DisableFree) 450 Res.push_back("-disable-free"); 451 if (Opts.RelocatablePCH) 452 Res.push_back("-relocatable-pch"); 453 if (Opts.ShowHelp) 454 Res.push_back("-help"); 455 if (Opts.ShowMacrosInCodeCompletion) 456 Res.push_back("-code-completion-macros"); 457 if (Opts.ShowCodePatternsInCodeCompletion) 458 Res.push_back("-code-completion-patterns"); 459 if (!Opts.ShowGlobalSymbolsInCodeCompletion) 460 Res.push_back("-no-code-completion-globals"); 461 if (Opts.ShowStats) 462 Res.push_back("-print-stats"); 463 if (Opts.ShowTimers) 464 Res.push_back("-ftime-report"); 465 if (Opts.ShowVersion) 466 Res.push_back("-version"); 467 if (Opts.FixWhatYouCan) 468 Res.push_back("-fix-what-you-can"); 469 if (Opts.FixOnlyWarnings) 470 Res.push_back("-fix-only-warnings"); 471 if (Opts.FixAndRecompile) 472 Res.push_back("-fixit-recompile"); 473 if (Opts.FixToTemporaries) 474 Res.push_back("-fixit-to-temporary"); 475 switch (Opts.ARCMTAction) { 476 case FrontendOptions::ARCMT_None: 477 break; 478 case FrontendOptions::ARCMT_Check: 479 Res.push_back("-arcmt-check"); 480 break; 481 case FrontendOptions::ARCMT_Modify: 482 Res.push_back("-arcmt-modify"); 483 break; 484 case FrontendOptions::ARCMT_Migrate: 485 Res.push_back("-arcmt-migrate"); 486 break; 487 } 488 if (!Opts.ARCMTMigrateDir.empty()) { 489 Res.push_back("-arcmt-migrate-directory"); 490 Res.push_back(Opts.ARCMTMigrateDir); 491 } 492 if (!Opts.ARCMTMigrateReportOut.empty()) { 493 Res.push_back("-arcmt-migrate-report-output"); 494 Res.push_back(Opts.ARCMTMigrateReportOut); 495 } 496 if (Opts.ARCMTMigrateEmitARCErrors) 497 Res.push_back("-arcmt-migrate-emit-errors"); 498 499 bool NeedLang = false; 500 for (unsigned i = 0, e = Opts.Inputs.size(); i != e; ++i) 501 if (FrontendOptions::getInputKindForExtension(Opts.Inputs[i].File) != 502 Opts.Inputs[i].Kind) 503 NeedLang = true; 504 if (NeedLang) { 505 Res.push_back("-x"); 506 Res.push_back(getInputKindName(Opts.Inputs[0].Kind)); 507 } 508 for (unsigned i = 0, e = Opts.Inputs.size(); i != e; ++i) { 509 assert((!NeedLang || Opts.Inputs[i].Kind == Opts.Inputs[0].Kind) && 510 "Unable to represent this input vector!"); 511 Res.push_back(Opts.Inputs[i].File); 512 } 513 514 if (!Opts.OutputFile.empty()) { 515 Res.push_back("-o"); 516 Res.push_back(Opts.OutputFile); 517 } 518 if (!Opts.CodeCompletionAt.FileName.empty()) { 519 Res.push_back("-code-completion-at"); 520 Res.push_back(Opts.CodeCompletionAt.FileName + ":" + 521 llvm::utostr(Opts.CodeCompletionAt.Line) + ":" + 522 llvm::utostr(Opts.CodeCompletionAt.Column)); 523 } 524 if (Opts.ProgramAction != frontend::PluginAction) 525 Res.push_back(getActionName(Opts.ProgramAction)); 526 if (!Opts.ActionName.empty()) { 527 Res.push_back("-plugin"); 528 Res.push_back(Opts.ActionName); 529 for(unsigned i = 0, e = Opts.PluginArgs.size(); i != e; ++i) { 530 Res.push_back("-plugin-arg-" + Opts.ActionName); 531 Res.push_back(Opts.PluginArgs[i]); 532 } 533 } 534 for (unsigned i = 0, e = Opts.Plugins.size(); i != e; ++i) { 535 Res.push_back("-load"); 536 Res.push_back(Opts.Plugins[i]); 537 } 538 for (unsigned i = 0, e = Opts.AddPluginActions.size(); i != e; ++i) { 539 Res.push_back("-add-plugin"); 540 Res.push_back(Opts.AddPluginActions[i]); 541 for(unsigned ai = 0, ae = Opts.AddPluginArgs.size(); ai != ae; ++ai) { 542 Res.push_back("-plugin-arg-" + Opts.AddPluginActions[i]); 543 Res.push_back(Opts.AddPluginArgs[i][ai]); 544 } 545 } 546 for (unsigned i = 0, e = Opts.ASTMergeFiles.size(); i != e; ++i) { 547 Res.push_back("-ast-merge"); 548 Res.push_back(Opts.ASTMergeFiles[i]); 549 } 550 for (unsigned i = 0, e = Opts.LLVMArgs.size(); i != e; ++i) { 551 Res.push_back("-mllvm"); 552 Res.push_back(Opts.LLVMArgs[i]); 553 } 554 } 555 556 static void HeaderSearchOptsToArgs(const HeaderSearchOptions &Opts, 557 std::vector<std::string> &Res) { 558 if (Opts.Sysroot != "/") { 559 Res.push_back("-isysroot"); 560 Res.push_back(Opts.Sysroot); 561 } 562 563 /// User specified include entries. 564 for (unsigned i = 0, e = Opts.UserEntries.size(); i != e; ++i) { 565 const HeaderSearchOptions::Entry &E = Opts.UserEntries[i]; 566 if (E.IsFramework && (E.Group != frontend::Angled || !E.IsUserSupplied)) 567 llvm::report_fatal_error("Invalid option set!"); 568 if (E.IsUserSupplied) { 569 switch (E.Group) { 570 case frontend::After: 571 Res.push_back("-idirafter"); 572 break; 573 574 case frontend::Quoted: 575 Res.push_back("-iquote"); 576 break; 577 578 case frontend::System: 579 Res.push_back("-isystem"); 580 break; 581 582 case frontend::IndexHeaderMap: 583 Res.push_back("-index-header-map"); 584 Res.push_back(E.IsFramework? "-F" : "-I"); 585 break; 586 587 case frontend::CSystem: 588 Res.push_back("-c-isystem"); 589 break; 590 591 case frontend::CXXSystem: 592 Res.push_back("-cxx-isystem"); 593 break; 594 595 case frontend::ObjCSystem: 596 Res.push_back("-objc-isystem"); 597 break; 598 599 case frontend::ObjCXXSystem: 600 Res.push_back("-objcxx-isystem"); 601 break; 602 603 case frontend::Angled: 604 Res.push_back(E.IsFramework ? "-F" : "-I"); 605 break; 606 } 607 } else { 608 if (E.IsInternal) { 609 assert(E.Group == frontend::System && "Unexpected header search group"); 610 if (E.ImplicitExternC) 611 Res.push_back("-internal-externc-isystem"); 612 else 613 Res.push_back("-internal-isystem"); 614 } else { 615 if (E.Group != frontend::Angled && E.Group != frontend::System) 616 llvm::report_fatal_error("Invalid option set!"); 617 Res.push_back(E.Group == frontend::Angled ? "-iwithprefixbefore" : 618 "-iwithprefix"); 619 } 620 } 621 Res.push_back(E.Path); 622 } 623 624 if (!Opts.ResourceDir.empty()) { 625 Res.push_back("-resource-dir"); 626 Res.push_back(Opts.ResourceDir); 627 } 628 if (!Opts.ModuleCachePath.empty()) { 629 Res.push_back("-fmodule-cache-path"); 630 Res.push_back(Opts.ModuleCachePath); 631 } 632 if (!Opts.UseStandardSystemIncludes) 633 Res.push_back("-nostdsysteminc"); 634 if (!Opts.UseStandardCXXIncludes) 635 Res.push_back("-nostdinc++"); 636 if (Opts.UseLibcxx) 637 Res.push_back("-stdlib=libc++"); 638 if (Opts.Verbose) 639 Res.push_back("-v"); 640 } 641 642 static void LangOptsToArgs(const LangOptions &Opts, 643 std::vector<std::string> &Res) { 644 LangOptions DefaultLangOpts; 645 646 // FIXME: Need to set -std to get all the implicit options. 647 648 // FIXME: We want to only pass options relative to the defaults, which 649 // requires constructing a target. :( 650 // 651 // It would be better to push the all target specific choices into the driver, 652 // so that everything below that was more uniform. 653 654 if (Opts.Trigraphs) 655 Res.push_back("-trigraphs"); 656 // Implicit based on the input kind: 657 // AsmPreprocessor, CPlusPlus, ObjC1, ObjC2, OpenCL 658 // Implicit based on the input language standard: 659 // BCPLComment, C99, CPlusPlus0x, Digraphs, GNUInline, ImplicitInt, GNUMode 660 if (Opts.DollarIdents) 661 Res.push_back("-fdollars-in-identifiers"); 662 if (Opts.GNUMode && !Opts.GNUKeywords) 663 Res.push_back("-fno-gnu-keywords"); 664 if (!Opts.GNUMode && Opts.GNUKeywords) 665 Res.push_back("-fgnu-keywords"); 666 if (Opts.MicrosoftExt) 667 Res.push_back("-fms-extensions"); 668 if (Opts.MicrosoftMode) 669 Res.push_back("-fms-compatibility"); 670 if (Opts.MSCVersion != 0) 671 Res.push_back("-fmsc-version=" + llvm::utostr(Opts.MSCVersion)); 672 if (Opts.Borland) 673 Res.push_back("-fborland-extensions"); 674 if (!Opts.ObjCNonFragileABI) 675 Res.push_back("-fobjc-fragile-abi"); 676 if (Opts.ObjCDefaultSynthProperties) 677 Res.push_back("-fobjc-default-synthesize-properties"); 678 // NoInline is implicit. 679 if (!Opts.CXXOperatorNames) 680 Res.push_back("-fno-operator-names"); 681 if (Opts.PascalStrings) 682 Res.push_back("-fpascal-strings"); 683 if (Opts.CatchUndefined) 684 Res.push_back("-fcatch-undefined-behavior"); 685 if (Opts.AddressSanitizer) 686 Res.push_back("-faddress-sanitizer"); 687 if (Opts.WritableStrings) 688 Res.push_back("-fwritable-strings"); 689 if (Opts.ConstStrings) 690 Res.push_back("-fconst-strings"); 691 if (!Opts.LaxVectorConversions) 692 Res.push_back("-fno-lax-vector-conversions"); 693 if (Opts.AltiVec) 694 Res.push_back("-faltivec"); 695 if (Opts.Exceptions) 696 Res.push_back("-fexceptions"); 697 if (Opts.ObjCExceptions) 698 Res.push_back("-fobjc-exceptions"); 699 if (Opts.CXXExceptions) 700 Res.push_back("-fcxx-exceptions"); 701 if (Opts.SjLjExceptions) 702 Res.push_back("-fsjlj-exceptions"); 703 if (Opts.TraditionalCPP) 704 Res.push_back("-traditional-cpp"); 705 if (!Opts.RTTI) 706 Res.push_back("-fno-rtti"); 707 if (Opts.MSBitfields) 708 Res.push_back("-mms-bitfields"); 709 if (!Opts.NeXTRuntime) 710 Res.push_back("-fgnu-runtime"); 711 if (Opts.Freestanding) 712 Res.push_back("-ffreestanding"); 713 if (Opts.NoBuiltin) 714 Res.push_back("-fno-builtin"); 715 if (!Opts.AssumeSaneOperatorNew) 716 Res.push_back("-fno-assume-sane-operator-new"); 717 if (!Opts.ThreadsafeStatics) 718 Res.push_back("-fno-threadsafe-statics"); 719 if (Opts.POSIXThreads) 720 Res.push_back("-pthread"); 721 if (Opts.Blocks) 722 Res.push_back("-fblocks"); 723 if (Opts.BlocksRuntimeOptional) 724 Res.push_back("-fblocks-runtime-optional"); 725 if (Opts.Modules) 726 Res.push_back("-fmodules"); 727 if (Opts.EmitAllDecls) 728 Res.push_back("-femit-all-decls"); 729 if (Opts.MathErrno) 730 Res.push_back("-fmath-errno"); 731 switch (Opts.getSignedOverflowBehavior()) { 732 case LangOptions::SOB_Undefined: break; 733 case LangOptions::SOB_Defined: Res.push_back("-fwrapv"); break; 734 case LangOptions::SOB_Trapping: 735 Res.push_back("-ftrapv"); 736 if (!Opts.OverflowHandler.empty()) { 737 Res.push_back("-ftrapv-handler"); 738 Res.push_back(Opts.OverflowHandler); 739 } 740 break; 741 } 742 if (Opts.HeinousExtensions) 743 Res.push_back("-fheinous-gnu-extensions"); 744 // Optimize is implicit. 745 // OptimizeSize is implicit. 746 if (Opts.FastMath) 747 Res.push_back("-ffast-math"); 748 if (Opts.Static) 749 Res.push_back("-static-define"); 750 if (Opts.DumpRecordLayouts) 751 Res.push_back("-fdump-record-layouts"); 752 if (Opts.DumpVTableLayouts) 753 Res.push_back("-fdump-vtable-layouts"); 754 if (Opts.NoBitFieldTypeAlign) 755 Res.push_back("-fno-bitfield-type-alignment"); 756 if (Opts.PICLevel) { 757 Res.push_back("-pic-level"); 758 Res.push_back(llvm::utostr(Opts.PICLevel)); 759 } 760 if (Opts.ObjCGCBitmapPrint) 761 Res.push_back("-print-ivar-layout"); 762 if (Opts.NoConstantCFStrings) 763 Res.push_back("-fno-constant-cfstrings"); 764 if (!Opts.AccessControl) 765 Res.push_back("-fno-access-control"); 766 if (!Opts.CharIsSigned) 767 Res.push_back("-fno-signed-char"); 768 if (Opts.ShortWChar) 769 Res.push_back("-fshort-wchar"); 770 if (!Opts.ElideConstructors) 771 Res.push_back("-fno-elide-constructors"); 772 if (Opts.getGC() != LangOptions::NonGC) { 773 if (Opts.getGC() == LangOptions::HybridGC) { 774 Res.push_back("-fobjc-gc"); 775 } else { 776 assert(Opts.getGC() == LangOptions::GCOnly && "Invalid GC mode!"); 777 Res.push_back("-fobjc-gc-only"); 778 } 779 } 780 if (Opts.ObjCAutoRefCount) 781 Res.push_back("-fobjc-arc"); 782 if (Opts.ObjCRuntimeHasWeak) 783 Res.push_back("-fobjc-runtime-has-weak"); 784 if (!Opts.ObjCInferRelatedResultType) 785 Res.push_back("-fno-objc-infer-related-result-type"); 786 787 if (Opts.AppleKext) 788 Res.push_back("-fapple-kext"); 789 790 if (Opts.getVisibilityMode() != DefaultVisibility) { 791 Res.push_back("-fvisibility"); 792 if (Opts.getVisibilityMode() == HiddenVisibility) { 793 Res.push_back("hidden"); 794 } else { 795 assert(Opts.getVisibilityMode() == ProtectedVisibility && 796 "Invalid visibility!"); 797 Res.push_back("protected"); 798 } 799 } 800 if (Opts.InlineVisibilityHidden) 801 Res.push_back("-fvisibility-inlines-hidden"); 802 803 if (Opts.getStackProtector() != 0) { 804 Res.push_back("-stack-protector"); 805 Res.push_back(llvm::utostr(Opts.getStackProtector())); 806 } 807 if (Opts.InstantiationDepth != DefaultLangOpts.InstantiationDepth) { 808 Res.push_back("-ftemplate-depth"); 809 Res.push_back(llvm::utostr(Opts.InstantiationDepth)); 810 } 811 if (Opts.ConstexprCallDepth != DefaultLangOpts.ConstexprCallDepth) { 812 Res.push_back("-fconstexpr-depth"); 813 Res.push_back(llvm::utostr(Opts.ConstexprCallDepth)); 814 } 815 if (!Opts.ObjCConstantStringClass.empty()) { 816 Res.push_back("-fconstant-string-class"); 817 Res.push_back(Opts.ObjCConstantStringClass); 818 } 819 if (Opts.FakeAddressSpaceMap) 820 Res.push_back("-ffake-address-space-map"); 821 if (Opts.ParseUnknownAnytype) 822 Res.push_back("-funknown-anytype"); 823 if (Opts.DebuggerSupport) 824 Res.push_back("-fdebugger-support"); 825 if (Opts.DelayedTemplateParsing) 826 Res.push_back("-fdelayed-template-parsing"); 827 if (Opts.Deprecated) 828 Res.push_back("-fdeprecated-macro"); 829 if (Opts.ApplePragmaPack) 830 Res.push_back("-fapple-pragma-pack"); 831 if (!Opts.CurrentModule.empty()) 832 Res.push_back("-fmodule-name=" + Opts.CurrentModule); 833 } 834 835 static void PreprocessorOptsToArgs(const PreprocessorOptions &Opts, 836 std::vector<std::string> &Res) { 837 for (unsigned i = 0, e = Opts.Macros.size(); i != e; ++i) 838 Res.push_back(std::string(Opts.Macros[i].second ? "-U" : "-D") + 839 Opts.Macros[i].first); 840 for (unsigned i = 0, e = Opts.Includes.size(); i != e; ++i) { 841 // FIXME: We need to avoid reincluding the implicit PCH and PTH includes. 842 Res.push_back("-include"); 843 Res.push_back(Opts.Includes[i]); 844 } 845 for (unsigned i = 0, e = Opts.MacroIncludes.size(); i != e; ++i) { 846 Res.push_back("-imacros"); 847 Res.push_back(Opts.MacroIncludes[i]); 848 } 849 if (!Opts.UsePredefines) 850 Res.push_back("-undef"); 851 if (Opts.DetailedRecord) 852 Res.push_back("-detailed-preprocessing-record"); 853 if (!Opts.ImplicitPCHInclude.empty()) { 854 Res.push_back("-include-pch"); 855 Res.push_back(Opts.ImplicitPCHInclude); 856 } 857 if (!Opts.ImplicitPTHInclude.empty()) { 858 Res.push_back("-include-pth"); 859 Res.push_back(Opts.ImplicitPTHInclude); 860 } 861 if (!Opts.TokenCache.empty()) { 862 if (Opts.ImplicitPTHInclude.empty()) { 863 Res.push_back("-token-cache"); 864 Res.push_back(Opts.TokenCache); 865 } else 866 assert(Opts.ImplicitPTHInclude == Opts.TokenCache && 867 "Unsupported option combination!"); 868 } 869 for (unsigned i = 0, e = Opts.ChainedIncludes.size(); i != e; ++i) { 870 Res.push_back("-chain-include"); 871 Res.push_back(Opts.ChainedIncludes[i]); 872 } 873 for (unsigned i = 0, e = Opts.RemappedFiles.size(); i != e; ++i) { 874 Res.push_back("-remap-file"); 875 Res.push_back(Opts.RemappedFiles[i].first + ";" + 876 Opts.RemappedFiles[i].second); 877 } 878 } 879 880 static void PreprocessorOutputOptsToArgs(const PreprocessorOutputOptions &Opts, 881 std::vector<std::string> &Res) { 882 if (!Opts.ShowCPP && !Opts.ShowMacros) 883 llvm::report_fatal_error("Invalid option combination!"); 884 885 if (Opts.ShowCPP && Opts.ShowMacros) 886 Res.push_back("-dD"); 887 else if (!Opts.ShowCPP && Opts.ShowMacros) 888 Res.push_back("-dM"); 889 890 if (!Opts.ShowLineMarkers) 891 Res.push_back("-P"); 892 if (Opts.ShowComments) 893 Res.push_back("-C"); 894 if (Opts.ShowMacroComments) 895 Res.push_back("-CC"); 896 } 897 898 static void TargetOptsToArgs(const TargetOptions &Opts, 899 std::vector<std::string> &Res) { 900 Res.push_back("-triple"); 901 Res.push_back(Opts.Triple); 902 if (!Opts.CPU.empty()) { 903 Res.push_back("-target-cpu"); 904 Res.push_back(Opts.CPU); 905 } 906 if (!Opts.ABI.empty()) { 907 Res.push_back("-target-abi"); 908 Res.push_back(Opts.ABI); 909 } 910 if (!Opts.LinkerVersion.empty()) { 911 Res.push_back("-target-linker-version"); 912 Res.push_back(Opts.LinkerVersion); 913 } 914 if (!Opts.CXXABI.empty()) { 915 Res.push_back("-cxx-abi"); 916 Res.push_back(Opts.CXXABI); 917 } 918 for (unsigned i = 0, e = Opts.Features.size(); i != e; ++i) { 919 Res.push_back("-target-feature"); 920 Res.push_back(Opts.Features[i]); 921 } 922 } 923 924 void CompilerInvocation::toArgs(std::vector<std::string> &Res) { 925 AnalyzerOptsToArgs(getAnalyzerOpts(), Res); 926 CodeGenOptsToArgs(getCodeGenOpts(), Res); 927 DependencyOutputOptsToArgs(getDependencyOutputOpts(), Res); 928 DiagnosticOptsToArgs(getDiagnosticOpts(), Res); 929 FileSystemOptsToArgs(getFileSystemOpts(), Res); 930 FrontendOptsToArgs(getFrontendOpts(), Res); 931 HeaderSearchOptsToArgs(getHeaderSearchOpts(), Res); 932 LangOptsToArgs(*getLangOpts(), Res); 933 PreprocessorOptsToArgs(getPreprocessorOpts(), Res); 934 PreprocessorOutputOptsToArgs(getPreprocessorOutputOpts(), Res); 935 TargetOptsToArgs(getTargetOpts(), Res); 936 } 937 938 //===----------------------------------------------------------------------===// 939 // Deserialization (to args) 940 //===----------------------------------------------------------------------===// 941 942 using namespace clang::driver; 943 using namespace clang::driver::cc1options; 944 945 // 946 947 static unsigned getOptimizationLevel(ArgList &Args, InputKind IK, 948 DiagnosticsEngine &Diags) { 949 unsigned DefaultOpt = 0; 950 if (IK == IK_OpenCL && !Args.hasArg(OPT_cl_opt_disable)) 951 DefaultOpt = 2; 952 // -Os/-Oz implies -O2 953 return (Args.hasArg(OPT_Os) || Args.hasArg (OPT_Oz)) ? 2 : 954 Args.getLastArgIntValue(OPT_O, DefaultOpt, Diags); 955 } 956 957 static bool ParseAnalyzerArgs(AnalyzerOptions &Opts, ArgList &Args, 958 DiagnosticsEngine &Diags) { 959 using namespace cc1options; 960 bool Success = true; 961 if (Arg *A = Args.getLastArg(OPT_analyzer_store)) { 962 StringRef Name = A->getValue(Args); 963 AnalysisStores Value = llvm::StringSwitch<AnalysisStores>(Name) 964 #define ANALYSIS_STORE(NAME, CMDFLAG, DESC, CREATFN) \ 965 .Case(CMDFLAG, NAME##Model) 966 #include "clang/Frontend/Analyses.def" 967 .Default(NumStores); 968 if (Value == NumStores) { 969 Diags.Report(diag::err_drv_invalid_value) 970 << A->getAsString(Args) << Name; 971 Success = false; 972 } else { 973 Opts.AnalysisStoreOpt = Value; 974 } 975 } 976 977 if (Arg *A = Args.getLastArg(OPT_analyzer_constraints)) { 978 StringRef Name = A->getValue(Args); 979 AnalysisConstraints Value = llvm::StringSwitch<AnalysisConstraints>(Name) 980 #define ANALYSIS_CONSTRAINTS(NAME, CMDFLAG, DESC, CREATFN) \ 981 .Case(CMDFLAG, NAME##Model) 982 #include "clang/Frontend/Analyses.def" 983 .Default(NumConstraints); 984 if (Value == NumConstraints) { 985 Diags.Report(diag::err_drv_invalid_value) 986 << A->getAsString(Args) << Name; 987 Success = false; 988 } else { 989 Opts.AnalysisConstraintsOpt = Value; 990 } 991 } 992 993 if (Arg *A = Args.getLastArg(OPT_analyzer_output)) { 994 StringRef Name = A->getValue(Args); 995 AnalysisDiagClients Value = llvm::StringSwitch<AnalysisDiagClients>(Name) 996 #define ANALYSIS_DIAGNOSTICS(NAME, CMDFLAG, DESC, CREATFN, AUTOCREAT) \ 997 .Case(CMDFLAG, PD_##NAME) 998 #include "clang/Frontend/Analyses.def" 999 .Default(NUM_ANALYSIS_DIAG_CLIENTS); 1000 if (Value == NUM_ANALYSIS_DIAG_CLIENTS) { 1001 Diags.Report(diag::err_drv_invalid_value) 1002 << A->getAsString(Args) << Name; 1003 Success = false; 1004 } else { 1005 Opts.AnalysisDiagOpt = Value; 1006 } 1007 } 1008 1009 if (Arg *A = Args.getLastArg(OPT_analyzer_purge)) { 1010 StringRef Name = A->getValue(Args); 1011 AnalysisPurgeMode Value = llvm::StringSwitch<AnalysisPurgeMode>(Name) 1012 #define ANALYSIS_PURGE(NAME, CMDFLAG, DESC) \ 1013 .Case(CMDFLAG, NAME) 1014 #include "clang/Frontend/Analyses.def" 1015 .Default(NumPurgeModes); 1016 if (Value == NumPurgeModes) { 1017 Diags.Report(diag::err_drv_invalid_value) 1018 << A->getAsString(Args) << Name; 1019 Success = false; 1020 } else { 1021 Opts.AnalysisPurgeOpt = Value; 1022 } 1023 } 1024 1025 Opts.ShowCheckerHelp = Args.hasArg(OPT_analyzer_checker_help); 1026 Opts.VisualizeEGDot = Args.hasArg(OPT_analyzer_viz_egraph_graphviz); 1027 Opts.VisualizeEGUbi = Args.hasArg(OPT_analyzer_viz_egraph_ubigraph); 1028 Opts.AnalyzeAll = Args.hasArg(OPT_analyzer_opt_analyze_headers); 1029 Opts.AnalyzerDisplayProgress = Args.hasArg(OPT_analyzer_display_progress); 1030 Opts.AnalyzeNestedBlocks = 1031 Args.hasArg(OPT_analyzer_opt_analyze_nested_blocks); 1032 Opts.EagerlyAssume = Args.hasArg(OPT_analyzer_eagerly_assume); 1033 Opts.AnalyzeSpecificFunction = Args.getLastArgValue(OPT_analyze_function); 1034 Opts.UnoptimizedCFG = Args.hasArg(OPT_analysis_UnoptimizedCFG); 1035 Opts.CFGAddImplicitDtors = Args.hasArg(OPT_analysis_CFGAddImplicitDtors); 1036 Opts.CFGAddInitializers = Args.hasArg(OPT_analysis_CFGAddInitializers); 1037 Opts.TrimGraph = Args.hasArg(OPT_trim_egraph); 1038 Opts.MaxNodes = Args.getLastArgIntValue(OPT_analyzer_max_nodes, 150000,Diags); 1039 Opts.MaxLoop = Args.getLastArgIntValue(OPT_analyzer_max_loop, 4, Diags); 1040 Opts.EagerlyTrimEGraph = !Args.hasArg(OPT_analyzer_no_eagerly_trim_egraph); 1041 Opts.InlineCall = Args.hasArg(OPT_analyzer_inline_call); 1042 1043 Opts.CheckersControlList.clear(); 1044 for (arg_iterator it = Args.filtered_begin(OPT_analyzer_checker, 1045 OPT_analyzer_disable_checker), 1046 ie = Args.filtered_end(); it != ie; ++it) { 1047 const Arg *A = *it; 1048 A->claim(); 1049 bool enable = (A->getOption().getID() == OPT_analyzer_checker); 1050 // We can have a list of comma separated checker names, e.g: 1051 // '-analyzer-checker=cocoa,unix' 1052 StringRef checkerList = A->getValue(Args); 1053 SmallVector<StringRef, 4> checkers; 1054 checkerList.split(checkers, ","); 1055 for (unsigned i = 0, e = checkers.size(); i != e; ++i) 1056 Opts.CheckersControlList.push_back(std::make_pair(checkers[i], enable)); 1057 } 1058 1059 return Success; 1060 } 1061 1062 static bool ParseMigratorArgs(MigratorOptions &Opts, ArgList &Args) { 1063 Opts.NoNSAllocReallocError = Args.hasArg(OPT_migrator_no_nsalloc_error); 1064 return true; 1065 } 1066 1067 static bool ParseCodeGenArgs(CodeGenOptions &Opts, ArgList &Args, InputKind IK, 1068 DiagnosticsEngine &Diags) { 1069 using namespace cc1options; 1070 bool Success = true; 1071 1072 Opts.OptimizationLevel = getOptimizationLevel(Args, IK, Diags); 1073 if (Opts.OptimizationLevel > 3) { 1074 Diags.Report(diag::err_drv_invalid_value) 1075 << Args.getLastArg(OPT_O)->getAsString(Args) << Opts.OptimizationLevel; 1076 Opts.OptimizationLevel = 3; 1077 Success = false; 1078 } 1079 1080 // We must always run at least the always inlining pass. 1081 Opts.Inlining = (Opts.OptimizationLevel > 1) ? CodeGenOptions::NormalInlining 1082 : CodeGenOptions::OnlyAlwaysInlining; 1083 1084 Opts.DebugInfo = Args.hasArg(OPT_g); 1085 Opts.LimitDebugInfo = !Args.hasArg(OPT_fno_limit_debug_info) 1086 || Args.hasArg(OPT_flimit_debug_info); 1087 Opts.DisableLLVMOpts = Args.hasArg(OPT_disable_llvm_optzns); 1088 Opts.DisableRedZone = Args.hasArg(OPT_disable_red_zone); 1089 Opts.ForbidGuardVariables = Args.hasArg(OPT_fforbid_guard_variables); 1090 Opts.UseRegisterSizedBitfieldAccess = Args.hasArg( 1091 OPT_fuse_register_sized_bitfield_access); 1092 Opts.RelaxedAliasing = Args.hasArg(OPT_relaxed_aliasing); 1093 Opts.DwarfDebugFlags = Args.getLastArgValue(OPT_dwarf_debug_flags); 1094 Opts.MergeAllConstants = !Args.hasArg(OPT_fno_merge_all_constants); 1095 Opts.NoCommon = Args.hasArg(OPT_fno_common); 1096 Opts.NoImplicitFloat = Args.hasArg(OPT_no_implicit_float); 1097 Opts.OptimizeSize = Args.hasArg(OPT_Os); 1098 Opts.OptimizeSize = Args.hasArg(OPT_Oz) ? 2 : Opts.OptimizeSize; 1099 Opts.SimplifyLibCalls = !(Args.hasArg(OPT_fno_builtin) || 1100 Args.hasArg(OPT_ffreestanding)); 1101 Opts.UnrollLoops = Args.hasArg(OPT_funroll_loops) || 1102 (Opts.OptimizationLevel > 1 && !Opts.OptimizeSize); 1103 1104 Opts.AsmVerbose = Args.hasArg(OPT_masm_verbose); 1105 Opts.ObjCAutoRefCountExceptions = Args.hasArg(OPT_fobjc_arc_exceptions); 1106 Opts.ObjCRuntimeHasARC = Args.hasArg(OPT_fobjc_runtime_has_arc); 1107 Opts.ObjCRuntimeHasTerminate = Args.hasArg(OPT_fobjc_runtime_has_terminate); 1108 Opts.CUDAIsDevice = Args.hasArg(OPT_fcuda_is_device); 1109 Opts.CXAAtExit = !Args.hasArg(OPT_fno_use_cxa_atexit); 1110 Opts.CXXCtorDtorAliases = Args.hasArg(OPT_mconstructor_aliases); 1111 Opts.CodeModel = Args.getLastArgValue(OPT_mcode_model); 1112 Opts.DebugPass = Args.getLastArgValue(OPT_mdebug_pass); 1113 Opts.DisableFPElim = Args.hasArg(OPT_mdisable_fp_elim); 1114 Opts.DisableTailCalls = Args.hasArg(OPT_mdisable_tail_calls); 1115 Opts.FloatABI = Args.getLastArgValue(OPT_mfloat_abi); 1116 Opts.HiddenWeakVTables = Args.hasArg(OPT_fhidden_weak_vtables); 1117 Opts.LessPreciseFPMAD = Args.hasArg(OPT_cl_mad_enable); 1118 Opts.LimitFloatPrecision = Args.getLastArgValue(OPT_mlimit_float_precision); 1119 Opts.NoInfsFPMath = (Args.hasArg(OPT_menable_no_infinities) || 1120 Args.hasArg(OPT_cl_finite_math_only)|| 1121 Args.hasArg(OPT_cl_fast_relaxed_math)); 1122 Opts.NoNaNsFPMath = (Args.hasArg(OPT_menable_no_nans) || 1123 Args.hasArg(OPT_cl_finite_math_only)|| 1124 Args.hasArg(OPT_cl_fast_relaxed_math)); 1125 Opts.NoZeroInitializedInBSS = Args.hasArg(OPT_mno_zero_initialized_in_bss); 1126 Opts.BackendOptions = Args.getAllArgValues(OPT_backend_option); 1127 Opts.NumRegisterParameters = Args.getLastArgIntValue(OPT_mregparm, 0, Diags); 1128 Opts.NoGlobalMerge = Args.hasArg(OPT_mno_global_merge); 1129 Opts.NoExecStack = Args.hasArg(OPT_mno_exec_stack); 1130 Opts.RelaxAll = Args.hasArg(OPT_mrelax_all); 1131 Opts.OmitLeafFramePointer = Args.hasArg(OPT_momit_leaf_frame_pointer); 1132 Opts.SaveTempLabels = Args.hasArg(OPT_msave_temp_labels); 1133 Opts.NoDwarf2CFIAsm = Args.hasArg(OPT_fno_dwarf2_cfi_asm); 1134 Opts.NoDwarfDirectoryAsm = Args.hasArg(OPT_fno_dwarf_directory_asm); 1135 Opts.SoftFloat = Args.hasArg(OPT_msoft_float); 1136 Opts.UnsafeFPMath = Args.hasArg(OPT_menable_unsafe_fp_math) || 1137 Args.hasArg(OPT_cl_unsafe_math_optimizations) || 1138 Args.hasArg(OPT_cl_fast_relaxed_math); 1139 Opts.UnwindTables = Args.hasArg(OPT_munwind_tables); 1140 Opts.RelocationModel = Args.getLastArgValue(OPT_mrelocation_model, "pic"); 1141 1142 Opts.FunctionSections = Args.hasArg(OPT_ffunction_sections); 1143 Opts.DataSections = Args.hasArg(OPT_fdata_sections); 1144 1145 Opts.MainFileName = Args.getLastArgValue(OPT_main_file_name); 1146 Opts.VerifyModule = !Args.hasArg(OPT_disable_llvm_verifier); 1147 1148 Opts.InstrumentFunctions = Args.hasArg(OPT_finstrument_functions); 1149 Opts.InstrumentForProfiling = Args.hasArg(OPT_pg); 1150 Opts.EmitGcovArcs = Args.hasArg(OPT_femit_coverage_data); 1151 Opts.EmitGcovNotes = Args.hasArg(OPT_femit_coverage_notes); 1152 Opts.CoverageFile = Args.getLastArgValue(OPT_coverage_file); 1153 Opts.DebugCompilationDir = Args.getLastArgValue(OPT_fdebug_compilation_dir); 1154 Opts.LinkBitcodeFile = Args.getLastArgValue(OPT_mlink_bitcode_file); 1155 Opts.StackRealignment = Args.hasArg(OPT_mstackrealign); 1156 if (Arg *A = Args.getLastArg(OPT_mstack_alignment)) { 1157 StringRef Val = A->getValue(Args); 1158 Val.getAsInteger(10, Opts.StackAlignment); 1159 } 1160 1161 if (Arg *A = Args.getLastArg(OPT_fobjc_dispatch_method_EQ)) { 1162 StringRef Name = A->getValue(Args); 1163 unsigned Method = llvm::StringSwitch<unsigned>(Name) 1164 .Case("legacy", CodeGenOptions::Legacy) 1165 .Case("non-legacy", CodeGenOptions::NonLegacy) 1166 .Case("mixed", CodeGenOptions::Mixed) 1167 .Default(~0U); 1168 if (Method == ~0U) { 1169 Diags.Report(diag::err_drv_invalid_value) << A->getAsString(Args) << Name; 1170 Success = false; 1171 } else { 1172 Opts.ObjCDispatchMethod = Method; 1173 } 1174 } 1175 1176 return Success; 1177 } 1178 1179 static void ParseDependencyOutputArgs(DependencyOutputOptions &Opts, 1180 ArgList &Args) { 1181 using namespace cc1options; 1182 Opts.OutputFile = Args.getLastArgValue(OPT_dependency_file); 1183 Opts.Targets = Args.getAllArgValues(OPT_MT); 1184 Opts.IncludeSystemHeaders = Args.hasArg(OPT_sys_header_deps); 1185 Opts.UsePhonyTargets = Args.hasArg(OPT_MP); 1186 Opts.ShowHeaderIncludes = Args.hasArg(OPT_H); 1187 Opts.HeaderIncludeOutputFile = Args.getLastArgValue(OPT_header_include_file); 1188 Opts.AddMissingHeaderDeps = Args.hasArg(OPT_MG); 1189 } 1190 1191 static bool ParseDiagnosticArgs(DiagnosticOptions &Opts, ArgList &Args, 1192 DiagnosticsEngine &Diags) { 1193 using namespace cc1options; 1194 bool Success = true; 1195 1196 Opts.DiagnosticLogFile = Args.getLastArgValue(OPT_diagnostic_log_file); 1197 Opts.DiagnosticSerializationFile = 1198 Args.getLastArgValue(OPT_diagnostic_serialized_file); 1199 Opts.IgnoreWarnings = Args.hasArg(OPT_w); 1200 Opts.NoRewriteMacros = Args.hasArg(OPT_Wno_rewrite_macros); 1201 Opts.Pedantic = Args.hasArg(OPT_pedantic); 1202 Opts.PedanticErrors = Args.hasArg(OPT_pedantic_errors); 1203 Opts.ShowCarets = !Args.hasArg(OPT_fno_caret_diagnostics); 1204 Opts.ShowColors = Args.hasArg(OPT_fcolor_diagnostics); 1205 Opts.ShowColumn = Args.hasFlag(OPT_fshow_column, 1206 OPT_fno_show_column, 1207 /*Default=*/true); 1208 Opts.ShowFixits = !Args.hasArg(OPT_fno_diagnostics_fixit_info); 1209 Opts.ShowLocation = !Args.hasArg(OPT_fno_show_source_location); 1210 Opts.ShowNames = Args.hasArg(OPT_fdiagnostics_show_name); 1211 Opts.ShowOptionNames = Args.hasArg(OPT_fdiagnostics_show_option); 1212 1213 // Default behavior is to not to show note include stacks. 1214 Opts.ShowNoteIncludeStack = false; 1215 if (Arg *A = Args.getLastArg(OPT_fdiagnostics_show_note_include_stack, 1216 OPT_fno_diagnostics_show_note_include_stack)) 1217 if (A->getOption().matches(OPT_fdiagnostics_show_note_include_stack)) 1218 Opts.ShowNoteIncludeStack = true; 1219 1220 StringRef ShowOverloads = 1221 Args.getLastArgValue(OPT_fshow_overloads_EQ, "all"); 1222 if (ShowOverloads == "best") 1223 Opts.ShowOverloads = DiagnosticsEngine::Ovl_Best; 1224 else if (ShowOverloads == "all") 1225 Opts.ShowOverloads = DiagnosticsEngine::Ovl_All; 1226 else { 1227 Diags.Report(diag::err_drv_invalid_value) 1228 << Args.getLastArg(OPT_fshow_overloads_EQ)->getAsString(Args) 1229 << ShowOverloads; 1230 Success = false; 1231 } 1232 1233 StringRef ShowCategory = 1234 Args.getLastArgValue(OPT_fdiagnostics_show_category, "none"); 1235 if (ShowCategory == "none") 1236 Opts.ShowCategories = 0; 1237 else if (ShowCategory == "id") 1238 Opts.ShowCategories = 1; 1239 else if (ShowCategory == "name") 1240 Opts.ShowCategories = 2; 1241 else { 1242 Diags.Report(diag::err_drv_invalid_value) 1243 << Args.getLastArg(OPT_fdiagnostics_show_category)->getAsString(Args) 1244 << ShowCategory; 1245 Success = false; 1246 } 1247 1248 StringRef Format = 1249 Args.getLastArgValue(OPT_fdiagnostics_format, "clang"); 1250 if (Format == "clang") 1251 Opts.Format = DiagnosticOptions::Clang; 1252 else if (Format == "msvc") 1253 Opts.Format = DiagnosticOptions::Msvc; 1254 else if (Format == "vi") 1255 Opts.Format = DiagnosticOptions::Vi; 1256 else { 1257 Diags.Report(diag::err_drv_invalid_value) 1258 << Args.getLastArg(OPT_fdiagnostics_format)->getAsString(Args) 1259 << Format; 1260 Success = false; 1261 } 1262 1263 Opts.ShowSourceRanges = Args.hasArg(OPT_fdiagnostics_print_source_range_info); 1264 Opts.ShowParseableFixits = Args.hasArg(OPT_fdiagnostics_parseable_fixits); 1265 Opts.VerifyDiagnostics = Args.hasArg(OPT_verify); 1266 Opts.ErrorLimit = Args.getLastArgIntValue(OPT_ferror_limit, 0, Diags); 1267 Opts.MacroBacktraceLimit 1268 = Args.getLastArgIntValue(OPT_fmacro_backtrace_limit, 1269 DiagnosticOptions::DefaultMacroBacktraceLimit, Diags); 1270 Opts.TemplateBacktraceLimit 1271 = Args.getLastArgIntValue(OPT_ftemplate_backtrace_limit, 1272 DiagnosticOptions::DefaultTemplateBacktraceLimit, 1273 Diags); 1274 Opts.ConstexprBacktraceLimit 1275 = Args.getLastArgIntValue(OPT_fconstexpr_backtrace_limit, 1276 DiagnosticOptions::DefaultConstexprBacktraceLimit, 1277 Diags); 1278 Opts.TabStop = Args.getLastArgIntValue(OPT_ftabstop, 1279 DiagnosticOptions::DefaultTabStop, Diags); 1280 if (Opts.TabStop == 0 || Opts.TabStop > DiagnosticOptions::MaxTabStop) { 1281 Diags.Report(diag::warn_ignoring_ftabstop_value) 1282 << Opts.TabStop << DiagnosticOptions::DefaultTabStop; 1283 Opts.TabStop = DiagnosticOptions::DefaultTabStop; 1284 } 1285 Opts.MessageLength = Args.getLastArgIntValue(OPT_fmessage_length, 0, Diags); 1286 Opts.DumpBuildInformation = Args.getLastArgValue(OPT_dump_build_information); 1287 Opts.Warnings = Args.getAllArgValues(OPT_W); 1288 1289 return Success; 1290 } 1291 1292 static void ParseFileSystemArgs(FileSystemOptions &Opts, ArgList &Args) { 1293 Opts.WorkingDir = Args.getLastArgValue(OPT_working_directory); 1294 } 1295 1296 static InputKind ParseFrontendArgs(FrontendOptions &Opts, ArgList &Args, 1297 DiagnosticsEngine &Diags) { 1298 using namespace cc1options; 1299 Opts.ProgramAction = frontend::ParseSyntaxOnly; 1300 if (const Arg *A = Args.getLastArg(OPT_Action_Group)) { 1301 switch (A->getOption().getID()) { 1302 default: 1303 llvm_unreachable("Invalid option in group!"); 1304 case OPT_ast_dump: 1305 Opts.ProgramAction = frontend::ASTDump; break; 1306 case OPT_ast_dump_xml: 1307 Opts.ProgramAction = frontend::ASTDumpXML; break; 1308 case OPT_ast_print: 1309 Opts.ProgramAction = frontend::ASTPrint; break; 1310 case OPT_ast_view: 1311 Opts.ProgramAction = frontend::ASTView; break; 1312 case OPT_dump_raw_tokens: 1313 Opts.ProgramAction = frontend::DumpRawTokens; break; 1314 case OPT_dump_tokens: 1315 Opts.ProgramAction = frontend::DumpTokens; break; 1316 case OPT_S: 1317 Opts.ProgramAction = frontend::EmitAssembly; break; 1318 case OPT_emit_llvm_bc: 1319 Opts.ProgramAction = frontend::EmitBC; break; 1320 case OPT_emit_html: 1321 Opts.ProgramAction = frontend::EmitHTML; break; 1322 case OPT_emit_llvm: 1323 Opts.ProgramAction = frontend::EmitLLVM; break; 1324 case OPT_emit_llvm_only: 1325 Opts.ProgramAction = frontend::EmitLLVMOnly; break; 1326 case OPT_emit_codegen_only: 1327 Opts.ProgramAction = frontend::EmitCodeGenOnly; break; 1328 case OPT_emit_obj: 1329 Opts.ProgramAction = frontend::EmitObj; break; 1330 case OPT_fixit_EQ: 1331 Opts.FixItSuffix = A->getValue(Args); 1332 // fall-through! 1333 case OPT_fixit: 1334 Opts.ProgramAction = frontend::FixIt; break; 1335 case OPT_emit_module: 1336 Opts.ProgramAction = frontend::GenerateModule; break; 1337 case OPT_emit_pch: 1338 Opts.ProgramAction = frontend::GeneratePCH; break; 1339 case OPT_emit_pth: 1340 Opts.ProgramAction = frontend::GeneratePTH; break; 1341 case OPT_init_only: 1342 Opts.ProgramAction = frontend::InitOnly; break; 1343 case OPT_fsyntax_only: 1344 Opts.ProgramAction = frontend::ParseSyntaxOnly; break; 1345 case OPT_print_decl_contexts: 1346 Opts.ProgramAction = frontend::PrintDeclContext; break; 1347 case OPT_print_preamble: 1348 Opts.ProgramAction = frontend::PrintPreamble; break; 1349 case OPT_E: 1350 Opts.ProgramAction = frontend::PrintPreprocessedInput; break; 1351 case OPT_rewrite_macros: 1352 Opts.ProgramAction = frontend::RewriteMacros; break; 1353 case OPT_rewrite_objc: 1354 Opts.ProgramAction = frontend::RewriteObjC; break; 1355 case OPT_rewrite_test: 1356 Opts.ProgramAction = frontend::RewriteTest; break; 1357 case OPT_analyze: 1358 Opts.ProgramAction = frontend::RunAnalysis; break; 1359 case OPT_Eonly: 1360 Opts.ProgramAction = frontend::RunPreprocessorOnly; break; 1361 } 1362 } 1363 1364 if (const Arg* A = Args.getLastArg(OPT_plugin)) { 1365 Opts.Plugins.push_back(A->getValue(Args,0)); 1366 Opts.ProgramAction = frontend::PluginAction; 1367 Opts.ActionName = A->getValue(Args); 1368 1369 for (arg_iterator it = Args.filtered_begin(OPT_plugin_arg), 1370 end = Args.filtered_end(); it != end; ++it) { 1371 if ((*it)->getValue(Args, 0) == Opts.ActionName) 1372 Opts.PluginArgs.push_back((*it)->getValue(Args, 1)); 1373 } 1374 } 1375 1376 Opts.AddPluginActions = Args.getAllArgValues(OPT_add_plugin); 1377 Opts.AddPluginArgs.resize(Opts.AddPluginActions.size()); 1378 for (int i = 0, e = Opts.AddPluginActions.size(); i != e; ++i) { 1379 for (arg_iterator it = Args.filtered_begin(OPT_plugin_arg), 1380 end = Args.filtered_end(); it != end; ++it) { 1381 if ((*it)->getValue(Args, 0) == Opts.AddPluginActions[i]) 1382 Opts.AddPluginArgs[i].push_back((*it)->getValue(Args, 1)); 1383 } 1384 } 1385 1386 if (const Arg *A = Args.getLastArg(OPT_code_completion_at)) { 1387 Opts.CodeCompletionAt = 1388 ParsedSourceLocation::FromString(A->getValue(Args)); 1389 if (Opts.CodeCompletionAt.FileName.empty()) 1390 Diags.Report(diag::err_drv_invalid_value) 1391 << A->getAsString(Args) << A->getValue(Args); 1392 } 1393 Opts.DisableFree = Args.hasArg(OPT_disable_free); 1394 1395 Opts.OutputFile = Args.getLastArgValue(OPT_o); 1396 Opts.Plugins = Args.getAllArgValues(OPT_load); 1397 Opts.RelocatablePCH = Args.hasArg(OPT_relocatable_pch); 1398 Opts.ShowHelp = Args.hasArg(OPT_help); 1399 Opts.ShowMacrosInCodeCompletion = Args.hasArg(OPT_code_completion_macros); 1400 Opts.ShowCodePatternsInCodeCompletion 1401 = Args.hasArg(OPT_code_completion_patterns); 1402 Opts.ShowGlobalSymbolsInCodeCompletion 1403 = !Args.hasArg(OPT_no_code_completion_globals); 1404 Opts.ShowStats = Args.hasArg(OPT_print_stats); 1405 Opts.ShowTimers = Args.hasArg(OPT_ftime_report); 1406 Opts.ShowVersion = Args.hasArg(OPT_version); 1407 Opts.ASTMergeFiles = Args.getAllArgValues(OPT_ast_merge); 1408 Opts.LLVMArgs = Args.getAllArgValues(OPT_mllvm); 1409 Opts.FixWhatYouCan = Args.hasArg(OPT_fix_what_you_can); 1410 Opts.FixOnlyWarnings = Args.hasArg(OPT_fix_only_warnings); 1411 Opts.FixAndRecompile = Args.hasArg(OPT_fixit_recompile); 1412 Opts.FixToTemporaries = Args.hasArg(OPT_fixit_to_temp); 1413 1414 Opts.ARCMTAction = FrontendOptions::ARCMT_None; 1415 if (const Arg *A = Args.getLastArg(OPT_arcmt_check, 1416 OPT_arcmt_modify, 1417 OPT_arcmt_migrate)) { 1418 switch (A->getOption().getID()) { 1419 default: 1420 llvm_unreachable("missed a case"); 1421 case OPT_arcmt_check: 1422 Opts.ARCMTAction = FrontendOptions::ARCMT_Check; 1423 break; 1424 case OPT_arcmt_modify: 1425 Opts.ARCMTAction = FrontendOptions::ARCMT_Modify; 1426 break; 1427 case OPT_arcmt_migrate: 1428 Opts.ARCMTAction = FrontendOptions::ARCMT_Migrate; 1429 break; 1430 } 1431 } 1432 Opts.ARCMTMigrateDir = Args.getLastArgValue(OPT_arcmt_migrate_directory); 1433 Opts.ARCMTMigrateReportOut 1434 = Args.getLastArgValue(OPT_arcmt_migrate_report_output); 1435 Opts.ARCMTMigrateEmitARCErrors 1436 = Args.hasArg(OPT_arcmt_migrate_emit_arc_errors); 1437 1438 InputKind DashX = IK_None; 1439 if (const Arg *A = Args.getLastArg(OPT_x)) { 1440 DashX = llvm::StringSwitch<InputKind>(A->getValue(Args)) 1441 .Case("c", IK_C) 1442 .Case("cl", IK_OpenCL) 1443 .Case("cuda", IK_CUDA) 1444 .Case("c++", IK_CXX) 1445 .Case("objective-c", IK_ObjC) 1446 .Case("objective-c++", IK_ObjCXX) 1447 .Case("cpp-output", IK_PreprocessedC) 1448 .Case("assembler-with-cpp", IK_Asm) 1449 .Case("c++-cpp-output", IK_PreprocessedCXX) 1450 .Case("objective-c-cpp-output", IK_PreprocessedObjC) 1451 .Case("objc-cpp-output", IK_PreprocessedObjC) 1452 .Case("objective-c++-cpp-output", IK_PreprocessedObjCXX) 1453 .Case("objc++-cpp-output", IK_PreprocessedObjCXX) 1454 .Case("c-header", IK_C) 1455 .Case("cl-header", IK_OpenCL) 1456 .Case("objective-c-header", IK_ObjC) 1457 .Case("c++-header", IK_CXX) 1458 .Case("objective-c++-header", IK_ObjCXX) 1459 .Case("ast", IK_AST) 1460 .Case("ir", IK_LLVM_IR) 1461 .Default(IK_None); 1462 if (DashX == IK_None) 1463 Diags.Report(diag::err_drv_invalid_value) 1464 << A->getAsString(Args) << A->getValue(Args); 1465 } 1466 1467 // '-' is the default input if none is given. 1468 std::vector<std::string> Inputs = Args.getAllArgValues(OPT_INPUT); 1469 Opts.Inputs.clear(); 1470 if (Inputs.empty()) 1471 Inputs.push_back("-"); 1472 for (unsigned i = 0, e = Inputs.size(); i != e; ++i) { 1473 InputKind IK = DashX; 1474 if (IK == IK_None) { 1475 IK = FrontendOptions::getInputKindForExtension( 1476 StringRef(Inputs[i]).rsplit('.').second); 1477 // FIXME: Remove this hack. 1478 if (i == 0) 1479 DashX = IK; 1480 } 1481 Opts.Inputs.push_back(FrontendInputFile(Inputs[i], IK)); 1482 } 1483 1484 return DashX; 1485 } 1486 1487 std::string CompilerInvocation::GetResourcesPath(const char *Argv0, 1488 void *MainAddr) { 1489 llvm::sys::Path P = llvm::sys::Path::GetMainExecutable(Argv0, MainAddr); 1490 1491 if (!P.isEmpty()) { 1492 P.eraseComponent(); // Remove /clang from foo/bin/clang 1493 P.eraseComponent(); // Remove /bin from foo/bin 1494 1495 // Get foo/lib/clang/<version>/include 1496 P.appendComponent("lib"); 1497 P.appendComponent("clang"); 1498 P.appendComponent(CLANG_VERSION_STRING); 1499 } 1500 1501 return P.str(); 1502 } 1503 1504 static void ParseHeaderSearchArgs(HeaderSearchOptions &Opts, ArgList &Args) { 1505 using namespace cc1options; 1506 Opts.Sysroot = Args.getLastArgValue(OPT_isysroot, "/"); 1507 Opts.Verbose = Args.hasArg(OPT_v); 1508 Opts.UseBuiltinIncludes = !Args.hasArg(OPT_nobuiltininc); 1509 Opts.UseStandardSystemIncludes = !Args.hasArg(OPT_nostdsysteminc); 1510 Opts.UseStandardCXXIncludes = !Args.hasArg(OPT_nostdincxx); 1511 if (const Arg *A = Args.getLastArg(OPT_stdlib_EQ)) 1512 Opts.UseLibcxx = (strcmp(A->getValue(Args), "libc++") == 0); 1513 Opts.ResourceDir = Args.getLastArgValue(OPT_resource_dir); 1514 Opts.ModuleCachePath = Args.getLastArgValue(OPT_fmodule_cache_path); 1515 Opts.DisableModuleHash = Args.hasArg(OPT_fdisable_module_hash); 1516 1517 // Add -I..., -F..., and -index-header-map options in order. 1518 bool IsIndexHeaderMap = false; 1519 for (arg_iterator it = Args.filtered_begin(OPT_I, OPT_F, 1520 OPT_index_header_map), 1521 ie = Args.filtered_end(); it != ie; ++it) { 1522 if ((*it)->getOption().matches(OPT_index_header_map)) { 1523 // -index-header-map applies to the next -I or -F. 1524 IsIndexHeaderMap = true; 1525 continue; 1526 } 1527 1528 frontend::IncludeDirGroup Group 1529 = IsIndexHeaderMap? frontend::IndexHeaderMap : frontend::Angled; 1530 1531 Opts.AddPath((*it)->getValue(Args), Group, true, 1532 /*IsFramework=*/ (*it)->getOption().matches(OPT_F), false); 1533 IsIndexHeaderMap = false; 1534 } 1535 1536 // Add -iprefix/-iwith-prefix/-iwithprefixbefore options. 1537 StringRef Prefix = ""; // FIXME: This isn't the correct default prefix. 1538 for (arg_iterator it = Args.filtered_begin(OPT_iprefix, OPT_iwithprefix, 1539 OPT_iwithprefixbefore), 1540 ie = Args.filtered_end(); it != ie; ++it) { 1541 const Arg *A = *it; 1542 if (A->getOption().matches(OPT_iprefix)) 1543 Prefix = A->getValue(Args); 1544 else if (A->getOption().matches(OPT_iwithprefix)) 1545 Opts.AddPath(Prefix.str() + A->getValue(Args), 1546 frontend::System, false, false, false); 1547 else 1548 Opts.AddPath(Prefix.str() + A->getValue(Args), 1549 frontend::Angled, false, false, false); 1550 } 1551 1552 for (arg_iterator it = Args.filtered_begin(OPT_idirafter), 1553 ie = Args.filtered_end(); it != ie; ++it) 1554 Opts.AddPath((*it)->getValue(Args), frontend::After, true, false, false); 1555 for (arg_iterator it = Args.filtered_begin(OPT_iquote), 1556 ie = Args.filtered_end(); it != ie; ++it) 1557 Opts.AddPath((*it)->getValue(Args), frontend::Quoted, true, false, false); 1558 for (arg_iterator it = Args.filtered_begin(OPT_isystem, 1559 OPT_iwithsysroot), ie = Args.filtered_end(); it != ie; ++it) 1560 Opts.AddPath((*it)->getValue(Args), frontend::System, true, false, 1561 !(*it)->getOption().matches(OPT_iwithsysroot)); 1562 for (arg_iterator it = Args.filtered_begin(OPT_iframework), 1563 ie = Args.filtered_end(); it != ie; ++it) 1564 Opts.AddPath((*it)->getValue(Args), frontend::System, true, true, 1565 true); 1566 1567 // Add the paths for the various language specific isystem flags. 1568 for (arg_iterator it = Args.filtered_begin(OPT_c_isystem), 1569 ie = Args.filtered_end(); it != ie; ++it) 1570 Opts.AddPath((*it)->getValue(Args), frontend::CSystem, true, false, true); 1571 for (arg_iterator it = Args.filtered_begin(OPT_cxx_isystem), 1572 ie = Args.filtered_end(); it != ie; ++it) 1573 Opts.AddPath((*it)->getValue(Args), frontend::CXXSystem, true, false, true); 1574 for (arg_iterator it = Args.filtered_begin(OPT_objc_isystem), 1575 ie = Args.filtered_end(); it != ie; ++it) 1576 Opts.AddPath((*it)->getValue(Args), frontend::ObjCSystem, true, false,true); 1577 for (arg_iterator it = Args.filtered_begin(OPT_objcxx_isystem), 1578 ie = Args.filtered_end(); it != ie; ++it) 1579 Opts.AddPath((*it)->getValue(Args), frontend::ObjCXXSystem, true, false, 1580 true); 1581 1582 // Add the internal paths from a driver that detects standard include paths. 1583 for (arg_iterator I = Args.filtered_begin(OPT_internal_isystem, 1584 OPT_internal_externc_isystem), 1585 E = Args.filtered_end(); 1586 I != E; ++I) 1587 Opts.AddPath((*I)->getValue(Args), frontend::System, 1588 false, false, /*IgnoreSysRoot=*/true, /*IsInternal=*/true, 1589 (*I)->getOption().matches(OPT_internal_externc_isystem)); 1590 } 1591 1592 void CompilerInvocation::setLangDefaults(LangOptions &Opts, InputKind IK, 1593 LangStandard::Kind LangStd) { 1594 // Set some properties which depend solely on the input kind; it would be nice 1595 // to move these to the language standard, and have the driver resolve the 1596 // input kind + language standard. 1597 if (IK == IK_Asm) { 1598 Opts.AsmPreprocessor = 1; 1599 } else if (IK == IK_ObjC || 1600 IK == IK_ObjCXX || 1601 IK == IK_PreprocessedObjC || 1602 IK == IK_PreprocessedObjCXX) { 1603 Opts.ObjC1 = Opts.ObjC2 = 1; 1604 } 1605 1606 if (LangStd == LangStandard::lang_unspecified) { 1607 // Based on the base language, pick one. 1608 switch (IK) { 1609 case IK_None: 1610 case IK_AST: 1611 case IK_LLVM_IR: 1612 llvm_unreachable("Invalid input kind!"); 1613 case IK_OpenCL: 1614 LangStd = LangStandard::lang_opencl; 1615 break; 1616 case IK_CUDA: 1617 LangStd = LangStandard::lang_cuda; 1618 break; 1619 case IK_Asm: 1620 case IK_C: 1621 case IK_PreprocessedC: 1622 case IK_ObjC: 1623 case IK_PreprocessedObjC: 1624 LangStd = LangStandard::lang_gnu99; 1625 break; 1626 case IK_CXX: 1627 case IK_PreprocessedCXX: 1628 case IK_ObjCXX: 1629 case IK_PreprocessedObjCXX: 1630 LangStd = LangStandard::lang_gnucxx98; 1631 break; 1632 } 1633 } 1634 1635 const LangStandard &Std = LangStandard::getLangStandardForKind(LangStd); 1636 Opts.BCPLComment = Std.hasBCPLComments(); 1637 Opts.C99 = Std.isC99(); 1638 Opts.C11 = Std.isC11(); 1639 Opts.CPlusPlus = Std.isCPlusPlus(); 1640 Opts.CPlusPlus0x = Std.isCPlusPlus0x(); 1641 Opts.Digraphs = Std.hasDigraphs(); 1642 Opts.GNUMode = Std.isGNUMode(); 1643 Opts.GNUInline = !Std.isC99(); 1644 Opts.HexFloats = Std.hasHexFloats(); 1645 Opts.ImplicitInt = Std.hasImplicitInt(); 1646 1647 // OpenCL has some additional defaults. 1648 if (LangStd == LangStandard::lang_opencl) { 1649 Opts.OpenCL = 1; 1650 Opts.AltiVec = 0; 1651 Opts.CXXOperatorNames = 1; 1652 Opts.LaxVectorConversions = 0; 1653 Opts.DefaultFPContract = 1; 1654 } 1655 1656 if (LangStd == LangStandard::lang_cuda) 1657 Opts.CUDA = 1; 1658 1659 // OpenCL and C++ both have bool, true, false keywords. 1660 Opts.Bool = Opts.OpenCL || Opts.CPlusPlus; 1661 1662 Opts.GNUKeywords = Opts.GNUMode; 1663 Opts.CXXOperatorNames = Opts.CPlusPlus; 1664 1665 // Mimicing gcc's behavior, trigraphs are only enabled if -trigraphs 1666 // is specified, or -std is set to a conforming mode. 1667 Opts.Trigraphs = !Opts.GNUMode; 1668 1669 Opts.DollarIdents = !Opts.AsmPreprocessor; 1670 } 1671 1672 static void ParseLangArgs(LangOptions &Opts, ArgList &Args, InputKind IK, 1673 DiagnosticsEngine &Diags) { 1674 // FIXME: Cleanup per-file based stuff. 1675 LangStandard::Kind LangStd = LangStandard::lang_unspecified; 1676 if (const Arg *A = Args.getLastArg(OPT_std_EQ)) { 1677 LangStd = llvm::StringSwitch<LangStandard::Kind>(A->getValue(Args)) 1678 #define LANGSTANDARD(id, name, desc, features) \ 1679 .Case(name, LangStandard::lang_##id) 1680 #include "clang/Frontend/LangStandards.def" 1681 .Default(LangStandard::lang_unspecified); 1682 if (LangStd == LangStandard::lang_unspecified) 1683 Diags.Report(diag::err_drv_invalid_value) 1684 << A->getAsString(Args) << A->getValue(Args); 1685 else { 1686 // Valid standard, check to make sure language and standard are compatable. 1687 const LangStandard &Std = LangStandard::getLangStandardForKind(LangStd); 1688 switch (IK) { 1689 case IK_C: 1690 case IK_ObjC: 1691 case IK_PreprocessedC: 1692 case IK_PreprocessedObjC: 1693 if (!(Std.isC89() || Std.isC99())) 1694 Diags.Report(diag::err_drv_argument_not_allowed_with) 1695 << A->getAsString(Args) << "C/ObjC"; 1696 break; 1697 case IK_CXX: 1698 case IK_ObjCXX: 1699 case IK_PreprocessedCXX: 1700 case IK_PreprocessedObjCXX: 1701 if (!Std.isCPlusPlus()) 1702 Diags.Report(diag::err_drv_argument_not_allowed_with) 1703 << A->getAsString(Args) << "C++/ObjC++"; 1704 break; 1705 case IK_OpenCL: 1706 if (!Std.isC99()) 1707 Diags.Report(diag::err_drv_argument_not_allowed_with) 1708 << A->getAsString(Args) << "OpenCL"; 1709 break; 1710 case IK_CUDA: 1711 if (!Std.isCPlusPlus()) 1712 Diags.Report(diag::err_drv_argument_not_allowed_with) 1713 << A->getAsString(Args) << "CUDA"; 1714 break; 1715 default: 1716 break; 1717 } 1718 } 1719 } 1720 1721 if (const Arg *A = Args.getLastArg(OPT_cl_std_EQ)) { 1722 if (strcmp(A->getValue(Args), "CL1.1") != 0) { 1723 Diags.Report(diag::err_drv_invalid_value) 1724 << A->getAsString(Args) << A->getValue(Args); 1725 } 1726 } 1727 1728 CompilerInvocation::setLangDefaults(Opts, IK, LangStd); 1729 1730 // We abuse '-f[no-]gnu-keywords' to force overriding all GNU-extension 1731 // keywords. This behavior is provided by GCC's poorly named '-fasm' flag, 1732 // while a subset (the non-C++ GNU keywords) is provided by GCC's 1733 // '-fgnu-keywords'. Clang conflates the two for simplicity under the single 1734 // name, as it doesn't seem a useful distinction. 1735 Opts.GNUKeywords = Args.hasFlag(OPT_fgnu_keywords, OPT_fno_gnu_keywords, 1736 Opts.GNUKeywords); 1737 1738 if (Args.hasArg(OPT_fno_operator_names)) 1739 Opts.CXXOperatorNames = 0; 1740 1741 if (Opts.ObjC1) { 1742 if (Args.hasArg(OPT_fobjc_gc_only)) 1743 Opts.setGC(LangOptions::GCOnly); 1744 else if (Args.hasArg(OPT_fobjc_gc)) 1745 Opts.setGC(LangOptions::HybridGC); 1746 else if (Args.hasArg(OPT_fobjc_arc)) { 1747 Opts.ObjCAutoRefCount = 1; 1748 if (Args.hasArg(OPT_fobjc_fragile_abi)) 1749 Diags.Report(diag::err_arc_nonfragile_abi); 1750 } 1751 1752 if (Args.hasArg(OPT_fobjc_runtime_has_weak)) 1753 Opts.ObjCRuntimeHasWeak = 1; 1754 1755 if (Args.hasArg(OPT_fno_objc_infer_related_result_type)) 1756 Opts.ObjCInferRelatedResultType = 0; 1757 } 1758 1759 if (Args.hasArg(OPT_fgnu89_inline)) 1760 Opts.GNUInline = 1; 1761 1762 if (Args.hasArg(OPT_fapple_kext)) { 1763 if (!Opts.CPlusPlus) 1764 Diags.Report(diag::warn_c_kext); 1765 else 1766 Opts.AppleKext = 1; 1767 } 1768 1769 if (Args.hasArg(OPT_print_ivar_layout)) 1770 Opts.ObjCGCBitmapPrint = 1; 1771 if (Args.hasArg(OPT_fno_constant_cfstrings)) 1772 Opts.NoConstantCFStrings = 1; 1773 1774 if (Args.hasArg(OPT_faltivec)) 1775 Opts.AltiVec = 1; 1776 1777 if (Args.hasArg(OPT_pthread)) 1778 Opts.POSIXThreads = 1; 1779 1780 if (Args.hasArg(OPT_fdelayed_template_parsing)) 1781 Opts.DelayedTemplateParsing = 1; 1782 1783 StringRef Vis = Args.getLastArgValue(OPT_fvisibility, "default"); 1784 if (Vis == "default") 1785 Opts.setVisibilityMode(DefaultVisibility); 1786 else if (Vis == "hidden") 1787 Opts.setVisibilityMode(HiddenVisibility); 1788 else if (Vis == "protected") 1789 Opts.setVisibilityMode(ProtectedVisibility); 1790 else 1791 Diags.Report(diag::err_drv_invalid_value) 1792 << Args.getLastArg(OPT_fvisibility)->getAsString(Args) << Vis; 1793 1794 if (Args.hasArg(OPT_fvisibility_inlines_hidden)) 1795 Opts.InlineVisibilityHidden = 1; 1796 1797 if (Args.hasArg(OPT_ftrapv)) { 1798 Opts.setSignedOverflowBehavior(LangOptions::SOB_Trapping); 1799 // Set the handler, if one is specified. 1800 Opts.OverflowHandler = 1801 Args.getLastArgValue(OPT_ftrapv_handler); 1802 } 1803 else if (Args.hasArg(OPT_fwrapv)) 1804 Opts.setSignedOverflowBehavior(LangOptions::SOB_Defined); 1805 1806 if (Args.hasArg(OPT_trigraphs)) 1807 Opts.Trigraphs = 1; 1808 1809 Opts.DollarIdents = Args.hasFlag(OPT_fdollars_in_identifiers, 1810 OPT_fno_dollars_in_identifiers, 1811 Opts.DollarIdents); 1812 Opts.PascalStrings = Args.hasArg(OPT_fpascal_strings); 1813 Opts.MicrosoftExt 1814 = Args.hasArg(OPT_fms_extensions) || Args.hasArg(OPT_fms_compatibility); 1815 Opts.MicrosoftMode = Args.hasArg(OPT_fms_compatibility); 1816 Opts.MSCVersion = Args.getLastArgIntValue(OPT_fmsc_version, 0, Diags); 1817 Opts.Borland = Args.hasArg(OPT_fborland_extensions); 1818 Opts.WritableStrings = Args.hasArg(OPT_fwritable_strings); 1819 Opts.ConstStrings = Args.hasFlag(OPT_fconst_strings, OPT_fno_const_strings, 1820 Opts.ConstStrings); 1821 if (Args.hasArg(OPT_fno_lax_vector_conversions)) 1822 Opts.LaxVectorConversions = 0; 1823 if (Args.hasArg(OPT_fno_threadsafe_statics)) 1824 Opts.ThreadsafeStatics = 0; 1825 Opts.Exceptions = Args.hasArg(OPT_fexceptions); 1826 Opts.ObjCExceptions = Args.hasArg(OPT_fobjc_exceptions); 1827 Opts.CXXExceptions = Args.hasArg(OPT_fcxx_exceptions); 1828 Opts.SjLjExceptions = Args.hasArg(OPT_fsjlj_exceptions); 1829 Opts.TraditionalCPP = Args.hasArg(OPT_traditional_cpp); 1830 1831 Opts.RTTI = !Args.hasArg(OPT_fno_rtti); 1832 Opts.Blocks = Args.hasArg(OPT_fblocks); 1833 Opts.BlocksRuntimeOptional = Args.hasArg(OPT_fblocks_runtime_optional); 1834 Opts.Modules = Args.hasArg(OPT_fmodules); 1835 Opts.CharIsSigned = !Args.hasArg(OPT_fno_signed_char); 1836 Opts.ShortWChar = Args.hasArg(OPT_fshort_wchar); 1837 Opts.ShortEnums = Args.hasArg(OPT_fshort_enums); 1838 Opts.Freestanding = Args.hasArg(OPT_ffreestanding); 1839 Opts.NoBuiltin = Args.hasArg(OPT_fno_builtin) || Opts.Freestanding; 1840 Opts.AssumeSaneOperatorNew = !Args.hasArg(OPT_fno_assume_sane_operator_new); 1841 Opts.HeinousExtensions = Args.hasArg(OPT_fheinous_gnu_extensions); 1842 Opts.AccessControl = !Args.hasArg(OPT_fno_access_control); 1843 Opts.ElideConstructors = !Args.hasArg(OPT_fno_elide_constructors); 1844 Opts.MathErrno = Args.hasArg(OPT_fmath_errno); 1845 Opts.InstantiationDepth = Args.getLastArgIntValue(OPT_ftemplate_depth, 1024, 1846 Diags); 1847 Opts.ConstexprCallDepth = Args.getLastArgIntValue(OPT_fconstexpr_depth, 512, 1848 Diags); 1849 Opts.DelayedTemplateParsing = Args.hasArg(OPT_fdelayed_template_parsing); 1850 Opts.NumLargeByValueCopy = Args.getLastArgIntValue(OPT_Wlarge_by_value_copy, 1851 0, Diags); 1852 Opts.MSBitfields = Args.hasArg(OPT_mms_bitfields); 1853 Opts.NeXTRuntime = !Args.hasArg(OPT_fgnu_runtime); 1854 Opts.ObjCConstantStringClass = 1855 Args.getLastArgValue(OPT_fconstant_string_class); 1856 Opts.ObjCNonFragileABI = !Args.hasArg(OPT_fobjc_fragile_abi); 1857 if (Opts.ObjCNonFragileABI) 1858 Opts.ObjCNonFragileABI2 = true; 1859 Opts.ObjCDefaultSynthProperties = 1860 Args.hasArg(OPT_fobjc_default_synthesize_properties); 1861 Opts.CatchUndefined = Args.hasArg(OPT_fcatch_undefined_behavior); 1862 Opts.EmitAllDecls = Args.hasArg(OPT_femit_all_decls); 1863 Opts.PackStruct = Args.getLastArgIntValue(OPT_fpack_struct, 0, Diags); 1864 Opts.PICLevel = Args.getLastArgIntValue(OPT_pic_level, 0, Diags); 1865 Opts.Static = Args.hasArg(OPT_static_define); 1866 Opts.DumpRecordLayouts = Args.hasArg(OPT_fdump_record_layouts); 1867 Opts.DumpVTableLayouts = Args.hasArg(OPT_fdump_vtable_layouts); 1868 Opts.SpellChecking = !Args.hasArg(OPT_fno_spell_checking); 1869 Opts.NoBitFieldTypeAlign = Args.hasArg(OPT_fno_bitfield_type_align); 1870 Opts.SinglePrecisionConstants = Args.hasArg(OPT_cl_single_precision_constant); 1871 Opts.FastRelaxedMath = Args.hasArg(OPT_cl_fast_relaxed_math); 1872 Opts.MRTD = Args.hasArg(OPT_mrtd); 1873 Opts.HexagonQdsp6Compat = Args.hasArg(OPT_mqdsp6_compat); 1874 Opts.FakeAddressSpaceMap = Args.hasArg(OPT_ffake_address_space_map); 1875 Opts.ParseUnknownAnytype = Args.hasArg(OPT_funknown_anytype); 1876 Opts.DebuggerSupport = Args.hasArg(OPT_fdebugger_support); 1877 Opts.AddressSanitizer = Args.hasArg(OPT_faddress_sanitizer); 1878 Opts.ApplePragmaPack = Args.hasArg(OPT_fapple_pragma_pack); 1879 Opts.CurrentModule = Args.getLastArgValue(OPT_fmodule_name); 1880 1881 // Record whether the __DEPRECATED define was requested. 1882 Opts.Deprecated = Args.hasFlag(OPT_fdeprecated_macro, 1883 OPT_fno_deprecated_macro, 1884 Opts.Deprecated); 1885 1886 // FIXME: Eliminate this dependency. 1887 unsigned Opt = getOptimizationLevel(Args, IK, Diags); 1888 Opts.Optimize = Opt != 0; 1889 Opts.OptimizeSize = Args.hasArg(OPT_Os) || Args.hasArg(OPT_Oz); 1890 1891 // This is the __NO_INLINE__ define, which just depends on things like the 1892 // optimization level and -fno-inline, not actually whether the backend has 1893 // inlining enabled. 1894 // 1895 // FIXME: This is affected by other options (-fno-inline). 1896 Opts.NoInline = !Opt; 1897 1898 Opts.FastMath = Args.hasArg(OPT_ffast_math); 1899 1900 unsigned SSP = Args.getLastArgIntValue(OPT_stack_protector, 0, Diags); 1901 switch (SSP) { 1902 default: 1903 Diags.Report(diag::err_drv_invalid_value) 1904 << Args.getLastArg(OPT_stack_protector)->getAsString(Args) << SSP; 1905 break; 1906 case 0: Opts.setStackProtector(LangOptions::SSPOff); break; 1907 case 1: Opts.setStackProtector(LangOptions::SSPOn); break; 1908 case 2: Opts.setStackProtector(LangOptions::SSPReq); break; 1909 } 1910 } 1911 1912 static void ParsePreprocessorArgs(PreprocessorOptions &Opts, ArgList &Args, 1913 FileManager &FileMgr, 1914 DiagnosticsEngine &Diags) { 1915 using namespace cc1options; 1916 Opts.ImplicitPCHInclude = Args.getLastArgValue(OPT_include_pch); 1917 Opts.ImplicitPTHInclude = Args.getLastArgValue(OPT_include_pth); 1918 if (const Arg *A = Args.getLastArg(OPT_token_cache)) 1919 Opts.TokenCache = A->getValue(Args); 1920 else 1921 Opts.TokenCache = Opts.ImplicitPTHInclude; 1922 Opts.UsePredefines = !Args.hasArg(OPT_undef); 1923 Opts.DetailedRecord = Args.hasArg(OPT_detailed_preprocessing_record); 1924 Opts.DisablePCHValidation = Args.hasArg(OPT_fno_validate_pch); 1925 1926 Opts.DumpDeserializedPCHDecls = Args.hasArg(OPT_dump_deserialized_pch_decls); 1927 for (arg_iterator it = Args.filtered_begin(OPT_error_on_deserialized_pch_decl), 1928 ie = Args.filtered_end(); it != ie; ++it) { 1929 const Arg *A = *it; 1930 Opts.DeserializedPCHDeclsToErrorOn.insert(A->getValue(Args)); 1931 } 1932 1933 if (const Arg *A = Args.getLastArg(OPT_preamble_bytes_EQ)) { 1934 StringRef Value(A->getValue(Args)); 1935 size_t Comma = Value.find(','); 1936 unsigned Bytes = 0; 1937 unsigned EndOfLine = 0; 1938 1939 if (Comma == StringRef::npos || 1940 Value.substr(0, Comma).getAsInteger(10, Bytes) || 1941 Value.substr(Comma + 1).getAsInteger(10, EndOfLine)) 1942 Diags.Report(diag::err_drv_preamble_format); 1943 else { 1944 Opts.PrecompiledPreambleBytes.first = Bytes; 1945 Opts.PrecompiledPreambleBytes.second = (EndOfLine != 0); 1946 } 1947 } 1948 1949 // Add macros from the command line. 1950 for (arg_iterator it = Args.filtered_begin(OPT_D, OPT_U), 1951 ie = Args.filtered_end(); it != ie; ++it) { 1952 if ((*it)->getOption().matches(OPT_D)) 1953 Opts.addMacroDef((*it)->getValue(Args)); 1954 else 1955 Opts.addMacroUndef((*it)->getValue(Args)); 1956 } 1957 1958 Opts.MacroIncludes = Args.getAllArgValues(OPT_imacros); 1959 1960 // Add the ordered list of -includes. 1961 for (arg_iterator it = Args.filtered_begin(OPT_include, OPT_include_pch, 1962 OPT_include_pth), 1963 ie = Args.filtered_end(); it != ie; ++it) { 1964 const Arg *A = *it; 1965 // PCH is handled specially, we need to extra the original include path. 1966 if (A->getOption().matches(OPT_include_pch)) { 1967 std::string OriginalFile = 1968 ASTReader::getOriginalSourceFile(A->getValue(Args), FileMgr, Diags); 1969 if (OriginalFile.empty()) 1970 continue; 1971 1972 Opts.Includes.push_back(OriginalFile); 1973 } else 1974 Opts.Includes.push_back(A->getValue(Args)); 1975 } 1976 1977 for (arg_iterator it = Args.filtered_begin(OPT_chain_include), 1978 ie = Args.filtered_end(); it != ie; ++it) { 1979 const Arg *A = *it; 1980 Opts.ChainedIncludes.push_back(A->getValue(Args)); 1981 } 1982 1983 // Include 'altivec.h' if -faltivec option present 1984 if (Args.hasArg(OPT_faltivec)) 1985 Opts.Includes.push_back("altivec.h"); 1986 1987 for (arg_iterator it = Args.filtered_begin(OPT_remap_file), 1988 ie = Args.filtered_end(); it != ie; ++it) { 1989 const Arg *A = *it; 1990 std::pair<StringRef,StringRef> Split = 1991 StringRef(A->getValue(Args)).split(';'); 1992 1993 if (Split.second.empty()) { 1994 Diags.Report(diag::err_drv_invalid_remap_file) << A->getAsString(Args); 1995 continue; 1996 } 1997 1998 Opts.addRemappedFile(Split.first, Split.second); 1999 } 2000 2001 if (Arg *A = Args.getLastArg(OPT_fobjc_arc_cxxlib_EQ)) { 2002 StringRef Name = A->getValue(Args); 2003 unsigned Library = llvm::StringSwitch<unsigned>(Name) 2004 .Case("libc++", ARCXX_libcxx) 2005 .Case("libstdc++", ARCXX_libstdcxx) 2006 .Case("none", ARCXX_nolib) 2007 .Default(~0U); 2008 if (Library == ~0U) 2009 Diags.Report(diag::err_drv_invalid_value) << A->getAsString(Args) << Name; 2010 else 2011 Opts.ObjCXXARCStandardLibrary = (ObjCXXARCStandardLibraryKind)Library; 2012 } 2013 } 2014 2015 static void ParsePreprocessorOutputArgs(PreprocessorOutputOptions &Opts, 2016 ArgList &Args) { 2017 using namespace cc1options; 2018 Opts.ShowCPP = !Args.hasArg(OPT_dM); 2019 Opts.ShowComments = Args.hasArg(OPT_C); 2020 Opts.ShowLineMarkers = !Args.hasArg(OPT_P); 2021 Opts.ShowMacroComments = Args.hasArg(OPT_CC); 2022 Opts.ShowMacros = Args.hasArg(OPT_dM) || Args.hasArg(OPT_dD); 2023 } 2024 2025 static void ParseTargetArgs(TargetOptions &Opts, ArgList &Args) { 2026 using namespace cc1options; 2027 Opts.ABI = Args.getLastArgValue(OPT_target_abi); 2028 Opts.CXXABI = Args.getLastArgValue(OPT_cxx_abi); 2029 Opts.CPU = Args.getLastArgValue(OPT_target_cpu); 2030 Opts.Features = Args.getAllArgValues(OPT_target_feature); 2031 Opts.LinkerVersion = Args.getLastArgValue(OPT_target_linker_version); 2032 Opts.Triple = llvm::Triple::normalize(Args.getLastArgValue(OPT_triple)); 2033 2034 // Use the default target triple if unspecified. 2035 if (Opts.Triple.empty()) 2036 Opts.Triple = llvm::sys::getDefaultTargetTriple(); 2037 } 2038 2039 // 2040 2041 bool CompilerInvocation::CreateFromArgs(CompilerInvocation &Res, 2042 const char *const *ArgBegin, 2043 const char *const *ArgEnd, 2044 DiagnosticsEngine &Diags) { 2045 bool Success = true; 2046 2047 // Parse the arguments. 2048 llvm::OwningPtr<OptTable> Opts(createCC1OptTable()); 2049 unsigned MissingArgIndex, MissingArgCount; 2050 llvm::OwningPtr<InputArgList> Args( 2051 Opts->ParseArgs(ArgBegin, ArgEnd,MissingArgIndex, MissingArgCount)); 2052 2053 // Check for missing argument error. 2054 if (MissingArgCount) { 2055 Diags.Report(diag::err_drv_missing_argument) 2056 << Args->getArgString(MissingArgIndex) << MissingArgCount; 2057 Success = false; 2058 } 2059 2060 // Issue errors on unknown arguments. 2061 for (arg_iterator it = Args->filtered_begin(OPT_UNKNOWN), 2062 ie = Args->filtered_end(); it != ie; ++it) { 2063 Diags.Report(diag::err_drv_unknown_argument) << (*it)->getAsString(*Args); 2064 Success = false; 2065 } 2066 2067 Success = ParseAnalyzerArgs(Res.getAnalyzerOpts(), *Args, Diags) && Success; 2068 Success = ParseMigratorArgs(Res.getMigratorOpts(), *Args) && Success; 2069 ParseDependencyOutputArgs(Res.getDependencyOutputOpts(), *Args); 2070 Success = ParseDiagnosticArgs(Res.getDiagnosticOpts(), *Args, Diags) 2071 && Success; 2072 ParseFileSystemArgs(Res.getFileSystemOpts(), *Args); 2073 // FIXME: We shouldn't have to pass the DashX option around here 2074 InputKind DashX = ParseFrontendArgs(Res.getFrontendOpts(), *Args, Diags); 2075 Success = ParseCodeGenArgs(Res.getCodeGenOpts(), *Args, DashX, Diags) 2076 && Success; 2077 ParseHeaderSearchArgs(Res.getHeaderSearchOpts(), *Args); 2078 if (DashX != IK_AST && DashX != IK_LLVM_IR) { 2079 ParseLangArgs(*Res.getLangOpts(), *Args, DashX, Diags); 2080 if (Res.getFrontendOpts().ProgramAction == frontend::RewriteObjC) 2081 Res.getLangOpts()->ObjCExceptions = 1; 2082 } 2083 // FIXME: ParsePreprocessorArgs uses the FileManager to read the contents of 2084 // PCH file and find the original header name. Remove the need to do that in 2085 // ParsePreprocessorArgs and remove the FileManager 2086 // parameters from the function and the "FileManager.h" #include. 2087 FileManager FileMgr(Res.getFileSystemOpts()); 2088 ParsePreprocessorArgs(Res.getPreprocessorOpts(), *Args, FileMgr, Diags); 2089 ParsePreprocessorOutputArgs(Res.getPreprocessorOutputOpts(), *Args); 2090 ParseTargetArgs(Res.getTargetOpts(), *Args); 2091 2092 return Success; 2093 } 2094 2095 namespace { 2096 2097 class ModuleSignature { 2098 llvm::SmallVector<uint64_t, 16> Data; 2099 unsigned CurBit; 2100 uint64_t CurValue; 2101 2102 public: 2103 ModuleSignature() : CurBit(0), CurValue(0) { } 2104 2105 void add(uint64_t Value, unsigned Bits); 2106 void add(StringRef Value); 2107 void flush(); 2108 2109 llvm::APInt getAsInteger() const; 2110 }; 2111 } 2112 2113 void ModuleSignature::add(uint64_t Value, unsigned int NumBits) { 2114 CurValue |= Value << CurBit; 2115 if (CurBit + NumBits < 64) { 2116 CurBit += NumBits; 2117 return; 2118 } 2119 2120 // Add the current word. 2121 Data.push_back(CurValue); 2122 2123 if (CurBit) 2124 CurValue = Value >> (64-CurBit); 2125 else 2126 CurValue = 0; 2127 CurBit = (CurBit+NumBits) & 63; 2128 } 2129 2130 void ModuleSignature::flush() { 2131 if (CurBit == 0) 2132 return; 2133 2134 Data.push_back(CurValue); 2135 CurBit = 0; 2136 CurValue = 0; 2137 } 2138 2139 void ModuleSignature::add(StringRef Value) { 2140 for (StringRef::iterator I = Value.begin(), IEnd = Value.end(); I != IEnd;++I) 2141 add(*I, 8); 2142 } 2143 2144 llvm::APInt ModuleSignature::getAsInteger() const { 2145 return llvm::APInt(Data.size() * 64, Data); 2146 } 2147 2148 std::string CompilerInvocation::getModuleHash() const { 2149 ModuleSignature Signature; 2150 2151 // Start the signature with the compiler version. 2152 Signature.add(getClangFullRepositoryVersion()); 2153 2154 // Extend the signature with the language options 2155 #define LANGOPT(Name, Bits, Default, Description) \ 2156 Signature.add(LangOpts->Name, Bits); 2157 #define ENUM_LANGOPT(Name, Type, Bits, Default, Description) \ 2158 Signature.add(static_cast<unsigned>(LangOpts->get##Name()), Bits); 2159 #define BENIGN_LANGOPT(Name, Bits, Default, Description) 2160 #define BENIGN_ENUM_LANGOPT(Name, Type, Bits, Default, Description) 2161 #include "clang/Basic/LangOptions.def" 2162 2163 // Extend the signature with the target triple 2164 llvm::Triple T(TargetOpts.Triple); 2165 Signature.add((unsigned)T.getArch(), 5); 2166 Signature.add((unsigned)T.getVendor(), 4); 2167 Signature.add((unsigned)T.getOS(), 5); 2168 Signature.add((unsigned)T.getEnvironment(), 4); 2169 2170 // Extend the signature with preprocessor options. 2171 Signature.add(getPreprocessorOpts().UsePredefines, 1); 2172 Signature.add(getPreprocessorOpts().DetailedRecord, 1); 2173 2174 // Hash the preprocessor defines. 2175 // FIXME: This is terrible. Use an MD5 sum of the preprocessor defines. 2176 std::vector<StringRef> MacroDefs; 2177 for (std::vector<std::pair<std::string, bool/*isUndef*/> >::const_iterator 2178 I = getPreprocessorOpts().Macros.begin(), 2179 IEnd = getPreprocessorOpts().Macros.end(); 2180 I != IEnd; ++I) { 2181 if (!I->second) 2182 MacroDefs.push_back(I->first); 2183 } 2184 llvm::array_pod_sort(MacroDefs.begin(), MacroDefs.end()); 2185 2186 unsigned PPHashResult = 0; 2187 for (unsigned I = 0, N = MacroDefs.size(); I != N; ++I) 2188 PPHashResult = llvm::HashString(MacroDefs[I], PPHashResult); 2189 Signature.add(PPHashResult, 32); 2190 2191 // We've generated the signature. Treat it as one large APInt that we'll 2192 // encode in base-36 and return. 2193 Signature.flush(); 2194 return Signature.getAsInteger().toString(36, /*Signed=*/false); 2195 } 2196