From 537108043d51ebf4de3e245a15b3e297cd206969 Mon Sep 17 00:00:00 2001 From: rfuzzo Date: Mon, 23 Oct 2023 09:40:58 +0200 Subject: [PATCH 1/2] fix: relative file paths for uvfs --- src/scripting/LuaSandbox.cpp | 22 ++++++++++++++-------- src/scripting/LuaSandbox.h | 2 ++ 2 files changed, 16 insertions(+), 8 deletions(-) diff --git a/src/scripting/LuaSandbox.cpp b/src/scripting/LuaSandbox.cpp index 5c9cb1c0..51203cd3 100644 --- a/src/scripting/LuaSandbox.cpp +++ b/src/scripting/LuaSandbox.cpp @@ -507,7 +507,8 @@ void LuaSandbox::InitializeIOForSandbox(Sandbox& aSandbox, const sol::state& acp for (const auto& entry : std::filesystem::directory_iterator(path)) { sol::table item(stateView, sol::create); - item["name"] = UTF16ToUTF8(relative(entry.path(), path).native()); + item["relativePath"] = UTF16ToUTF8(Relative(entry.path(), path).native()); + item["name"] = UTF16ToUTF8(entry.path().filename().native()); item["type"] = entry.is_directory() ? "directory" : "file"; res[index++] = item; } @@ -673,6 +674,15 @@ std::filesystem::path LuaSandbox::GetLuaPath(const std::string& acFilePath, cons return GetLuaPath(UTF8ToUTF16(acFilePath), acRootPath, acAllowNonExisting); } +std::filesystem::path LuaSandbox::Relative(const std::filesystem::path& acFilePath, const std::filesystem::path& acRootPath) const +{ + if (m_isLaunchedThroughMO2) + { + return acFilePath.lexically_relative(acRootPath); + } + return relative(acFilePath, acRootPath); +} + std::filesystem::path LuaSandbox::GetLuaPath(std::filesystem::path aFilePath, const std::filesystem::path& acRootPath, const bool acAllowNonExisting) const { assert(!aFilePath.empty()); @@ -690,15 +700,11 @@ std::filesystem::path LuaSandbox::GetLuaPath(std::filesystem::path aFilePath, co if (aFilePath.empty()) return {}; - const auto relativeFilePathToRoot = relative(aFilePath, acRootPath); + const auto relativeFilePathToRoot = Relative(aFilePath, acRootPath); if (relativeFilePathToRoot.native().starts_with(L"..\\") || relativeFilePathToRoot.native().find(L"\\..\\") != std::wstring::npos) { - // make an exception if path outside of sandbox originates from MO2 - if (m_isLaunchedThroughMO2) - { - return aFilePath.lexically_relative(std::filesystem::current_path()); - } + return {}; } - return relative(aFilePath, std::filesystem::current_path()); + return Relative(aFilePath, std::filesystem::current_path()); } diff --git a/src/scripting/LuaSandbox.h b/src/scripting/LuaSandbox.h index 22dfb2cf..bc07ee31 100644 --- a/src/scripting/LuaSandbox.h +++ b/src/scripting/LuaSandbox.h @@ -29,6 +29,8 @@ struct LuaSandbox sol::table& GetGlobals(); const bool GetIsLaunchedThroughMO2() const { return m_isLaunchedThroughMO2; } + [[nodiscard]] std::filesystem::path + Relative(const std::filesystem::path& acFilePath, const std::filesystem::path& acRootPath) const; [[nodiscard]] std::filesystem::path GetLuaPath(const std::string& acFilePath, const std::filesystem::path& acRootPath, const bool acAllowNonExisting) const; [[nodiscard]] std::filesystem::path From ac08c1028bcf783746248c6b458e03f1454a9307 Mon Sep 17 00:00:00 2001 From: rfuzzo Date: Mon, 23 Oct 2023 14:37:28 +0200 Subject: [PATCH 2/2] revert dir api change --- src/scripting/LuaSandbox.cpp | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/scripting/LuaSandbox.cpp b/src/scripting/LuaSandbox.cpp index 51203cd3..7a26e824 100644 --- a/src/scripting/LuaSandbox.cpp +++ b/src/scripting/LuaSandbox.cpp @@ -507,8 +507,7 @@ void LuaSandbox::InitializeIOForSandbox(Sandbox& aSandbox, const sol::state& acp for (const auto& entry : std::filesystem::directory_iterator(path)) { sol::table item(stateView, sol::create); - item["relativePath"] = UTF16ToUTF8(Relative(entry.path(), path).native()); - item["name"] = UTF16ToUTF8(entry.path().filename().native()); + item["name"] = UTF16ToUTF8(Relative(entry.path(), path).native()); item["type"] = entry.is_directory() ? "directory" : "file"; res[index++] = item; }