2021-06-11 12:02:28 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2022-09-26 08:02:51 +00:00
|
|
|
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
|
2021-06-11 12:02:28 +00:00
|
|
|
Date: Sun, 17 May 2020 23:47:33 -0700
|
|
|
|
Subject: [PATCH] Fix for large move vectors crashing server
|
|
|
|
|
|
|
|
Check movement distance also based on current position.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2024-04-24 13:46:45 +00:00
|
|
|
index 5175475d75c393bfd5516d7dbede5200b7091b64..355b1726e90eb796fa2c1e21108bcf793637bf6c 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
2024-04-24 13:46:45 +00:00
|
|
|
@@ -498,9 +498,9 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2023-12-28 20:47:57 +00:00
|
|
|
float prevYaw = this.player.getYRot();
|
|
|
|
float prevPitch = this.player.getXRot();
|
|
|
|
// CraftBukkit end
|
2021-06-11 12:02:28 +00:00
|
|
|
- double d0 = entity.getX();
|
|
|
|
- double d1 = entity.getY();
|
|
|
|
- double d2 = entity.getZ();
|
2021-06-14 16:58:00 +00:00
|
|
|
+ double d0 = entity.getX();final double fromX = d0; // Paper - OBFHELPER
|
|
|
|
+ double d1 = entity.getY();final double fromY = d1; // Paper - OBFHELPER
|
|
|
|
+ double d2 = entity.getZ();final double fromZ = d2; // Paper - OBFHELPER
|
2022-03-14 19:28:02 +00:00
|
|
|
double d3 = ServerGamePacketListenerImpl.clampHorizontal(packet.getX()); final double toX = d3; // Paper - OBFHELPER
|
|
|
|
double d4 = ServerGamePacketListenerImpl.clampVertical(packet.getY()); final double toY = d4; // Paper - OBFHELPER
|
|
|
|
double d5 = ServerGamePacketListenerImpl.clampHorizontal(packet.getZ()); final double toZ = d5; // Paper - OBFHELPER
|
2024-04-24 13:46:45 +00:00
|
|
|
@@ -510,7 +510,16 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2021-06-11 12:02:28 +00:00
|
|
|
double d7 = d4 - this.vehicleFirstGoodY;
|
|
|
|
double d8 = d5 - this.vehicleFirstGoodZ;
|
|
|
|
double d9 = entity.getDeltaMovement().lengthSqr();
|
|
|
|
- double d10 = d6 * d6 + d7 * d7 + d8 * d8;
|
|
|
|
+ // Paper start - fix large move vectors killing the server
|
|
|
|
+ double currDeltaX = toX - fromX;
|
|
|
|
+ double currDeltaY = toY - fromY;
|
|
|
|
+ double currDeltaZ = toZ - fromZ;
|
|
|
|
+ double d10 = Math.max(d6 * d6 + d7 * d7 + d8 * d8, (currDeltaX * currDeltaX + currDeltaY * currDeltaY + currDeltaZ * currDeltaZ) - 1);
|
2021-08-26 02:16:27 +00:00
|
|
|
+ double otherFieldX = d3 - this.vehicleLastGoodX;
|
|
|
|
+ double otherFieldY = d4 - this.vehicleLastGoodY - 1.0E-6D;
|
|
|
|
+ double otherFieldZ = d5 - this.vehicleLastGoodZ;
|
|
|
|
+ d10 = Math.max(d10, (otherFieldX * otherFieldX + otherFieldY * otherFieldY + otherFieldZ * otherFieldZ) - 1);
|
|
|
|
+ // Paper end - fix large move vectors killing the server
|
2021-06-11 12:02:28 +00:00
|
|
|
|
|
|
|
// CraftBukkit start - handle custom speeds and skipped ticks
|
2021-08-26 02:16:27 +00:00
|
|
|
this.allowedPlayerTicks += (System.currentTimeMillis() / 50) - this.lastTick;
|
2024-04-24 13:46:45 +00:00
|
|
|
@@ -556,9 +565,9 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2021-08-26 02:16:27 +00:00
|
|
|
|
|
|
|
boolean flag = worldserver.noCollision(entity, entity.getBoundingBox().deflate(0.0625D));
|
|
|
|
|
|
|
|
- d6 = d3 - this.vehicleLastGoodX;
|
|
|
|
- d7 = d4 - this.vehicleLastGoodY - 1.0E-6D;
|
|
|
|
- d8 = d5 - this.vehicleLastGoodZ;
|
|
|
|
+ d6 = d3 - this.vehicleLastGoodX; // Paper - diff on change, used for checking large move vectors above
|
|
|
|
+ d7 = d4 - this.vehicleLastGoodY - 1.0E-6D; // Paper - diff on change, used for checking large move vectors above
|
|
|
|
+ d8 = d5 - this.vehicleLastGoodZ; // Paper - diff on change, used for checking large move vectors above
|
2022-03-01 05:43:03 +00:00
|
|
|
boolean flag1 = entity.verticalCollisionBelow;
|
2021-08-26 02:16:27 +00:00
|
|
|
|
2023-06-07 23:44:11 +00:00
|
|
|
if (entity instanceof LivingEntity) {
|
2024-04-24 13:46:45 +00:00
|
|
|
@@ -1265,7 +1274,16 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2023-06-07 23:44:11 +00:00
|
|
|
double d7 = d1 - this.firstGoodY;
|
|
|
|
double d8 = d2 - this.firstGoodZ;
|
|
|
|
double d9 = this.player.getDeltaMovement().lengthSqr();
|
|
|
|
- double d10 = d6 * d6 + d7 * d7 + d8 * d8;
|
2021-06-11 12:02:28 +00:00
|
|
|
+ // Paper start - fix large move vectors killing the server
|
|
|
|
+ double currDeltaX = toX - prevX;
|
|
|
|
+ double currDeltaY = toY - prevY;
|
|
|
|
+ double currDeltaZ = toZ - prevZ;
|
2023-06-12 18:26:43 +00:00
|
|
|
+ double d10 = Math.max(d6 * d6 + d7 * d7 + d8 * d8, (currDeltaX * currDeltaX + currDeltaY * currDeltaY + currDeltaZ * currDeltaZ) - 1);
|
2021-08-26 02:16:27 +00:00
|
|
|
+ double otherFieldX = d0 - this.lastGoodX;
|
|
|
|
+ double otherFieldY = d1 - this.lastGoodY;
|
|
|
|
+ double otherFieldZ = d2 - this.lastGoodZ;
|
2023-06-07 23:44:11 +00:00
|
|
|
+ d10 = Math.max(d10, (otherFieldX * otherFieldX + otherFieldY * otherFieldY + otherFieldZ * otherFieldZ) - 1);
|
2021-06-11 12:02:28 +00:00
|
|
|
+ // Paper end - fix large move vectors killing the server
|
|
|
|
|
|
|
|
if (this.player.isSleeping()) {
|
2023-06-07 23:44:11 +00:00
|
|
|
if (d10 > 1.0D) {
|
2024-04-24 13:46:45 +00:00
|
|
|
@@ -1321,9 +1339,9 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
2021-08-26 02:16:27 +00:00
|
|
|
|
|
|
|
AABB axisalignedbb = this.player.getBoundingBox();
|
|
|
|
|
2023-06-07 23:44:11 +00:00
|
|
|
- d6 = d0 - this.lastGoodX;
|
|
|
|
- d7 = d1 - this.lastGoodY;
|
|
|
|
- d8 = d2 - this.lastGoodZ;
|
|
|
|
+ d6 = d0 - this.lastGoodX; // Paper - diff on change, used for checking large move vectors above
|
|
|
|
+ d7 = d1 - this.lastGoodY; // Paper - diff on change, used for checking large move vectors above
|
|
|
|
+ d8 = d2 - this.lastGoodZ; // Paper - diff on change, used for checking large move vectors above
|
2024-04-24 13:46:45 +00:00
|
|
|
boolean flag1 = d7 > 0.0D;
|
2021-08-26 02:16:27 +00:00
|
|
|
|
2024-04-24 13:46:45 +00:00
|
|
|
if (this.player.onGround() && !packet.isOnGround() && flag1) {
|