Merge pull request #107632 from gongpha/potentially-memory-leak

Free nodes from instantiating if it is not a `Control` in the theme editor
This commit is contained in:
Thaddeus Crews 2025-06-18 18:14:07 -05:00
commit 3f99c09685
No known key found for this signature in database
GPG key ID: 8C6E5FEB5FC03CCC

View file

@ -510,8 +510,15 @@ bool SceneThemeEditorPreview::set_preview_scene(const String &p_path) {
}
Node *instance = loaded_scene->instantiate();
if (!instance || !Object::cast_to<Control>(instance)) {
if (!instance) {
EditorNode::get_singleton()->show_warning(TTR("Invalid PackedScene resource, could not instantiate it."));
return false;
}
if (!Object::cast_to<Control>(instance)) {
EditorNode::get_singleton()->show_warning(TTR("Invalid PackedScene resource, must have a Control node at its root."));
memdelete(instance);
return false;
}