Fix problem with wchar_t* to std::string conversion. (#419)

VS2019 correctly points out that a conversion from a wide NTCS to std::string requires narrowing. This may result in an undesired string value. Implement the string conversion properly.

Signed-off-by: Daniela Engert <dani@ngrt.de>
This commit is contained in:
Daniela Engert 2019-01-27 23:08:01 +01:00 committed by Howard Hinnant
parent 4e7e76b981
commit 61c3d35634

View File

@ -98,6 +98,7 @@
#include <cctype> #include <cctype>
#include <cstdlib> #include <cstdlib>
#include <cstring> #include <cstring>
#include <cwchar>
#include <exception> #include <exception>
#include <fstream> #include <fstream>
#include <iostream> #include <iostream>
@ -208,7 +209,14 @@ get_known_folder(const GUID& folderid)
if (SUCCEEDED(hr)) if (SUCCEEDED(hr))
{ {
co_task_mem_ptr folder_ptr(pfolder); co_task_mem_ptr folder_ptr(pfolder);
folder = std::string(folder_ptr.get(), folder_ptr.get() + wcslen(folder_ptr.get())); const wchar_t* fptr = folder_ptr.get();
auto state = std::mbstate_t();
const auto required = std::wcsrtombs(nullptr, &fptr, 0, &state);
if (required != 0 && required != -1)
{
folder.resize(required);
std::wcsrtombs(folder.data(), &fptr, folder.size(), &state);
}
} }
return folder; return folder;
} }