Use getFileStatus instead of Path::isDirectory().
authorChris Lattner <sabre@nondot.org>
Tue, 1 Aug 2006 17:59:14 +0000 (17:59 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 1 Aug 2006 17:59:14 +0000 (17:59 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29443 91177308-0d34-0410-b5e6-96231b3b80d8

lib/System/Unix/Signals.inc
lib/System/Win32/Signals.inc

index 4096ad27273b91cdbd86186350f5fbecd5df9447..05b9abf8a30ab9811bb83f59c6863b0415bb7457 100644 (file)
@@ -21,6 +21,7 @@
 #if HAVE_SIGNAL_H
 #include <signal.h>
 #endif
+using namespace llvm;
 
 namespace {
 
@@ -30,7 +31,7 @@ bool StackTraceRequested = false;
 void (*InterruptFunction)() = 0;
 
 std::vector<std::string> *FilesToRemove = 0 ;
-std::vector<llvm::sys::Path> *DirectoriesToRemove = 0;
+std::vector<sys::Path> *DirectoriesToRemove = 0;
 
 // IntSigs - Signals that may interrupt the program at any time.
 const int IntSigs[] = {
@@ -146,7 +147,6 @@ void RegisterHandler(int Signal) {
 
 }
 
-namespace llvm {
 
 void sys::SetInterruptFunction(void (*IF)()) {
   InterruptFunction = IF;
@@ -165,8 +165,10 @@ void sys::RemoveFileOnSignal(const sys::Path &Filename) {
 }
 
 // RemoveDirectoryOnSignal - The public API
-void sys::RemoveDirectoryOnSignal(const llvm::sys::Path& path) {
-  if (!path.isDirectory())
+void sys::RemoveDirectoryOnSignal(const sys::Path& path) {
+  // Not a directory?
+  sys::FileStatus Status;
+  if (path.getFileStatus(Status) || !Status.isDir)
     return;
 
   if (DirectoriesToRemove == 0)
@@ -184,6 +186,3 @@ void sys::PrintStackTraceOnErrorSignal() {
   StackTraceRequested = true;
   std::for_each(KillSigs, KillSigsEnd, RegisterHandler);
 }
-
-}
-
index a44c034ba1d9334533214157406c884db8ff3822..c2bfb01b386c2269d5a0497cc0013baa0a819308 100644 (file)
@@ -96,17 +96,19 @@ void sys::RemoveFileOnSignal(const sys::Path &Filename) {
 
 // RemoveDirectoryOnSignal - The public API
 void sys::RemoveDirectoryOnSignal(const sys::Path& path) {
+  // Not a directory?
+  sys::FileStatus Status;
+  if (path.getFileStatus(Status) || !Status.isDir)
+    return;
+
   RegisterHandler();
 
   if (CleanupExecuted)
     throw std::string("Process terminating -- cannot register for removal");
 
-  if (path.isDirectory()) {
-    if (DirectoriesToRemove == NULL)
-      DirectoriesToRemove = new std::vector<sys::Path>;
-
-    DirectoriesToRemove->push_back(path);
-  }
+  if (DirectoriesToRemove == NULL)
+    DirectoriesToRemove = new std::vector<sys::Path>;
+  DirectoriesToRemove->push_back(path);
 
   LeaveCriticalSection(&CriticalSection);
 }