diff options
| author | Rafael Espindola <rafael.espindola@gmail.com> | 2013-07-17 14:58:25 +0000 |
|---|---|---|
| committer | Rafael Espindola <rafael.espindola@gmail.com> | 2013-07-17 14:58:25 +0000 |
| commit | a0d9b6b69322b27fae1c646271b5d4cc44a7bce5 (patch) | |
| tree | b9800e9a52d1c9eb5727d2db575463f25071a81c /llvm/lib/Support | |
| parent | ec7cd269680336be3eb0a99e1752bba05eb07d38 (diff) | |
| download | bcm5719-llvm-a0d9b6b69322b27fae1c646271b5d4cc44a7bce5.tar.gz bcm5719-llvm-a0d9b6b69322b27fae1c646271b5d4cc44a7bce5.zip | |
Split openFileForRead into Windows and Unix versions.
This has some advantages:
* Lets us use native, utf16 windows functions.
* Easy to produce good errors on windows about trying to use a
directory when we want a file.
* Simplifies the unix version a bit.
llvm-svn: 186511
Diffstat (limited to 'llvm/lib/Support')
| -rw-r--r-- | llvm/lib/Support/Path.cpp | 15 | ||||
| -rw-r--r-- | llvm/lib/Support/Unix/Path.inc | 9 | ||||
| -rw-r--r-- | llvm/lib/Support/Windows/Path.inc | 31 |
3 files changed, 40 insertions, 15 deletions
diff --git a/llvm/lib/Support/Path.cpp b/llvm/lib/Support/Path.cpp index 0fb7666aeba..171ccc3970e 100644 --- a/llvm/lib/Support/Path.cpp +++ b/llvm/lib/Support/Path.cpp @@ -722,21 +722,6 @@ error_code openFileForWrite(const Twine &Name, int &ResultFD, return error_code::success(); } -error_code openFileForRead(const Twine &Name, int &ResultFD) { - int OpenFlags = O_RDONLY; -#ifdef O_BINARY - OpenFlags |= O_BINARY; // Open input file in binary mode on win32. -#endif - - SmallString<128> Storage; - StringRef P = Name.toNullTerminatedStringRef(Storage); - while ((ResultFD = open(P.begin(), OpenFlags)) < 0) { - if (errno != EINTR) - return error_code(errno, system_category()); - } - return error_code::success(); -} - error_code make_absolute(SmallVectorImpl<char> &path) { StringRef p(path.data(), path.size()); diff --git a/llvm/lib/Support/Unix/Path.inc b/llvm/lib/Support/Unix/Path.inc index 0c1623acdc7..84f8d374931 100644 --- a/llvm/lib/Support/Unix/Path.inc +++ b/llvm/lib/Support/Unix/Path.inc @@ -815,6 +815,15 @@ error_code unmap_file_pages(void *base, size_t size) { return error_code::success(); } +error_code openFileForRead(const Twine &Name, int &ResultFD) { + SmallString<128> Storage; + StringRef P = Name.toNullTerminatedStringRef(Storage); + while ((ResultFD = open(P.begin(), O_RDONLY)) < 0) { + if (errno != EINTR) + return error_code(errno, system_category()); + } + return error_code::success(); +} } // end namespace fs } // end namespace sys diff --git a/llvm/lib/Support/Windows/Path.inc b/llvm/lib/Support/Windows/Path.inc index 5a62a609b83..1da60d67118 100644 --- a/llvm/lib/Support/Windows/Path.inc +++ b/llvm/lib/Support/Windows/Path.inc @@ -1041,7 +1041,38 @@ error_code unmap_file_pages(void *base, size_t size) { return windows_error::invalid_function; } +error_code openFileForRead(const Twine &Name, int &ResultFD) { + SmallString<128> PathStorage; + SmallVector<wchar_t, 128> PathUTF16; + + if (error_code EC = UTF8ToUTF16(Name.toStringRef(PathStorage), + PathUTF16)) + return EC; + HANDLE H = ::CreateFileW(PathUTF16.begin(), GENERIC_READ, + FILE_SHARE_READ, NULL, + OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); + if (H == INVALID_HANDLE_VALUE) { + error_code EC = windows_error(::GetLastError()); + // Provide a better error massage when trying to open directories. + // This only runs if we failed to open the file, so there is probably + // no performances issues. + if (EC != windows_error::access_denied) + return EC; + if (is_directory(Name)) + return error_code(errc::is_a_directory, posix_category()); + return EC; + } + + int FD = ::_open_osfhandle(intptr_t(H), 0); + if (FD == -1) { + ::CloseHandle(H); + return windows_error::invalid_handle; + } + + ResultFD = FD; + return error_code::success(); +} } // end namespace fs } // end namespace sys |

