diff --git a/scene/3d/collision_object_3d.cpp b/scene/3d/collision_object_3d.cpp index 9e2912e60f0..914b3ad8163 100644 --- a/scene/3d/collision_object_3d.cpp +++ b/scene/3d/collision_object_3d.cpp @@ -200,7 +200,7 @@ void CollisionObject3D::_update_shape_data(uint32_t p_owner) { } } -void CollisionObject3D::_shape_changed(Ref p_shape) { +void CollisionObject3D::_shape_changed(const Ref &p_shape) { for (Map::Element *E = shapes.front(); E; E = E->next()) { ShapeData &shapedata = E->get(); ShapeData::ShapeBase *shapes = shapedata.shapes.ptrw(); @@ -485,8 +485,8 @@ void CollisionObject3D::shape_owner_remove_shape(uint32_t p_owner, int p_shape) if (s.debug_shape.is_valid()) { RS::get_singleton()->free(s.debug_shape); - if (s.shape.is_valid() && s.shape->is_connected("changed", callable_mp(this, &CollisionObject3D::_update_shape_data))) { - s.shape->disconnect("changed", callable_mp(this, &CollisionObject3D::_update_shape_data)); + if (s.shape.is_valid() && s.shape->is_connected("changed", callable_mp(this, &CollisionObject3D::_shape_changed))) { + s.shape->disconnect("changed", callable_mp(this, &CollisionObject3D::_shape_changed)); } --debug_shapes_count; } diff --git a/scene/3d/collision_object_3d.h b/scene/3d/collision_object_3d.h index 80bfcbcf054..7ff3c5efdea 100644 --- a/scene/3d/collision_object_3d.h +++ b/scene/3d/collision_object_3d.h @@ -72,7 +72,7 @@ class CollisionObject3D : public Node3D { bool _are_collision_shapes_visible(); void _update_shape_data(uint32_t p_owner); - void _shape_changed(Ref p_shape); + void _shape_changed(const Ref &p_shape); void _update_debug_shapes(); void _clear_debug_shapes();