2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
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.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/ai/navigation/PathNavigation.java b/src/main/java/net/minecraft/world/entity/ai/navigation/PathNavigation.java
|
2024-01-23 14:34:17 +01:00
|
|
|
index c3b406e6302ae0ac1ef56253ab614ca201a7a1c8..a04fb58c29b462e20ed0b702cef478e3985b7cd2 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/ai/navigation/PathNavigation.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/ai/navigation/PathNavigation.java
|
2024-01-23 14:34:17 +01:00
|
|
|
@@ -193,9 +193,29 @@ public abstract class PathNavigation {
|
2021-06-11 14:02:28 +02:00
|
|
|
return this.moveTo(this.createPath(x, y, z, 1), speed);
|
|
|
|
}
|
|
|
|
|
2024-01-21 12:11:43 +01:00
|
|
|
+ // Paper start - Perf: Optimise pathfinding
|
2021-06-11 14:02:28 +02:00
|
|
|
+ private int lastFailure = 0;
|
|
|
|
+ private int pathfindFailures = 0;
|
2024-01-21 12:11:43 +01:00
|
|
|
+ // Paper end - Perf: Optimise pathfinding
|
2021-06-11 14:02:28 +02:00
|
|
|
+
|
|
|
|
public boolean moveTo(Entity entity, double speed) {
|
2024-01-21 12:11:43 +01:00
|
|
|
+ // Paper start - Perf: Optimise pathfinding
|
2021-06-14 03:06:38 +02:00
|
|
|
+ if (this.pathfindFailures > 10 && this.path == null && net.minecraft.server.MinecraftServer.currentTick < this.lastFailure + 40) {
|
2021-06-11 14:02:28 +02:00
|
|
|
+ return false;
|
|
|
|
+ }
|
2024-01-21 12:11:43 +01:00
|
|
|
+ // Paper end - Perf: Optimise pathfinding
|
2021-06-14 03:06:38 +02:00
|
|
|
Path path = this.createPath(entity, 1);
|
|
|
|
- return path != null && this.moveTo(path, speed);
|
2024-01-21 12:11:43 +01:00
|
|
|
+ // Paper start - Perf: Optimise pathfinding
|
2021-06-14 03:06:38 +02:00
|
|
|
+ if (path != null && this.moveTo(path, speed)) {
|
2021-06-11 14:02:28 +02:00
|
|
|
+ this.lastFailure = 0;
|
|
|
|
+ this.pathfindFailures = 0;
|
|
|
|
+ return true;
|
|
|
|
+ } else {
|
|
|
|
+ this.pathfindFailures++;
|
2021-06-14 03:06:38 +02:00
|
|
|
+ this.lastFailure = net.minecraft.server.MinecraftServer.currentTick;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ return false;
|
|
|
|
+ }
|
2024-01-21 12:11:43 +01:00
|
|
|
+ // Paper end - Perf: Optimise pathfinding
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
2021-06-17 23:39:36 +02:00
|
|
|
public boolean moveTo(@Nullable Path path, double speed) {
|