From 461c5eac3e38de0c7d8d79f9c55f49e02c7182b6 Mon Sep 17 00:00:00 2001 From: WerWolv Date: Thu, 7 Jul 2022 23:28:40 +0200 Subject: [PATCH] fix: Crash when closing the file picker without picking a file --- lib/libimhex/source/helpers/fs.cpp | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/lib/libimhex/source/helpers/fs.cpp b/lib/libimhex/source/helpers/fs.cpp index b756769be..a741f8c84 100644 --- a/lib/libimhex/source/helpers/fs.cpp +++ b/lib/libimhex/source/helpers/fs.cpp @@ -71,7 +71,7 @@ namespace hex::fs { bool openFileBrowser(DialogMode mode, const std::vector &validExtensions, const std::function &callback, const std::string &defaultPath) { NFD::Init(); - nfdchar_t *outPath; + nfdchar_t *outPath = nullptr; nfdresult_t result; switch (mode) { case DialogMode::Open: @@ -87,17 +87,17 @@ namespace hex::fs { hex::unreachable(); } - std::fs::path path; - #if defined(OS_LINUX) - // xdg-desktop-portal, which is the file picker backend used on Linux, returns all paths with URI encoding. - // This is a bit ugly and will most likely be fixed sometime in the future but until then, we'll just use - // curl to decode the URI string into a valid file path string - path = Net().decode(outPath); - #else - path = reinterpret_cast(outPath); - #endif + if (result == NFD_OKAY && outPath != nullptr) { + std::fs::path path; + #if defined(OS_LINUX) + // xdg-desktop-portal, which is the file picker backend used on Linux, returns all paths with URI encoding. + // This is a bit ugly and will most likely be fixed sometime in the future but until then, we'll just use + // curl to decode the URI string into a valid file path string + path = Net().decode(outPath); + #else + path = reinterpret_cast(outPath); + #endif - if (result == NFD_OKAY) { callback(path); NFD::FreePath(outPath); }