Attempt to resolve the entity concurrency issue, by simply deferring unload

to the next tick
This commit is contained in:
Christian 2012-12-30 23:26:04 -05:00
parent 937c84090f
commit f594109b30

View file

@ -243,7 +243,26 @@
{ {
float var2 = this.getCelestialAngle(par1); float var2 = this.getCelestialAngle(par1);
float var3 = 1.0F - (MathHelper.cos(var2 * (float)Math.PI * 2.0F) * 2.0F + 0.25F); float var3 = 1.0F - (MathHelper.cos(var2 * (float)Math.PI * 2.0F) * 2.0F + 0.25F);
@@ -2095,7 +2186,7 @@ @@ -2038,16 +2129,8 @@
if (var2.isDead)
{
- var3 = var2.chunkCoordX;
- var13 = var2.chunkCoordZ;
-
- if (var2.addedToChunk && this.chunkExists(var3, var13))
- {
- this.getChunkFromChunkCoords(var3, var13).removeEntity(var2);
- }
-
- this.loadedEntityList.remove(var1--);
- this.releaseEntitySkin(var2);
+ // If it's dead, move it to the unloaded list for removal on the next tick
+ unloadedEntityList.add(var2);
}
this.theProfiler.endSection();
@@ -2095,7 +2178,7 @@
if (var11 != null) if (var11 != null)
{ {
@ -252,7 +271,7 @@
} }
} }
} }
@@ -2104,6 +2195,10 @@ @@ -2104,6 +2187,10 @@
if (!this.entityRemoval.isEmpty()) if (!this.entityRemoval.isEmpty())
{ {
@ -263,7 +282,7 @@
this.loadedTileEntityList.removeAll(this.entityRemoval); this.loadedTileEntityList.removeAll(this.entityRemoval);
this.entityRemoval.clear(); this.entityRemoval.clear();
} }
@@ -2124,18 +2219,18 @@ @@ -2124,18 +2211,18 @@
{ {
this.loadedTileEntityList.add(var12); this.loadedTileEntityList.add(var12);
} }
@ -286,7 +305,7 @@
} }
} }
@@ -2148,13 +2243,13 @@ @@ -2148,13 +2235,13 @@
public void addTileEntity(Collection par1Collection) public void addTileEntity(Collection par1Collection)
{ {
@ -307,7 +326,7 @@
} }
} }
@@ -2174,9 +2269,17 @@ @@ -2174,9 +2261,17 @@
{ {
int var3 = MathHelper.floor_double(par1Entity.posX); int var3 = MathHelper.floor_double(par1Entity.posX);
int var4 = MathHelper.floor_double(par1Entity.posZ); int var4 = MathHelper.floor_double(par1Entity.posZ);
@ -328,7 +347,7 @@
{ {
par1Entity.lastTickPosX = par1Entity.posX; par1Entity.lastTickPosX = par1Entity.posX;
par1Entity.lastTickPosY = par1Entity.posY; par1Entity.lastTickPosY = par1Entity.posY;
@@ -2409,6 +2512,14 @@ @@ -2409,6 +2504,14 @@
{ {
return true; return true;
} }
@ -343,7 +362,7 @@
} }
} }
} }
@@ -2714,25 +2825,21 @@ @@ -2714,25 +2817,21 @@
*/ */
public void setBlockTileEntity(int par1, int par2, int par3, TileEntity par4TileEntity) public void setBlockTileEntity(int par1, int par2, int par3, TileEntity par4TileEntity)
{ {
@ -384,7 +403,7 @@
} }
} }
@@ -2741,27 +2848,10 @@ @@ -2741,27 +2840,10 @@
*/ */
public void removeBlockTileEntity(int par1, int par2, int par3) public void removeBlockTileEntity(int par1, int par2, int par3)
{ {
@ -416,7 +435,7 @@
} }
} }
@@ -2787,7 +2877,8 @@ @@ -2787,7 +2869,8 @@
*/ */
public boolean isBlockNormalCube(int par1, int par2, int par3) public boolean isBlockNormalCube(int par1, int par2, int par3)
{ {
@ -426,7 +445,7 @@
} }
public boolean func_85174_u(int par1, int par2, int par3) public boolean func_85174_u(int par1, int par2, int par3)
@@ -2810,8 +2901,7 @@ @@ -2810,8 +2893,7 @@
*/ */
public boolean doesBlockHaveSolidTopSurface(int par1, int par2, int par3) public boolean doesBlockHaveSolidTopSurface(int par1, int par2, int par3)
{ {
@ -436,7 +455,7 @@
} }
/** /**
@@ -2827,7 +2917,7 @@ @@ -2827,7 +2909,7 @@
if (var5 != null && !var5.isEmpty()) if (var5 != null && !var5.isEmpty())
{ {
Block var6 = Block.blocksList[this.getBlockId(par1, par2, par3)]; Block var6 = Block.blocksList[this.getBlockId(par1, par2, par3)];
@ -445,7 +464,7 @@
} }
else else
{ {
@@ -2858,8 +2948,7 @@ @@ -2858,8 +2940,7 @@
*/ */
public void setAllowedSpawnTypes(boolean par1, boolean par2) public void setAllowedSpawnTypes(boolean par1, boolean par2)
{ {
@ -455,7 +474,7 @@
} }
/** /**
@@ -2875,6 +2964,11 @@ @@ -2875,6 +2956,11 @@
*/ */
private void calculateInitialWeather() private void calculateInitialWeather()
{ {
@ -467,7 +486,7 @@
if (this.worldInfo.isRaining()) if (this.worldInfo.isRaining())
{ {
this.rainingStrength = 1.0F; this.rainingStrength = 1.0F;
@@ -2890,6 +2984,11 @@ @@ -2890,6 +2976,11 @@
* Updates all weather states. * Updates all weather states.
*/ */
protected void updateWeather() protected void updateWeather()
@ -479,7 +498,7 @@
{ {
if (!this.provider.hasNoSky) if (!this.provider.hasNoSky)
{ {
@@ -2987,12 +3086,14 @@ @@ -2987,12 +3078,14 @@
public void toggleRain() public void toggleRain()
{ {
@ -495,7 +514,7 @@
this.theProfiler.startSection("buildList"); this.theProfiler.startSection("buildList");
int var1; int var1;
EntityPlayer var2; EntityPlayer var2;
@@ -3099,6 +3200,11 @@ @@ -3099,6 +3192,11 @@
*/ */
public boolean canBlockFreeze(int par1, int par2, int par3, boolean par4) public boolean canBlockFreeze(int par1, int par2, int par3, boolean par4)
{ {
@ -507,7 +526,7 @@
BiomeGenBase var5 = this.getBiomeGenForCoords(par1, par3); BiomeGenBase var5 = this.getBiomeGenForCoords(par1, par3);
float var6 = var5.getFloatTemperature(); float var6 = var5.getFloatTemperature();
@@ -3156,6 +3262,11 @@ @@ -3156,6 +3254,11 @@
* Tests whether or not snow can be placed at a given location * Tests whether or not snow can be placed at a given location
*/ */
public boolean canSnowAt(int par1, int par2, int par3) public boolean canSnowAt(int par1, int par2, int par3)
@ -519,7 +538,7 @@
{ {
BiomeGenBase var4 = this.getBiomeGenForCoords(par1, par3); BiomeGenBase var4 = this.getBiomeGenForCoords(par1, par3);
float var5 = var4.getFloatTemperature(); float var5 = var4.getFloatTemperature();
@@ -3249,7 +3360,7 @@ @@ -3249,7 +3352,7 @@
private int computeBlockLightValue(int par1, int par2, int par3, int par4, int par5, int par6) private int computeBlockLightValue(int par1, int par2, int par3, int par4, int par5, int par6)
{ {
@ -528,7 +547,7 @@
int var8 = this.getSavedLightValue(EnumSkyBlock.Block, par2 - 1, par3, par4) - par6; int var8 = this.getSavedLightValue(EnumSkyBlock.Block, par2 - 1, par3, par4) - par6;
int var9 = this.getSavedLightValue(EnumSkyBlock.Block, par2 + 1, par3, par4) - par6; int var9 = this.getSavedLightValue(EnumSkyBlock.Block, par2 + 1, par3, par4) - par6;
int var10 = this.getSavedLightValue(EnumSkyBlock.Block, par2, par3 - 1, par4) - par6; int var10 = this.getSavedLightValue(EnumSkyBlock.Block, par2, par3 - 1, par4) - par6;
@@ -3384,7 +3495,7 @@ @@ -3384,7 +3487,7 @@
int var21 = var24 + (var18 / 2 + 1) % 3 / 2 * var19; int var21 = var24 + (var18 / 2 + 1) % 3 / 2 * var19;
int var22 = var12 + (var18 / 2 + 2) % 3 / 2 * var19; int var22 = var12 + (var18 / 2 + 2) % 3 / 2 * var19;
var14 = this.getSavedLightValue(par1EnumSkyBlock, var20, var21, var22); var14 = this.getSavedLightValue(par1EnumSkyBlock, var20, var21, var22);
@ -537,7 +556,7 @@
if (var23 == 0) if (var23 == 0)
{ {
@@ -3415,7 +3526,7 @@ @@ -3415,7 +3518,7 @@
var12 = (var9 >> 12 & 63) - 32 + par4; var12 = (var9 >> 12 & 63) - 32 + par4;
var13 = this.getSavedLightValue(par1EnumSkyBlock, var10, var24, var12); var13 = this.getSavedLightValue(par1EnumSkyBlock, var10, var24, var12);
var14 = this.getBlockId(var10, var24, var12); var14 = this.getBlockId(var10, var24, var12);
@ -546,7 +565,7 @@
if (var15 == 0) if (var15 == 0)
{ {
@@ -3517,10 +3628,10 @@ @@ -3517,10 +3620,10 @@
public List getEntitiesWithinAABBExcludingEntity(Entity par1Entity, AxisAlignedBB par2AxisAlignedBB) public List getEntitiesWithinAABBExcludingEntity(Entity par1Entity, AxisAlignedBB par2AxisAlignedBB)
{ {
this.entitiesWithinAABBExcludingEntity.clear(); this.entitiesWithinAABBExcludingEntity.clear();
@ -561,7 +580,7 @@
for (int var7 = var3; var7 <= var4; ++var7) for (int var7 = var3; var7 <= var4; ++var7)
{ {
@@ -3546,10 +3657,10 @@ @@ -3546,10 +3649,10 @@
public List selectEntitiesWithinAABB(Class par1Class, AxisAlignedBB par2AxisAlignedBB, IEntitySelector par3IEntitySelector) public List selectEntitiesWithinAABB(Class par1Class, AxisAlignedBB par2AxisAlignedBB, IEntitySelector par3IEntitySelector)
{ {
@ -576,7 +595,7 @@
ArrayList var8 = new ArrayList(); ArrayList var8 = new ArrayList();
for (int var9 = var4; var9 <= var5; ++var9) for (int var9 = var4; var9 <= var5; ++var9)
@@ -3642,11 +3753,14 @@ @@ -3642,11 +3745,14 @@
*/ */
public void addLoadedEntities(List par1List) public void addLoadedEntities(List par1List)
{ {
@ -594,7 +613,7 @@
} }
} }
@@ -3680,6 +3794,11 @@ @@ -3680,6 +3786,11 @@
else else
{ {
if (var9 != null && (var9 == Block.waterMoving || var9 == Block.waterStill || var9 == Block.lavaMoving || var9 == Block.lavaStill || var9 == Block.fire || var9.blockMaterial.isReplaceable())) if (var9 != null && (var9 == Block.waterMoving || var9 == Block.waterStill || var9 == Block.lavaMoving || var9 == Block.lavaStill || var9 == Block.fire || var9.blockMaterial.isReplaceable()))
@ -606,7 +625,7 @@
{ {
var9 = null; var9 = null;
} }
@@ -3897,7 +4016,7 @@ @@ -3897,7 +4008,7 @@
*/ */
public long getSeed() public long getSeed()
{ {
@ -615,7 +634,7 @@
} }
public long getTotalWorldTime() public long getTotalWorldTime()
@@ -3907,7 +4026,7 @@ @@ -3907,7 +4018,7 @@
public long getWorldTime() public long getWorldTime()
{ {
@ -624,7 +643,7 @@
} }
/** /**
@@ -3915,7 +4034,7 @@ @@ -3915,7 +4026,7 @@
*/ */
public void setWorldTime(long par1) public void setWorldTime(long par1)
{ {
@ -633,7 +652,7 @@
} }
/** /**
@@ -3923,13 +4042,13 @@ @@ -3923,13 +4034,13 @@
*/ */
public ChunkCoordinates getSpawnPoint() public ChunkCoordinates getSpawnPoint()
{ {
@ -649,7 +668,7 @@
} }
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
@@ -3953,7 +4072,10 @@ @@ -3953,7 +4064,10 @@
if (!this.loadedEntityList.contains(par1Entity)) if (!this.loadedEntityList.contains(par1Entity))
{ {
@ -661,7 +680,7 @@
} }
} }
@@ -3961,6 +4083,11 @@ @@ -3961,6 +4075,11 @@
* Called when checking if a certain block can be mined or not. The 'spawn safe zone' check is located here. * Called when checking if a certain block can be mined or not. The 'spawn safe zone' check is located here.
*/ */
public boolean canMineBlock(EntityPlayer par1EntityPlayer, int par2, int par3, int par4) public boolean canMineBlock(EntityPlayer par1EntityPlayer, int par2, int par3, int par4)
@ -673,7 +692,7 @@
{ {
return true; return true;
} }
@@ -4081,8 +4208,7 @@ @@ -4081,8 +4200,7 @@
*/ */
public boolean isBlockHighHumidity(int par1, int par2, int par3) public boolean isBlockHighHumidity(int par1, int par2, int par3)
{ {
@ -683,7 +702,7 @@
} }
/** /**
@@ -4157,7 +4283,7 @@ @@ -4157,7 +4275,7 @@
*/ */
public int getHeight() public int getHeight()
{ {
@ -692,7 +711,7 @@
} }
/** /**
@@ -4165,7 +4291,7 @@ @@ -4165,7 +4283,7 @@
*/ */
public int getActualHeight() public int getActualHeight()
{ {
@ -701,7 +720,7 @@
} }
public IUpdatePlayerListBox func_82735_a(EntityMinecart par1EntityMinecart) public IUpdatePlayerListBox func_82735_a(EntityMinecart par1EntityMinecart)
@@ -4208,7 +4334,7 @@ @@ -4208,7 +4326,7 @@
*/ */
public double getHorizon() public double getHorizon()
{ {
@ -710,7 +729,7 @@
} }
/** /**
@@ -4269,4 +4395,75 @@ @@ -4269,4 +4387,75 @@
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
public void func_92088_a(double par1, double par3, double par5, double par7, double par9, double par11, NBTTagCompound par13NBTTagCompound) {} public void func_92088_a(double par1, double par3, double par5, double par7, double par9, double par11, NBTTagCompound par13NBTTagCompound) {}