2022-09-17 05:30:00 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: MWHunter <s0521458@student.rockvalleycollege.edu>
|
|
|
|
Date: Wed, 24 Aug 2022 09:54:11 -0400
|
|
|
|
Subject: [PATCH] Stop large look changes from crashing the server
|
|
|
|
|
|
|
|
Co-authored-by: Jaren Knodel <Jaren@Knodel.com>
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/LivingEntity.java b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
2024-04-28 03:00:01 +02:00
|
|
|
index 44ce7ffd8304f0f295f632211931f5b9f6c72d17..33506e82025656df4a13aeacb788d73e5e5a4929 100644
|
2022-09-17 05:30:00 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
2024-04-28 03:00:01 +02:00
|
|
|
@@ -3142,37 +3142,15 @@ public abstract class LivingEntity extends Entity implements Attackable {
|
2023-06-08 10:47:19 +02:00
|
|
|
this.level().getProfiler().pop();
|
|
|
|
this.level().getProfiler().push("rangeChecks");
|
2022-09-17 05:30:00 +02:00
|
|
|
|
|
|
|
- while (this.getYRot() - this.yRotO < -180.0F) {
|
|
|
|
- this.yRotO -= 360.0F;
|
|
|
|
- }
|
2023-03-23 22:57:03 +01:00
|
|
|
-
|
2022-09-17 05:30:00 +02:00
|
|
|
- while (this.getYRot() - this.yRotO >= 180.0F) {
|
|
|
|
- this.yRotO += 360.0F;
|
|
|
|
- }
|
2023-03-23 22:57:03 +01:00
|
|
|
+ // Paper start - stop large pitch and yaw changes from crashing the server
|
|
|
|
+ this.yRotO += Math.round((this.getYRot() - this.yRotO) / 360.0F) * 360.0F;
|
2022-09-17 05:30:00 +02:00
|
|
|
|
|
|
|
- while (this.yBodyRot - this.yBodyRotO < -180.0F) {
|
|
|
|
- this.yBodyRotO -= 360.0F;
|
|
|
|
- }
|
2023-03-23 22:57:03 +01:00
|
|
|
+ this.yBodyRotO += Math.round((this.yBodyRot - this.yBodyRotO) / 360.0F) * 360.0F;
|
2022-09-17 05:30:00 +02:00
|
|
|
|
|
|
|
- while (this.yBodyRot - this.yBodyRotO >= 180.0F) {
|
|
|
|
- this.yBodyRotO += 360.0F;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- while (this.getXRot() - this.xRotO < -180.0F) {
|
|
|
|
- this.xRotO -= 360.0F;
|
|
|
|
- }
|
2023-03-23 22:57:03 +01:00
|
|
|
+ this.xRotO += Math.round((this.getXRot() - this.xRotO) / 360.0F) * 360.0F;
|
|
|
|
|
2022-09-17 05:30:00 +02:00
|
|
|
- while (this.getXRot() - this.xRotO >= 180.0F) {
|
|
|
|
- this.xRotO += 360.0F;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- while (this.yHeadRot - this.yHeadRotO < -180.0F) {
|
|
|
|
- this.yHeadRotO -= 360.0F;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- while (this.yHeadRot - this.yHeadRotO >= 180.0F) {
|
|
|
|
- this.yHeadRotO += 360.0F;
|
|
|
|
- }
|
|
|
|
+ this.yHeadRotO += Math.round((this.yHeadRot - this.yHeadRotO) / 360.0F) * 360.0F;
|
|
|
|
+ // Paper end
|
|
|
|
|
2023-06-08 10:47:19 +02:00
|
|
|
this.level().getProfiler().pop();
|
2022-09-17 05:30:00 +02:00
|
|
|
this.animStep += f2;
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/projectile/Projectile.java b/src/main/java/net/minecraft/world/entity/projectile/Projectile.java
|
2024-04-26 03:51:28 +02:00
|
|
|
index ccb7aa341e3087255bce1f6fb953d33584147fd3..4c6fbf19d6bb01e67c6141aea757fae434ee8233 100644
|
2022-09-17 05:30:00 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/projectile/Projectile.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/projectile/Projectile.java
|
2024-04-24 23:23:56 +02:00
|
|
|
@@ -298,13 +298,7 @@ public abstract class Projectile extends Entity implements TraceableEntity {
|
2022-09-17 05:30:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
protected static float lerpRotation(float prevRot, float newRot) {
|
|
|
|
- while (newRot - prevRot < -180.0F) {
|
|
|
|
- prevRot -= 360.0F;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- while (newRot - prevRot >= 180.0F) {
|
|
|
|
- prevRot += 360.0F;
|
|
|
|
- }
|
|
|
|
+ prevRot += Math.round((newRot - prevRot) / 360.0F) * 360.0F; // Paper - stop large look changes from crashing the server
|
|
|
|
|
|
|
|
return Mth.lerp(0.2F, prevRot, newRot);
|
|
|
|
}
|