aboutsummaryrefslogtreecommitdiff
path: root/src/dynamics/island_manager.rs
diff options
context:
space:
mode:
authorCrozet Sébastien <developer@crozet.re>2021-06-01 12:36:01 +0200
committerCrozet Sébastien <developer@crozet.re>2021-06-01 12:36:01 +0200
commit826ce5f014281fd04b7a18238f102f2591d0b255 (patch)
treeb35c16371dcfac726c2821b7bfd9da21184155bd /src/dynamics/island_manager.rs
parent1bef66fea941307a7305ddaebdb0abe3d0cb281f (diff)
downloadrapier-826ce5f014281fd04b7a18238f102f2591d0b255.tar.gz
rapier-826ce5f014281fd04b7a18238f102f2591d0b255.tar.bz2
rapier-826ce5f014281fd04b7a18238f102f2591d0b255.zip
Rework the event system
Diffstat (limited to 'src/dynamics/island_manager.rs')
-rw-r--r--src/dynamics/island_manager.rs22
1 files changed, 10 insertions, 12 deletions
diff --git a/src/dynamics/island_manager.rs b/src/dynamics/island_manager.rs
index b79cdb2..34fa3bd 100644
--- a/src/dynamics/island_manager.rs
+++ b/src/dynamics/island_manager.rs
@@ -229,19 +229,17 @@ impl IslandManager {
stack: &mut Vec<RigidBodyHandle>,
) {
for collider_handle in &rb_colliders.0 {
- if let Some(contacts) = narrow_phase.contacts_with(*collider_handle) {
- for inter in contacts {
- for manifold in &inter.2.manifolds {
- if !manifold.data.solver_contacts.is_empty() {
- let other = crate::utils::select_other(
- (inter.0, inter.1),
- *collider_handle,
- );
- if let Some(other_body) = colliders.get(other.0) {
- stack.push(other_body.handle);
- }
- break;
+ for inter in narrow_phase.contacts_with(*collider_handle) {
+ for manifold in &inter.manifolds {
+ if !manifold.data.solver_contacts.is_empty() {
+ let other = crate::utils::select_other(
+ (inter.collider1, inter.collider2),
+ *collider_handle,
+ );
+ if let Some(other_body) = colliders.get(other.0) {
+ stack.push(other_body.handle);
}
+ break;
}
}
}