Tweak MemoryBuffer::getSTDIN so that it returns after the first EOF.
authorEli Friedman <eli.friedman@gmail.com>
Mon, 18 May 2009 08:44:04 +0000 (08:44 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Mon, 18 May 2009 08:44:04 +0000 (08:44 +0000)
It doesn't matter for piped input, but it's annoying when typing at the
console.

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

lib/Support/MemoryBuffer.cpp

index a4963d92fb65f7e0a539fdd0a1d773128d3fa2c7..e35c626c4086e45521ca40dbc69539383ec8e0a1 100644 (file)
@@ -258,13 +258,16 @@ public:
 
 MemoryBuffer *MemoryBuffer::getSTDIN() {
   char Buffer[4096*4];
-  
+
   std::vector<char> FileData;
-  
+
   // Read in all of the data from stdin, we cannot mmap stdin.
   sys::Program::ChangeStdinToBinary();
-  while (size_t ReadBytes = fread(Buffer, sizeof(char), 4096*4, stdin))
+  size_t ReadBytes;
+  do {
+    ReadBytes = fread(Buffer, sizeof(char), sizeof(Buffer), stdin);
     FileData.insert(FileData.end(), Buffer, Buffer+ReadBytes);
+  } while (ReadBytes == sizeof(Buffer));
 
   FileData.push_back(0); // &FileData[Size] is invalid. So is &*FileData.end().
   size_t Size = FileData.size();