1 //===--- Driver.cpp - Clang GCC Compatible Driver -------------------------===//
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/Driver/Driver.h"
11 #include "InputInfo.h"
12 #include "ToolChains.h"
13 #include "clang/Basic/Version.h"
14 #include "clang/Driver/Action.h"
15 #include "clang/Driver/Compilation.h"
16 #include "clang/Driver/DriverDiagnostic.h"
17 #include "clang/Driver/Job.h"
18 #include "clang/Driver/Options.h"
19 #include "clang/Driver/SanitizerArgs.h"
20 #include "clang/Driver/Tool.h"
21 #include "clang/Driver/ToolChain.h"
22 #include "llvm/ADT/ArrayRef.h"
23 #include "llvm/ADT/OwningPtr.h"
24 #include "llvm/ADT/STLExtras.h"
25 #include "llvm/ADT/StringSet.h"
26 #include "llvm/ADT/StringSwitch.h"
27 #include "llvm/Option/Arg.h"
28 #include "llvm/Option/ArgList.h"
29 #include "llvm/Option/OptTable.h"
30 #include "llvm/Option/Option.h"
31 #include "llvm/Option/OptSpecifier.h"
32 #include "llvm/Support/Debug.h"
33 #include "llvm/Support/ErrorHandling.h"
34 #include "llvm/Support/FileSystem.h"
35 #include "llvm/Support/Path.h"
36 #include "llvm/Support/PrettyStackTrace.h"
37 #include "llvm/Support/Program.h"
38 #include "llvm/Support/raw_ostream.h"
39 #include <map>
40 
41 // FIXME: It would prevent us from including llvm-config.h
42 // if config.h were included before system_error.h.
43 #include "clang/Config/config.h"
44 
45 using namespace clang::driver;
46 using namespace clang;
47 using namespace llvm::opt;
48 
49 Driver::Driver(StringRef ClangExecutable,
50                StringRef DefaultTargetTriple,
51                StringRef DefaultImageName,
52                DiagnosticsEngine &Diags)
53   : Opts(createDriverOptTable()), Diags(Diags), Mode(GCCMode),
54     ClangExecutable(ClangExecutable), SysRoot(DEFAULT_SYSROOT),
55     UseStdLib(true), DefaultTargetTriple(DefaultTargetTriple),
56     DefaultImageName(DefaultImageName),
57     DriverTitle("clang LLVM compiler"),
58     CCPrintOptionsFilename(0), CCPrintHeadersFilename(0),
59     CCLogDiagnosticsFilename(0),
60     CCCPrintBindings(false),
61     CCPrintHeaders(false), CCLogDiagnostics(false),
62     CCGenDiagnostics(false), CCCGenericGCCName(""), CheckInputsExist(true),
63     CCCUsePCH(true), SuppressMissingInputWarning(false) {
64 
65   Name = llvm::sys::path::stem(ClangExecutable);
66   Dir  = llvm::sys::path::parent_path(ClangExecutable);
67 
68   // Compute the path to the resource directory.
69   StringRef ClangResourceDir(CLANG_RESOURCE_DIR);
70   SmallString<128> P(Dir);
71   if (ClangResourceDir != "")
72     llvm::sys::path::append(P, ClangResourceDir);
73   else
74     llvm::sys::path::append(P, "..", "lib", "clang", CLANG_VERSION_STRING);
75   ResourceDir = P.str();
76 }
77 
78 Driver::~Driver() {
79   delete Opts;
80 
81   for (llvm::StringMap<ToolChain *>::iterator I = ToolChains.begin(),
82                                               E = ToolChains.end();
83        I != E; ++I)
84     delete I->second;
85 }
86 
87 void Driver::ParseDriverMode(ArrayRef<const char *> Args) {
88   const std::string OptName =
89     getOpts().getOption(options::OPT_driver_mode).getPrefixedName();
90 
91   for (size_t I = 0, E = Args.size(); I != E; ++I) {
92     const StringRef Arg = Args[I];
93     if (!Arg.startswith(OptName))
94       continue;
95 
96     const StringRef Value = Arg.drop_front(OptName.size());
97     const unsigned M = llvm::StringSwitch<unsigned>(Value)
98         .Case("gcc", GCCMode)
99         .Case("g++", GXXMode)
100         .Case("cpp", CPPMode)
101         .Case("cl",  CLMode)
102         .Default(~0U);
103 
104     if (M != ~0U)
105       Mode = static_cast<DriverMode>(M);
106     else
107       Diag(diag::err_drv_unsupported_option_argument) << OptName << Value;
108   }
109 }
110 
111 InputArgList *Driver::ParseArgStrings(ArrayRef<const char *> ArgList) {
112   llvm::PrettyStackTraceString CrashInfo("Command line argument parsing");
113 
114   unsigned IncludedFlagsBitmask;
115   unsigned ExcludedFlagsBitmask;
116   llvm::tie(IncludedFlagsBitmask, ExcludedFlagsBitmask) =
117     getIncludeExcludeOptionFlagMasks();
118 
119   unsigned MissingArgIndex, MissingArgCount;
120   InputArgList *Args = getOpts().ParseArgs(ArgList.begin(), ArgList.end(),
121                                            MissingArgIndex, MissingArgCount,
122                                            IncludedFlagsBitmask,
123                                            ExcludedFlagsBitmask);
124 
125   // Check for missing argument error.
126   if (MissingArgCount)
127     Diag(clang::diag::err_drv_missing_argument)
128       << Args->getArgString(MissingArgIndex) << MissingArgCount;
129 
130   // Check for unsupported options.
131   for (ArgList::const_iterator it = Args->begin(), ie = Args->end();
132        it != ie; ++it) {
133     Arg *A = *it;
134     if (A->getOption().hasFlag(options::Unsupported)) {
135       Diag(clang::diag::err_drv_unsupported_opt) << A->getAsString(*Args);
136       continue;
137     }
138 
139     // Warn about -mcpu= without an argument.
140     if (A->getOption().matches(options::OPT_mcpu_EQ) &&
141         A->containsValue("")) {
142       Diag(clang::diag::warn_drv_empty_joined_argument) <<
143         A->getAsString(*Args);
144     }
145   }
146 
147   for (arg_iterator it = Args->filtered_begin(options::OPT_UNKNOWN),
148          ie = Args->filtered_end(); it != ie; ++it) {
149     Diags.Report(diag::err_drv_unknown_argument) << (*it) ->getAsString(*Args);
150   }
151 
152   return Args;
153 }
154 
155 // Determine which compilation mode we are in. We look for options which
156 // affect the phase, starting with the earliest phases, and record which
157 // option we used to determine the final phase.
158 phases::ID Driver::getFinalPhase(const DerivedArgList &DAL, Arg **FinalPhaseArg)
159 const {
160   Arg *PhaseArg = 0;
161   phases::ID FinalPhase;
162 
163   // -{E,M,MM} only run the preprocessor.
164   if (CCCIsCPP() ||
165       (PhaseArg = DAL.getLastArg(options::OPT_E)) ||
166       (PhaseArg = DAL.getLastArg(options::OPT_M, options::OPT_MM))) {
167     FinalPhase = phases::Preprocess;
168 
169     // -{fsyntax-only,-analyze,emit-ast,S} only run up to the compiler.
170   } else if ((PhaseArg = DAL.getLastArg(options::OPT_fsyntax_only)) ||
171              (PhaseArg = DAL.getLastArg(options::OPT_module_file_info)) ||
172              (PhaseArg = DAL.getLastArg(options::OPT_rewrite_objc)) ||
173              (PhaseArg = DAL.getLastArg(options::OPT_rewrite_legacy_objc)) ||
174              (PhaseArg = DAL.getLastArg(options::OPT__migrate)) ||
175              (PhaseArg = DAL.getLastArg(options::OPT__analyze,
176                                         options::OPT__analyze_auto)) ||
177              (PhaseArg = DAL.getLastArg(options::OPT_emit_ast)) ||
178              (PhaseArg = DAL.getLastArg(options::OPT_S))) {
179     FinalPhase = phases::Compile;
180 
181     // -c only runs up to the assembler.
182   } else if ((PhaseArg = DAL.getLastArg(options::OPT_c))) {
183     FinalPhase = phases::Assemble;
184 
185     // Otherwise do everything.
186   } else
187     FinalPhase = phases::Link;
188 
189   if (FinalPhaseArg)
190     *FinalPhaseArg = PhaseArg;
191 
192   return FinalPhase;
193 }
194 
195 static Arg* MakeInputArg(const DerivedArgList &Args, OptTable *Opts,
196                          StringRef Value) {
197   Arg *A = new Arg(Opts->getOption(options::OPT_INPUT), Value,
198                    Args.getBaseArgs().MakeIndex(Value), Value.data());
199   A->claim();
200   return A;
201 }
202 
203 DerivedArgList *Driver::TranslateInputArgs(const InputArgList &Args) const {
204   DerivedArgList *DAL = new DerivedArgList(Args);
205 
206   bool HasNostdlib = Args.hasArg(options::OPT_nostdlib);
207   for (ArgList::const_iterator it = Args.begin(),
208          ie = Args.end(); it != ie; ++it) {
209     const Arg *A = *it;
210 
211     // Unfortunately, we have to parse some forwarding options (-Xassembler,
212     // -Xlinker, -Xpreprocessor) because we either integrate their functionality
213     // (assembler and preprocessor), or bypass a previous driver ('collect2').
214 
215     // Rewrite linker options, to replace --no-demangle with a custom internal
216     // option.
217     if ((A->getOption().matches(options::OPT_Wl_COMMA) ||
218          A->getOption().matches(options::OPT_Xlinker)) &&
219         A->containsValue("--no-demangle")) {
220       // Add the rewritten no-demangle argument.
221       DAL->AddFlagArg(A, Opts->getOption(options::OPT_Z_Xlinker__no_demangle));
222 
223       // Add the remaining values as Xlinker arguments.
224       for (unsigned i = 0, e = A->getNumValues(); i != e; ++i)
225         if (StringRef(A->getValue(i)) != "--no-demangle")
226           DAL->AddSeparateArg(A, Opts->getOption(options::OPT_Xlinker),
227                               A->getValue(i));
228 
229       continue;
230     }
231 
232     // Rewrite preprocessor options, to replace -Wp,-MD,FOO which is used by
233     // some build systems. We don't try to be complete here because we don't
234     // care to encourage this usage model.
235     if (A->getOption().matches(options::OPT_Wp_COMMA) &&
236         (A->getValue(0) == StringRef("-MD") ||
237          A->getValue(0) == StringRef("-MMD"))) {
238       // Rewrite to -MD/-MMD along with -MF.
239       if (A->getValue(0) == StringRef("-MD"))
240         DAL->AddFlagArg(A, Opts->getOption(options::OPT_MD));
241       else
242         DAL->AddFlagArg(A, Opts->getOption(options::OPT_MMD));
243       if (A->getNumValues() == 2)
244         DAL->AddSeparateArg(A, Opts->getOption(options::OPT_MF),
245                             A->getValue(1));
246       continue;
247     }
248 
249     // Rewrite reserved library names.
250     if (A->getOption().matches(options::OPT_l)) {
251       StringRef Value = A->getValue();
252 
253       // Rewrite unless -nostdlib is present.
254       if (!HasNostdlib && Value == "stdc++") {
255         DAL->AddFlagArg(A, Opts->getOption(
256                               options::OPT_Z_reserved_lib_stdcxx));
257         continue;
258       }
259 
260       // Rewrite unconditionally.
261       if (Value == "cc_kext") {
262         DAL->AddFlagArg(A, Opts->getOption(
263                               options::OPT_Z_reserved_lib_cckext));
264         continue;
265       }
266     }
267 
268     // Pick up inputs via the -- option.
269     if (A->getOption().matches(options::OPT__DASH_DASH)) {
270       A->claim();
271       for (unsigned i = 0, e = A->getNumValues(); i != e; ++i)
272         DAL->append(MakeInputArg(*DAL, Opts, A->getValue(i)));
273       continue;
274     }
275 
276     DAL->append(*it);
277   }
278 
279   // Add a default value of -mlinker-version=, if one was given and the user
280   // didn't specify one.
281 #if defined(HOST_LINK_VERSION)
282   if (!Args.hasArg(options::OPT_mlinker_version_EQ)) {
283     DAL->AddJoinedArg(0, Opts->getOption(options::OPT_mlinker_version_EQ),
284                       HOST_LINK_VERSION);
285     DAL->getLastArg(options::OPT_mlinker_version_EQ)->claim();
286   }
287 #endif
288 
289   return DAL;
290 }
291 
292 Compilation *Driver::BuildCompilation(ArrayRef<const char *> ArgList) {
293   llvm::PrettyStackTraceString CrashInfo("Compilation construction");
294 
295   // FIXME: Handle environment options which affect driver behavior, somewhere
296   // (client?). GCC_EXEC_PREFIX, LPATH, CC_PRINT_OPTIONS.
297 
298   if (char *env = ::getenv("COMPILER_PATH")) {
299     StringRef CompilerPath = env;
300     while (!CompilerPath.empty()) {
301       std::pair<StringRef, StringRef> Split
302         = CompilerPath.split(llvm::sys::EnvPathSeparator);
303       PrefixDirs.push_back(Split.first);
304       CompilerPath = Split.second;
305     }
306   }
307 
308   // We look for the driver mode option early, because the mode can affect
309   // how other options are parsed.
310   ParseDriverMode(ArgList.slice(1));
311 
312   // FIXME: What are we going to do with -V and -b?
313 
314   // FIXME: This stuff needs to go into the Compilation, not the driver.
315   bool CCCPrintActions;
316 
317   InputArgList *Args = ParseArgStrings(ArgList.slice(1));
318 
319   // -no-canonical-prefixes is used very early in main.
320   Args->ClaimAllArgs(options::OPT_no_canonical_prefixes);
321 
322   // Ignore -pipe.
323   Args->ClaimAllArgs(options::OPT_pipe);
324 
325   // Extract -ccc args.
326   //
327   // FIXME: We need to figure out where this behavior should live. Most of it
328   // should be outside in the client; the parts that aren't should have proper
329   // options, either by introducing new ones or by overloading gcc ones like -V
330   // or -b.
331   CCCPrintActions = Args->hasArg(options::OPT_ccc_print_phases);
332   CCCPrintBindings = Args->hasArg(options::OPT_ccc_print_bindings);
333   if (const Arg *A = Args->getLastArg(options::OPT_ccc_gcc_name))
334     CCCGenericGCCName = A->getValue();
335   CCCUsePCH = Args->hasFlag(options::OPT_ccc_pch_is_pch,
336                             options::OPT_ccc_pch_is_pth);
337   // FIXME: DefaultTargetTriple is used by the target-prefixed calls to as/ld
338   // and getToolChain is const.
339   if (IsCLMode()) {
340     // clang-cl targets Win32.
341     llvm::Triple T(DefaultTargetTriple);
342     T.setOSName(llvm::Triple::getOSTypeName(llvm::Triple::Win32));
343     DefaultTargetTriple = T.str();
344   }
345   if (const Arg *A = Args->getLastArg(options::OPT_target))
346     DefaultTargetTriple = A->getValue();
347   if (const Arg *A = Args->getLastArg(options::OPT_ccc_install_dir))
348     Dir = InstalledDir = A->getValue();
349   for (arg_iterator it = Args->filtered_begin(options::OPT_B),
350          ie = Args->filtered_end(); it != ie; ++it) {
351     const Arg *A = *it;
352     A->claim();
353     PrefixDirs.push_back(A->getValue(0));
354   }
355   if (const Arg *A = Args->getLastArg(options::OPT__sysroot_EQ))
356     SysRoot = A->getValue();
357   if (const Arg *A = Args->getLastArg(options::OPT__dyld_prefix_EQ))
358     DyldPrefix = A->getValue();
359   if (Args->hasArg(options::OPT_nostdlib))
360     UseStdLib = false;
361 
362   if (const Arg *A = Args->getLastArg(options::OPT_resource_dir))
363     ResourceDir = A->getValue();
364 
365   // Perform the default argument translations.
366   DerivedArgList *TranslatedArgs = TranslateInputArgs(*Args);
367 
368   // Owned by the host.
369   const ToolChain &TC = getToolChain(*Args);
370 
371   // The compilation takes ownership of Args.
372   Compilation *C = new Compilation(*this, TC, Args, TranslatedArgs);
373 
374   if (!HandleImmediateArgs(*C))
375     return C;
376 
377   // Construct the list of inputs.
378   InputList Inputs;
379   BuildInputs(C->getDefaultToolChain(), *TranslatedArgs, Inputs);
380 
381   // Construct the list of abstract actions to perform for this compilation. On
382   // Darwin target OSes this uses the driver-driver and universal actions.
383   if (TC.getTriple().isOSDarwin())
384     BuildUniversalActions(C->getDefaultToolChain(), C->getArgs(),
385                           Inputs, C->getActions());
386   else
387     BuildActions(C->getDefaultToolChain(), C->getArgs(), Inputs,
388                  C->getActions());
389 
390   if (CCCPrintActions) {
391     PrintActions(*C);
392     return C;
393   }
394 
395   BuildJobs(*C);
396 
397   return C;
398 }
399 
400 // When clang crashes, produce diagnostic information including the fully
401 // preprocessed source file(s).  Request that the developer attach the
402 // diagnostic information to a bug report.
403 void Driver::generateCompilationDiagnostics(Compilation &C,
404                                             const Command *FailingCommand) {
405   if (C.getArgs().hasArg(options::OPT_fno_crash_diagnostics))
406     return;
407 
408   // Don't try to generate diagnostics for link or dsymutil jobs.
409   if (FailingCommand && (FailingCommand->getCreator().isLinkJob() ||
410                          FailingCommand->getCreator().isDsymutilJob()))
411     return;
412 
413   // Print the version of the compiler.
414   PrintVersion(C, llvm::errs());
415 
416   Diag(clang::diag::note_drv_command_failed_diag_msg)
417     << "PLEASE submit a bug report to " BUG_REPORT_URL " and include the "
418     "crash backtrace, preprocessed source, and associated run script.";
419 
420   // Suppress driver output and emit preprocessor output to temp file.
421   Mode = CPPMode;
422   CCGenDiagnostics = true;
423   C.getArgs().AddFlagArg(0, Opts->getOption(options::OPT_frewrite_includes));
424 
425   // Save the original job command(s).
426   std::string Cmd;
427   llvm::raw_string_ostream OS(Cmd);
428   if (FailingCommand)
429     FailingCommand->Print(OS, "\n", /*Quote*/ false, /*CrashReport*/ true);
430   else
431     // Crash triggered by FORCE_CLANG_DIAGNOSTICS_CRASH, which doesn't have an
432     // associated FailingCommand, so just pass all jobs.
433     C.getJobs().Print(OS, "\n", /*Quote*/ false, /*CrashReport*/ true);
434   OS.flush();
435 
436   // Keep track of whether we produce any errors while trying to produce
437   // preprocessed sources.
438   DiagnosticErrorTrap Trap(Diags);
439 
440   // Suppress tool output.
441   C.initCompilationForDiagnostics();
442 
443   // Construct the list of inputs.
444   InputList Inputs;
445   BuildInputs(C.getDefaultToolChain(), C.getArgs(), Inputs);
446 
447   for (InputList::iterator it = Inputs.begin(), ie = Inputs.end(); it != ie;) {
448     bool IgnoreInput = false;
449 
450     // Ignore input from stdin or any inputs that cannot be preprocessed.
451     if (!strcmp(it->second->getValue(), "-")) {
452       Diag(clang::diag::note_drv_command_failed_diag_msg)
453         << "Error generating preprocessed source(s) - ignoring input from stdin"
454         ".";
455       IgnoreInput = true;
456     } else if (types::getPreprocessedType(it->first) == types::TY_INVALID) {
457       IgnoreInput = true;
458     }
459 
460     if (IgnoreInput) {
461       it = Inputs.erase(it);
462       ie = Inputs.end();
463     } else {
464       ++it;
465     }
466   }
467 
468   if (Inputs.empty()) {
469     Diag(clang::diag::note_drv_command_failed_diag_msg)
470       << "Error generating preprocessed source(s) - no preprocessable inputs.";
471     return;
472   }
473 
474   // Don't attempt to generate preprocessed files if multiple -arch options are
475   // used, unless they're all duplicates.
476   llvm::StringSet<> ArchNames;
477   for (ArgList::const_iterator it = C.getArgs().begin(), ie = C.getArgs().end();
478        it != ie; ++it) {
479     Arg *A = *it;
480     if (A->getOption().matches(options::OPT_arch)) {
481       StringRef ArchName = A->getValue();
482       ArchNames.insert(ArchName);
483     }
484   }
485   if (ArchNames.size() > 1) {
486     Diag(clang::diag::note_drv_command_failed_diag_msg)
487       << "Error generating preprocessed source(s) - cannot generate "
488       "preprocessed source with multiple -arch options.";
489     return;
490   }
491 
492   // Construct the list of abstract actions to perform for this compilation. On
493   // Darwin OSes this uses the driver-driver and builds universal actions.
494   const ToolChain &TC = C.getDefaultToolChain();
495   if (TC.getTriple().isOSDarwin())
496     BuildUniversalActions(TC, C.getArgs(), Inputs, C.getActions());
497   else
498     BuildActions(TC, C.getArgs(), Inputs, C.getActions());
499 
500   BuildJobs(C);
501 
502   // If there were errors building the compilation, quit now.
503   if (Trap.hasErrorOccurred()) {
504     Diag(clang::diag::note_drv_command_failed_diag_msg)
505       << "Error generating preprocessed source(s).";
506     return;
507   }
508 
509   // Generate preprocessed output.
510   SmallVector<std::pair<int, const Command *>, 4> FailingCommands;
511   C.ExecuteJob(C.getJobs(), FailingCommands);
512 
513   // If the command succeeded, we are done.
514   if (FailingCommands.empty()) {
515     Diag(clang::diag::note_drv_command_failed_diag_msg)
516       << "\n********************\n\n"
517       "PLEASE ATTACH THE FOLLOWING FILES TO THE BUG REPORT:\n"
518       "Preprocessed source(s) and associated run script(s) are located at:";
519     ArgStringList Files = C.getTempFiles();
520     for (ArgStringList::const_iterator it = Files.begin(), ie = Files.end();
521          it != ie; ++it) {
522       Diag(clang::diag::note_drv_command_failed_diag_msg) << *it;
523 
524       std::string Err;
525       std::string Script = StringRef(*it).rsplit('.').first;
526       Script += ".sh";
527       llvm::raw_fd_ostream ScriptOS(
528           Script.c_str(), Err, llvm::sys::fs::F_Excl | llvm::sys::fs::F_Binary);
529       if (!Err.empty()) {
530         Diag(clang::diag::note_drv_command_failed_diag_msg)
531           << "Error generating run script: " + Script + " " + Err;
532       } else {
533         // Append the new filename with correct preprocessed suffix.
534         size_t I, E;
535         I = Cmd.find("-main-file-name ");
536         assert (I != std::string::npos && "Expected to find -main-file-name");
537         I += 16;
538         E = Cmd.find(" ", I);
539         assert (E != std::string::npos && "-main-file-name missing argument?");
540         StringRef OldFilename = StringRef(Cmd).slice(I, E);
541         StringRef NewFilename = llvm::sys::path::filename(*it);
542         I = StringRef(Cmd).rfind(OldFilename);
543         E = I + OldFilename.size();
544         I = Cmd.rfind(" ", I) + 1;
545         Cmd.replace(I, E - I, NewFilename.data(), NewFilename.size());
546         ScriptOS << Cmd;
547         Diag(clang::diag::note_drv_command_failed_diag_msg) << Script;
548       }
549     }
550     Diag(clang::diag::note_drv_command_failed_diag_msg)
551       << "\n\n********************";
552   } else {
553     // Failure, remove preprocessed files.
554     if (!C.getArgs().hasArg(options::OPT_save_temps))
555       C.CleanupFileList(C.getTempFiles(), true);
556 
557     Diag(clang::diag::note_drv_command_failed_diag_msg)
558       << "Error generating preprocessed source(s).";
559   }
560 }
561 
562 int Driver::ExecuteCompilation(const Compilation &C,
563     SmallVectorImpl< std::pair<int, const Command *> > &FailingCommands) const {
564   // Just print if -### was present.
565   if (C.getArgs().hasArg(options::OPT__HASH_HASH_HASH)) {
566     C.getJobs().Print(llvm::errs(), "\n", true);
567     return 0;
568   }
569 
570   // If there were errors building the compilation, quit now.
571   if (Diags.hasErrorOccurred())
572     return 1;
573 
574   C.ExecuteJob(C.getJobs(), FailingCommands);
575 
576   // Remove temp files.
577   C.CleanupFileList(C.getTempFiles());
578 
579   // If the command succeeded, we are done.
580   if (FailingCommands.empty())
581     return 0;
582 
583   // Otherwise, remove result files and print extra information about abnormal
584   // failures.
585   for (SmallVectorImpl< std::pair<int, const Command *> >::iterator it =
586          FailingCommands.begin(), ie = FailingCommands.end(); it != ie; ++it) {
587     int Res = it->first;
588     const Command *FailingCommand = it->second;
589 
590     // Remove result files if we're not saving temps.
591     if (!C.getArgs().hasArg(options::OPT_save_temps)) {
592       const JobAction *JA = cast<JobAction>(&FailingCommand->getSource());
593       C.CleanupFileMap(C.getResultFiles(), JA, true);
594 
595       // Failure result files are valid unless we crashed.
596       if (Res < 0)
597         C.CleanupFileMap(C.getFailureResultFiles(), JA, true);
598     }
599 
600     // Print extra information about abnormal failures, if possible.
601     //
602     // This is ad-hoc, but we don't want to be excessively noisy. If the result
603     // status was 1, assume the command failed normally. In particular, if it
604     // was the compiler then assume it gave a reasonable error code. Failures
605     // in other tools are less common, and they generally have worse
606     // diagnostics, so always print the diagnostic there.
607     const Tool &FailingTool = FailingCommand->getCreator();
608 
609     if (!FailingCommand->getCreator().hasGoodDiagnostics() || Res != 1) {
610       // FIXME: See FIXME above regarding result code interpretation.
611       if (Res < 0)
612         Diag(clang::diag::err_drv_command_signalled)
613           << FailingTool.getShortName();
614       else
615         Diag(clang::diag::err_drv_command_failed)
616           << FailingTool.getShortName() << Res;
617     }
618   }
619   return 0;
620 }
621 
622 void Driver::PrintHelp(bool ShowHidden) const {
623   unsigned IncludedFlagsBitmask;
624   unsigned ExcludedFlagsBitmask;
625   llvm::tie(IncludedFlagsBitmask, ExcludedFlagsBitmask) =
626     getIncludeExcludeOptionFlagMasks();
627 
628   ExcludedFlagsBitmask |= options::NoDriverOption;
629   if (!ShowHidden)
630     ExcludedFlagsBitmask |= HelpHidden;
631 
632   getOpts().PrintHelp(llvm::outs(), Name.c_str(), DriverTitle.c_str(),
633                       IncludedFlagsBitmask, ExcludedFlagsBitmask);
634 }
635 
636 void Driver::PrintVersion(const Compilation &C, raw_ostream &OS) const {
637   // FIXME: The following handlers should use a callback mechanism, we don't
638   // know what the client would like to do.
639   OS << getClangFullVersion() << '\n';
640   const ToolChain &TC = C.getDefaultToolChain();
641   OS << "Target: " << TC.getTripleString() << '\n';
642 
643   // Print the threading model.
644   //
645   // FIXME: Implement correctly.
646   OS << "Thread model: " << "posix" << '\n';
647 }
648 
649 /// PrintDiagnosticCategories - Implement the --print-diagnostic-categories
650 /// option.
651 static void PrintDiagnosticCategories(raw_ostream &OS) {
652   // Skip the empty category.
653   for (unsigned i = 1, max = DiagnosticIDs::getNumberOfCategories();
654        i != max; ++i)
655     OS << i << ',' << DiagnosticIDs::getCategoryNameFromID(i) << '\n';
656 }
657 
658 bool Driver::HandleImmediateArgs(const Compilation &C) {
659   // The order these options are handled in gcc is all over the place, but we
660   // don't expect inconsistencies w.r.t. that to matter in practice.
661 
662   if (C.getArgs().hasArg(options::OPT_dumpmachine)) {
663     llvm::outs() << C.getDefaultToolChain().getTripleString() << '\n';
664     return false;
665   }
666 
667   if (C.getArgs().hasArg(options::OPT_dumpversion)) {
668     // Since -dumpversion is only implemented for pedantic GCC compatibility, we
669     // return an answer which matches our definition of __VERSION__.
670     //
671     // If we want to return a more correct answer some day, then we should
672     // introduce a non-pedantically GCC compatible mode to Clang in which we
673     // provide sensible definitions for -dumpversion, __VERSION__, etc.
674     llvm::outs() << "4.2.1\n";
675     return false;
676   }
677 
678   if (C.getArgs().hasArg(options::OPT__print_diagnostic_categories)) {
679     PrintDiagnosticCategories(llvm::outs());
680     return false;
681   }
682 
683   if (C.getArgs().hasArg(options::OPT_help) ||
684       C.getArgs().hasArg(options::OPT__help_hidden)) {
685     PrintHelp(C.getArgs().hasArg(options::OPT__help_hidden));
686     return false;
687   }
688 
689   if (C.getArgs().hasArg(options::OPT__version)) {
690     // Follow gcc behavior and use stdout for --version and stderr for -v.
691     PrintVersion(C, llvm::outs());
692     return false;
693   }
694 
695   if (C.getArgs().hasArg(options::OPT_v) ||
696       C.getArgs().hasArg(options::OPT__HASH_HASH_HASH)) {
697     PrintVersion(C, llvm::errs());
698     SuppressMissingInputWarning = true;
699   }
700 
701   const ToolChain &TC = C.getDefaultToolChain();
702 
703   if (C.getArgs().hasArg(options::OPT_v))
704     TC.printVerboseInfo(llvm::errs());
705 
706   if (C.getArgs().hasArg(options::OPT_print_search_dirs)) {
707     llvm::outs() << "programs: =";
708     for (ToolChain::path_list::const_iterator it = TC.getProgramPaths().begin(),
709            ie = TC.getProgramPaths().end(); it != ie; ++it) {
710       if (it != TC.getProgramPaths().begin())
711         llvm::outs() << ':';
712       llvm::outs() << *it;
713     }
714     llvm::outs() << "\n";
715     llvm::outs() << "libraries: =" << ResourceDir;
716 
717     StringRef sysroot = C.getSysRoot();
718 
719     for (ToolChain::path_list::const_iterator it = TC.getFilePaths().begin(),
720            ie = TC.getFilePaths().end(); it != ie; ++it) {
721       llvm::outs() << ':';
722       const char *path = it->c_str();
723       if (path[0] == '=')
724         llvm::outs() << sysroot << path + 1;
725       else
726         llvm::outs() << path;
727     }
728     llvm::outs() << "\n";
729     return false;
730   }
731 
732   // FIXME: The following handlers should use a callback mechanism, we don't
733   // know what the client would like to do.
734   if (Arg *A = C.getArgs().getLastArg(options::OPT_print_file_name_EQ)) {
735     llvm::outs() << GetFilePath(A->getValue(), TC) << "\n";
736     return false;
737   }
738 
739   if (Arg *A = C.getArgs().getLastArg(options::OPT_print_prog_name_EQ)) {
740     llvm::outs() << GetProgramPath(A->getValue(), TC) << "\n";
741     return false;
742   }
743 
744   if (C.getArgs().hasArg(options::OPT_print_libgcc_file_name)) {
745     llvm::outs() << GetFilePath("libgcc.a", TC) << "\n";
746     return false;
747   }
748 
749   if (C.getArgs().hasArg(options::OPT_print_multi_lib)) {
750     // FIXME: We need tool chain support for this.
751     llvm::outs() << ".;\n";
752 
753     switch (C.getDefaultToolChain().getTriple().getArch()) {
754     default:
755       break;
756 
757     case llvm::Triple::x86_64:
758       llvm::outs() << "x86_64;@m64" << "\n";
759       break;
760 
761     case llvm::Triple::ppc64:
762       llvm::outs() << "ppc64;@m64" << "\n";
763       break;
764 
765     case llvm::Triple::ppc64le:
766       llvm::outs() << "ppc64le;@m64" << "\n";
767       break;
768     }
769     return false;
770   }
771 
772   // FIXME: What is the difference between print-multi-directory and
773   // print-multi-os-directory?
774   if (C.getArgs().hasArg(options::OPT_print_multi_directory) ||
775       C.getArgs().hasArg(options::OPT_print_multi_os_directory)) {
776     switch (C.getDefaultToolChain().getTriple().getArch()) {
777     default:
778     case llvm::Triple::x86:
779     case llvm::Triple::ppc:
780       llvm::outs() << "." << "\n";
781       break;
782 
783     case llvm::Triple::x86_64:
784       llvm::outs() << "x86_64" << "\n";
785       break;
786 
787     case llvm::Triple::ppc64:
788       llvm::outs() << "ppc64" << "\n";
789       break;
790 
791     case llvm::Triple::ppc64le:
792       llvm::outs() << "ppc64le" << "\n";
793       break;
794     }
795     return false;
796   }
797 
798   return true;
799 }
800 
801 static unsigned PrintActions1(const Compilation &C, Action *A,
802                               std::map<Action*, unsigned> &Ids) {
803   if (Ids.count(A))
804     return Ids[A];
805 
806   std::string str;
807   llvm::raw_string_ostream os(str);
808 
809   os << Action::getClassName(A->getKind()) << ", ";
810   if (InputAction *IA = dyn_cast<InputAction>(A)) {
811     os << "\"" << IA->getInputArg().getValue() << "\"";
812   } else if (BindArchAction *BIA = dyn_cast<BindArchAction>(A)) {
813     os << '"' << BIA->getArchName() << '"'
814        << ", {" << PrintActions1(C, *BIA->begin(), Ids) << "}";
815   } else {
816     os << "{";
817     for (Action::iterator it = A->begin(), ie = A->end(); it != ie;) {
818       os << PrintActions1(C, *it, Ids);
819       ++it;
820       if (it != ie)
821         os << ", ";
822     }
823     os << "}";
824   }
825 
826   unsigned Id = Ids.size();
827   Ids[A] = Id;
828   llvm::errs() << Id << ": " << os.str() << ", "
829                << types::getTypeName(A->getType()) << "\n";
830 
831   return Id;
832 }
833 
834 void Driver::PrintActions(const Compilation &C) const {
835   std::map<Action*, unsigned> Ids;
836   for (ActionList::const_iterator it = C.getActions().begin(),
837          ie = C.getActions().end(); it != ie; ++it)
838     PrintActions1(C, *it, Ids);
839 }
840 
841 /// \brief Check whether the given input tree contains any compilation or
842 /// assembly actions.
843 static bool ContainsCompileOrAssembleAction(const Action *A) {
844   if (isa<CompileJobAction>(A) || isa<AssembleJobAction>(A))
845     return true;
846 
847   for (Action::const_iterator it = A->begin(), ie = A->end(); it != ie; ++it)
848     if (ContainsCompileOrAssembleAction(*it))
849       return true;
850 
851   return false;
852 }
853 
854 void Driver::BuildUniversalActions(const ToolChain &TC,
855                                    DerivedArgList &Args,
856                                    const InputList &BAInputs,
857                                    ActionList &Actions) const {
858   llvm::PrettyStackTraceString CrashInfo("Building universal build actions");
859   // Collect the list of architectures. Duplicates are allowed, but should only
860   // be handled once (in the order seen).
861   llvm::StringSet<> ArchNames;
862   SmallVector<const char *, 4> Archs;
863   for (ArgList::const_iterator it = Args.begin(), ie = Args.end();
864        it != ie; ++it) {
865     Arg *A = *it;
866 
867     if (A->getOption().matches(options::OPT_arch)) {
868       // Validate the option here; we don't save the type here because its
869       // particular spelling may participate in other driver choices.
870       llvm::Triple::ArchType Arch =
871         tools::darwin::getArchTypeForDarwinArchName(A->getValue());
872       if (Arch == llvm::Triple::UnknownArch) {
873         Diag(clang::diag::err_drv_invalid_arch_name)
874           << A->getAsString(Args);
875         continue;
876       }
877 
878       A->claim();
879       if (ArchNames.insert(A->getValue()))
880         Archs.push_back(A->getValue());
881     }
882   }
883 
884   // When there is no explicit arch for this platform, make sure we still bind
885   // the architecture (to the default) so that -Xarch_ is handled correctly.
886   if (!Archs.size())
887     Archs.push_back(Args.MakeArgString(TC.getDefaultUniversalArchName()));
888 
889   ActionList SingleActions;
890   BuildActions(TC, Args, BAInputs, SingleActions);
891 
892   // Add in arch bindings for every top level action, as well as lipo and
893   // dsymutil steps if needed.
894   for (unsigned i = 0, e = SingleActions.size(); i != e; ++i) {
895     Action *Act = SingleActions[i];
896 
897     // Make sure we can lipo this kind of output. If not (and it is an actual
898     // output) then we disallow, since we can't create an output file with the
899     // right name without overwriting it. We could remove this oddity by just
900     // changing the output names to include the arch, which would also fix
901     // -save-temps. Compatibility wins for now.
902 
903     if (Archs.size() > 1 && !types::canLipoType(Act->getType()))
904       Diag(clang::diag::err_drv_invalid_output_with_multiple_archs)
905         << types::getTypeName(Act->getType());
906 
907     ActionList Inputs;
908     for (unsigned i = 0, e = Archs.size(); i != e; ++i) {
909       Inputs.push_back(new BindArchAction(Act, Archs[i]));
910       if (i != 0)
911         Inputs.back()->setOwnsInputs(false);
912     }
913 
914     // Lipo if necessary, we do it this way because we need to set the arch flag
915     // so that -Xarch_ gets overwritten.
916     if (Inputs.size() == 1 || Act->getType() == types::TY_Nothing)
917       Actions.append(Inputs.begin(), Inputs.end());
918     else
919       Actions.push_back(new LipoJobAction(Inputs, Act->getType()));
920 
921     // Handle debug info queries.
922     Arg *A = Args.getLastArg(options::OPT_g_Group);
923     if (A && !A->getOption().matches(options::OPT_g0) &&
924         !A->getOption().matches(options::OPT_gstabs) &&
925         ContainsCompileOrAssembleAction(Actions.back())) {
926 
927       // Add a 'dsymutil' step if necessary, when debug info is enabled and we
928       // have a compile input. We need to run 'dsymutil' ourselves in such cases
929       // because the debug info will refer to a temporary object file which
930       // will be removed at the end of the compilation process.
931       if (Act->getType() == types::TY_Image) {
932         ActionList Inputs;
933         Inputs.push_back(Actions.back());
934         Actions.pop_back();
935         Actions.push_back(new DsymutilJobAction(Inputs, types::TY_dSYM));
936       }
937 
938       // Verify the output (debug information only) if we passed '-verify'.
939       if (Args.hasArg(options::OPT_verify)) {
940         ActionList VerifyInputs;
941         VerifyInputs.push_back(Actions.back());
942         Actions.pop_back();
943         Actions.push_back(new VerifyJobAction(VerifyInputs,
944                                               types::TY_Nothing));
945       }
946     }
947   }
948 }
949 
950 /// \brief Check that the file referenced by Value exists. If it doesn't,
951 /// issue a diagnostic and return false.
952 static bool DiagnoseInputExistance(const Driver &D, const DerivedArgList &Args,
953                                    StringRef Value) {
954   if (!D.getCheckInputsExist())
955     return true;
956 
957   // stdin always exists.
958   if (Value == "-")
959     return true;
960 
961   SmallString<64> Path(Value);
962   if (Arg *WorkDir = Args.getLastArg(options::OPT_working_directory)) {
963     if (!llvm::sys::path::is_absolute(Path.str())) {
964       SmallString<64> Directory(WorkDir->getValue());
965       llvm::sys::path::append(Directory, Value);
966       Path.assign(Directory);
967     }
968   }
969 
970   if (llvm::sys::fs::exists(Twine(Path)))
971     return true;
972 
973   D.Diag(clang::diag::err_drv_no_such_file) << Path.str();
974   return false;
975 }
976 
977 // Construct a the list of inputs and their types.
978 void Driver::BuildInputs(const ToolChain &TC, const DerivedArgList &Args,
979                          InputList &Inputs) const {
980   // Track the current user specified (-x) input. We also explicitly track the
981   // argument used to set the type; we only want to claim the type when we
982   // actually use it, so we warn about unused -x arguments.
983   types::ID InputType = types::TY_Nothing;
984   Arg *InputTypeArg = 0;
985 
986   // The last /TC or /TP option sets the input type to C or C++ globally.
987   if (Arg *TCTP = Args.getLastArg(options::OPT__SLASH_TC,
988                                   options::OPT__SLASH_TP)) {
989     InputTypeArg = TCTP;
990     InputType = TCTP->getOption().matches(options::OPT__SLASH_TC)
991         ? types::TY_C : types::TY_CXX;
992 
993     arg_iterator it = Args.filtered_begin(options::OPT__SLASH_TC,
994                                           options::OPT__SLASH_TP);
995     const arg_iterator ie = Args.filtered_end();
996     Arg *Previous = *it++;
997     bool ShowNote = false;
998     while (it != ie) {
999       Diag(clang::diag::warn_drv_overriding_flag_option)
1000           << Previous->getSpelling() << (*it)->getSpelling();
1001       Previous = *it++;
1002       ShowNote = true;
1003     }
1004     if (ShowNote)
1005       Diag(clang::diag::note_drv_t_option_is_global);
1006 
1007     // No driver mode exposes -x and /TC or /TP; we don't support mixing them.
1008     assert(!Args.hasArg(options::OPT_x) && "-x and /TC or /TP is not allowed");
1009   }
1010 
1011   for (ArgList::const_iterator it = Args.begin(), ie = Args.end();
1012        it != ie; ++it) {
1013     Arg *A = *it;
1014 
1015     if (A->getOption().getKind() == Option::InputClass) {
1016       const char *Value = A->getValue();
1017       types::ID Ty = types::TY_INVALID;
1018 
1019       // Infer the input type if necessary.
1020       if (InputType == types::TY_Nothing) {
1021         // If there was an explicit arg for this, claim it.
1022         if (InputTypeArg)
1023           InputTypeArg->claim();
1024 
1025         // stdin must be handled specially.
1026         if (memcmp(Value, "-", 2) == 0) {
1027           // If running with -E, treat as a C input (this changes the builtin
1028           // macros, for example). This may be overridden by -ObjC below.
1029           //
1030           // Otherwise emit an error but still use a valid type to avoid
1031           // spurious errors (e.g., no inputs).
1032           if (!Args.hasArgNoClaim(options::OPT_E) && !CCCIsCPP())
1033             Diag(clang::diag::err_drv_unknown_stdin_type);
1034           Ty = types::TY_C;
1035         } else {
1036           // Otherwise lookup by extension.
1037           // Fallback is C if invoked as C preprocessor or Object otherwise.
1038           // We use a host hook here because Darwin at least has its own
1039           // idea of what .s is.
1040           if (const char *Ext = strrchr(Value, '.'))
1041             Ty = TC.LookupTypeForExtension(Ext + 1);
1042 
1043           if (Ty == types::TY_INVALID) {
1044             if (CCCIsCPP())
1045               Ty = types::TY_C;
1046             else
1047               Ty = types::TY_Object;
1048           }
1049 
1050           // If the driver is invoked as C++ compiler (like clang++ or c++) it
1051           // should autodetect some input files as C++ for g++ compatibility.
1052           if (CCCIsCXX()) {
1053             types::ID OldTy = Ty;
1054             Ty = types::lookupCXXTypeForCType(Ty);
1055 
1056             if (Ty != OldTy)
1057               Diag(clang::diag::warn_drv_treating_input_as_cxx)
1058                 << getTypeName(OldTy) << getTypeName(Ty);
1059           }
1060         }
1061 
1062         // -ObjC and -ObjC++ override the default language, but only for "source
1063         // files". We just treat everything that isn't a linker input as a
1064         // source file.
1065         //
1066         // FIXME: Clean this up if we move the phase sequence into the type.
1067         if (Ty != types::TY_Object) {
1068           if (Args.hasArg(options::OPT_ObjC))
1069             Ty = types::TY_ObjC;
1070           else if (Args.hasArg(options::OPT_ObjCXX))
1071             Ty = types::TY_ObjCXX;
1072         }
1073       } else {
1074         assert(InputTypeArg && "InputType set w/o InputTypeArg");
1075         InputTypeArg->claim();
1076         Ty = InputType;
1077       }
1078 
1079       if (DiagnoseInputExistance(*this, Args, Value))
1080         Inputs.push_back(std::make_pair(Ty, A));
1081 
1082     } else if (A->getOption().matches(options::OPT__SLASH_Tc)) {
1083       StringRef Value = A->getValue();
1084       if (DiagnoseInputExistance(*this, Args, Value)) {
1085         Arg *InputArg = MakeInputArg(Args, Opts, A->getValue());
1086         Inputs.push_back(std::make_pair(types::TY_C, InputArg));
1087       }
1088       A->claim();
1089     } else if (A->getOption().matches(options::OPT__SLASH_Tp)) {
1090       StringRef Value = A->getValue();
1091       if (DiagnoseInputExistance(*this, Args, Value)) {
1092         Arg *InputArg = MakeInputArg(Args, Opts, A->getValue());
1093         Inputs.push_back(std::make_pair(types::TY_CXX, InputArg));
1094       }
1095       A->claim();
1096     } else if (A->getOption().hasFlag(options::LinkerInput)) {
1097       // Just treat as object type, we could make a special type for this if
1098       // necessary.
1099       Inputs.push_back(std::make_pair(types::TY_Object, A));
1100 
1101     } else if (A->getOption().matches(options::OPT_x)) {
1102       InputTypeArg = A;
1103       InputType = types::lookupTypeForTypeSpecifier(A->getValue());
1104       A->claim();
1105 
1106       // Follow gcc behavior and treat as linker input for invalid -x
1107       // options. Its not clear why we shouldn't just revert to unknown; but
1108       // this isn't very important, we might as well be bug compatible.
1109       if (!InputType) {
1110         Diag(clang::diag::err_drv_unknown_language) << A->getValue();
1111         InputType = types::TY_Object;
1112       }
1113     }
1114   }
1115   if (CCCIsCPP() && Inputs.empty()) {
1116     // If called as standalone preprocessor, stdin is processed
1117     // if no other input is present.
1118     Arg *A = MakeInputArg(Args, Opts, "-");
1119     Inputs.push_back(std::make_pair(types::TY_C, A));
1120   }
1121 }
1122 
1123 void Driver::BuildActions(const ToolChain &TC, DerivedArgList &Args,
1124                           const InputList &Inputs, ActionList &Actions) const {
1125   llvm::PrettyStackTraceString CrashInfo("Building compilation actions");
1126 
1127   if (!SuppressMissingInputWarning && Inputs.empty()) {
1128     Diag(clang::diag::err_drv_no_input_files);
1129     return;
1130   }
1131 
1132   Arg *FinalPhaseArg;
1133   phases::ID FinalPhase = getFinalPhase(Args, &FinalPhaseArg);
1134 
1135   if (FinalPhase == phases::Link && Args.hasArg(options::OPT_emit_llvm)) {
1136     Diag(clang::diag::err_drv_emit_llvm_link);
1137   }
1138 
1139   // Reject -Z* at the top level, these options should never have been exposed
1140   // by gcc.
1141   if (Arg *A = Args.getLastArg(options::OPT_Z_Joined))
1142     Diag(clang::diag::err_drv_use_of_Z_option) << A->getAsString(Args);
1143 
1144   // Diagnose misuse of /Fo.
1145   if (Arg *A = Args.getLastArg(options::OPT__SLASH_Fo)) {
1146     StringRef V = A->getValue();
1147     if (V.empty()) {
1148       // It has to have a value.
1149       Diag(clang::diag::err_drv_missing_argument) << A->getSpelling() << 1;
1150       Args.eraseArg(options::OPT__SLASH_Fo);
1151     } else if (Inputs.size() > 1 && !llvm::sys::path::is_separator(V.back())) {
1152       // Check whether /Fo tries to name an output file for multiple inputs.
1153       Diag(clang::diag::err_drv_out_file_argument_with_multiple_sources)
1154         << A->getSpelling() << V;
1155       Args.eraseArg(options::OPT__SLASH_Fo);
1156     }
1157   }
1158 
1159   // Diagnose misuse of /Fa.
1160   if (Arg *A = Args.getLastArg(options::OPT__SLASH_Fa)) {
1161     StringRef V = A->getValue();
1162     if (Inputs.size() > 1 && !llvm::sys::path::is_separator(V.back())) {
1163       // Check whether /Fa tries to name an asm file for multiple inputs.
1164       Diag(clang::diag::err_drv_out_file_argument_with_multiple_sources)
1165         << A->getSpelling() << V;
1166       Args.eraseArg(options::OPT__SLASH_Fa);
1167     }
1168   }
1169 
1170   // Diagnose misuse of /Fe.
1171   if (Arg *A = Args.getLastArg(options::OPT__SLASH_Fe)) {
1172     if (A->getValue()[0] == '\0') {
1173       // It has to have a value.
1174       Diag(clang::diag::err_drv_missing_argument) << A->getSpelling() << 1;
1175       Args.eraseArg(options::OPT__SLASH_Fe);
1176     }
1177   }
1178 
1179   // Construct the actions to perform.
1180   ActionList LinkerInputs;
1181   ActionList SplitInputs;
1182   llvm::SmallVector<phases::ID, phases::MaxNumberOfPhases> PL;
1183   for (unsigned i = 0, e = Inputs.size(); i != e; ++i) {
1184     types::ID InputType = Inputs[i].first;
1185     const Arg *InputArg = Inputs[i].second;
1186 
1187     PL.clear();
1188     types::getCompilationPhases(InputType, PL);
1189 
1190     // If the first step comes after the final phase we are doing as part of
1191     // this compilation, warn the user about it.
1192     phases::ID InitialPhase = PL[0];
1193     if (InitialPhase > FinalPhase) {
1194       // Claim here to avoid the more general unused warning.
1195       InputArg->claim();
1196 
1197       // Suppress all unused style warnings with -Qunused-arguments
1198       if (Args.hasArg(options::OPT_Qunused_arguments))
1199         continue;
1200 
1201       // Special case when final phase determined by binary name, rather than
1202       // by a command-line argument with a corresponding Arg.
1203       if (CCCIsCPP())
1204         Diag(clang::diag::warn_drv_input_file_unused_by_cpp)
1205           << InputArg->getAsString(Args)
1206           << getPhaseName(InitialPhase);
1207       // Special case '-E' warning on a previously preprocessed file to make
1208       // more sense.
1209       else if (InitialPhase == phases::Compile &&
1210                FinalPhase == phases::Preprocess &&
1211                getPreprocessedType(InputType) == types::TY_INVALID)
1212         Diag(clang::diag::warn_drv_preprocessed_input_file_unused)
1213           << InputArg->getAsString(Args)
1214           << !!FinalPhaseArg
1215           << FinalPhaseArg ? FinalPhaseArg->getOption().getName() : "";
1216       else
1217         Diag(clang::diag::warn_drv_input_file_unused)
1218           << InputArg->getAsString(Args)
1219           << getPhaseName(InitialPhase)
1220           << !!FinalPhaseArg
1221           << FinalPhaseArg ? FinalPhaseArg->getOption().getName() : "";
1222       continue;
1223     }
1224 
1225     // Build the pipeline for this file.
1226     OwningPtr<Action> Current(new InputAction(*InputArg, InputType));
1227     for (SmallVectorImpl<phases::ID>::iterator
1228            i = PL.begin(), e = PL.end(); i != e; ++i) {
1229       phases::ID Phase = *i;
1230 
1231       // We are done if this step is past what the user requested.
1232       if (Phase > FinalPhase)
1233         break;
1234 
1235       // Queue linker inputs.
1236       if (Phase == phases::Link) {
1237         assert((i + 1) == e && "linking must be final compilation step.");
1238         LinkerInputs.push_back(Current.take());
1239         break;
1240       }
1241 
1242       // Some types skip the assembler phase (e.g., llvm-bc), but we can't
1243       // encode this in the steps because the intermediate type depends on
1244       // arguments. Just special case here.
1245       if (Phase == phases::Assemble && Current->getType() != types::TY_PP_Asm)
1246         continue;
1247 
1248       // Otherwise construct the appropriate action.
1249       Current.reset(ConstructPhaseAction(Args, Phase, Current.take()));
1250       if (Current->getType() == types::TY_Nothing)
1251         break;
1252     }
1253 
1254     // If we ended with something, add to the output list.
1255     if (Current)
1256       Actions.push_back(Current.take());
1257   }
1258 
1259   // Add a link action if necessary.
1260   if (!LinkerInputs.empty())
1261     Actions.push_back(new LinkJobAction(LinkerInputs, types::TY_Image));
1262 
1263   // If we are linking, claim any options which are obviously only used for
1264   // compilation.
1265   if (FinalPhase == phases::Link && PL.size() == 1) {
1266     Args.ClaimAllArgs(options::OPT_CompileOnly_Group);
1267     Args.ClaimAllArgs(options::OPT_cl_compile_Group);
1268   }
1269 
1270   // Claim ignored clang-cl options.
1271   Args.ClaimAllArgs(options::OPT_cl_ignored_Group);
1272 }
1273 
1274 Action *Driver::ConstructPhaseAction(const ArgList &Args, phases::ID Phase,
1275                                      Action *Input) const {
1276   llvm::PrettyStackTraceString CrashInfo("Constructing phase actions");
1277   // Build the appropriate action.
1278   switch (Phase) {
1279   case phases::Link: llvm_unreachable("link action invalid here.");
1280   case phases::Preprocess: {
1281     types::ID OutputTy;
1282     // -{M, MM} alter the output type.
1283     if (Args.hasArg(options::OPT_M, options::OPT_MM)) {
1284       OutputTy = types::TY_Dependencies;
1285     } else {
1286       OutputTy = Input->getType();
1287       if (!Args.hasFlag(options::OPT_frewrite_includes,
1288                         options::OPT_fno_rewrite_includes, false))
1289         OutputTy = types::getPreprocessedType(OutputTy);
1290       assert(OutputTy != types::TY_INVALID &&
1291              "Cannot preprocess this input type!");
1292     }
1293     return new PreprocessJobAction(Input, OutputTy);
1294   }
1295   case phases::Precompile: {
1296     types::ID OutputTy = types::TY_PCH;
1297     if (Args.hasArg(options::OPT_fsyntax_only)) {
1298       // Syntax checks should not emit a PCH file
1299       OutputTy = types::TY_Nothing;
1300     }
1301     return new PrecompileJobAction(Input, OutputTy);
1302   }
1303   case phases::Compile: {
1304     if (Args.hasArg(options::OPT_fsyntax_only)) {
1305       return new CompileJobAction(Input, types::TY_Nothing);
1306     } else if (Args.hasArg(options::OPT_rewrite_objc)) {
1307       return new CompileJobAction(Input, types::TY_RewrittenObjC);
1308     } else if (Args.hasArg(options::OPT_rewrite_legacy_objc)) {
1309       return new CompileJobAction(Input, types::TY_RewrittenLegacyObjC);
1310     } else if (Args.hasArg(options::OPT__analyze, options::OPT__analyze_auto)) {
1311       return new AnalyzeJobAction(Input, types::TY_Plist);
1312     } else if (Args.hasArg(options::OPT__migrate)) {
1313       return new MigrateJobAction(Input, types::TY_Remap);
1314     } else if (Args.hasArg(options::OPT_emit_ast)) {
1315       return new CompileJobAction(Input, types::TY_AST);
1316     } else if (Args.hasArg(options::OPT_module_file_info)) {
1317       return new CompileJobAction(Input, types::TY_ModuleFile);
1318     } else if (IsUsingLTO(Args)) {
1319       types::ID Output =
1320         Args.hasArg(options::OPT_S) ? types::TY_LTO_IR : types::TY_LTO_BC;
1321       return new CompileJobAction(Input, Output);
1322     } else if (Args.hasArg(options::OPT_emit_llvm)) {
1323       types::ID Output =
1324         Args.hasArg(options::OPT_S) ? types::TY_LLVM_IR : types::TY_LLVM_BC;
1325       return new CompileJobAction(Input, Output);
1326     } else {
1327       return new CompileJobAction(Input, types::TY_PP_Asm);
1328     }
1329   }
1330   case phases::Assemble:
1331     return new AssembleJobAction(Input, types::TY_Object);
1332   }
1333 
1334   llvm_unreachable("invalid phase in ConstructPhaseAction");
1335 }
1336 
1337 bool Driver::IsUsingLTO(const ArgList &Args) const {
1338   if (Args.hasFlag(options::OPT_flto, options::OPT_fno_lto, false))
1339     return true;
1340 
1341   return false;
1342 }
1343 
1344 void Driver::BuildJobs(Compilation &C) const {
1345   llvm::PrettyStackTraceString CrashInfo("Building compilation jobs");
1346 
1347   Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o);
1348 
1349   // It is an error to provide a -o option if we are making multiple output
1350   // files.
1351   if (FinalOutput) {
1352     unsigned NumOutputs = 0;
1353     for (ActionList::const_iterator it = C.getActions().begin(),
1354            ie = C.getActions().end(); it != ie; ++it)
1355       if ((*it)->getType() != types::TY_Nothing)
1356         ++NumOutputs;
1357 
1358     if (NumOutputs > 1) {
1359       Diag(clang::diag::err_drv_output_argument_with_multiple_files);
1360       FinalOutput = 0;
1361     }
1362   }
1363 
1364   // Collect the list of architectures.
1365   llvm::StringSet<> ArchNames;
1366   if (C.getDefaultToolChain().getTriple().isOSDarwin()) {
1367     for (ArgList::const_iterator it = C.getArgs().begin(), ie = C.getArgs().end();
1368          it != ie; ++it) {
1369       Arg *A = *it;
1370       if (A->getOption().matches(options::OPT_arch))
1371         ArchNames.insert(A->getValue());
1372     }
1373   }
1374 
1375   for (ActionList::const_iterator it = C.getActions().begin(),
1376          ie = C.getActions().end(); it != ie; ++it) {
1377     Action *A = *it;
1378 
1379     // If we are linking an image for multiple archs then the linker wants
1380     // -arch_multiple and -final_output <final image name>. Unfortunately, this
1381     // doesn't fit in cleanly because we have to pass this information down.
1382     //
1383     // FIXME: This is a hack; find a cleaner way to integrate this into the
1384     // process.
1385     const char *LinkingOutput = 0;
1386     if (isa<LipoJobAction>(A)) {
1387       if (FinalOutput)
1388         LinkingOutput = FinalOutput->getValue();
1389       else
1390         LinkingOutput = DefaultImageName.c_str();
1391     }
1392 
1393     InputInfo II;
1394     BuildJobsForAction(C, A, &C.getDefaultToolChain(),
1395                        /*BoundArch*/0,
1396                        /*AtTopLevel*/ true,
1397                        /*MultipleArchs*/ ArchNames.size() > 1,
1398                        /*LinkingOutput*/ LinkingOutput,
1399                        II);
1400   }
1401 
1402   // If the user passed -Qunused-arguments or there were errors, don't warn
1403   // about any unused arguments.
1404   if (Diags.hasErrorOccurred() ||
1405       C.getArgs().hasArg(options::OPT_Qunused_arguments))
1406     return;
1407 
1408   // Claim -### here.
1409   (void) C.getArgs().hasArg(options::OPT__HASH_HASH_HASH);
1410 
1411   // Claim --driver-mode, it was handled earlier.
1412   (void) C.getArgs().hasArg(options::OPT_driver_mode);
1413 
1414   for (ArgList::const_iterator it = C.getArgs().begin(), ie = C.getArgs().end();
1415        it != ie; ++it) {
1416     Arg *A = *it;
1417 
1418     // FIXME: It would be nice to be able to send the argument to the
1419     // DiagnosticsEngine, so that extra values, position, and so on could be
1420     // printed.
1421     if (!A->isClaimed()) {
1422       if (A->getOption().hasFlag(options::NoArgumentUnused))
1423         continue;
1424 
1425       // Suppress the warning automatically if this is just a flag, and it is an
1426       // instance of an argument we already claimed.
1427       const Option &Opt = A->getOption();
1428       if (Opt.getKind() == Option::FlagClass) {
1429         bool DuplicateClaimed = false;
1430 
1431         for (arg_iterator it = C.getArgs().filtered_begin(&Opt),
1432                ie = C.getArgs().filtered_end(); it != ie; ++it) {
1433           if ((*it)->isClaimed()) {
1434             DuplicateClaimed = true;
1435             break;
1436           }
1437         }
1438 
1439         if (DuplicateClaimed)
1440           continue;
1441       }
1442 
1443       Diag(clang::diag::warn_drv_unused_argument)
1444         << A->getAsString(C.getArgs());
1445     }
1446   }
1447 }
1448 
1449 static const Tool *SelectToolForJob(Compilation &C, const ToolChain *TC,
1450                                     const JobAction *JA,
1451                                     const ActionList *&Inputs) {
1452   const Tool *ToolForJob = 0;
1453 
1454   // See if we should look for a compiler with an integrated assembler. We match
1455   // bottom up, so what we are actually looking for is an assembler job with a
1456   // compiler input.
1457 
1458   if (TC->useIntegratedAs() &&
1459       !C.getArgs().hasArg(options::OPT_save_temps) &&
1460       !C.getArgs().hasArg(options::OPT__SLASH_FA) &&
1461       !C.getArgs().hasArg(options::OPT__SLASH_Fa) &&
1462       isa<AssembleJobAction>(JA) &&
1463       Inputs->size() == 1 && isa<CompileJobAction>(*Inputs->begin())) {
1464     const Tool *Compiler =
1465       TC->SelectTool(cast<JobAction>(**Inputs->begin()));
1466     if (!Compiler)
1467       return NULL;
1468     if (Compiler->hasIntegratedAssembler()) {
1469       Inputs = &(*Inputs)[0]->getInputs();
1470       ToolForJob = Compiler;
1471     }
1472   }
1473 
1474   // Otherwise use the tool for the current job.
1475   if (!ToolForJob)
1476     ToolForJob = TC->SelectTool(*JA);
1477 
1478   // See if we should use an integrated preprocessor. We do so when we have
1479   // exactly one input, since this is the only use case we care about
1480   // (irrelevant since we don't support combine yet).
1481   if (Inputs->size() == 1 && isa<PreprocessJobAction>(*Inputs->begin()) &&
1482       !C.getArgs().hasArg(options::OPT_no_integrated_cpp) &&
1483       !C.getArgs().hasArg(options::OPT_traditional_cpp) &&
1484       !C.getArgs().hasArg(options::OPT_save_temps) &&
1485       !C.getArgs().hasArg(options::OPT_rewrite_objc) &&
1486       ToolForJob->hasIntegratedCPP())
1487     Inputs = &(*Inputs)[0]->getInputs();
1488 
1489   return ToolForJob;
1490 }
1491 
1492 void Driver::BuildJobsForAction(Compilation &C,
1493                                 const Action *A,
1494                                 const ToolChain *TC,
1495                                 const char *BoundArch,
1496                                 bool AtTopLevel,
1497                                 bool MultipleArchs,
1498                                 const char *LinkingOutput,
1499                                 InputInfo &Result) const {
1500   llvm::PrettyStackTraceString CrashInfo("Building compilation jobs");
1501 
1502   if (const InputAction *IA = dyn_cast<InputAction>(A)) {
1503     // FIXME: It would be nice to not claim this here; maybe the old scheme of
1504     // just using Args was better?
1505     const Arg &Input = IA->getInputArg();
1506     Input.claim();
1507     if (Input.getOption().matches(options::OPT_INPUT)) {
1508       const char *Name = Input.getValue();
1509       Result = InputInfo(Name, A->getType(), Name);
1510     } else
1511       Result = InputInfo(&Input, A->getType(), "");
1512     return;
1513   }
1514 
1515   if (const BindArchAction *BAA = dyn_cast<BindArchAction>(A)) {
1516     const ToolChain *TC;
1517     const char *ArchName = BAA->getArchName();
1518 
1519     if (ArchName)
1520       TC = &getToolChain(C.getArgs(), ArchName);
1521     else
1522       TC = &C.getDefaultToolChain();
1523 
1524     BuildJobsForAction(C, *BAA->begin(), TC, BAA->getArchName(),
1525                        AtTopLevel, MultipleArchs, LinkingOutput, Result);
1526     return;
1527   }
1528 
1529   const ActionList *Inputs = &A->getInputs();
1530 
1531   const JobAction *JA = cast<JobAction>(A);
1532   const Tool *T = SelectToolForJob(C, TC, JA, Inputs);
1533   if (!T)
1534     return;
1535 
1536   // Only use pipes when there is exactly one input.
1537   InputInfoList InputInfos;
1538   for (ActionList::const_iterator it = Inputs->begin(), ie = Inputs->end();
1539        it != ie; ++it) {
1540     // Treat dsymutil and verify sub-jobs as being at the top-level too, they
1541     // shouldn't get temporary output names.
1542     // FIXME: Clean this up.
1543     bool SubJobAtTopLevel = false;
1544     if (AtTopLevel && (isa<DsymutilJobAction>(A) || isa<VerifyJobAction>(A)))
1545       SubJobAtTopLevel = true;
1546 
1547     InputInfo II;
1548     BuildJobsForAction(C, *it, TC, BoundArch, SubJobAtTopLevel, MultipleArchs,
1549                        LinkingOutput, II);
1550     InputInfos.push_back(II);
1551   }
1552 
1553   // Always use the first input as the base input.
1554   const char *BaseInput = InputInfos[0].getBaseInput();
1555 
1556   // ... except dsymutil actions, which use their actual input as the base
1557   // input.
1558   if (JA->getType() == types::TY_dSYM)
1559     BaseInput = InputInfos[0].getFilename();
1560 
1561   // Determine the place to write output to, if any.
1562   if (JA->getType() == types::TY_Nothing)
1563     Result = InputInfo(A->getType(), BaseInput);
1564   else
1565     Result = InputInfo(GetNamedOutputPath(C, *JA, BaseInput, BoundArch,
1566                                           AtTopLevel, MultipleArchs),
1567                        A->getType(), BaseInput);
1568 
1569   if (CCCPrintBindings && !CCGenDiagnostics) {
1570     llvm::errs() << "# \"" << T->getToolChain().getTripleString() << '"'
1571                  << " - \"" << T->getName() << "\", inputs: [";
1572     for (unsigned i = 0, e = InputInfos.size(); i != e; ++i) {
1573       llvm::errs() << InputInfos[i].getAsString();
1574       if (i + 1 != e)
1575         llvm::errs() << ", ";
1576     }
1577     llvm::errs() << "], output: " << Result.getAsString() << "\n";
1578   } else {
1579     T->ConstructJob(C, *JA, Result, InputInfos,
1580                     C.getArgsForToolChain(TC, BoundArch), LinkingOutput);
1581   }
1582 }
1583 
1584 /// \brief Create output filename based on ArgValue, which could either be a
1585 /// full filename, filename without extension, or a directory. If ArgValue
1586 /// does not provide a filename, then use BaseName, and use the extension
1587 /// suitable for FileType.
1588 static const char *MakeCLOutputFilename(const ArgList &Args, StringRef ArgValue,
1589                                         StringRef BaseName, types::ID FileType) {
1590   SmallString<128> Filename = ArgValue;
1591 
1592   if (ArgValue.empty()) {
1593     // If the argument is empty, output to BaseName in the current dir.
1594     Filename = BaseName;
1595   } else if (llvm::sys::path::is_separator(Filename.back())) {
1596     // If the argument is a directory, output to BaseName in that dir.
1597     llvm::sys::path::append(Filename, BaseName);
1598   }
1599 
1600   if (!llvm::sys::path::has_extension(ArgValue)) {
1601     // If the argument didn't provide an extension, then set it.
1602     const char *Extension = types::getTypeTempSuffix(FileType, true);
1603 
1604     if (FileType == types::TY_Image &&
1605         Args.hasArg(options::OPT__SLASH_LD, options::OPT__SLASH_LDd)) {
1606       // The output file is a dll.
1607       Extension = "dll";
1608     }
1609 
1610     llvm::sys::path::replace_extension(Filename, Extension);
1611   }
1612 
1613   return Args.MakeArgString(Filename.c_str());
1614 }
1615 
1616 const char *Driver::GetNamedOutputPath(Compilation &C,
1617                                        const JobAction &JA,
1618                                        const char *BaseInput,
1619                                        const char *BoundArch,
1620                                        bool AtTopLevel,
1621                                        bool MultipleArchs) const {
1622   llvm::PrettyStackTraceString CrashInfo("Computing output path");
1623   // Output to a user requested destination?
1624   if (AtTopLevel && !isa<DsymutilJobAction>(JA) &&
1625       !isa<VerifyJobAction>(JA)) {
1626     if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o))
1627       return C.addResultFile(FinalOutput->getValue(), &JA);
1628   }
1629 
1630   // Default to writing to stdout?
1631   if (AtTopLevel && !CCGenDiagnostics &&
1632       (isa<PreprocessJobAction>(JA) || JA.getType() == types::TY_ModuleFile))
1633     return "-";
1634 
1635   // Is this the assembly listing for /FA?
1636   if (JA.getType() == types::TY_PP_Asm &&
1637       (C.getArgs().hasArg(options::OPT__SLASH_FA) ||
1638        C.getArgs().hasArg(options::OPT__SLASH_Fa))) {
1639     // Use /Fa and the input filename to determine the asm file name.
1640     StringRef BaseName = llvm::sys::path::filename(BaseInput);
1641     StringRef FaValue = C.getArgs().getLastArgValue(options::OPT__SLASH_Fa);
1642     return C.addResultFile(MakeCLOutputFilename(C.getArgs(), FaValue, BaseName,
1643                                                 JA.getType()), &JA);
1644   }
1645 
1646   // Output to a temporary file?
1647   if ((!AtTopLevel && !C.getArgs().hasArg(options::OPT_save_temps) &&
1648         !C.getArgs().hasArg(options::OPT__SLASH_Fo)) ||
1649       CCGenDiagnostics) {
1650     StringRef Name = llvm::sys::path::filename(BaseInput);
1651     std::pair<StringRef, StringRef> Split = Name.split('.');
1652     std::string TmpName =
1653       GetTemporaryPath(Split.first,
1654           types::getTypeTempSuffix(JA.getType(), IsCLMode()));
1655     return C.addTempFile(C.getArgs().MakeArgString(TmpName.c_str()));
1656   }
1657 
1658   SmallString<128> BasePath(BaseInput);
1659   StringRef BaseName;
1660 
1661   // Dsymutil actions should use the full path.
1662   if (isa<DsymutilJobAction>(JA) || isa<VerifyJobAction>(JA))
1663     BaseName = BasePath;
1664   else
1665     BaseName = llvm::sys::path::filename(BasePath);
1666 
1667   // Determine what the derived output name should be.
1668   const char *NamedOutput;
1669 
1670   if (JA.getType() == types::TY_Object &&
1671       C.getArgs().hasArg(options::OPT__SLASH_Fo)) {
1672     // The /Fo flag decides the object filename.
1673     StringRef Val = C.getArgs().getLastArg(options::OPT__SLASH_Fo)->getValue();
1674     NamedOutput = MakeCLOutputFilename(C.getArgs(), Val, BaseName,
1675                                        types::TY_Object);
1676   } else if (JA.getType() == types::TY_Image &&
1677              C.getArgs().hasArg(options::OPT__SLASH_Fe)) {
1678     // The /Fe flag names the linked file.
1679     StringRef Val = C.getArgs().getLastArg(options::OPT__SLASH_Fe)->getValue();
1680     NamedOutput = MakeCLOutputFilename(C.getArgs(), Val, BaseName,
1681                                        types::TY_Image);
1682   } else if (JA.getType() == types::TY_Image) {
1683     if (IsCLMode()) {
1684       // clang-cl uses BaseName for the executable name.
1685       NamedOutput = MakeCLOutputFilename(C.getArgs(), "", BaseName,
1686                                          types::TY_Image);
1687     } else if (MultipleArchs && BoundArch) {
1688       SmallString<128> Output(DefaultImageName.c_str());
1689       Output += "-";
1690       Output.append(BoundArch);
1691       NamedOutput = C.getArgs().MakeArgString(Output.c_str());
1692     } else
1693       NamedOutput = DefaultImageName.c_str();
1694   } else {
1695     const char *Suffix = types::getTypeTempSuffix(JA.getType(), IsCLMode());
1696     assert(Suffix && "All types used for output should have a suffix.");
1697 
1698     std::string::size_type End = std::string::npos;
1699     if (!types::appendSuffixForType(JA.getType()))
1700       End = BaseName.rfind('.');
1701     SmallString<128> Suffixed(BaseName.substr(0, End));
1702     if (MultipleArchs && BoundArch) {
1703       Suffixed += "-";
1704       Suffixed.append(BoundArch);
1705     }
1706     Suffixed += '.';
1707     Suffixed += Suffix;
1708     NamedOutput = C.getArgs().MakeArgString(Suffixed.c_str());
1709   }
1710 
1711   // If we're saving temps and the temp file conflicts with the input file,
1712   // then avoid overwriting input file.
1713   if (!AtTopLevel && C.getArgs().hasArg(options::OPT_save_temps) &&
1714       NamedOutput == BaseName) {
1715 
1716     bool SameFile = false;
1717     SmallString<256> Result;
1718     llvm::sys::fs::current_path(Result);
1719     llvm::sys::path::append(Result, BaseName);
1720     llvm::sys::fs::equivalent(BaseInput, Result.c_str(), SameFile);
1721     // Must share the same path to conflict.
1722     if (SameFile) {
1723       StringRef Name = llvm::sys::path::filename(BaseInput);
1724       std::pair<StringRef, StringRef> Split = Name.split('.');
1725       std::string TmpName =
1726         GetTemporaryPath(Split.first,
1727             types::getTypeTempSuffix(JA.getType(), IsCLMode()));
1728       return C.addTempFile(C.getArgs().MakeArgString(TmpName.c_str()));
1729     }
1730   }
1731 
1732   // As an annoying special case, PCH generation doesn't strip the pathname.
1733   if (JA.getType() == types::TY_PCH) {
1734     llvm::sys::path::remove_filename(BasePath);
1735     if (BasePath.empty())
1736       BasePath = NamedOutput;
1737     else
1738       llvm::sys::path::append(BasePath, NamedOutput);
1739     return C.addResultFile(C.getArgs().MakeArgString(BasePath.c_str()), &JA);
1740   } else {
1741     return C.addResultFile(NamedOutput, &JA);
1742   }
1743 }
1744 
1745 std::string Driver::GetFilePath(const char *Name, const ToolChain &TC) const {
1746   // Respect a limited subset of the '-Bprefix' functionality in GCC by
1747   // attempting to use this prefix when looking for file paths.
1748   for (Driver::prefix_list::const_iterator it = PrefixDirs.begin(),
1749        ie = PrefixDirs.end(); it != ie; ++it) {
1750     std::string Dir(*it);
1751     if (Dir.empty())
1752       continue;
1753     if (Dir[0] == '=')
1754       Dir = SysRoot + Dir.substr(1);
1755     SmallString<128> P(Dir);
1756     llvm::sys::path::append(P, Name);
1757     if (llvm::sys::fs::exists(Twine(P)))
1758       return P.str();
1759   }
1760 
1761   SmallString<128> P(ResourceDir);
1762   llvm::sys::path::append(P, Name);
1763   if (llvm::sys::fs::exists(Twine(P)))
1764     return P.str();
1765 
1766   const ToolChain::path_list &List = TC.getFilePaths();
1767   for (ToolChain::path_list::const_iterator
1768          it = List.begin(), ie = List.end(); it != ie; ++it) {
1769     std::string Dir(*it);
1770     if (Dir.empty())
1771       continue;
1772     if (Dir[0] == '=')
1773       Dir = SysRoot + Dir.substr(1);
1774     SmallString<128> P(Dir);
1775     llvm::sys::path::append(P, Name);
1776     if (llvm::sys::fs::exists(Twine(P)))
1777       return P.str();
1778   }
1779 
1780   return Name;
1781 }
1782 
1783 std::string Driver::GetProgramPath(const char *Name,
1784                                    const ToolChain &TC) const {
1785   // FIXME: Needs a better variable than DefaultTargetTriple
1786   std::string TargetSpecificExecutable(DefaultTargetTriple + "-" + Name);
1787   // Respect a limited subset of the '-Bprefix' functionality in GCC by
1788   // attempting to use this prefix when looking for program paths.
1789   for (Driver::prefix_list::const_iterator it = PrefixDirs.begin(),
1790        ie = PrefixDirs.end(); it != ie; ++it) {
1791     if (llvm::sys::fs::is_directory(*it)) {
1792       SmallString<128> P(*it);
1793       llvm::sys::path::append(P, TargetSpecificExecutable);
1794       if (llvm::sys::fs::can_execute(Twine(P)))
1795         return P.str();
1796       llvm::sys::path::remove_filename(P);
1797       llvm::sys::path::append(P, Name);
1798       if (llvm::sys::fs::can_execute(Twine(P)))
1799         return P.str();
1800     } else {
1801       SmallString<128> P(*it + Name);
1802       if (llvm::sys::fs::can_execute(Twine(P)))
1803         return P.str();
1804     }
1805   }
1806 
1807   const ToolChain::path_list &List = TC.getProgramPaths();
1808   for (ToolChain::path_list::const_iterator
1809          it = List.begin(), ie = List.end(); it != ie; ++it) {
1810     SmallString<128> P(*it);
1811     llvm::sys::path::append(P, TargetSpecificExecutable);
1812     if (llvm::sys::fs::can_execute(Twine(P)))
1813       return P.str();
1814     llvm::sys::path::remove_filename(P);
1815     llvm::sys::path::append(P, Name);
1816     if (llvm::sys::fs::can_execute(Twine(P)))
1817       return P.str();
1818   }
1819 
1820   // If all else failed, search the path.
1821   std::string P(llvm::sys::FindProgramByName(TargetSpecificExecutable));
1822   if (!P.empty())
1823     return P;
1824 
1825   P = llvm::sys::FindProgramByName(Name);
1826   if (!P.empty())
1827     return P;
1828 
1829   return Name;
1830 }
1831 
1832 std::string Driver::GetTemporaryPath(StringRef Prefix, const char *Suffix)
1833   const {
1834   SmallString<128> Path;
1835   llvm::error_code EC =
1836       llvm::sys::fs::createTemporaryFile(Prefix, Suffix, Path);
1837   if (EC) {
1838     Diag(clang::diag::err_unable_to_make_temp) << EC.message();
1839     return "";
1840   }
1841 
1842   return Path.str();
1843 }
1844 
1845 /// \brief Compute target triple from args.
1846 ///
1847 /// This routine provides the logic to compute a target triple from various
1848 /// args passed to the driver and the default triple string.
1849 static llvm::Triple computeTargetTriple(StringRef DefaultTargetTriple,
1850                                         const ArgList &Args,
1851                                         StringRef DarwinArchName) {
1852   // FIXME: Already done in Compilation *Driver::BuildCompilation
1853   if (const Arg *A = Args.getLastArg(options::OPT_target))
1854     DefaultTargetTriple = A->getValue();
1855 
1856   llvm::Triple Target(llvm::Triple::normalize(DefaultTargetTriple));
1857 
1858   // Handle Darwin-specific options available here.
1859   if (Target.isOSDarwin()) {
1860     // If an explict Darwin arch name is given, that trumps all.
1861     if (!DarwinArchName.empty()) {
1862       Target.setArch(
1863         tools::darwin::getArchTypeForDarwinArchName(DarwinArchName));
1864       return Target;
1865     }
1866 
1867     // Handle the Darwin '-arch' flag.
1868     if (Arg *A = Args.getLastArg(options::OPT_arch)) {
1869       llvm::Triple::ArchType DarwinArch
1870         = tools::darwin::getArchTypeForDarwinArchName(A->getValue());
1871       if (DarwinArch != llvm::Triple::UnknownArch)
1872         Target.setArch(DarwinArch);
1873     }
1874   }
1875 
1876   // Handle pseudo-target flags '-EL' and '-EB'.
1877   if (Arg *A = Args.getLastArg(options::OPT_EL, options::OPT_EB)) {
1878     if (A->getOption().matches(options::OPT_EL)) {
1879       if (Target.getArch() == llvm::Triple::mips)
1880         Target.setArch(llvm::Triple::mipsel);
1881       else if (Target.getArch() == llvm::Triple::mips64)
1882         Target.setArch(llvm::Triple::mips64el);
1883     } else {
1884       if (Target.getArch() == llvm::Triple::mipsel)
1885         Target.setArch(llvm::Triple::mips);
1886       else if (Target.getArch() == llvm::Triple::mips64el)
1887         Target.setArch(llvm::Triple::mips64);
1888     }
1889   }
1890 
1891   // Skip further flag support on OSes which don't support '-m32' or '-m64'.
1892   if (Target.getArchName() == "tce" ||
1893       Target.getOS() == llvm::Triple::AuroraUX ||
1894       Target.getOS() == llvm::Triple::Minix)
1895     return Target;
1896 
1897   // Handle pseudo-target flags '-m32' and '-m64'.
1898   // FIXME: Should this information be in llvm::Triple?
1899   if (Arg *A = Args.getLastArg(options::OPT_m32, options::OPT_m64)) {
1900     if (A->getOption().matches(options::OPT_m32)) {
1901       if (Target.getArch() == llvm::Triple::x86_64)
1902         Target.setArch(llvm::Triple::x86);
1903       if (Target.getArch() == llvm::Triple::ppc64)
1904         Target.setArch(llvm::Triple::ppc);
1905     } else {
1906       if (Target.getArch() == llvm::Triple::x86)
1907         Target.setArch(llvm::Triple::x86_64);
1908       if (Target.getArch() == llvm::Triple::ppc)
1909         Target.setArch(llvm::Triple::ppc64);
1910     }
1911   }
1912 
1913   return Target;
1914 }
1915 
1916 const ToolChain &Driver::getToolChain(const ArgList &Args,
1917                                       StringRef DarwinArchName) const {
1918   llvm::Triple Target = computeTargetTriple(DefaultTargetTriple, Args,
1919                                             DarwinArchName);
1920 
1921   ToolChain *&TC = ToolChains[Target.str()];
1922   if (!TC) {
1923     switch (Target.getOS()) {
1924     case llvm::Triple::AuroraUX:
1925       TC = new toolchains::AuroraUX(*this, Target, Args);
1926       break;
1927     case llvm::Triple::Darwin:
1928     case llvm::Triple::MacOSX:
1929     case llvm::Triple::IOS:
1930       if (Target.getArch() == llvm::Triple::x86 ||
1931           Target.getArch() == llvm::Triple::x86_64 ||
1932           Target.getArch() == llvm::Triple::arm ||
1933           Target.getArch() == llvm::Triple::thumb)
1934         TC = new toolchains::DarwinClang(*this, Target, Args);
1935       else
1936         TC = new toolchains::Darwin_Generic_GCC(*this, Target, Args);
1937       break;
1938     case llvm::Triple::DragonFly:
1939       TC = new toolchains::DragonFly(*this, Target, Args);
1940       break;
1941     case llvm::Triple::OpenBSD:
1942       TC = new toolchains::OpenBSD(*this, Target, Args);
1943       break;
1944     case llvm::Triple::Bitrig:
1945       TC = new toolchains::Bitrig(*this, Target, Args);
1946       break;
1947     case llvm::Triple::NetBSD:
1948       TC = new toolchains::NetBSD(*this, Target, Args);
1949       break;
1950     case llvm::Triple::FreeBSD:
1951       TC = new toolchains::FreeBSD(*this, Target, Args);
1952       break;
1953     case llvm::Triple::Minix:
1954       TC = new toolchains::Minix(*this, Target, Args);
1955       break;
1956     case llvm::Triple::Linux:
1957       if (Target.getArch() == llvm::Triple::hexagon)
1958         TC = new toolchains::Hexagon_TC(*this, Target, Args);
1959       else
1960         TC = new toolchains::Linux(*this, Target, Args);
1961       break;
1962     case llvm::Triple::Solaris:
1963       TC = new toolchains::Solaris(*this, Target, Args);
1964       break;
1965     case llvm::Triple::Win32:
1966       TC = new toolchains::Windows(*this, Target, Args);
1967       break;
1968     case llvm::Triple::MinGW32:
1969       // FIXME: We need a MinGW toolchain. Fallthrough for now.
1970     default:
1971       // TCE is an OSless target
1972       if (Target.getArchName() == "tce") {
1973         TC = new toolchains::TCEToolChain(*this, Target, Args);
1974         break;
1975       }
1976       // If Hexagon is configured as an OSless target
1977       if (Target.getArch() == llvm::Triple::hexagon) {
1978         TC = new toolchains::Hexagon_TC(*this, Target, Args);
1979         break;
1980       }
1981       if (Target.getArch() == llvm::Triple::xcore) {
1982         TC = new toolchains::XCore(*this, Target, Args);
1983         break;
1984       }
1985       TC = new toolchains::Generic_GCC(*this, Target, Args);
1986       break;
1987     }
1988   }
1989   return *TC;
1990 }
1991 
1992 bool Driver::ShouldUseClangCompiler(const JobAction &JA) const {
1993   // Check if user requested no clang, or clang doesn't understand this type (we
1994   // only handle single inputs for now).
1995   if (JA.size() != 1 ||
1996       !types::isAcceptedByClang((*JA.begin())->getType()))
1997     return false;
1998 
1999   // Otherwise make sure this is an action clang understands.
2000   if (!isa<PreprocessJobAction>(JA) && !isa<PrecompileJobAction>(JA) &&
2001       !isa<CompileJobAction>(JA))
2002     return false;
2003 
2004   return true;
2005 }
2006 
2007 /// GetReleaseVersion - Parse (([0-9]+)(.([0-9]+)(.([0-9]+)?))?)? and return the
2008 /// grouped values as integers. Numbers which are not provided are set to 0.
2009 ///
2010 /// \return True if the entire string was parsed (9.2), or all groups were
2011 /// parsed (10.3.5extrastuff).
2012 bool Driver::GetReleaseVersion(const char *Str, unsigned &Major,
2013                                unsigned &Minor, unsigned &Micro,
2014                                bool &HadExtra) {
2015   HadExtra = false;
2016 
2017   Major = Minor = Micro = 0;
2018   if (*Str == '\0')
2019     return true;
2020 
2021   char *End;
2022   Major = (unsigned) strtol(Str, &End, 10);
2023   if (*Str != '\0' && *End == '\0')
2024     return true;
2025   if (*End != '.')
2026     return false;
2027 
2028   Str = End+1;
2029   Minor = (unsigned) strtol(Str, &End, 10);
2030   if (*Str != '\0' && *End == '\0')
2031     return true;
2032   if (*End != '.')
2033     return false;
2034 
2035   Str = End+1;
2036   Micro = (unsigned) strtol(Str, &End, 10);
2037   if (*Str != '\0' && *End == '\0')
2038     return true;
2039   if (Str == End)
2040     return false;
2041   HadExtra = true;
2042   return true;
2043 }
2044 
2045 std::pair<unsigned, unsigned> Driver::getIncludeExcludeOptionFlagMasks() const {
2046   unsigned IncludedFlagsBitmask = 0;
2047   unsigned ExcludedFlagsBitmask = options::NoDriverOption;
2048 
2049   if (Mode == CLMode) {
2050     // Include CL and Core options.
2051     IncludedFlagsBitmask |= options::CLOption;
2052     IncludedFlagsBitmask |= options::CoreOption;
2053   } else {
2054     ExcludedFlagsBitmask |= options::CLOption;
2055   }
2056 
2057   return std::make_pair(IncludedFlagsBitmask, ExcludedFlagsBitmask);
2058 }
2059 
2060 const SanitizerArgs &
2061 Driver::getOrParseSanitizerArgs(const ArgList &Args) const {
2062   if (!SanitizerArguments.get())
2063     SanitizerArguments.reset(new SanitizerArgs(*this, Args));
2064   return *SanitizerArguments.get();
2065 }
2066