From 5d37cb3b74b1e47fef78fdabaedb791091018dc6 Mon Sep 17 00:00:00 2001 From: Alexei Kotov Date: Thu, 31 Oct 2024 12:17:50 +0300 Subject: [PATCH] Exterminate script blacklisting (#8214) --- CHANGELOG.md | 1 + README.md | 4 --- apps/opencs/CMakeLists.txt | 2 +- apps/opencs/editor.cpp | 10 ------- apps/opencs/model/doc/blacklist.cpp | 32 ----------------------- apps/opencs/model/doc/blacklist.hpp | 24 ----------------- apps/opencs/model/doc/document.cpp | 11 +------- apps/opencs/model/doc/document.hpp | 7 +---- apps/opencs/model/doc/documentmanager.cpp | 8 +----- apps/opencs/model/doc/documentmanager.hpp | 3 --- apps/opencs/model/tools/scriptcheck.cpp | 3 --- apps/openmw/engine.cpp | 14 +--------- apps/openmw/engine.hpp | 6 ----- apps/openmw/main.cpp | 8 ------ apps/openmw/mwscript/scriptmanagerimp.cpp | 16 +++--------- apps/openmw/mwscript/scriptmanagerimp.hpp | 4 +-- apps/openmw/options.cpp | 7 ----- components/config/gamesettings.cpp | 6 ++--- files/openmw.cfg | 6 ----- files/openmw.cfg.local | 6 ----- 20 files changed, 13 insertions(+), 165 deletions(-) delete mode 100644 apps/opencs/model/doc/blacklist.cpp delete mode 100644 apps/opencs/model/doc/blacklist.hpp diff --git a/CHANGELOG.md b/CHANGELOG.md index baf6b8062b..37799eaf60 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -286,6 +286,7 @@ Task #7182: FFMpeg 5.1.1+ support Task #7394: Drop support for --fs-strict Task #7720: Drop 360-degree screenshot support + Task #8214: Drop script blacklisting functionality 0.48.0 ------ diff --git a/README.md b/README.md index 67ba2ce003..bca5851c7b 100644 --- a/README.md +++ b/README.md @@ -74,10 +74,6 @@ Command line options 1 - show warning but consider script as correctly compiled anyway 2 - treat warnings as errors - --script-blacklist arg ignore the specified script (if the use - of the blacklist is enabled) - --script-blacklist-use [=arg(=1)] (=1) - enable script blacklisting --load-savegame arg load a save game file on game startup (specify an absolute filename or a filename relative to the current diff --git a/apps/opencs/CMakeLists.txt b/apps/opencs/CMakeLists.txt index 87b1821cba..c2800a4024 100644 --- a/apps/opencs/CMakeLists.txt +++ b/apps/opencs/CMakeLists.txt @@ -8,7 +8,7 @@ opencs_units (model/doc ) opencs_units (model/doc - savingstate savingstages blacklist messages + savingstate savingstages messages ) opencs_hdrs (model/doc diff --git a/apps/opencs/editor.cpp b/apps/opencs/editor.cpp index 24957b0015..4cab88e5f2 100644 --- a/apps/opencs/editor.cpp +++ b/apps/opencs/editor.cpp @@ -126,13 +126,6 @@ boost::program_options::variables_map CS::Editor::readConfiguration() addOption("fallback", boost::program_options::value()->default_value(FallbackMap(), "")->multitoken()->composing(), "fallback values"); - addOption("script-blacklist", - boost::program_options::value>() - ->default_value(std::vector(), "") - ->multitoken(), - "exclude specified script from the verifier (if the use of the blacklist is enabled)"); - addOption("script-blacklist-use", boost::program_options::value()->implicit_value(true)->default_value(true), - "enable script blacklisting"); Files::ConfigurationManager::addCommonOptions(desc); boost::program_options::notify(variables); @@ -159,9 +152,6 @@ std::pair> CS::Editor::readConfig .u8string()); // This call to u8string is redundant, but required // to build on MSVC 14.26 due to implementation bugs. - if (variables["script-blacklist-use"].as()) - mDocumentManager.setBlacklistedScripts(variables["script-blacklist"].as>()); - Files::PathContainer dataDirs, dataLocal; if (!variables["data"].empty()) { diff --git a/apps/opencs/model/doc/blacklist.cpp b/apps/opencs/model/doc/blacklist.cpp deleted file mode 100644 index 9b422cb751..0000000000 --- a/apps/opencs/model/doc/blacklist.cpp +++ /dev/null @@ -1,32 +0,0 @@ -#include "blacklist.hpp" - -#include -#include -#include - -#include - -#include - -bool CSMDoc::Blacklist::isBlacklisted(const CSMWorld::UniversalId& id) const -{ - std::map>::const_iterator iter = mIds.find(id.getType()); - - if (iter == mIds.end()) - return false; - - return std::binary_search(iter->second.begin(), iter->second.end(), Misc::StringUtils::lowerCase(id.getId())); -} - -void CSMDoc::Blacklist::add(CSMWorld::UniversalId::Type type, const std::vector& ids) -{ - std::vector& list = mIds[type]; - - size_t size = list.size(); - - list.resize(size + ids.size()); - - std::transform(ids.begin(), ids.end(), list.begin() + size, - [](const std::string& s) { return Misc::StringUtils::lowerCase(s); }); - std::sort(list.begin(), list.end()); -} diff --git a/apps/opencs/model/doc/blacklist.hpp b/apps/opencs/model/doc/blacklist.hpp deleted file mode 100644 index e565aa252b..0000000000 --- a/apps/opencs/model/doc/blacklist.hpp +++ /dev/null @@ -1,24 +0,0 @@ -#ifndef CSM_DOC_BLACKLIST_H -#define CSM_DOC_BLACKLIST_H - -#include -#include -#include - -#include "../world/universalid.hpp" - -namespace CSMDoc -{ - /// \brief ID blacklist sorted by UniversalId type - class Blacklist - { - std::map> mIds; - - public: - bool isBlacklisted(const CSMWorld::UniversalId& id) const; - - void add(CSMWorld::UniversalId::Type type, const std::vector& ids); - }; -} - -#endif diff --git a/apps/opencs/model/doc/document.cpp b/apps/opencs/model/doc/document.cpp index f604608c7b..21e5ab306b 100644 --- a/apps/opencs/model/doc/document.cpp +++ b/apps/opencs/model/doc/document.cpp @@ -2,7 +2,6 @@ #include "state.hpp" -#include #include #include #include @@ -295,8 +294,7 @@ void CSMDoc::Document::createBase() CSMDoc::Document::Document(const Files::ConfigurationManager& configuration, std::vector files, bool new_, const std::filesystem::path& savePath, const std::filesystem::path& resDir, ToUTF8::FromType encoding, - const std::vector& blacklistedScripts, const Files::PathContainer& dataPaths, - const std::vector& archives) + const Files::PathContainer& dataPaths, const std::vector& archives) : mSavePath(savePath) , mContentFiles(std::move(files)) , mNew(new_) @@ -339,8 +337,6 @@ CSMDoc::Document::Document(const Files::ConfigurationManager& configuration, std createBase(); } - mBlacklist.add(CSMWorld::UniversalId::Type_Script, blacklistedScripts); - addOptionalGmsts(); addOptionalGlobals(); addOptionalMagicEffects(); @@ -485,11 +481,6 @@ CSMTools::ReportModel* CSMDoc::Document::getReport(const CSMWorld::UniversalId& return mTools.getReport(id); } -bool CSMDoc::Document::isBlacklisted(const CSMWorld::UniversalId& id) const -{ - return mBlacklist.isBlacklisted(id); -} - void CSMDoc::Document::startRunning(const std::string& profile, const std::string& startupInstruction) { std::vector contentFiles; diff --git a/apps/opencs/model/doc/document.hpp b/apps/opencs/model/doc/document.hpp index 4acdfafa41..60516cdc8c 100644 --- a/apps/opencs/model/doc/document.hpp +++ b/apps/opencs/model/doc/document.hpp @@ -19,7 +19,6 @@ #include "../tools/tools.hpp" -#include "blacklist.hpp" #include "operationholder.hpp" #include "runner.hpp" #include "saving.hpp" @@ -61,7 +60,6 @@ namespace CSMDoc Saving mSavingOperation; OperationHolder mSaving; std::filesystem::path mResDir; - Blacklist mBlacklist; Runner mRunner; bool mDirty; @@ -95,8 +93,7 @@ namespace CSMDoc public: Document(const Files::ConfigurationManager& configuration, std::vector files, bool new_, const std::filesystem::path& savePath, const std::filesystem::path& resDir, ToUTF8::FromType encoding, - const std::vector& blacklistedScripts, const Files::PathContainer& dataPaths, - const std::vector& archives); + const Files::PathContainer& dataPaths, const std::vector& archives); ~Document() override = default; @@ -136,8 +133,6 @@ namespace CSMDoc CSMTools::ReportModel* getReport(const CSMWorld::UniversalId& id); ///< The ownership of the returned report is not transferred. - bool isBlacklisted(const CSMWorld::UniversalId& id) const; - void startRunning(const std::string& profile, const std::string& startupInstruction = ""); void stopRunning(); diff --git a/apps/opencs/model/doc/documentmanager.cpp b/apps/opencs/model/doc/documentmanager.cpp index 4052c8a789..72c315b004 100644 --- a/apps/opencs/model/doc/documentmanager.cpp +++ b/apps/opencs/model/doc/documentmanager.cpp @@ -61,8 +61,7 @@ void CSMDoc::DocumentManager::addDocument( CSMDoc::Document* CSMDoc::DocumentManager::makeDocument( const std::vector& files, const std::filesystem::path& savePath, bool new_) { - return new Document( - mConfiguration, files, new_, savePath, mResDir, mEncoding, mBlacklistedScripts, mDataPaths, mArchives); + return new Document(mConfiguration, files, new_, savePath, mResDir, mEncoding, mDataPaths, mArchives); } void CSMDoc::DocumentManager::insertDocument(CSMDoc::Document* document) @@ -102,11 +101,6 @@ void CSMDoc::DocumentManager::setEncoding(ToUTF8::FromType encoding) mEncoding = encoding; } -void CSMDoc::DocumentManager::setBlacklistedScripts(const std::vector& scriptIds) -{ - mBlacklistedScripts = scriptIds; -} - void CSMDoc::DocumentManager::documentLoaded(Document* document) { emit documentAdded(document); diff --git a/apps/opencs/model/doc/documentmanager.hpp b/apps/opencs/model/doc/documentmanager.hpp index 25f7d1d4f0..2c9ee1e98e 100644 --- a/apps/opencs/model/doc/documentmanager.hpp +++ b/apps/opencs/model/doc/documentmanager.hpp @@ -31,7 +31,6 @@ namespace CSMDoc QThread mLoaderThread; Loader mLoader; ToUTF8::FromType mEncoding; - std::vector mBlacklistedScripts; std::filesystem::path mResDir; @@ -64,8 +63,6 @@ namespace CSMDoc void setEncoding(ToUTF8::FromType encoding); - void setBlacklistedScripts(const std::vector& scriptIds); - /// Sets the file data that gets passed to newly created documents. void setFileData(const Files::PathContainer& dataPaths, const std::vector& archives); diff --git a/apps/opencs/model/tools/scriptcheck.cpp b/apps/opencs/model/tools/scriptcheck.cpp index 7a76efa483..2ba8e33347 100644 --- a/apps/opencs/model/tools/scriptcheck.cpp +++ b/apps/opencs/model/tools/scriptcheck.cpp @@ -106,9 +106,6 @@ void CSMTools::ScriptCheckStage::perform(int stage, CSMDoc::Messages& messages) mId = mDocument.getData().getScripts().getId(stage); - if (mDocument.isBlacklisted(CSMWorld::UniversalId(CSMWorld::UniversalId::Type_Script, mId.getRefIdString()))) - return; - // Skip "Base" records (setting!) and "Deleted" records if ((mIgnoreBaseRecords && record.mState == CSMWorld::RecordBase::State_BaseOnly) || record.isDeleted()) return; diff --git a/apps/openmw/engine.cpp b/apps/openmw/engine.cpp index ca1b0f577d..2736f339e4 100644 --- a/apps/openmw/engine.cpp +++ b/apps/openmw/engine.cpp @@ -374,7 +374,6 @@ OMW::Engine::Engine(Files::ConfigurationManager& configurationManager) , mActivationDistanceOverride(-1) , mGrab(true) , mRandomSeed(0) - , mScriptBlacklistUse(true) , mNewGame(false) , mCfgMgr(configurationManager) , mGlMaxTextureImageUnits(0) @@ -884,8 +883,7 @@ void OMW::Engine::prepareEngine() mScriptContext = std::make_unique(MWScript::CompilerContext::Type_Full); mScriptContext->setExtensions(&mExtensions); - mScriptManager = std::make_unique(mWorld->getStore(), *mScriptContext, mWarningsMode, - mScriptBlacklistUse ? mScriptBlacklist : std::vector()); + mScriptManager = std::make_unique(mWorld->getStore(), *mScriptContext, mWarningsMode); mEnvironment.setScriptManager(*mScriptManager); // Create game mechanics system @@ -1111,16 +1109,6 @@ void OMW::Engine::setWarningsMode(int mode) mWarningsMode = mode; } -void OMW::Engine::setScriptBlacklist(const std::vector& list) -{ - mScriptBlacklist = list; -} - -void OMW::Engine::setScriptBlacklistUse(bool use) -{ - mScriptBlacklistUse = use; -} - void OMW::Engine::setSaveGameFile(const std::filesystem::path& savegame) { mSaveGameFile = savegame; diff --git a/apps/openmw/engine.hpp b/apps/openmw/engine.hpp index bf7bf7441b..39056af560 100644 --- a/apps/openmw/engine.hpp +++ b/apps/openmw/engine.hpp @@ -178,8 +178,6 @@ namespace OMW Files::Collections mFileCollections; Translation::Storage mTranslationDataStorage; - std::vector mScriptBlacklist; - bool mScriptBlacklistUse; bool mNewGame; // not implemented @@ -253,10 +251,6 @@ namespace OMW void setWarningsMode(int mode); - void setScriptBlacklist(const std::vector& list); - - void setScriptBlacklistUse(bool use); - /// Set the save game file to load after initialising the engine. void setSaveGameFile(const std::filesystem::path& savegame); diff --git a/apps/openmw/main.cpp b/apps/openmw/main.cpp index 4fa4e4f39f..5b89bca960 100644 --- a/apps/openmw/main.cpp +++ b/apps/openmw/main.cpp @@ -149,14 +149,6 @@ bool parseOptions(int argc, char** argv, OMW::Engine& engine, Files::Configurati engine.setScriptConsoleMode(variables["script-console"].as()); engine.setStartupScript(variables["script-run"].as()); engine.setWarningsMode(variables["script-warn"].as()); - std::vector scriptBlacklist; - auto& scriptBlacklistString = variables["script-blacklist"].as(); - for (const auto& blacklistString : scriptBlacklistString) - { - scriptBlacklist.push_back(ESM::RefId::stringRefId(blacklistString)); - } - engine.setScriptBlacklist(scriptBlacklist); - engine.setScriptBlacklistUse(variables["script-blacklist-use"].as()); engine.setSaveGameFile(variables["load-savegame"].as().u8string()); // other settings diff --git a/apps/openmw/mwscript/scriptmanagerimp.cpp b/apps/openmw/mwscript/scriptmanagerimp.cpp index 82f234bf76..e8d57b4c74 100644 --- a/apps/openmw/mwscript/scriptmanagerimp.cpp +++ b/apps/openmw/mwscript/scriptmanagerimp.cpp @@ -24,8 +24,7 @@ namespace MWScript { - ScriptManager::ScriptManager(const MWWorld::ESMStore& store, Compiler::Context& compilerContext, int warningsMode, - const std::vector& scriptBlacklist) + ScriptManager::ScriptManager(const MWWorld::ESMStore& store, Compiler::Context& compilerContext, int warningsMode) : mErrorHandler() , mStore(store) , mCompilerContext(compilerContext) @@ -35,10 +34,6 @@ namespace MWScript installOpcodes(mInterpreter); mErrorHandler.setWarningsMode(warningsMode); - - mScriptBlacklist.resize(scriptBlacklist.size()); - - std::sort(mScriptBlacklist.begin(), mScriptBlacklist.end()); } bool ScriptManager::compile(const ESM::RefId& name) @@ -148,13 +143,10 @@ namespace MWScript for (auto& script : mStore.get()) { - if (!std::binary_search(mScriptBlacklist.begin(), mScriptBlacklist.end(), script.mId)) - { - ++count; + ++count; - if (compile(script.mId)) - ++success; - } + if (compile(script.mId)) + ++success; } return std::make_pair(count, success); diff --git a/apps/openmw/mwscript/scriptmanagerimp.hpp b/apps/openmw/mwscript/scriptmanagerimp.hpp index 326ded7bc6..b17057ae28 100644 --- a/apps/openmw/mwscript/scriptmanagerimp.hpp +++ b/apps/openmw/mwscript/scriptmanagerimp.hpp @@ -59,11 +59,9 @@ namespace MWScript std::unordered_map mScripts; GlobalScripts mGlobalScripts; std::unordered_map mOtherLocals; - std::vector mScriptBlacklist; public: - ScriptManager(const MWWorld::ESMStore& store, Compiler::Context& compilerContext, int warningsMode, - const std::vector& scriptBlacklist); + ScriptManager(const MWWorld::ESMStore& store, Compiler::Context& compilerContext, int warningsMode); void clear() override; diff --git a/apps/openmw/options.cpp b/apps/openmw/options.cpp index 9465175daa..7dfc19d465 100644 --- a/apps/openmw/options.cpp +++ b/apps/openmw/options.cpp @@ -64,13 +64,6 @@ namespace OpenMW "\t1 - show warning but consider script as correctly compiled anyway\n" "\t2 - treat warnings as errors"); - addOption("script-blacklist", - bpo::value()->default_value(StringsVector(), "")->multitoken()->composing(), - "ignore the specified script (if the use of the blacklist is enabled)"); - - addOption("script-blacklist-use", bpo::value()->implicit_value(true)->default_value(true), - "enable script blacklisting"); - addOption("load-savegame", bpo::value()->default_value(Files::MaybeQuotedPath(), ""), "load a save game file on game startup (specify an absolute filename or a filename relative to the current " "working directory)"); diff --git a/components/config/gamesettings.cpp b/components/config/gamesettings.cpp index a2cbe5bf9a..3210716a5c 100644 --- a/components/config/gamesettings.cpp +++ b/components/config/gamesettings.cpp @@ -121,8 +121,7 @@ bool Config::GameSettings::readFile( // Replace composing entries with a replace= line if (key == QLatin1String("config") || key == QLatin1String("replace") || key == QLatin1String("data") || key == QLatin1String("fallback-archive") || key == QLatin1String("content") - || key == QLatin1String("groundcover") || key == QLatin1String("script-blacklist") - || key == QLatin1String("fallback")) + || key == QLatin1String("groundcover") || key == QLatin1String("fallback")) settings.remove(key); } } @@ -145,8 +144,7 @@ bool Config::GameSettings::readFile( // Don't remove composing entries if (key != QLatin1String("config") && key != QLatin1String("replace") && key != QLatin1String("data") && key != QLatin1String("fallback-archive") && key != QLatin1String("content") - && key != QLatin1String("groundcover") && key != QLatin1String("script-blacklist") - && key != QLatin1String("fallback")) + && key != QLatin1String("groundcover") && key != QLatin1String("fallback")) settings.remove(key); if (key == QLatin1String("config") || key == QLatin1String("user-data") || key == QLatin1String("resources") diff --git a/files/openmw.cfg b/files/openmw.cfg index 20e11323cf..c059e14796 100644 --- a/files/openmw.cfg +++ b/files/openmw.cfg @@ -7,12 +7,6 @@ user-data="?userdata?" config="?userconfig?" resources=${OPENMW_RESOURCE_FILES} data=${OPENMW_RESOURCE_FILES}/vfs-mw -script-blacklist=Museum -script-blacklist=MockChangeScript -script-blacklist=doortestwarp -script-blacklist=WereChange2Script -script-blacklist=wereDreamScript2 -script-blacklist=wereDreamScript3 # lighting fallback=LightAttenuation_UseConstant,0 diff --git a/files/openmw.cfg.local b/files/openmw.cfg.local index 65f8b31136..b79b33427c 100644 --- a/files/openmw.cfg.local +++ b/files/openmw.cfg.local @@ -7,12 +7,6 @@ user-data="?userdata?" config="?userconfig?" resources=./resources data=./resources/vfs-mw -script-blacklist=Museum -script-blacklist=MockChangeScript -script-blacklist=doortestwarp -script-blacklist=WereChange2Script -script-blacklist=wereDreamScript2 -script-blacklist=wereDreamScript3 # lighting fallback=LightAttenuation_UseConstant,0