[Driver] Don't remove non-regular files that were outputs.
authorDaniel Dunbar <daniel@zuster.org>
Wed, 23 Jan 2013 01:08:23 +0000 (01:08 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Wed, 23 Jan 2013 01:08:23 +0000 (01:08 +0000)
llvm-svn: 173215

clang/lib/Driver/Compilation.cpp
clang/test/Driver/output-file-is-dir.c [new file with mode: 0644]

index f550a27..9c7100f 100644 (file)
@@ -210,9 +210,9 @@ bool Compilation::CleanupFileList(const ArgStringList &Files,
     std::string Error;
 
     // Don't try to remove files which we don't have write access to (but may be
-    // able to remove). Underlying tools may have intentionally not overwritten
-    // them.
-    if (!P.canWrite())
+    // able to remove), or non-regular files. Underlying tools may have
+    // intentionally not overwritten them.
+    if (!P.canWrite() || !P.isRegularFile())
       continue;
 
     if (P.eraseFromDisk(false, &Error)) {
diff --git a/clang/test/Driver/output-file-is-dir.c b/clang/test/Driver/output-file-is-dir.c
new file mode 100644 (file)
index 0000000..50f4cf9
--- /dev/null
@@ -0,0 +1,6 @@
+// RUN: rm -rf %t.dir
+// RUN: mkdir -p %t.dir/a.out
+// RUN: cd %t.dir && not %clang %s
+// RUN: test -d %t.dir/a.out
+
+int main() { return 0; }