Restore world unload event for client worlds Closes #531
This commit is contained in:
parent
06727b965e
commit
c998db6a86
1 changed files with 22 additions and 8 deletions
|
@ -1,17 +1,19 @@
|
||||||
--- ../src_base/minecraft/net/minecraft/client/Minecraft.java
|
--- ../src_base/minecraft/net/minecraft/client/Minecraft.java
|
||||||
+++ ../src_work/minecraft/net/minecraft/client/Minecraft.java
|
+++ ../src_work/minecraft/net/minecraft/client/Minecraft.java
|
||||||
@@ -123,6 +123,10 @@
|
@@ -123,6 +123,12 @@
|
||||||
|
|
||||||
import com.google.common.collect.MapDifference;
|
import com.google.common.collect.MapDifference;
|
||||||
|
|
||||||
+import net.minecraftforge.common.ForgeHooks;
|
+import net.minecraftforge.common.ForgeHooks;
|
||||||
|
+import net.minecraftforge.common.MinecraftForge;
|
||||||
+import net.minecraftforge.event.ForgeEventFactory;
|
+import net.minecraftforge.event.ForgeEventFactory;
|
||||||
+import net.minecraftforge.event.entity.player.PlayerInteractEvent.Action;
|
+import net.minecraftforge.event.entity.player.PlayerInteractEvent.Action;
|
||||||
|
+import net.minecraftforge.event.world.WorldEvent;
|
||||||
+
|
+
|
||||||
@SideOnly(Side.CLIENT)
|
@SideOnly(Side.CLIENT)
|
||||||
public abstract class Minecraft implements Runnable, IPlayerUsage
|
public abstract class Minecraft implements Runnable, IPlayerUsage
|
||||||
{
|
{
|
||||||
@@ -1238,7 +1242,7 @@
|
@@ -1238,7 +1244,7 @@
|
||||||
|
|
||||||
if (this.thePlayer.canCurrentToolHarvestBlock(j, k, l))
|
if (this.thePlayer.canCurrentToolHarvestBlock(j, k, l))
|
||||||
{
|
{
|
||||||
|
@ -20,7 +22,7 @@
|
||||||
this.thePlayer.swingItem();
|
this.thePlayer.swingItem();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1304,7 +1308,8 @@
|
@@ -1304,7 +1310,8 @@
|
||||||
{
|
{
|
||||||
int j1 = itemstack != null ? itemstack.stackSize : 0;
|
int j1 = itemstack != null ? itemstack.stackSize : 0;
|
||||||
|
|
||||||
|
@ -30,7 +32,7 @@
|
||||||
{
|
{
|
||||||
flag = false;
|
flag = false;
|
||||||
this.thePlayer.swingItem();
|
this.thePlayer.swingItem();
|
||||||
@@ -1330,7 +1335,8 @@
|
@@ -1330,7 +1337,8 @@
|
||||||
{
|
{
|
||||||
ItemStack itemstack1 = this.thePlayer.inventory.getCurrentItem();
|
ItemStack itemstack1 = this.thePlayer.inventory.getCurrentItem();
|
||||||
|
|
||||||
|
@ -40,7 +42,19 @@
|
||||||
{
|
{
|
||||||
this.entityRenderer.itemRenderer.resetEquippedProgress2();
|
this.entityRenderer.itemRenderer.resetEquippedProgress2();
|
||||||
}
|
}
|
||||||
@@ -2027,6 +2033,18 @@
|
@@ -2010,6 +2018,11 @@
|
||||||
|
{
|
||||||
|
this.statFileWriter.syncStats();
|
||||||
|
|
||||||
|
+ if (theWorld != null)
|
||||||
|
+ {
|
||||||
|
+ MinecraftForge.EVENT_BUS.post(new WorldEvent.Unload(theWorld));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if (par1WorldClient == null)
|
||||||
|
{
|
||||||
|
NetClientHandler netclienthandler = this.getNetHandler();
|
||||||
|
@@ -2027,6 +2040,18 @@
|
||||||
if (this.theIntegratedServer != null)
|
if (this.theIntegratedServer != null)
|
||||||
{
|
{
|
||||||
this.theIntegratedServer.initiateShutdown();
|
this.theIntegratedServer.initiateShutdown();
|
||||||
|
@ -59,7 +73,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
this.theIntegratedServer = null;
|
this.theIntegratedServer = null;
|
||||||
@@ -2354,103 +2372,12 @@
|
@@ -2354,103 +2379,12 @@
|
||||||
if (this.objectMouseOver != null)
|
if (this.objectMouseOver != null)
|
||||||
{
|
{
|
||||||
boolean flag = this.thePlayer.capabilities.isCreativeMode;
|
boolean flag = this.thePlayer.capabilities.isCreativeMode;
|
||||||
|
@ -167,7 +181,7 @@
|
||||||
|
|
||||||
if (flag)
|
if (flag)
|
||||||
{
|
{
|
||||||
@@ -2539,11 +2466,18 @@
|
@@ -2539,11 +2473,18 @@
|
||||||
par1PlayerUsageSnooper.addData("gl_max_texture_size", Integer.valueOf(getGLMaximumTextureSize()));
|
par1PlayerUsageSnooper.addData("gl_max_texture_size", Integer.valueOf(getGLMaximumTextureSize()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -186,7 +200,7 @@
|
||||||
for (int i = 16384; i > 0; i >>= 1)
|
for (int i = 16384; i > 0; i >>= 1)
|
||||||
{
|
{
|
||||||
GL11.glTexImage2D(GL11.GL_PROXY_TEXTURE_2D, 0, GL11.GL_RGBA, i, i, 0, GL11.GL_RGBA, GL11.GL_UNSIGNED_BYTE, (ByteBuffer)null);
|
GL11.glTexImage2D(GL11.GL_PROXY_TEXTURE_2D, 0, GL11.GL_RGBA, i, i, 0, GL11.GL_RGBA, GL11.GL_UNSIGNED_BYTE, (ByteBuffer)null);
|
||||||
@@ -2551,6 +2485,7 @@
|
@@ -2551,6 +2492,7 @@
|
||||||
|
|
||||||
if (j != 0)
|
if (j != 0)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue