diff --git a/doc/classes/EditorPlugin.xml b/doc/classes/EditorPlugin.xml index 6fb209e70b4..ca267aff335 100644 --- a/doc/classes/EditorPlugin.xml +++ b/doc/classes/EditorPlugin.xml @@ -518,6 +518,7 @@ + Emitted when the given [code]resource[/code] was saved on disc. See also [signal scene_saved], which is used for edited scenes instead of this signal. The [PackedScene] does not count as a saved resource. @@ -529,7 +530,13 @@ - Emitted when user closes a scene. The argument is file path to a closed scene. + Emitted when user closes a scene. The argument is a file path to the closed scene. + + + + + + Emitted when a scene was saved on disc. The argument is a file path to the saved scene. See also [signal resource_saved], used for other resources. diff --git a/editor/editor_data.cpp b/editor/editor_data.cpp index 53098bcf994..0787293930f 100644 --- a/editor/editor_data.cpp +++ b/editor/editor_data.cpp @@ -376,6 +376,12 @@ void EditorData::notify_resource_saved(const Ref &p_resource) { } } +void EditorData::notify_scene_saved(const String &p_path) { + for (int i = 0; i < editor_plugins.size(); i++) { + editor_plugins[i]->notify_scene_saved(p_path); + } +} + void EditorData::clear_editor_states() { for (int i = 0; i < editor_plugins.size(); i++) { editor_plugins[i]->clear(); diff --git a/editor/editor_data.h b/editor/editor_data.h index e8e3b7c2264..49c2a3afafa 100644 --- a/editor/editor_data.h +++ b/editor/editor_data.h @@ -208,6 +208,7 @@ public: Dictionary restore_edited_scene_state(EditorSelection *p_selection, EditorHistory *p_history); void notify_edited_scene_changed(); void notify_resource_saved(const Ref &p_resource); + void notify_scene_saved(const String &p_path); bool script_class_is_parent(const String &p_class, const String &p_inherits); StringName script_class_get_base(const String &p_class) const; diff --git a/editor/editor_node.cpp b/editor/editor_node.cpp index c4bcec17ad6..41cc0b97b76 100644 --- a/editor/editor_node.cpp +++ b/editor/editor_node.cpp @@ -1577,6 +1577,7 @@ void EditorNode::_save_scene(String p_file, int idx) { // This needs to be emitted before saving external resources. emit_signal("scene_saved", p_file); + editor_data.notify_scene_saved(p_file); _save_external_resources(); editor_data.save_editor_external_data(); diff --git a/editor/editor_plugin.cpp b/editor/editor_plugin.cpp index c8a62929d50..84974bae009 100644 --- a/editor/editor_plugin.cpp +++ b/editor/editor_plugin.cpp @@ -547,6 +547,10 @@ void EditorPlugin::notify_resource_saved(const Ref &p_resource) { emit_signal("resource_saved", p_resource); } +void EditorPlugin::notify_scene_saved(const String &p_scene_filepath) { + emit_signal("scene_saved", p_scene_filepath); +} + bool EditorPlugin::forward_canvas_gui_input(const Ref &p_event) { if (get_script_instance() && get_script_instance()->has_method("forward_canvas_gui_input")) { return get_script_instance()->call("forward_canvas_gui_input", p_event); @@ -884,6 +888,7 @@ void EditorPlugin::_bind_methods() { ADD_SIGNAL(MethodInfo("scene_closed", PropertyInfo(Variant::STRING, "filepath"))); ADD_SIGNAL(MethodInfo("main_screen_changed", PropertyInfo(Variant::STRING, "screen_name"))); ADD_SIGNAL(MethodInfo("resource_saved", PropertyInfo(Variant::OBJECT, "resource", PROPERTY_HINT_RESOURCE_TYPE, "Resource"))); + ADD_SIGNAL(MethodInfo("scene_saved", PropertyInfo(Variant::STRING, "filepath"))); BIND_ENUM_CONSTANT(CONTAINER_TOOLBAR); BIND_ENUM_CONSTANT(CONTAINER_SPATIAL_EDITOR_MENU); diff --git a/editor/editor_plugin.h b/editor/editor_plugin.h index 1270fe6ae61..04e81f75d9f 100644 --- a/editor/editor_plugin.h +++ b/editor/editor_plugin.h @@ -190,6 +190,7 @@ public: void notify_scene_changed(const Node *scn_root); void notify_scene_closed(const String &scene_filepath); void notify_resource_saved(const Ref &p_resource); + void notify_scene_saved(const String &p_scene_filepath); virtual bool forward_canvas_gui_input(const Ref &p_event); virtual void forward_canvas_draw_over_viewport(Control *p_overlay);