From 3c97759aa770d4d137dfbd812fb01a38740ee18d Mon Sep 17 00:00:00 2001 From: WerWolv Date: Wed, 19 Jul 2023 22:35:55 +0200 Subject: [PATCH] fix: Crash when trying to load files with invalid paths --- .../source/content/providers/file_provider.cpp | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/plugins/builtin/source/content/providers/file_provider.cpp b/plugins/builtin/source/content/providers/file_provider.cpp index 8c02d39dc..8465dc3e0 100644 --- a/plugins/builtin/source/content/providers/file_provider.cpp +++ b/plugins/builtin/source/content/providers/file_provider.cpp @@ -249,8 +249,17 @@ namespace hex::plugin::builtin { auto pathString = settings.at("path").get(); std::fs::path path = std::u8string(pathString.begin(), pathString.end()); - if (auto projectPath = ProjectFile::getPath(); !projectPath.empty()) - this->setPath(std::fs::weakly_canonical(projectPath.parent_path() / path)); + if (auto projectPath = ProjectFile::getPath(); !projectPath.empty()) { + try { + this->setPath(std::fs::weakly_canonical(projectPath.parent_path() / path)); + } catch (const std::fs::filesystem_error &) { + try { + this->setPath(projectPath.parent_path() / path); + } catch (const std::fs::filesystem_error &e) { + this->setErrorMessage(hex::format("hex.builtin.provider.file.error.open"_lang, this->m_path.string(), e.what())); + } + } + } else this->setPath(path); }