2020-05-06 09:48:49 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2020-04-12 20:50:34 +00:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Thu, 3 Mar 2016 02:02:07 -0600
|
|
|
|
Subject: [PATCH] Optimize Pathfinding
|
|
|
|
|
|
|
|
Prevents pathfinding from spamming failures for things such as
|
|
|
|
arrow attacks.
|
|
|
|
|
2021-03-16 07:19:45 +00:00
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/ai/navigation/NavigationAbstract.java b/src/main/java/net/minecraft/world/entity/ai/navigation/NavigationAbstract.java
|
|
|
|
index ab469f1698b4f0e36c0d077472f1adea36f95ce9..795224a31142bebbe1b62ae00c3c098617e21f6c 100644
|
|
|
|
--- a/src/main/java/net/minecraft/world/entity/ai/navigation/NavigationAbstract.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/ai/navigation/NavigationAbstract.java
|
|
|
|
@@ -31,7 +31,7 @@ public abstract class NavigationAbstract {
|
2020-04-12 20:50:34 +00:00
|
|
|
protected final EntityInsentient a; public Entity getEntity() { return a; } // Paper - OBFHELPER
|
|
|
|
protected final World b;
|
|
|
|
@Nullable
|
|
|
|
- protected PathEntity c;
|
|
|
|
+ protected PathEntity c; protected final PathEntity getCurrentPath() { return this.c; } // Paper - OBFHELPER
|
|
|
|
protected double d;
|
|
|
|
protected int e;
|
2020-06-26 01:53:21 +00:00
|
|
|
protected int f;
|
2021-03-16 07:19:45 +00:00
|
|
|
@@ -183,10 +183,30 @@ public abstract class NavigationAbstract {
|
2020-04-12 20:50:34 +00:00
|
|
|
return this.a(this.a(d0, d1, d2, 1), d3);
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start - optimise pathfinding
|
|
|
|
+ private int lastFailure = 0;
|
|
|
|
+ private int pathfindFailures = 0;
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
public boolean a(Entity entity, double d0) {
|
|
|
|
+ // Paper start - Pathfinding optimizations
|
|
|
|
+ if (this.pathfindFailures > 10 && this.getCurrentPath() == null && MinecraftServer.currentTick < this.lastFailure + 40) {
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
PathEntity pathentity = this.a(entity, 1);
|
|
|
|
|
|
|
|
- return pathentity != null && this.a(pathentity, d0);
|
|
|
|
+ // Paper start - Pathfinding optimizations
|
|
|
|
+ if (pathentity != null && this.a(pathentity, d0)) {
|
|
|
|
+ this.lastFailure = 0;
|
|
|
|
+ this.pathfindFailures = 0;
|
|
|
|
+ return true;
|
|
|
|
+ } else {
|
|
|
|
+ this.pathfindFailures++;
|
|
|
|
+ this.lastFailure = MinecraftServer.currentTick;
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean setDestination(@Nullable PathEntity pathentity, double speed) { return a(pathentity, speed); } // Paper - OBFHELPER
|