From 24ecdc37a78384c365b2bb643310a68b8e4d2eed Mon Sep 17 00:00:00 2001 From: Petr Mikheev Date: Thu, 30 Sep 2021 02:59:38 +0200 Subject: [PATCH] Fix crash in LuaUtil::ScriptsContainer::~ScriptsContainer() --- components/lua/scriptscontainer.cpp | 6 ++++++ components/lua/scriptscontainer.hpp | 2 +- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/components/lua/scriptscontainer.cpp b/components/lua/scriptscontainer.cpp index b6882b0988..703381a453 100644 --- a/components/lua/scriptscontainer.cpp +++ b/components/lua/scriptscontainer.cpp @@ -328,6 +328,12 @@ namespace LuaUtil std::make_heap(mHoursTimersQueue.begin(), mHoursTimersQueue.end()); } + ScriptsContainer::~ScriptsContainer() + { + for (auto& [_, script] : mScripts) + script.mHiddenData[ScriptId::KEY] = sol::nil; + } + void ScriptsContainer::removeAllScripts() { for (auto& [_, script] : mScripts) diff --git a/components/lua/scriptscontainer.hpp b/components/lua/scriptscontainer.hpp index 0bf50b8793..69aa18e940 100644 --- a/components/lua/scriptscontainer.hpp +++ b/components/lua/scriptscontainer.hpp @@ -75,7 +75,7 @@ namespace LuaUtil ScriptsContainer(LuaUtil::LuaState* lua, std::string_view namePrefix); ScriptsContainer(const ScriptsContainer&) = delete; ScriptsContainer(ScriptsContainer&&) = delete; - virtual ~ScriptsContainer() { removeAllScripts(); } + virtual ~ScriptsContainer(); // Adds package that will be available (via `require`) for all scripts in the container. // Automatically applies LuaUtil::makeReadOnly to the package.