summaryrefslogtreecommitdiffstats
path: root/editor/plugins/tiles
diff options
context:
space:
mode:
authorGilles Roudière <gilles.roudiere@gmail.com>2024-07-05 17:08:18 +0200
committerGilles Roudière <gilles.roudiere@gmail.com>2024-07-05 17:08:18 +0200
commit8ebaf4437ae603031495270ba233941eca67e7e5 (patch)
treed50777a4a60548e4025308ca12e721224eb095a0 /editor/plugins/tiles
parentc9ca3aa9aba1f213e5eaa31f98183d3a6910d19f (diff)
downloadredot-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.cpp11
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);