diff options
| author | Sébastien Crozet <developer@crozet.re> | 2020-11-03 15:33:11 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-11-03 15:33:11 +0100 |
| commit | f70a840f79943aa6da49db2590e13dcd3f3a89ed (patch) | |
| tree | 1c743ed924b10ebd0eb0982e5c7d798235c12cee /src/geometry/collider.rs | |
| parent | 0cc850dc505a4034103d229fdce22f9ec7bc410a (diff) | |
| parent | 71611d3e30ce2fddee20832db3c3e0c8b6ba0d07 (diff) | |
| download | rapier-f70a840f79943aa6da49db2590e13dcd3f3a89ed.tar.gz rapier-f70a840f79943aa6da49db2590e13dcd3f3a89ed.tar.bz2 rapier-f70a840f79943aa6da49db2590e13dcd3f3a89ed.zip | |
Merge pull request #54 from dimforge/idiomatic_clone
Allow cloning all the physics components worth cloning
Diffstat (limited to 'src/geometry/collider.rs')
| -rw-r--r-- | src/geometry/collider.rs | 19 |
1 files changed, 7 insertions, 12 deletions
diff --git a/src/geometry/collider.rs b/src/geometry/collider.rs index f53d75a..c2adc59 100644 --- a/src/geometry/collider.rs +++ b/src/geometry/collider.rs @@ -188,6 +188,7 @@ impl<'de> serde::Deserialize<'de> for ColliderShape { } #[cfg_attr(feature = "serde-serialize", derive(Serialize, Deserialize))] +#[derive(Clone)] /// A geometric entity that can be attached to a body so it can be affected by contacts and proximity queries. /// /// To build a new collider, use the `ColliderBuilder` structure. @@ -212,20 +213,14 @@ pub struct Collider { pub user_data: u128, } -impl Clone for Collider { - fn clone(&self) -> Self { - Self { - shape: self.shape.clone(), - parent: RigidBodySet::invalid_handle(), - contact_graph_index: ColliderGraphIndex::new(crate::INVALID_U32), - proximity_graph_index: ColliderGraphIndex::new(crate::INVALID_U32), - proxy_index: crate::INVALID_USIZE, - ..*self - } +impl Collider { + pub(crate) fn reset_internal_references(&mut self) { + self.parent = RigidBodySet::invalid_handle(); + self.contact_graph_index = InteractionGraph::<Contact>::invalid_graph_index(); + self.proximity_graph_index = InteractionGraph::<Proximity>::invalid_graph_index(); + self.proxy_index = crate::INVALID_USIZE; } -} -impl Collider { /// The rigid body this collider is attached to. pub fn parent(&self) -> RigidBodyHandle { self.parent |
