SPIGOT-5560, SPIGOT-6574, SPIGOT-6632: Remove no longer needed tile entity fix

By: DerFrZocker <derrieple@gmail.com>
This commit is contained in:
CraftBukkit/Spigot 2021-07-11 09:05:59 +10:00
parent 02134e4ee6
commit 413825611f

View File

@ -1,14 +1,11 @@
--- a/net/minecraft/server/level/WorldServer.java --- a/net/minecraft/server/level/WorldServer.java
+++ b/net/minecraft/server/level/WorldServer.java +++ b/net/minecraft/server/level/WorldServer.java
@@ -152,6 +152,22 @@ @@ -152,6 +152,19 @@
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; import org.apache.logging.log4j.Logger;
+// CraftBukkit start +// CraftBukkit start
+import java.util.logging.Level;
+import net.minecraft.world.entity.monster.EntityDrowned; +import net.minecraft.world.entity.monster.EntityDrowned;
+import net.minecraft.world.level.block.ITileEntity;
+import net.minecraft.world.level.block.entity.TileEntity;
+import net.minecraft.world.level.storage.WorldDataServer; +import net.minecraft.world.level.storage.WorldDataServer;
+import org.bukkit.Bukkit; +import org.bukkit.Bukkit;
+import org.bukkit.WeatherType; +import org.bukkit.WeatherType;
@ -23,7 +20,7 @@
public class WorldServer extends World implements GeneratorAccessSeed { public class WorldServer extends World implements GeneratorAccessSeed {
public static final BlockPosition END_SPAWN_POINT = new BlockPosition(100, 50, 0); public static final BlockPosition END_SPAWN_POINT = new BlockPosition(100, 50, 0);
@@ -160,7 +176,7 @@ @@ -160,7 +173,7 @@
final List<EntityPlayer> players; final List<EntityPlayer> players;
private final ChunkProviderServer chunkSource; private final ChunkProviderServer chunkSource;
private final MinecraftServer server; private final MinecraftServer server;
@ -32,7 +29,7 @@
final EntityTickList entityTickList; final EntityTickList entityTickList;
public final PersistentEntitySectionManager<Entity> entityManager; public final PersistentEntitySectionManager<Entity> entityManager;
public boolean noSave; public boolean noSave;
@@ -180,31 +196,52 @@ @@ -180,31 +193,52 @@
private final StructureManager structureFeatureManager; private final StructureManager structureFeatureManager;
private final boolean tickTime; private final boolean tickTime;
@ -93,7 +90,7 @@
boolean flag2 = minecraftserver.isSyncChunkWrites(); boolean flag2 = minecraftserver.isSyncChunkWrites();
DataFixer datafixer = minecraftserver.getDataFixer(); DataFixer datafixer = minecraftserver.getDataFixer();
EntityPersistentStorage<Entity> entitypersistentstorage = new EntityStorage(this, new File(convertable_conversionsession.a(resourcekey), "entities"), datafixer, flag2, minecraftserver); EntityPersistentStorage<Entity> entitypersistentstorage = new EntityStorage(this, new File(convertable_conversionsession.a(resourcekey), "entities"), datafixer, flag2, minecraftserver);
@@ -231,15 +268,51 @@ @@ -231,14 +265,15 @@
iworlddataserver.setGameType(minecraftserver.getGamemode()); iworlddataserver.setGameType(minecraftserver.getGamemode());
} }
@ -108,46 +105,10 @@
this.sleepStatus = new SleepStatus(); this.sleepStatus = new SleepStatus();
+ this.getCraftServer().addWorld(this.getWorld()); // CraftBukkit + this.getCraftServer().addWorld(this.getWorld()); // CraftBukkit
+ }
+
+ // CraftBukkit start
+ @Override
+ public TileEntity getTileEntity(BlockPosition pos, boolean validate) {
+ TileEntity result = super.getTileEntity(pos, validate);
+ if (!validate || Thread.currentThread() != this.thread) {
+ // SPIGOT-5378: avoid deadlock, this can be called in loading logic (i.e lighting) but getType() will block on chunk load
+ return result;
+ }
+ IBlockData type = getType(pos);
+
+ if (result != null && !type.a(Blocks.AIR)) {
+ if (!result.getTileType().isValidBlock(type)) {
+ result = fixTileEntity(pos, type, result);
+ }
+ }
+
+ return result;
+ }
+
+ private TileEntity fixTileEntity(BlockPosition pos, IBlockData type, TileEntity found) {
+ this.getCraftServer().getLogger().log(Level.SEVERE, "Block at {0}, {1}, {2} is {3} but has {4}" + ". "
+ + "Bukkit will attempt to fix this, but there may be additional damage that we cannot recover.", new Object[]{pos.getX(), pos.getY(), pos.getZ(), type, found});
+
+ if (type instanceof ITileEntity) {
+ TileEntity replacement = ((ITileEntity) type).createTile(pos, type);
+ if (replacement != null) {
+ this.setTileEntity(replacement);
+ }
+ return replacement;
+ } else {
+ return found;
+ }
} }
+ // CraftBukkit end
public void a(int i, int j, boolean flag, boolean flag1) { public void a(int i, int j, boolean flag, boolean flag1) {
this.serverLevelData.setClearWeatherTime(i); @@ -331,6 +366,7 @@
@@ -331,6 +404,7 @@
this.rainLevel = MathHelper.a(this.rainLevel, 0.0F, 1.0F); this.rainLevel = MathHelper.a(this.rainLevel, 0.0F, 1.0F);
} }
@ -155,7 +116,7 @@
if (this.oRainLevel != this.rainLevel) { if (this.oRainLevel != this.rainLevel) {
this.server.getPlayerList().a((Packet) (new PacketPlayOutGameStateChange(PacketPlayOutGameStateChange.RAIN_LEVEL_CHANGE, this.rainLevel)), this.getDimensionKey()); this.server.getPlayerList().a((Packet) (new PacketPlayOutGameStateChange(PacketPlayOutGameStateChange.RAIN_LEVEL_CHANGE, this.rainLevel)), this.getDimensionKey());
} }
@@ -349,16 +423,45 @@ @@ -349,16 +385,45 @@
this.server.getPlayerList().sendAll(new PacketPlayOutGameStateChange(PacketPlayOutGameStateChange.RAIN_LEVEL_CHANGE, this.rainLevel)); this.server.getPlayerList().sendAll(new PacketPlayOutGameStateChange(PacketPlayOutGameStateChange.RAIN_LEVEL_CHANGE, this.rainLevel));
this.server.getPlayerList().sendAll(new PacketPlayOutGameStateChange(PacketPlayOutGameStateChange.THUNDER_LEVEL_CHANGE, this.thunderLevel)); this.server.getPlayerList().sendAll(new PacketPlayOutGameStateChange(PacketPlayOutGameStateChange.THUNDER_LEVEL_CHANGE, this.thunderLevel));
} }
@ -204,7 +165,7 @@
if (this.getGameRules().getBoolean(GameRules.RULE_WEATHER_CYCLE)) { if (this.getGameRules().getBoolean(GameRules.RULE_WEATHER_CYCLE)) {
this.clearWeather(); this.clearWeather();
} }
@@ -380,7 +483,7 @@ @@ -380,7 +445,7 @@
this.aq(); this.aq();
this.handlingTick = false; this.handlingTick = false;
gameprofilerfiller.exit(); gameprofilerfiller.exit();
@ -213,7 +174,7 @@
if (flag3) { if (flag3) {
this.resetEmptyTime(); this.resetEmptyTime();
@@ -396,7 +499,7 @@ @@ -396,7 +461,7 @@
this.entityTickList.a((entity) -> { this.entityTickList.a((entity) -> {
if (!entity.isRemoved()) { if (!entity.isRemoved()) {
@ -222,7 +183,7 @@
entity.die(); entity.die();
} else { } else {
gameprofilerfiller.enter("checkDespawn"); gameprofilerfiller.enter("checkDespawn");
@@ -461,7 +564,7 @@ @@ -461,7 +526,7 @@
private void wakeupPlayers() { private void wakeupPlayers() {
this.sleepStatus.a(); this.sleepStatus.a();
@ -231,7 +192,7 @@
entityplayer.wakeup(false, false); entityplayer.wakeup(false, false);
}); });
} }
@@ -488,14 +591,14 @@ @@ -488,14 +553,14 @@
entityhorseskeleton.v(true); entityhorseskeleton.v(true);
entityhorseskeleton.setAgeRaw(0); entityhorseskeleton.setAgeRaw(0);
entityhorseskeleton.setPosition((double) blockposition.getX(), (double) blockposition.getY(), (double) blockposition.getZ()); entityhorseskeleton.setPosition((double) blockposition.getX(), (double) blockposition.getY(), (double) blockposition.getZ());
@ -248,7 +209,7 @@
} }
} }
@@ -506,12 +609,12 @@ @@ -506,12 +571,12 @@
BiomeBase biomebase = this.getBiome(blockposition); BiomeBase biomebase = this.getBiome(blockposition);
if (biomebase.a((IWorldReader) this, blockposition1)) { if (biomebase.a((IWorldReader) this, blockposition1)) {
@ -263,7 +224,7 @@
} }
IBlockData iblockdata = this.getType(blockposition1); IBlockData iblockdata = this.getType(blockposition1);
@@ -642,10 +745,22 @@ @@ -642,10 +707,22 @@
} }
private void clearWeather() { private void clearWeather() {
@ -288,7 +249,7 @@
} }
public void resetEmptyTime() { public void resetEmptyTime() {
@@ -680,6 +795,7 @@ @@ -680,6 +757,7 @@
}); });
gameprofilerfiller.c("tickNonPassenger"); gameprofilerfiller.c("tickNonPassenger");
entity.tick(); entity.tick();
@ -296,7 +257,7 @@
this.getMethodProfiler().exit(); this.getMethodProfiler().exit();
Iterator iterator = entity.getPassengers().iterator(); Iterator iterator = entity.getPassengers().iterator();
@@ -703,6 +819,7 @@ @@ -703,6 +781,7 @@
}); });
gameprofilerfiller.c("tickPassenger"); gameprofilerfiller.c("tickPassenger");
entity1.passengerTick(); entity1.passengerTick();
@ -304,7 +265,7 @@
gameprofilerfiller.exit(); gameprofilerfiller.exit();
Iterator iterator = entity1.getPassengers().iterator(); Iterator iterator = entity1.getPassengers().iterator();
@@ -727,6 +844,7 @@ @@ -727,6 +806,7 @@
ChunkProviderServer chunkproviderserver = this.getChunkProvider(); ChunkProviderServer chunkproviderserver = this.getChunkProvider();
if (!flag1) { if (!flag1) {
@ -312,7 +273,7 @@
if (iprogressupdate != null) { if (iprogressupdate != null) {
iprogressupdate.a(new ChatMessage("menu.savingLevel")); iprogressupdate.a(new ChatMessage("menu.savingLevel"));
} }
@@ -744,11 +862,19 @@ @@ -744,11 +824,19 @@
} }
} }
@ -333,7 +294,7 @@
} }
this.getChunkProvider().getWorldPersistentData().a(); this.getChunkProvider().getWorldPersistentData().a();
@@ -794,15 +920,34 @@ @@ -794,15 +882,34 @@
@Override @Override
public boolean addEntity(Entity entity) { public boolean addEntity(Entity entity) {
@ -371,7 +332,7 @@
} }
public void addPlayerCommand(EntityPlayer entityplayer) { public void addPlayerCommand(EntityPlayer entityplayer) {
@@ -830,27 +975,39 @@ @@ -830,27 +937,39 @@
this.a((EntityPlayer) entity, Entity.RemovalReason.DISCARDED); this.a((EntityPlayer) entity, Entity.RemovalReason.DISCARDED);
} }
@ -417,7 +378,7 @@
return true; return true;
} }
} }
@@ -863,10 +1020,32 @@ @@ -863,10 +982,32 @@
entityplayer.a(entity_removalreason); entityplayer.a(entity_removalreason);
} }
@ -450,7 +411,7 @@
while (iterator.hasNext()) { while (iterator.hasNext()) {
EntityPlayer entityplayer = (EntityPlayer) iterator.next(); EntityPlayer entityplayer = (EntityPlayer) iterator.next();
@@ -875,6 +1054,12 @@ @@ -875,6 +1016,12 @@
double d1 = (double) blockposition.getY() - entityplayer.locY(); double d1 = (double) blockposition.getY() - entityplayer.locY();
double d2 = (double) blockposition.getZ() - entityplayer.locZ(); double d2 = (double) blockposition.getZ() - entityplayer.locZ();
@ -463,7 +424,7 @@
if (d0 * d0 + d1 * d1 + d2 * d2 < 1024.0D) { if (d0 * d0 + d1 * d1 + d2 * d2 < 1024.0D) {
entityplayer.connection.sendPacket(new PacketPlayOutBlockBreakAnimation(i, blockposition, j)); entityplayer.connection.sendPacket(new PacketPlayOutBlockBreakAnimation(i, blockposition, j));
} }
@@ -923,7 +1108,18 @@ @@ -923,7 +1070,18 @@
Iterator iterator = this.navigatingMobs.iterator(); Iterator iterator = this.navigatingMobs.iterator();
while (iterator.hasNext()) { while (iterator.hasNext()) {
@ -483,7 +444,7 @@
NavigationAbstract navigationabstract = entityinsentient.getNavigation(); NavigationAbstract navigationabstract = entityinsentient.getNavigation();
if (!navigationabstract.i()) { if (!navigationabstract.i()) {
@@ -946,10 +1142,20 @@ @@ -946,10 +1104,20 @@
@Override @Override
public Explosion createExplosion(@Nullable Entity entity, @Nullable DamageSource damagesource, @Nullable ExplosionDamageCalculator explosiondamagecalculator, double d0, double d1, double d2, float f, boolean flag, Explosion.Effect explosion_effect) { public Explosion createExplosion(@Nullable Entity entity, @Nullable DamageSource damagesource, @Nullable ExplosionDamageCalculator explosiondamagecalculator, double d0, double d1, double d2, float f, boolean flag, Explosion.Effect explosion_effect) {
@ -504,7 +465,7 @@
if (explosion_effect == Explosion.Effect.NONE) { if (explosion_effect == Explosion.Effect.NONE) {
explosion.clearBlocks(); explosion.clearBlocks();
} }
@@ -1023,13 +1229,20 @@ @@ -1023,13 +1191,20 @@
} }
public <T extends ParticleParam> int a(T t0, double d0, double d1, double d2, int i, double d3, double d4, double d5, double d6) { public <T extends ParticleParam> int a(T t0, double d0, double d1, double d2, int i, double d3, double d4, double d5, double d6) {
@ -527,7 +488,7 @@
++j; ++j;
} }
} }
@@ -1079,7 +1292,7 @@ @@ -1079,7 +1254,7 @@
@Nullable @Nullable
public BlockPosition a(StructureGenerator<?> structuregenerator, BlockPosition blockposition, int i, boolean flag) { public BlockPosition a(StructureGenerator<?> structuregenerator, BlockPosition blockposition, int i, boolean flag) {
@ -536,7 +497,7 @@
} }
@Nullable @Nullable
@@ -1116,11 +1329,21 @@ @@ -1116,11 +1291,21 @@
@Nullable @Nullable
@Override @Override
public WorldMap a(String s) { public WorldMap a(String s) {
@ -559,7 +520,7 @@
this.getMinecraftServer().E().getWorldPersistentData().a(s, (PersistentBase) worldmap); this.getMinecraftServer().E().getWorldPersistentData().a(s, (PersistentBase) worldmap);
} }
@@ -1432,6 +1655,11 @@ @@ -1432,6 +1617,11 @@
@Override @Override
public void update(BlockPosition blockposition, Block block) { public void update(BlockPosition blockposition, Block block) {
if (!this.isDebugWorld()) { if (!this.isDebugWorld()) {
@ -571,7 +532,7 @@
this.applyPhysics(blockposition, block); this.applyPhysics(blockposition, block);
} }
@@ -1451,12 +1679,12 @@ @@ -1451,12 +1641,12 @@
} }
public boolean isFlatWorld() { public boolean isFlatWorld() {
@ -586,7 +547,7 @@
} }
@Nullable @Nullable
@@ -1484,7 +1712,7 @@ @@ -1484,7 +1674,7 @@
private static <T> String a(Iterable<T> iterable, Function<T, String> function) { private static <T> String a(Iterable<T> iterable, Function<T, String> function) {
try { try {
Object2IntOpenHashMap<String> object2intopenhashmap = new Object2IntOpenHashMap(); Object2IntOpenHashMap<String> object2intopenhashmap = new Object2IntOpenHashMap();
@ -595,7 +556,7 @@
while (iterator.hasNext()) { while (iterator.hasNext()) {
T t0 = iterator.next(); T t0 = iterator.next();
@@ -1493,7 +1721,7 @@ @@ -1493,7 +1683,7 @@
object2intopenhashmap.addTo(s, 1); object2intopenhashmap.addTo(s, 1);
} }
@ -604,7 +565,7 @@
String s1 = (String) entry.getKey(); String s1 = (String) entry.getKey();
return s1 + ":" + entry.getIntValue(); return s1 + ":" + entry.getIntValue();
@@ -1504,17 +1732,33 @@ @@ -1504,17 +1694,33 @@
} }
public static void a(WorldServer worldserver) { public static void a(WorldServer worldserver) {
@ -640,7 +601,7 @@
} }
@Override @Override
@@ -1601,6 +1845,7 @@ @@ -1601,6 +1807,7 @@
} }
} }
@ -648,7 +609,7 @@
} }
public void a(Entity entity) { public void a(Entity entity) {
@@ -1633,6 +1878,7 @@ @@ -1633,6 +1840,7 @@
gameeventlistenerregistrar.a(entity.level); gameeventlistenerregistrar.a(entity.level);
} }