summaryrefslogtreecommitdiffstats
path: root/editor
diff options
context:
space:
mode:
authorkit <kitbdev@gmail.com>2024-08-23 16:34:24 -0400
committerkit <kitbdev@gmail.com>2024-08-23 16:34:24 -0400
commit23927c3d9b960929b3fb350b3f11ab6ae07936f9 (patch)
tree925047468a59634dba6a1d100dfc1050a01c5f61 /editor
parent568589c9d8c763bfb3a4348174d53b42d7c59f21 (diff)
downloadredot-engine-23927c3d9b960929b3fb350b3f11ab6ae07936f9.tar.gz
Fix script overwriting with external editor
Diffstat (limited to 'editor')
-rw-r--r--editor/plugins/script_editor_plugin.cpp8
-rw-r--r--editor/plugins/script_editor_plugin.h1
2 files changed, 6 insertions, 3 deletions
diff --git a/editor/plugins/script_editor_plugin.cpp b/editor/plugins/script_editor_plugin.cpp
index 9da66a0862..26a62efd1c 100644
--- a/editor/plugins/script_editor_plugin.cpp
+++ b/editor/plugins/script_editor_plugin.cpp
@@ -2711,9 +2711,11 @@ void ScriptEditor::apply_scripts() const {
}
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++) {
ScriptEditorBase *se = Object::cast_to<ScriptEditorBase>(tab_container->get_tab_control(i));
if (!se) {
diff --git a/editor/plugins/script_editor_plugin.h b/editor/plugins/script_editor_plugin.h
index 9db1aff76a..ef88bc107b 100644
--- a/editor/plugins/script_editor_plugin.h
+++ b/editor/plugins/script_editor_plugin.h
@@ -436,6 +436,7 @@ class ScriptEditor : public PanelContainer {
void _file_removed(const String &p_file);
void _autosave_scripts();
void _update_autosave_timer();
+ void _reload_scripts(bool p_refresh_only = false);
void _update_members_overview_visibility();
void _update_members_overview();