2018-12-03 00:31:09 +01:00
|
|
|
From 4a83ac5a4ae5fd765288ba4bb3a77b949af484d5 Mon Sep 17 00:00:00 2001
|
2018-09-11 06:07:19 +02:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Mon, 10 Sep 2018 23:56:36 -0400
|
|
|
|
Subject: [PATCH] Prevent Mob AI Rules from Loading Chunks
|
|
|
|
|
|
|
|
|
2018-09-13 03:25:02 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/Chunk.java b/src/main/java/net/minecraft/server/Chunk.java
|
2018-11-12 19:23:18 +01:00
|
|
|
index 4e8eb137a..479a84a25 100644
|
2018-09-13 03:25:02 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/Chunk.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/Chunk.java
|
2018-10-06 06:56:20 +02:00
|
|
|
@@ -481,6 +481,7 @@ public class Chunk implements IChunkAccess {
|
2018-09-13 03:25:02 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
+ public Fluid getFluid(BlockPosition blockposition) { return b(blockposition); } // Paper - OBFHELPER
|
|
|
|
public Fluid b(BlockPosition blockposition) {
|
|
|
|
return this.b(blockposition.getX(), blockposition.getY(), blockposition.getZ());
|
|
|
|
}
|
2018-09-11 06:07:19 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/PathfinderGoalRemoveBlock.java b/src/main/java/net/minecraft/server/PathfinderGoalRemoveBlock.java
|
2018-11-12 19:23:18 +01:00
|
|
|
index 9c72848f1..d007d0387 100644
|
2018-09-11 06:07:19 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/PathfinderGoalRemoveBlock.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/PathfinderGoalRemoveBlock.java
|
2018-11-12 19:23:18 +01:00
|
|
|
@@ -12,11 +12,13 @@ public class PathfinderGoalRemoveBlock extends PathfinderGoalGotoTarget {
|
2018-09-11 06:07:19 +02:00
|
|
|
private final Block f;
|
|
|
|
private final EntityInsentient g;
|
|
|
|
private int h;
|
|
|
|
+ private World world; // Paper
|
|
|
|
|
|
|
|
public PathfinderGoalRemoveBlock(Block block, EntityCreature entitycreature, double d0, int i) {
|
|
|
|
super(entitycreature, d0, 24, i);
|
|
|
|
this.f = block;
|
|
|
|
this.g = entitycreature;
|
|
|
|
+ this.world = entitycreature.world; // Paper
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean a() {
|
2018-11-12 19:23:18 +01:00
|
|
|
@@ -99,7 +101,9 @@ public class PathfinderGoalRemoveBlock extends PathfinderGoalGotoTarget {
|
2018-09-11 06:07:19 +02:00
|
|
|
|
|
|
|
@Nullable
|
|
|
|
private BlockPosition a(BlockPosition blockposition, IBlockAccess iblockaccess) {
|
|
|
|
- if (iblockaccess.getType(blockposition).getBlock() == this.f) {
|
|
|
|
+ Block block = world.getBlockIfLoaded(blockposition); // Paper
|
|
|
|
+ if (block == null) return null; // Paper
|
|
|
|
+ if (block == this.f) { // Paper
|
|
|
|
return blockposition;
|
|
|
|
} else {
|
2018-11-12 19:23:18 +01:00
|
|
|
BlockPosition[] ablockposition = new BlockPosition[] { blockposition.down(), blockposition.west(), blockposition.east(), blockposition.north(), blockposition.south(), blockposition.down().down()};
|
|
|
|
@@ -109,7 +113,7 @@ public class PathfinderGoalRemoveBlock extends PathfinderGoalGotoTarget {
|
|
|
|
for (int j = 0; j < i; ++j) {
|
|
|
|
BlockPosition blockposition1 = ablockposition1[j];
|
2018-09-11 06:07:19 +02:00
|
|
|
|
|
|
|
- if (iblockaccess.getType(blockposition1).getBlock() == this.f) {
|
|
|
|
+ if (world.getBlockIfLoaded(blockposition1) == this.f) { // Paper
|
|
|
|
return blockposition1;
|
|
|
|
}
|
|
|
|
}
|
2018-11-12 19:23:18 +01:00
|
|
|
@@ -119,7 +123,8 @@ public class PathfinderGoalRemoveBlock extends PathfinderGoalGotoTarget {
|
2018-09-11 06:07:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
protected boolean a(IWorldReader iworldreader, BlockPosition blockposition) {
|
|
|
|
- Block block = iworldreader.getType(blockposition).getBlock();
|
|
|
|
+ Block block = world.getBlockIfLoaded(blockposition); // Paper
|
|
|
|
+ if (block == null) return false; // Paper
|
2018-11-12 19:23:18 +01:00
|
|
|
|
2018-09-11 06:07:19 +02:00
|
|
|
return block == this.f && iworldreader.getType(blockposition.up()).isAir() && iworldreader.getType(blockposition.up(2)).isAir();
|
|
|
|
}
|
2018-09-13 03:25:02 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/RandomPositionGenerator.java b/src/main/java/net/minecraft/server/RandomPositionGenerator.java
|
2018-11-12 19:23:18 +01:00
|
|
|
index 800e0046a..bfa6c2eef 100644
|
2018-09-13 03:25:02 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/RandomPositionGenerator.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/RandomPositionGenerator.java
|
2018-09-13 03:58:38 +02:00
|
|
|
@@ -78,6 +78,7 @@ public class RandomPositionGenerator {
|
|
|
|
}
|
|
|
|
|
|
|
|
BlockPosition blockposition2 = new BlockPosition((double)j1 + entitycreature.locX, (double)k1 + entitycreature.locY, (double)l1 + entitycreature.locZ);
|
|
|
|
+ if (!entitycreature.world.isLoaded(blockposition2)) continue; // Paper
|
|
|
|
if ((!flag1 || entitycreature.f(blockposition2)) && navigationabstract.a(blockposition2)) {
|
|
|
|
if (!flag) {
|
|
|
|
blockposition2 = a(blockposition2, entitycreature);
|
|
|
|
@@ -141,6 +142,7 @@ public class RandomPositionGenerator {
|
2018-09-13 03:25:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private static boolean b(BlockPosition blockposition, EntityCreature entitycreature) {
|
|
|
|
- return entitycreature.world.b(blockposition).a(TagsFluid.WATER);
|
|
|
|
+ Fluid fluid = entitycreature.world.getFluidIfLoaded(blockposition); // Paper
|
|
|
|
+ return fluid != null && fluid.a(TagsFluid.WATER); // Paper
|
|
|
|
}
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
2018-11-12 19:23:18 +01:00
|
|
|
index a5c655155..016d50d3c 100644
|
2018-09-13 03:25:02 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/World.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/World.java
|
2018-10-07 20:58:53 +02:00
|
|
|
@@ -763,6 +763,18 @@ public abstract class World implements IEntityAccess, GeneratorAccess, IIBlockAc
|
2018-09-13 03:25:02 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper start
|
|
|
|
+ public Fluid getFluidIfLoaded(BlockPosition blockposition) {
|
|
|
|
+ if (blockposition.isInvalidYLocation()) { // Paper
|
|
|
|
+ return getFluid(blockposition);
|
|
|
|
+ } else {
|
|
|
|
+ Chunk chunk = this.getChunkIfLoaded(blockposition);
|
|
|
|
+
|
|
|
|
+ return chunk != null ? chunk.getFluid(blockposition) : null;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+ public Fluid getFluid(BlockPosition blockposition) { return b(blockposition); } // Paper - OBFHELPER
|
|
|
|
public Fluid b(BlockPosition blockposition) {
|
|
|
|
if (blockposition.isInvalidYLocation()) { // Paper
|
|
|
|
return FluidTypes.a.i();
|
2018-09-11 06:07:19 +02:00
|
|
|
--
|
2018-10-21 21:27:53 +02:00
|
|
|
2.19.1
|
2018-09-11 06:07:19 +02:00
|
|
|
|