Revert r234615, "Have one raw_fd_ostream constructor forward to the other."
authorNAKAMURA Takumi <geek4civic@gmail.com>
Mon, 13 Apr 2015 04:54:19 +0000 (04:54 +0000)
committerNAKAMURA Takumi <geek4civic@gmail.com>
Mon, 13 Apr 2015 04:54:19 +0000 (04:54 +0000)
It broke MSVCRT hosts:

  LLVM :: Object/check_binary_output.ll
  LLVM :: Object/extract.ll

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

lib/Support/raw_ostream.cpp

index 199f0a6185b26fbee36bc5e3a7663023a2e3358b..37e892e68641fbc65be01e3ec7b520be9ec43b57 100644 (file)
@@ -487,41 +487,47 @@ void format_object_base::home() {
 //  raw_fd_ostream
 //===----------------------------------------------------------------------===//
 
 //  raw_fd_ostream
 //===----------------------------------------------------------------------===//
 
-static int getFD(StringRef Filename, std::error_code &EC,
-                 sys::fs::OpenFlags Flags) {
+raw_fd_ostream::raw_fd_ostream(StringRef Filename, std::error_code &EC,
+                               sys::fs::OpenFlags Flags)
+    : Error(false), UseAtomicWrites(false), pos(0) {
+  EC = std::error_code();
   // Handle "-" as stdout. Note that when we do this, we consider ourself
   // the owner of stdout. This means that we can do things like close the
   // file descriptor when we're done and set the "binary" flag globally.
   if (Filename == "-") {
   // Handle "-" as stdout. Note that when we do this, we consider ourself
   // the owner of stdout. This means that we can do things like close the
   // file descriptor when we're done and set the "binary" flag globally.
   if (Filename == "-") {
-    EC = std::error_code();
+    FD = STDOUT_FILENO;
     // If user requested binary then put stdout into binary mode if
     // possible.
     if (!(Flags & sys::fs::F_Text))
       sys::ChangeStdoutToBinary();
     // If user requested binary then put stdout into binary mode if
     // possible.
     if (!(Flags & sys::fs::F_Text))
       sys::ChangeStdoutToBinary();
-    return STDOUT_FILENO;
+    // Close stdout when we're done, to detect any output errors.
+    ShouldClose = true;
+    return;
   }
 
   }
 
-  int FD;
   EC = sys::fs::openFileForWrite(Filename, FD, Flags);
   EC = sys::fs::openFileForWrite(Filename, FD, Flags);
-  if (EC)
-    return -1;
 
 
-  return FD;
-}
+  if (EC) {
+    ShouldClose = false;
+    return;
+  }
 
 
-raw_fd_ostream::raw_fd_ostream(StringRef Filename, std::error_code &EC,
-                               sys::fs::OpenFlags Flags)
-    : raw_fd_ostream(getFD(Filename, EC, Flags), true) {}
+  // Ok, we successfully opened the file, so it'll need to be closed.
+  ShouldClose = true;
+}
 
 /// FD is the file descriptor that this writes to.  If ShouldClose is true, this
 /// closes the file when the stream is destroyed.
 raw_fd_ostream::raw_fd_ostream(int fd, bool shouldClose, bool unbuffered)
 
 /// FD is the file descriptor that this writes to.  If ShouldClose is true, this
 /// closes the file when the stream is destroyed.
 raw_fd_ostream::raw_fd_ostream(int fd, bool shouldClose, bool unbuffered)
-  : raw_ostream(unbuffered), FD(fd),
-    ShouldClose(shouldClose), Error(false), UseAtomicWrites(false) {
-  if (FD < 0 ) {
-    ShouldClose = false;
-    return;
-  }
+    : raw_ostream(unbuffered), FD(fd), ShouldClose(shouldClose), Error(false),
+      UseAtomicWrites(false) {
+#ifdef O_BINARY
+  // Setting STDOUT to binary mode is necessary in Win32
+  // to avoid undesirable linefeed conversion.
+  // Don't touch STDERR, or w*printf() (in assert()) would barf wide chars.
+  if (fd == STDOUT_FILENO)
+    setmode(fd, O_BINARY);
+#endif
 
   // Get the starting position.
   off_t loc = ::lseek(FD, 0, SEEK_CUR);
 
   // Get the starting position.
   off_t loc = ::lseek(FD, 0, SEEK_CUR);