diff options
author | kit <kitbdev@gmail.com> | 2024-05-03 16:27:59 -0400 |
---|---|---|
committer | kit <kitbdev@gmail.com> | 2024-05-03 16:27:59 -0400 |
commit | 55afb5b680091e7902b35cd0c949649d54fd0e79 (patch) | |
tree | 4abf09566f7eaf750cf2c723bba599da8c8cea0d /editor/editor_inspector.cpp | |
parent | 03e6fbb010c3546593bd91a0dabc045a9882705a (diff) | |
download | redot-engine-55afb5b680091e7902b35cd0c949649d54fd0e79.tar.gz |
Fix EditorInspector crash when exiting
Diffstat (limited to 'editor/editor_inspector.cpp')
-rw-r--r-- | editor/editor_inspector.cpp | 13 |
1 files changed, 2 insertions, 11 deletions
diff --git a/editor/editor_inspector.cpp b/editor/editor_inspector.cpp index 845ca9b26d..fa8c8451a0 100644 --- a/editor/editor_inspector.cpp +++ b/editor/editor_inspector.cpp @@ -4039,25 +4039,16 @@ void EditorInspector::_notification(int p_what) { EditorFeatureProfileManager::get_singleton()->connect("current_feature_profile_changed", callable_mp(this, &EditorInspector::_feature_profile_changed)); set_process(is_visible_in_tree()); add_theme_style_override("panel", get_theme_stylebox(SNAME("panel"), SNAME("Tree"))); - } break; - - case NOTIFICATION_ENTER_TREE: { if (!sub_inspector) { get_tree()->connect("node_removed", callable_mp(this, &EditorInspector::_node_removed)); } } break; case NOTIFICATION_PREDELETE: { - if (EditorNode::get_singleton() && !EditorNode::get_singleton()->is_exiting()) { - // Don't need to clean up if exiting, and object may already be freed. - edit(nullptr); - } - } break; - - case NOTIFICATION_EXIT_TREE: { - if (!sub_inspector) { + if (!sub_inspector && is_inside_tree()) { get_tree()->disconnect("node_removed", callable_mp(this, &EditorInspector::_node_removed)); } + edit(nullptr); } break; case NOTIFICATION_VISIBILITY_CHANGED: { |