Driver: Forcibly disable pipe support until we can execute them, the
authorDaniel Dunbar <daniel@zuster.org>
Wed, 18 Mar 2009 23:18:19 +0000 (23:18 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Wed, 18 Mar 2009 23:18:19 +0000 (23:18 +0000)
driver is functional without them.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67254 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Driver/Driver.cpp

index d1db63650c1eb0af7d8e8ac2325ce72eaf3d6483..b147bb3a415d60e0a098f23931901aabb6f401bb 100644 (file)
@@ -608,6 +608,11 @@ void Driver::BuildJobs(Compilation &C) const {
   llvm::PrettyStackTraceString CrashInfo("Building compilation jobs");
   bool SaveTemps = C.getArgs().hasArg(options::OPT_save_temps);
   bool UsePipes = C.getArgs().hasArg(options::OPT_pipe);
+
+  // FIXME: Pipes are forcibly disabled until we support executing
+  // them.
+  if (!CCCPrintBindings)
+    UsePipes = false;
   
   // -save-temps inhibits pipes.
   if (SaveTemps && UsePipes) {
@@ -684,6 +689,13 @@ void Driver::BuildJobsForAction(Compilation &C,
                                 const char *LinkingOutput,
                                 InputInfo &Result) const {
   llvm::PrettyStackTraceString CrashInfo("Building compilation jobs for action");
+
+  bool UsePipes = C.getArgs().hasArg(options::OPT_pipe);
+  // FIXME: Pipes are forcibly disabled until we support executing
+  // them.
+  if (!CCCPrintBindings)
+    UsePipes = false;
+
   if (const InputAction *IA = dyn_cast<InputAction>(A)) {
     // FIXME: This is broken, linker inputs won't work here.
     assert(isa<PositionalArg>(IA->getInputArg()) && "FIXME: Linker inputs");
@@ -749,7 +761,7 @@ void Driver::BuildJobsForAction(Compilation &C,
     if (AtTopLevel) {
       if (isa<PreprocessJobAction>(A) && !C.getArgs().hasArg(options::OPT_o))
         OutputToPipe = true;
-    } else if (C.getArgs().hasArg(options::OPT_pipe))
+    } else if (UsePipes)
       OutputToPipe = true;
   }