Skip to content

Commit

Permalink
Merge pull request #97315 from lawnjelly/fix_character_platform
Browse files Browse the repository at this point in the history
Fix physics platform behaviour regression
  • Loading branch information
akien-mga committed Sep 23, 2024
2 parents 9c9e704 + 6764338 commit b9b7932
Showing 1 changed file with 7 additions and 2 deletions.
9 changes: 7 additions & 2 deletions scene/3d/physics/character_body_3d.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -60,8 +60,13 @@ bool CharacterBody3D::move_and_slide() {

// We need to check the platform_rid object still exists before accessing.
// A valid RID is no guarantee that the object has not been deleted.
if (ObjectDB::get_instance(platform_object_id)) {
//this approach makes sure there is less delay between the actual body velocity and the one we saved

// We can only perform the ObjectDB lifetime check on Object derived objects.
// Note that physics also creates RIDs for non-Object derived objects, these cannot
// be lifetime checked through ObjectDB, and therefore there is a still a vulnerability
// to dangling RIDs (access after free) in this scenario.
if (platform_object_id.is_null() || ObjectDB::get_instance(platform_object_id)) {
// This approach makes sure there is less delay between the actual body velocity and the one we saved.
bs = PhysicsServer3D::get_singleton()->body_get_direct_state(platform_rid);
}

Expand Down

0 comments on commit b9b7932

Please sign in to comment.