diff options
author | kobewi <kobewi4e@gmail.com> | 2021-01-27 20:38:40 +0100 |
---|---|---|
committer | kobewi <kobewi4e@gmail.com> | 2021-01-27 21:02:33 +0100 |
commit | 4d172f1fcab6463f0afce3ed4715f67282523a49 (patch) | |
tree | 1a6f6dcc08b0a8ebfe1763cb92eb57980f790a72 /scene/3d/visibility_notifier_3d.cpp | |
parent | 69f77e83bf6430f1d76a3551d2787668646f9d76 (diff) | |
download | redot-engine-4d172f1fcab6463f0afce3ed4715f67282523a49.tar.gz |
Cache world in VisibilityNotifier3D to avoid crash
Diffstat (limited to 'scene/3d/visibility_notifier_3d.cpp')
-rw-r--r-- | scene/3d/visibility_notifier_3d.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/scene/3d/visibility_notifier_3d.cpp b/scene/3d/visibility_notifier_3d.cpp index 494709fe84..14c7659de4 100644 --- a/scene/3d/visibility_notifier_3d.cpp +++ b/scene/3d/visibility_notifier_3d.cpp @@ -80,13 +80,16 @@ AABB VisibilityNotifier3D::get_aabb() const { void VisibilityNotifier3D::_notification(int p_what) { switch (p_what) { case NOTIFICATION_ENTER_WORLD: { - get_world_3d()->_register_notifier(this, get_global_transform().xform(aabb)); + world = get_world_3d(); + ERR_FAIL_COND(!world.is_valid()); + world->_register_notifier(this, get_global_transform().xform(aabb)); } break; case NOTIFICATION_TRANSFORM_CHANGED: { - get_world_3d()->_update_notifier(this, get_global_transform().xform(aabb)); + world->_update_notifier(this, get_global_transform().xform(aabb)); } break; case NOTIFICATION_EXIT_WORLD: { - get_world_3d()->_remove_notifier(this); + ERR_FAIL_COND(!world.is_valid()); + world->_remove_notifier(this); } break; } } |