diff options
author | Gilles Roudière <gilles.roudiere@gmail.com> | 2024-07-05 17:08:18 +0200 |
---|---|---|
committer | Gilles Roudière <gilles.roudiere@gmail.com> | 2024-07-05 17:08:18 +0200 |
commit | 8ebaf4437ae603031495270ba233941eca67e7e5 (patch) | |
tree | d50777a4a60548e4025308ca12e721224eb095a0 /editor/plugins/tiles | |
parent | c9ca3aa9aba1f213e5eaa31f98183d3a6910d19f (diff) | |
download | redot-engine-8ebaf4437ae603031495270ba233941eca67e7e5.tar.gz |
Fix crash in the TileMapLayer editor when using editable children
Diffstat (limited to 'editor/plugins/tiles')
-rw-r--r-- | editor/plugins/tiles/tile_map_layer_editor.cpp | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/editor/plugins/tiles/tile_map_layer_editor.cpp b/editor/plugins/tiles/tile_map_layer_editor.cpp index d3afd25502..4a59530159 100644 --- a/editor/plugins/tiles/tile_map_layer_editor.cpp +++ b/editor/plugins/tiles/tile_map_layer_editor.cpp @@ -3630,9 +3630,16 @@ TileMapLayer *TileMapLayerEditor::_get_edited_layer() const { void TileMapLayerEditor::_find_tile_map_layers_in_scene(Node *p_current, const Node *p_owner, Vector<TileMapLayer *> &r_list) const { ERR_FAIL_COND(!p_current || !p_owner); - if (p_current != p_owner && p_current->get_owner() != p_owner) { - return; + + if (p_current != p_owner) { + if (!p_current->get_owner()) { + return; + } + if (p_current->get_owner() != p_owner && !p_owner->is_editable_instance(p_current->get_owner())) { + return; + } } + TileMapLayer *layer = Object::cast_to<TileMapLayer>(p_current); if (layer) { r_list.append(layer); |