Windows/Path.inc: Introduce file_type::character_file and file_type::fifo_file in...
authorNAKAMURA Takumi <geek4civic@gmail.com>
Thu, 18 Jul 2013 17:00:54 +0000 (17:00 +0000)
committerNAKAMURA Takumi <geek4civic@gmail.com>
Thu, 18 Jul 2013 17:00:54 +0000 (17:00 +0000)
It fixes llvm/test/Other/close-stderr.ll on msys.

FIXME: Provide unittests.
llvm-svn: 186588

llvm/lib/Support/Windows/Path.inc
llvm/test/Other/close-stderr.ll

index 0eb0759..5d95142 100644 (file)
@@ -579,6 +579,19 @@ static error_code getStatus(HANDLE FileHandle, file_status &Result) {
   if (FileHandle == INVALID_HANDLE_VALUE)
     goto handle_status_error;
 
+  switch (::GetFileType(FileHandle)) {
+  default:
+  case FILE_TYPE_UNKNOWN:
+  case FILE_TYPE_DISK:
+    break;
+  case FILE_TYPE_CHAR:
+    Result = file_status(file_type::character_file);
+    return error_code::success();
+  case FILE_TYPE_PIPE:
+    Result = file_status(file_type::fifo_file);
+    return error_code::success();
+  }
+
   BY_HANDLE_FILE_INFORMATION Info;
   if (!::GetFileInformationByHandle(FileHandle, &Info))
     goto handle_status_error;
index 007ab0e..6e180cd 100644 (file)
@@ -9,9 +9,6 @@
 ; XFAIL: vg_leak
 ; REQUIRES: shell
 
-; FIXME: sys::fs::status() doesn't work on pipes, since r186560.
-; XFAIL: mingw32
-
 ; opt will fail to open /dev/null on native win32.
 ; XFAIL: win32