diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-03-17 17:53:55 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-03-17 17:53:55 +0000 |
commit | 7a178a40a1e360b61068df8526bd6897ed53c7fb (patch) | |
tree | 4d83e00ec56fbd9dedf77e83cb214d129c9f4acf | |
parent | 106c22b2bb46e6d58924d1c2b6a929f9b23a7a4c (diff) | |
download | bcm5719-llvm-7a178a40a1e360b61068df8526bd6897ed53c7fb.tar.gz bcm5719-llvm-7a178a40a1e360b61068df8526bd6897ed53c7fb.zip |
Driver: Add logic for computing where to put job outputs (pipe,
temporary file, user provided name, derived name).
llvm-svn: 67088
-rw-r--r-- | clang/include/clang/Driver/Driver.h | 15 | ||||
-rw-r--r-- | clang/lib/Driver/Driver.cpp | 73 |
2 files changed, 87 insertions, 1 deletions
diff --git a/clang/include/clang/Driver/Driver.h b/clang/include/clang/Driver/Driver.h index 679259c925e..7bc83ae5007 100644 --- a/clang/include/clang/Driver/Driver.h +++ b/clang/include/clang/Driver/Driver.h @@ -28,6 +28,7 @@ namespace driver { class Compilation; class HostInfo; class InputInfo; + class JobAction; class OptTable; class PipedJob; class ToolChain; @@ -203,6 +204,20 @@ public: const char *LinkingOutput, InputInfo &Result) const; + /// GetNamedOutputPath - Return the name to use for the output of + /// the action \arg JA. The result is appended to the compilation's + /// list of temporary or result files, as appropriate. + /// + /// \param C - The compilation. + /// \param JA - The action of interest. + /// \param BaseInput - The original input file that this action was + /// triggered by. + /// \param AtTopLevel - Whether this is a "top-level" action. + const char *GetNamedOutputPath(Compilation &C, + const JobAction &JA, + const char *BaseInput, + bool AtTopLevel) const; + /// GetHostInfo - Construct a new host info object for the given /// host triple. static HostInfo *GetHostInfo(const char *HostTriple); diff --git a/clang/lib/Driver/Driver.cpp b/clang/lib/Driver/Driver.cpp index 980512285da..726823b48c1 100644 --- a/clang/lib/Driver/Driver.cpp +++ b/clang/lib/Driver/Driver.cpp @@ -717,18 +717,89 @@ void Driver::BuildJobsForAction(Compilation &C, // Figure out where to put the job (pipes). Job *Dest = &C.getJobs(); if (InputInfos[0].isPipe()) { + assert(TryToUsePipeInput && "Unrequested pipe!"); assert(InputInfos.size() == 1 && "Unexpected pipe with multiple inputs."); Dest = &InputInfos[0].getPipe(); } // Always use the first input as the base input. const char *BaseInput = InputInfos[0].getBaseInput(); - const char *Output = "foo"; + + // Determine the place to write output to (nothing, pipe, or + // filename) and where to put the new job. + PipedJob *OutputJob = 0; + const char *Output = 0; + if (JA->getType() == types::TY_Nothing) { + ; + } else if (OutputToPipe) { + // Append to current piped job or create a new one as appropriate. + if (PipedJob *PJ = dyn_cast<PipedJob>(Dest)) { + OutputJob = PJ; + Dest = OutputJob; + } else { + OutputJob = new PipedJob(); + cast<JobList>(Dest)->addJob(OutputJob); + Dest = OutputJob; + } + } else { + Output = GetNamedOutputPath(C, *JA, BaseInput, AtTopLevel); + } + // FIXME: Make the job. Result = InputInfo(Output, A->getType(), BaseInput); } +const char *Driver::GetNamedOutputPath(Compilation &C, + const JobAction &JA, + const char *BaseInput, + bool AtTopLevel) const { + // Output to a user requested destination? + if (AtTopLevel) { + if (Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o)) + return C.addResultFile(FinalOutput->getValue(C.getArgs())); + } + + // Output to a temporary file? + if (!AtTopLevel && !C.getArgs().hasArg(options::OPT_save_temps)) { + // FIXME: Get temporary name. + std::string Name("/tmp/foo"); + Name += '.'; + Name += types::getTypeTempSuffix(JA.getType()); + return C.addTempFile(C.getArgs().MakeArgString(Name.c_str())); + } + + llvm::sys::Path BasePath(BaseInput); + std::string BaseName(BasePath.getBasename()); + + // Determine what the derived output name should be. + const char *NamedOutput; + if (JA.getType() == types::TY_Image) { + NamedOutput = DefaultImageName.c_str(); + } else { + const char *Suffix = types::getTypeTempSuffix(JA.getType()); + assert(Suffix && "All types used for output should have a suffix."); + + std::string::size_type End = std::string::npos; + if (!types::appendSuffixForType(JA.getType())) + End = BaseName.rfind('.'); + std::string Suffixed(BaseName.substr(0, End)); + Suffixed += '.'; + Suffixed += Suffix; + NamedOutput = C.getArgs().MakeArgString(Suffixed.c_str()); + } + + // As an annoying special case, PCH generation doesn't strip the + // pathname. + if (JA.getType() == types::TY_PCH) { + BasePath.eraseComponent(); + BasePath.appendComponent(NamedOutput); + return C.addResultFile(C.getArgs().MakeArgString(BasePath.c_str())); + } else { + return C.addResultFile(NamedOutput); + } +} + llvm::sys::Path Driver::GetFilePath(const char *Name, const ToolChain *TC) const { // FIXME: Implement. |