From ede0d47ccd7aaf0b668cf94584d712e4b9394f1b Mon Sep 17 00:00:00 2001 From: Daniel Lungaro Date: Sun, 9 May 2021 05:17:15 -0700 Subject: [PATCH] Remove plugin from enabled if there's an error MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit inform user in warning message Co-authored-by: RĂ©mi Verschelde Refactor remove plugin from enabled (cherry picked from commit 2bae31a4df783de9fa3f6869f79bfe823c9d2664) --- editor/editor_node.cpp | 28 ++++++++++++++++------------ editor/editor_node.h | 1 + 2 files changed, 17 insertions(+), 12 deletions(-) diff --git a/editor/editor_node.cpp b/editor/editor_node.cpp index c5bd76e33ff..397a8a5eb06 100644 --- a/editor/editor_node.cpp +++ b/editor/editor_node.cpp @@ -642,6 +642,18 @@ void EditorNode::_on_plugin_ready(Object *p_script, const String &p_activate_nam push_item(script.operator->()); } +void EditorNode::_remove_plugin_from_enabled(const String &p_name) { + ProjectSettings *ps = ProjectSettings::get_singleton(); + PoolStringArray enabled_plugins = ps->get("editor_plugins/enabled"); + for (int i = 0; i < enabled_plugins.size(); ++i) { + if (enabled_plugins.get(i) == p_name) { + enabled_plugins.remove(i); + break; + } + } + ps->set("editor_plugins/enabled", enabled_plugins); +} + void EditorNode::_resources_changed(const PoolVector &p_resources) { List> changed; @@ -3163,17 +3175,8 @@ void EditorNode::set_addon_plugin_enabled(String p_addon, bool p_enabled, bool p Ref cf; cf.instance(); if (!DirAccess::exists(p_addon.get_base_dir())) { - ProjectSettings *ps = ProjectSettings::get_singleton(); - PoolStringArray enabled_plugins = ps->get("editor_plugins/enabled"); - for (int i = 0; i < enabled_plugins.size(); ++i) { - if (enabled_plugins.get(i) == p_addon) { - enabled_plugins.remove(i); - break; - } - } - ps->set("editor_plugins/enabled", enabled_plugins); - ps->save(); - WARN_PRINTS("Addon '" + p_addon + "' failed to load. No directory found. Removing from enabled plugins."); + _remove_plugin_from_enabled(p_addon); + WARN_PRINT("Addon '" + p_addon + "' failed to load. No directory found. Removing from enabled plugins."); return; } Error err = cf->load(p_addon); @@ -3202,7 +3205,8 @@ void EditorNode::set_addon_plugin_enabled(String p_addon, bool p_enabled, bool p // Errors in the script cause the base_type to be an empty string. if (String(script->get_instance_base_type()) == "") { - show_warning(vformat(TTR("Unable to load addon script from path: '%s' There seems to be an error in the code, please check the syntax."), script_path)); + show_warning(vformat(TTR("Unable to load addon script from path: '%s'. This might be due to a code error in that script. \nDisabling the addon at '%s' to prevent further errors."), script_path, p_addon)); + _remove_plugin_from_enabled(p_addon); return; } diff --git a/editor/editor_node.h b/editor/editor_node.h index 086d4b81d55..3f9e4ba5559 100644 --- a/editor/editor_node.h +++ b/editor/editor_node.h @@ -462,6 +462,7 @@ private: void _update_file_menu_closed(); void _on_plugin_ready(Object *p_script, const String &p_activate_name); + void _remove_plugin_from_enabled(const String &p_name); void _fs_changed(); void _resources_reimported(const Vector &p_resources);