mirror of
https://github.com/PaperMC/Paper.git
synced 2025-08-17 13:24:17 -07:00
Review EntityPathfindEvent
Add missing target forward
This commit is contained in:
@@ -18,7 +18,7 @@ index c76087614..475c93836 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/NavigationAbstract.java b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
diff --git a/src/main/java/net/minecraft/server/NavigationAbstract.java b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
index 6ce35018a..2a391be28 100644
|
index 7b27251b3..fe19167a1 100644
|
||||||
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
||||||
|
@@ -5,8 +5,21 @@ Subject: [PATCH] EntityPathfindEvent
|
|||||||
|
|
||||||
Fires when an Entity decides to start moving to a location.
|
Fires when an Entity decides to start moving to a location.
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/Navigation.java b/src/main/java/net/minecraft/server/Navigation.java
|
||||||
|
index 79b2d9297..b6e3bf823 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/Navigation.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/Navigation.java
|
||||||
|
@@ -0,0 +0,0 @@ public class Navigation extends NavigationAbstract {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PathEntity a(Entity entity) {
|
||||||
|
- return this.b(new BlockPosition(entity));
|
||||||
|
+ return this.b(new BlockPosition(entity), entity); // Paper - Forward target entity
|
||||||
|
}
|
||||||
|
|
||||||
|
private int s() {
|
||||||
diff --git a/src/main/java/net/minecraft/server/NavigationAbstract.java b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
diff --git a/src/main/java/net/minecraft/server/NavigationAbstract.java b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
index 2ced8dedd..6ce35018a 100644
|
index 2ced8dedd..7b27251b3 100644
|
||||||
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
@@ -0,0 +0,0 @@ import javax.annotation.Nullable;
|
@@ -0,0 +0,0 @@ import javax.annotation.Nullable;
|
||||||
@@ -22,11 +35,11 @@ index 2ced8dedd..6ce35018a 100644
|
|||||||
return this.b(new BlockPosition(d0, d1, d2));
|
return this.b(new BlockPosition(d0, d1, d2));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- @Nullable
|
||||||
|
- public PathEntity b(BlockPosition blockposition) {
|
||||||
+ // Paper start - Add target entity parameter for path find event
|
+ // Paper start - Add target entity parameter for path find event
|
||||||
+ @Nullable public PathEntity b(BlockPosition blockposition) { return this.b(blockposition, null); }
|
+ @Nullable public PathEntity b(BlockPosition blockposition) { return this.b(blockposition, null); }
|
||||||
@Nullable
|
+ @Nullable public PathEntity b(BlockPosition blockposition, Entity target) {
|
||||||
- public PathEntity b(BlockPosition blockposition) {
|
|
||||||
+ public PathEntity b(BlockPosition blockposition, Entity target) {
|
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
float f = (float) blockposition.getX() + 0.5F;
|
float f = (float) blockposition.getX() + 0.5F;
|
||||||
float f1 = (float) blockposition.getY() + 0.5F;
|
float f1 = (float) blockposition.getY() + 0.5F;
|
||||||
@@ -45,11 +58,11 @@ index 2ced8dedd..6ce35018a 100644
|
|||||||
+ return this.a(blockposition, entity, d0, d1, d2, 16, true); // Paper - Path find event
|
+ return this.a(blockposition, entity, d0, d1, d2, 16, true); // Paper - Path find event
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- @Nullable
|
||||||
|
- protected PathEntity a(BlockPosition blockposition, double d0, double d1, double d2, int i, boolean flag) {
|
||||||
+ // Paper start - Add target entity parameter for path find event
|
+ // Paper start - Add target entity parameter for path find event
|
||||||
+ @Nullable protected PathEntity a(BlockPosition blockposition, double d0, double d1, double d2, int i, boolean flag) { return this.a(blockposition, null, d0, d1, d2, i, flag); }
|
+ @Nullable protected PathEntity a(BlockPosition blockposition, double d0, double d1, double d2, int i, boolean flag) { return this.a(blockposition, null, d0, d1, d2, i, flag); }
|
||||||
@Nullable
|
+ @Nullable protected PathEntity a(BlockPosition blockposition, Entity target, double d0, double d1, double d2, int i, boolean flag) {
|
||||||
- protected PathEntity a(BlockPosition blockposition, double d0, double d1, double d2, int i, boolean flag) {
|
|
||||||
+ protected PathEntity a(BlockPosition blockposition, Entity target, double d0, double d1, double d2, int i, boolean flag) {
|
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
if (!this.a()) {
|
if (!this.a()) {
|
||||||
return null;
|
return null;
|
||||||
|
@@ -123,7 +123,7 @@ index 000000000..f68a07cb9
|
|||||||
+ }
|
+ }
|
||||||
+}
|
+}
|
||||||
diff --git a/src/main/java/net/minecraft/server/NavigationAbstract.java b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
diff --git a/src/main/java/net/minecraft/server/NavigationAbstract.java b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
index 0586597e7..583f2c5ad 100644
|
index 6a1d5a899..f6a5aa27b 100644
|
||||||
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
||||||
|
@@ -6,12 +6,12 @@ Subject: [PATCH] Prevent Pathfinding out of World Border
|
|||||||
This prevents Entities from trying to run outside of the World Border
|
This prevents Entities from trying to run outside of the World Border
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/NavigationAbstract.java b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
diff --git a/src/main/java/net/minecraft/server/NavigationAbstract.java b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
index 2a391be28a..0586597e73 100644
|
index fe19167a1..6a1d5a899 100644
|
||||||
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
--- a/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
+++ b/src/main/java/net/minecraft/server/NavigationAbstract.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
@@ -0,0 +0,0 @@ public abstract class NavigationAbstract {
|
||||||
@Nullable
|
@Nullable protected PathEntity a(BlockPosition blockposition, double d0, double d1, double d2, int i, boolean flag) { return this.a(blockposition, null, d0, d1, d2, i, flag); }
|
||||||
protected PathEntity a(BlockPosition blockposition, Entity target, double d0, double d1, double d2, int i, boolean flag) {
|
@Nullable protected PathEntity a(BlockPosition blockposition, Entity target, double d0, double d1, double d2, int i, boolean flag) {
|
||||||
// Paper end
|
// Paper end
|
||||||
+ if (!getEntity().getWorld().getWorldBorder().isInBounds(blockposition)) return null; // Paper - don't path out of world border
|
+ if (!getEntity().getWorld().getWorldBorder().isInBounds(blockposition)) return null; // Paper - don't path out of world border
|
||||||
if (!this.a()) {
|
if (!this.a()) {
|
||||||
|
Reference in New Issue
Block a user