From 5476554d5ed499d75ff7ef3c074e2aff195ca3e4 Mon Sep 17 00:00:00 2001 From: smix8 <52464204+smix8@users.noreply.github.com> Date: Sun, 9 Oct 2022 17:19:26 +0200 Subject: [PATCH] Fix Editor crash when MeshLibrary gets replaced while used in an open GridMap scene (cherry picked from commit d6805e8c332ccfcc9411f239d954cc0ff90abb64) --- modules/gridmap/grid_map.cpp | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/modules/gridmap/grid_map.cpp b/modules/gridmap/grid_map.cpp index b0a2689e0da..9c68c4217cf 100644 --- a/modules/gridmap/grid_map.cpp +++ b/modules/gridmap/grid_map.cpp @@ -561,10 +561,12 @@ bool GridMap::_octant_update(const OctantKey &p_key) { NavigationServer::get_singleton()->region_set_navigation_layers(region, navigation_layers); NavigationServer::get_singleton()->region_set_navmesh(region, navmesh); NavigationServer::get_singleton()->region_set_transform(region, get_global_transform() * nm.xform); - if (navigation) { - NavigationServer::get_singleton()->region_set_map(region, navigation->get_rid()); - } else { - NavigationServer::get_singleton()->region_set_map(region, get_world()->get_navigation_map()); + if (is_inside_tree()) { + if (navigation) { + NavigationServer::get_singleton()->region_set_map(region, navigation->get_rid()); + } else { + NavigationServer::get_singleton()->region_set_map(region, get_world()->get_navigation_map()); + } } nm.region = region;