diff options
author | Chris Lattner <sabre@nondot.org> | 2007-11-18 18:52:28 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-11-18 18:52:28 +0000 |
commit | 44158478bb5818ed7e7aad0b0eb98dfc7ff74b39 (patch) | |
tree | f62267d409994552193977eae24aeea3a66f8a85 | |
parent | b01e500f163f646b54d6f56115e9b1f6469f9229 (diff) | |
download | bcm5719-llvm-44158478bb5818ed7e7aad0b0eb98dfc7ff74b39.tar.gz bcm5719-llvm-44158478bb5818ed7e7aad0b0eb98dfc7ff74b39.zip |
Fix the Linker testcase regressions, by making MemoryBuffer::getFileOrSTDIN return
a valid but empty buffer if stdin is empty.
llvm-svn: 44219
-rw-r--r-- | llvm/include/llvm/Support/MemoryBuffer.h | 9 | ||||
-rw-r--r-- | llvm/lib/Support/MemoryBuffer.cpp | 18 |
2 files changed, 21 insertions, 6 deletions
diff --git a/llvm/include/llvm/Support/MemoryBuffer.h b/llvm/include/llvm/Support/MemoryBuffer.h index aa13bfc65a8..cfef6b1c6cf 100644 --- a/llvm/include/llvm/Support/MemoryBuffer.h +++ b/llvm/include/llvm/Support/MemoryBuffer.h @@ -88,14 +88,11 @@ public: /// getFileOrSTDIN - Open the specified file as a MemoryBuffer, or open stdin /// if the Filename is "-". If an error occurs, this returns null and fills - /// in *ErrStr with a reason. + /// in *ErrStr with a reason. If stdin is empty, this API (unlike getSTDIN) + /// returns an empty buffer. static MemoryBuffer *getFileOrSTDIN(const char *FilenameStart,unsigned FnSize, std::string *ErrStr = 0, - int64_t FileSize = -1) { - if (FnSize == 1 && FilenameStart[0] == '-') - return getSTDIN(); - return getFile(FilenameStart, FnSize, ErrStr, FileSize); - } + int64_t FileSize = -1); /// getFileOrSTDIN - Open the specified file as a MemoryBuffer, or open stdin /// if the Filename is "-". If an error occurs, this returns null and fills diff --git a/llvm/lib/Support/MemoryBuffer.cpp b/llvm/lib/Support/MemoryBuffer.cpp index f8779e122d5..20003777941 100644 --- a/llvm/lib/Support/MemoryBuffer.cpp +++ b/llvm/lib/Support/MemoryBuffer.cpp @@ -117,6 +117,24 @@ MemoryBuffer *MemoryBuffer::getNewMemBuffer(unsigned Size, } +/// getFileOrSTDIN - Open the specified file as a MemoryBuffer, or open stdin +/// if the Filename is "-". If an error occurs, this returns null and fills +/// in *ErrStr with a reason. If stdin is empty, this API (unlike getSTDIN) +/// returns an empty buffer. +MemoryBuffer *MemoryBuffer::getFileOrSTDIN(const char *FilenameStart, + unsigned FnSize, + std::string *ErrStr, + int64_t FileSize) { + if (FnSize != 1 || FilenameStart[0] != '-') + return getFile(FilenameStart, FnSize, ErrStr, FileSize); + MemoryBuffer *M = getSTDIN(); + if (M) return M; + + // If stdin was empty, M is null. Cons up an empty memory buffer now. + const char *EmptyStr = ""; + return MemoryBuffer::getMemBuffer(EmptyStr, EmptyStr, "<stdin>"); +} + //===----------------------------------------------------------------------===// // MemoryBufferMMapFile implementation. //===----------------------------------------------------------------------===// |