diff options
author | Aaron Ballman <aaron@aaronballman.com> | 2016-06-21 14:24:48 +0000 |
---|---|---|
committer | Aaron Ballman <aaron@aaronballman.com> | 2016-06-21 14:24:48 +0000 |
commit | 0ad004620cbf9f99543bec896903a39281c541c8 (patch) | |
tree | 2863d274cbb2a9c6e8a1d4fb99a6816c85072ea8 /llvm/lib/Support/Windows | |
parent | 3d6a130fee309468cef9cd93fe44090d326d76d7 (diff) | |
download | bcm5719-llvm-0ad004620cbf9f99543bec896903a39281c541c8.tar.gz bcm5719-llvm-0ad004620cbf9f99543bec896903a39281c541c8.zip |
Switch to using an API that handles non-ASCII paths appropriately on Windows.
llvm-svn: 273262
Diffstat (limited to 'llvm/lib/Support/Windows')
-rw-r--r-- | llvm/lib/Support/Windows/Path.inc | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/llvm/lib/Support/Windows/Path.inc b/llvm/lib/Support/Windows/Path.inc index 8e5931ce6d8..fab6aeca54a 100644 --- a/llvm/lib/Support/Windows/Path.inc +++ b/llvm/lib/Support/Windows/Path.inc @@ -820,33 +820,34 @@ std::error_code getPathFromOpenFD(int FD, SmallVectorImpl<char> &ResultPath) { return make_error_code(errc::bad_file_descriptor); DWORD CharCount; + SmallVector<wchar_t, 1024> TempPath; do { - // FIXME: We should be using the W version of this API and converting the - // resulting path to UTF-8 to handle non-ASCII file paths. - CharCount = ::GetFinalPathNameByHandleA(FileHandle, ResultPath.begin(), - ResultPath.capacity(), + CharCount = ::GetFinalPathNameByHandleW(FileHandle, TempPath.begin(), + TempPath.capacity(), FILE_NAME_NORMALIZED); - if (CharCount < ResultPath.capacity()) + if (CharCount < TempPath.capacity()) break; // Reserve sufficient space for the path as well as the null character. Even // though the API does not document that it is required, if we reserve just // CharCount space, the function call will not store the resulting path and // still report success. - ResultPath.reserve(CharCount + 1); + TempPath.reserve(CharCount + 1); } while (true); if (CharCount == 0) return mapWindowsError(::GetLastError()); - ResultPath.set_size(CharCount); + TempPath.set_size(CharCount); // On earlier Windows releases, the character count includes the terminating // null. - if (ResultPath.back() == '\0') - ResultPath.pop_back(); + if (TempPath.back() == L'\0') { + --CharCount; + TempPath.pop_back(); + } - return std::error_code(); + return windows::UTF16ToUTF8(TempPath.data(), CharCount, ResultPath); } } // end namespace fs |