Make sure we only use the output file as a base for debug splitting
authorEric Christopher <echristo@gmail.com>
Fri, 22 Feb 2013 01:33:46 +0000 (01:33 +0000)
committerEric Christopher <echristo@gmail.com>
Fri, 22 Feb 2013 01:33:46 +0000 (01:33 +0000)
if we're compiling.

llvm-svn: 175851

clang/lib/Driver/Tools.cpp
clang/test/Driver/split-debug.c

index e830bdc..ebbabcf 100644 (file)
@@ -1723,7 +1723,7 @@ void Clang::SplitDebugInfo(Compilation &C, const JobAction &JA,
   // Add an output for the extract.
   Arg *FinalOutput = C.getArgs().getLastArg(options::OPT_o);
   const char *OutFile;
-  if (FinalOutput) {
+  if (FinalOutput && C.getArgs().hasArg(options::OPT_c)) {
     SmallString<128> T(FinalOutput->getValue());
     llvm::sys::path::replace_extension(T, "dwo");
     OutFile = Args.MakeArgString(T);
index fb01953..5c77e6e 100644 (file)
@@ -12,3 +12,9 @@
 // RUN: FileCheck -check-prefix=CHECK-NO-ACTIONS < %t %s
 //
 // CHECK-NO-ACTIONS-NOT: -split-dwarf
+
+
+// RUN: %clang -target x86_64-unknown-linux-gnu -gsplit-dwarf -o Bad.x -### %s 2> %t
+// RUN: FileCheck -check-prefix=CHECK-BAD < %t %s
+//
+// CHECK-BAD-NOT: "Bad.dwo"