diff options
Diffstat (limited to 'src/common')
| -rw-r--r-- | src/common/fs/path_util.cpp | 34 | 
1 files changed, 15 insertions, 19 deletions
| diff --git a/src/common/fs/path_util.cpp b/src/common/fs/path_util.cpp index 0abd81a45..732c1559f 100644 --- a/src/common/fs/path_util.cpp +++ b/src/common/fs/path_util.cpp @@ -6,6 +6,7 @@  #include <unordered_map>  #include "common/fs/fs.h" +#include "common/string_util.h"  #ifdef ANDROID  #include "common/fs/fs_android.h"  #endif @@ -14,7 +15,7 @@  #include "common/logging/log.h"  #ifdef _WIN32 -#include <shlobj.h> // Used in GetExeDirectory() +#include <shlobj.h> // Used in GetExeDirectory() and GetWindowsDesktop()  #else  #include <cstdlib>     // Used in Get(Home/Data)Directory()  #include <pwd.h>       // Used in GetHomeDirectory() @@ -250,30 +251,25 @@ void SetYuzuPath(YuzuPath yuzu_path, const fs::path& new_path) {  #ifdef _WIN32  fs::path GetExeDirectory() { -    wchar_t exe_path[MAX_PATH]; - -    if (GetModuleFileNameW(nullptr, exe_path, MAX_PATH) == 0) { -        LOG_ERROR(Common_Filesystem, -                  "Failed to get the path to the executable of the current process"); +    WCHAR exe_path[MAX_PATH]; +    if (SUCCEEDED(GetModuleFileNameW(nullptr, exe_path, MAX_PATH))) { +        std::wstring wide_exe_path(exe_path); +        return fs::path{Common::UTF16ToUTF8(wide_exe_path)}.parent_path();      } - -    return fs::path{exe_path}.parent_path(); +    LOG_ERROR(Common_Filesystem, "Failed to get the path to the executable of the current " +                                 "process"); +    return fs::path{};  }  fs::path GetAppDataRoamingDirectory() {      PWSTR appdata_roaming_path = nullptr; - -    SHGetKnownFolderPath(FOLDERID_RoamingAppData, 0, nullptr, &appdata_roaming_path); - -    auto fs_appdata_roaming_path = fs::path{appdata_roaming_path}; - -    CoTaskMemFree(appdata_roaming_path); - -    if (fs_appdata_roaming_path.empty()) { -        LOG_ERROR(Common_Filesystem, "Failed to get the path to the %APPDATA% directory"); +    if (SUCCEEDED(SHGetKnownFolderPath(FOLDERID_RoamingAppData, 0, NULL, &appdata_roaming_path))) { +        std::wstring wide_appdata_roaming_path(appdata_roaming_path); +        CoTaskMemFree(appdata_roaming_path); +        return fs::path{Common::UTF16ToUTF8(wide_appdata_roaming_path)};      } - -    return fs_appdata_roaming_path; +    LOG_ERROR(Common_Filesystem, "Failed to get the path to the %APPDATA% directory"); +    return fs::path{};  }  #else | 
