aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src/vcpkg_System.cpp
diff options
context:
space:
mode:
authorRobert Schumacher <roschuma@microsoft.com>2017-08-29 18:58:01 -0700
committerRobert Schumacher <roschuma@microsoft.com>2017-08-29 18:58:01 -0700
commite0a9cae9283b78f4470479d0001ea058cc655789 (patch)
treef7feb7029312e195da3748ce6bed1516ffd17134 /toolsrc/src/vcpkg_System.cpp
parent526b1436a16b5c60760cbfc16a7f64e49cf13a01 (diff)
parent5b42ec9b5d7277d9a4452c4c3a109770d9437205 (diff)
downloadvcpkg-e0a9cae9283b78f4470479d0001ea058cc655789.tar.gz
vcpkg-e0a9cae9283b78f4470479d0001ea058cc655789.zip
Merge branch 'utf-1702'
Diffstat (limited to 'toolsrc/src/vcpkg_System.cpp')
-rw-r--r--toolsrc/src/vcpkg_System.cpp14
1 files changed, 7 insertions, 7 deletions
diff --git a/toolsrc/src/vcpkg_System.cpp b/toolsrc/src/vcpkg_System.cpp
index c48f719e1..db4dfec9b 100644
--- a/toolsrc/src/vcpkg_System.cpp
+++ b/toolsrc/src/vcpkg_System.cpp
@@ -184,24 +184,24 @@ namespace vcpkg::System
const std::wstring& actual_cmd_line = Strings::wformat(LR"###("%s 2>&1")###", cmd_line);
Debug::println("_wpopen(%s)", Strings::to_utf8(actual_cmd_line));
- std::string output;
- char buf[1024];
+ std::wstring output;
+ wchar_t buf[1024];
auto pipe = _wpopen(actual_cmd_line.c_str(), L"r");
if (pipe == nullptr)
{
- return {1, output};
+ return {1, Strings::to_utf8(output)};
}
- while (fgets(buf, 1024, pipe))
+ while (fgetws(buf, 1024, pipe))
{
output.append(buf);
}
if (!feof(pipe))
{
- return {1, output};
+ return {1, Strings::to_utf8(output)};
}
auto ec = _pclose(pipe);
- Debug::println("_wpopen() returned %d", ec);
- return {ec, output};
+ Debug::println("_pclose() returned %d", ec);
+ return {ec, Strings::to_utf8(output)};
}
std::wstring create_powershell_script_cmd(const fs::path& script_path, const CWStringView args)