summaryrefslogtreecommitdiffstats
path: root/editor/editor_script.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'editor/editor_script.cpp')
-rw-r--r--editor/editor_script.cpp20
1 files changed, 18 insertions, 2 deletions
diff --git a/editor/editor_script.cpp b/editor/editor_script.cpp
index a2af5a760e..30a4b6811c 100644
--- a/editor/editor_script.cpp
+++ b/editor/editor_script.cpp
@@ -32,7 +32,10 @@
#include "editor/editor_interface.h"
#include "editor/editor_node.h"
+#include "editor/editor_undo_redo_manager.h"
+#include "editor/gui/editor_scene_tabs.h"
#include "scene/main/node.h"
+#include "scene/resources/packed_scene.h"
void EditorScript::add_root_node(Node *p_node) {
if (!EditorNode::get_singleton()) {
@@ -41,11 +44,24 @@ void EditorScript::add_root_node(Node *p_node) {
}
if (EditorNode::get_singleton()->get_edited_scene()) {
- EditorNode::add_io_error("EditorScript::add_root_node: " + TTR("There is an edited scene already."));
+ EditorNode::add_io_error("EditorScript::add_root_node: " + TTR("The current scene already has a root node."));
return;
}
- //editor->set_edited_scene(p_node);
+ const String &scene_path = p_node->get_scene_file_path();
+ if (!scene_path.is_empty()) {
+ Ref<PackedScene> scene = ResourceLoader::load(scene_path);
+ if (scene.is_valid()) {
+ memfree(scene->instantiate(PackedScene::GEN_EDIT_STATE_INSTANCE)); // Ensure node cache.
+
+ p_node->set_scene_inherited_state(scene->get_state());
+ p_node->set_scene_file_path(String());
+ }
+ }
+
+ EditorNode::get_singleton()->set_edited_scene(p_node);
+ EditorUndoRedoManager::get_singleton()->set_history_as_unsaved(EditorNode::get_editor_data().get_current_edited_scene_history_id());
+ EditorSceneTabs::get_singleton()->update_scene_tabs();
}
Node *EditorScript::get_scene() const {