diff --git a/modules/navigation/nav_map.cpp b/modules/navigation/nav_map.cpp index f163f4e5294a..a3f2ee2e615e 100644 --- a/modules/navigation/nav_map.cpp +++ b/modules/navigation/nav_map.cpp @@ -54,6 +54,15 @@ r_path_owners->push_back(poly->owner->get_owner_id()); \ } +#ifdef DEBUG_ENABLED +#define NAVMAP_ITERATION_ZERO_ERROR_MSG() \ + ERR_PRINT_ONCE("NavigationServer navigation map query failed because it was made before first map synchronization.\n\ + NavigationServer 'map_changed' signal can be used to receive update notifications.\n\ + NavigationServer 'map_get_iteration_id()' can be used to check if a map has finished its newest iteration."); +#else +#define NAVMAP_ITERATION_ZERO_ERROR_MSG() +#endif // DEBUG_ENABLED + void NavMap::set_up(Vector3 p_up) { if (up == p_up) { return; @@ -129,7 +138,8 @@ gd::PointKey NavMap::get_point_key(const Vector3 &p_pos) const { Vector NavMap::get_path(Vector3 p_origin, Vector3 p_destination, bool p_optimize, uint32_t p_navigation_layers, Vector *r_path_types, TypedArray *r_path_rids, Vector *r_path_owners) const { RWLockRead read_lock(map_rwlock); if (iteration_id == 0) { - ERR_FAIL_V_MSG(Vector(), "NavigationServer map query failed because it was made before first map synchronization."); + NAVMAP_ITERATION_ZERO_ERROR_MSG(); + return Vector(); } // Clear metadata outputs. @@ -593,7 +603,8 @@ Vector NavMap::get_path(Vector3 p_origin, Vector3 p_destination, bool p Vector3 NavMap::get_closest_point_to_segment(const Vector3 &p_from, const Vector3 &p_to, const bool p_use_collision) const { RWLockRead read_lock(map_rwlock); if (iteration_id == 0) { - ERR_FAIL_V_MSG(Vector3(), "NavigationServer map query failed because it was made before first map synchronization."); + NAVMAP_ITERATION_ZERO_ERROR_MSG(); + return Vector3(); } bool use_collision = p_use_collision; @@ -645,7 +656,8 @@ Vector3 NavMap::get_closest_point_to_segment(const Vector3 &p_from, const Vector Vector3 NavMap::get_closest_point(const Vector3 &p_point) const { RWLockRead read_lock(map_rwlock); if (iteration_id == 0) { - ERR_FAIL_V_MSG(Vector3(), "NavigationServer map query failed because it was made before first map synchronization."); + NAVMAP_ITERATION_ZERO_ERROR_MSG(); + return Vector3(); } gd::ClosestPointQueryResult cp = get_closest_point_info(p_point); return cp.point; @@ -654,7 +666,8 @@ Vector3 NavMap::get_closest_point(const Vector3 &p_point) const { Vector3 NavMap::get_closest_point_normal(const Vector3 &p_point) const { RWLockRead read_lock(map_rwlock); if (iteration_id == 0) { - ERR_FAIL_V_MSG(Vector3(), "NavigationServer map query failed because it was made before first map synchronization."); + NAVMAP_ITERATION_ZERO_ERROR_MSG(); + return Vector3(); } gd::ClosestPointQueryResult cp = get_closest_point_info(p_point); return cp.normal; @@ -663,7 +676,8 @@ Vector3 NavMap::get_closest_point_normal(const Vector3 &p_point) const { RID NavMap::get_closest_point_owner(const Vector3 &p_point) const { RWLockRead read_lock(map_rwlock); if (iteration_id == 0) { - ERR_FAIL_V_MSG(RID(), "NavigationServer map query failed because it was made before first map synchronization."); + NAVMAP_ITERATION_ZERO_ERROR_MSG(); + return RID(); } gd::ClosestPointQueryResult cp = get_closest_point_info(p_point); return cp.owner;