瀏覽代碼

Merge pull request #96007 from kitbdev/fix-external-script-reloading

Fix script overwriting with external editor
Rémi Verschelde 1 年之前
父節點
當前提交
61f2a33353
共有 2 個文件被更改,包括 6 次插入3 次删除
  1. 5 3
      editor/plugins/script_editor_plugin.cpp
  2. 1 0
      editor/plugins/script_editor_plugin.h

+ 5 - 3
editor/plugins/script_editor_plugin.cpp

@@ -2711,9 +2711,11 @@ void ScriptEditor::apply_scripts() const {
 }
 }
 
 
 void ScriptEditor::reload_scripts(bool p_refresh_only) {
 void ScriptEditor::reload_scripts(bool p_refresh_only) {
-	if (external_editor_active) {
-		return;
-	}
+	// Call deferred to make sure it runs on the main thread.
+	callable_mp(this, &ScriptEditor::_reload_scripts).call_deferred(p_refresh_only);
+}
+
+void ScriptEditor::_reload_scripts(bool p_refresh_only) {
 	for (int i = 0; i < tab_container->get_tab_count(); i++) {
 	for (int i = 0; i < tab_container->get_tab_count(); i++) {
 		ScriptEditorBase *se = Object::cast_to<ScriptEditorBase>(tab_container->get_tab_control(i));
 		ScriptEditorBase *se = Object::cast_to<ScriptEditorBase>(tab_container->get_tab_control(i));
 		if (!se) {
 		if (!se) {

+ 1 - 0
editor/plugins/script_editor_plugin.h

@@ -436,6 +436,7 @@ class ScriptEditor : public PanelContainer {
 	void _file_removed(const String &p_file);
 	void _file_removed(const String &p_file);
 	void _autosave_scripts();
 	void _autosave_scripts();
 	void _update_autosave_timer();
 	void _update_autosave_timer();
+	void _reload_scripts(bool p_refresh_only = false);
 
 
 	void _update_members_overview_visibility();
 	void _update_members_overview_visibility();
 	void _update_members_overview();
 	void _update_members_overview();