Update from upstream SpigotMC
Upstream merge (we must go deeper) SpigotMC/Spigot@1e7bc383c3
This commit is contained in:
61
CraftBukkit-Patches/0169-Plug-WorldMap-Memory-Leak.patch
Normal file
61
CraftBukkit-Patches/0169-Plug-WorldMap-Memory-Leak.patch
Normal file
@@ -0,0 +1,61 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: md_5 <git@md-5.net>
|
||||
Date: Fri, 8 Aug 2014 19:57:03 +1000
|
||||
Subject: [PATCH] Plug WorldMap Memory Leak
|
||||
|
||||
|
||||
diff --git a/src/main/java/net/minecraft/server/PersistentCollection.java b/src/main/java/net/minecraft/server/PersistentCollection.java
|
||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||
--- a/src/main/java/net/minecraft/server/PersistentCollection.java
|
||||
+++ b/src/main/java/net/minecraft/server/PersistentCollection.java
|
||||
@@ -0,0 +0,0 @@ public class PersistentCollection {
|
||||
|
||||
private IDataManager a;
|
||||
private Map b = new HashMap();
|
||||
- private List c = new ArrayList();
|
||||
+ public List c = new ArrayList(); // Spigot
|
||||
private Map d = new HashMap();
|
||||
|
||||
public PersistentCollection(IDataManager idatamanager) {
|
||||
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||
--- a/src/main/java/net/minecraft/server/World.java
|
||||
+++ b/src/main/java/net/minecraft/server/World.java
|
||||
@@ -0,0 +0,0 @@ public abstract class World implements IBlockAccess {
|
||||
entity.die();
|
||||
if (entity instanceof EntityHuman) {
|
||||
this.players.remove(entity);
|
||||
+ // Spigot start
|
||||
+ for ( Object o : worldMaps.c )
|
||||
+ {
|
||||
+ if ( o instanceof WorldMap )
|
||||
+ {
|
||||
+ WorldMap map = (WorldMap) o;
|
||||
+ map.i.remove( entity );
|
||||
+ for ( Iterator<WorldMapHumanTracker> iter = (Iterator<WorldMapHumanTracker>) map.f.iterator(); iter.hasNext(); )
|
||||
+ {
|
||||
+ if ( iter.next().trackee == entity )
|
||||
+ {
|
||||
+ iter.remove();
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+ // Spigot end
|
||||
this.everyoneSleeping();
|
||||
}
|
||||
}
|
||||
diff --git a/src/main/java/net/minecraft/server/WorldMap.java b/src/main/java/net/minecraft/server/WorldMap.java
|
||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||
--- a/src/main/java/net/minecraft/server/WorldMap.java
|
||||
+++ b/src/main/java/net/minecraft/server/WorldMap.java
|
||||
@@ -0,0 +0,0 @@ public class WorldMap extends PersistentBase {
|
||||
public byte scale;
|
||||
public byte[] colors = new byte[16384];
|
||||
public List f = new ArrayList();
|
||||
- private Map i = new HashMap();
|
||||
+ public Map i = new HashMap(); // Spigot
|
||||
public Map decorations = new LinkedHashMap();
|
||||
|
||||
// CraftBukkit start
|
||||
--
|
||||
Reference in New Issue
Block a user