Driver: Add -ccc-print-bindings option (for testing); the Python
driver has no corresponding option.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67125 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/Driver/Driver.cpp b/lib/Driver/Driver.cpp
index c2df48c..5f29195 100644
--- a/lib/Driver/Driver.cpp
+++ b/lib/Driver/Driver.cpp
@@ -40,7 +40,7 @@
Name(_Name), Dir(_Dir), DefaultHostTriple(_DefaultHostTriple),
DefaultImageName(_DefaultImageName),
Host(0),
- CCCIsCXX(false), CCCEcho(false),
+ CCCIsCXX(false), CCCEcho(false), CCCPrintBindings(false),
CCCNoClang(false), CCCNoClangCXX(false), CCCNoClangCPP(false),
SuppressMissingInputWarning(false)
{
@@ -114,6 +114,8 @@
CCCPrintOptions = true;
} else if (!strcmp(Opt, "print-phases")) {
CCCPrintActions = true;
+ } else if (!strcmp(Opt, "print-bindings")) {
+ CCCPrintBindings = true;
} else if (!strcmp(Opt, "cxx")) {
CCCIsCXX = true;
} else if (!strcmp(Opt, "echo")) {
@@ -729,27 +731,32 @@
// 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) {
- ;
+ Result = InputInfo(A->getType(), BaseInput);
} 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;
+ PipedJob *PJ = dyn_cast<PipedJob>(Dest);
+ if (!PJ) {
+ PJ = new PipedJob();
+ cast<JobList>(Dest)->addJob(PJ);
}
+ Result = InputInfo(PJ, A->getType(), BaseInput);
} else {
- Output = GetNamedOutputPath(C, *JA, BaseInput, AtTopLevel);
+ Result = InputInfo(GetNamedOutputPath(C, *JA, BaseInput, AtTopLevel),
+ A->getType(), BaseInput);
}
- // FIXME: Make the job.
-
- Result = InputInfo(Output, A->getType(), BaseInput);
+ if (CCCPrintBindings) {
+ llvm::errs() << "bind - \"" << T.getName() << "\", inputs: [";
+ for (unsigned i = 0, e = InputInfos.size(); i != e; ++i) {
+ llvm::errs() << InputInfos[i].getAsString();
+ if (i + 1 != e)
+ llvm::errs() << ", ";
+ }
+ llvm::errs() << "], output: " << Result.getAsString() << "\n";
+ } else {
+ assert(0 && "FIXME: Make the job.");
+ }
}
const char *Driver::GetNamedOutputPath(Compilation &C,