From 0265f4eaef9f1d2012155250576825febca4a639 Mon Sep 17 00:00:00 2001 From: Jedediah Smith Date: Tue, 22 Dec 2015 21:55:00 -0600 Subject: [PATCH] Fix player leak from entity tracker and item frames https://github.com/OvercastNetwork/SportBukkit/commit/3005a20c5c31fa89e169bd1fae9c6f93f34e1945 --- ...sition-the-first-time-an-entity-is-s.patch | 47 +++++++++++-------- 1 file changed, 28 insertions(+), 19 deletions(-) diff --git a/Spigot-Server-Patches/0062-Send-absolute-position-the-first-time-an-entity-is-s.patch b/Spigot-Server-Patches/0062-Send-absolute-position-the-first-time-an-entity-is-s.patch index 175e85b7c9..da07e91b93 100644 --- a/Spigot-Server-Patches/0062-Send-absolute-position-the-first-time-an-entity-is-s.patch +++ b/Spigot-Server-Patches/0062-Send-absolute-position-the-first-time-an-entity-is-s.patch @@ -1,22 +1,28 @@ -From 5b6d3af20b71d1941643519ce0e037432d264c17 Mon Sep 17 00:00:00 2001 +From 601b8ccd9ffc815477f336e6c54610f478726e44 Mon Sep 17 00:00:00 2001 From: Jedediah Smith Date: Fri, 3 Apr 2015 17:26:21 -0400 Subject: [PATCH] Send absolute position the first time an entity is seen diff --git a/src/main/java/net/minecraft/server/EntityTrackerEntry.java b/src/main/java/net/minecraft/server/EntityTrackerEntry.java -index f0149bf..b77de55 100644 +index f0149bf..1fc2388 100644 --- a/src/main/java/net/minecraft/server/EntityTrackerEntry.java +++ b/src/main/java/net/minecraft/server/EntityTrackerEntry.java -@@ -40,6 +40,7 @@ public class EntityTrackerEntry { +@@ -39,7 +39,12 @@ public class EntityTrackerEntry { + private boolean x; private boolean y; public boolean n; - public Set trackedPlayers = Sets.newHashSet(); -+ public Set freshViewers = Sets.newHashSet(); // PaperSpigot +- public Set trackedPlayers = Sets.newHashSet(); ++ // PaperSpigot start ++ // Replace trackedPlayers Set with a Map. The value is true until the player receives ++ // their first update (which is forced to have absolute coordinates), false afterward. ++ public java.util.Map trackedPlayerMap = new java.util.HashMap(); ++ public Set trackedPlayers = trackedPlayerMap.keySet(); ++ // PaperSpigot end public EntityTrackerEntry(Entity entity, int i, int j, boolean flag) { this.tracker = entity; -@@ -121,20 +122,20 @@ public class EntityTrackerEntry { +@@ -121,20 +126,20 @@ public class EntityTrackerEntry { boolean flag = Math.abs(j1) >= 4 || Math.abs(k1) >= 4 || Math.abs(l1) >= 4 || this.m % 60 == 0; boolean flag1 = Math.abs(l - this.yRot) >= 4 || Math.abs(i1 - this.xRot) >= 4; @@ -26,7 +32,7 @@ index f0149bf..b77de55 100644 - this.yLoc = j; - this.zLoc = k; - } -+ if (this.m > 0 || this.tracker instanceof EntityArrow) { // PaperSpigot - Move up ++ if (this.m > 0 || this.tracker instanceof EntityArrow) { // PaperSpigot - Moved up + // CraftBukkit start - Code moved from below + if (flag) { + this.xLoc = i; @@ -49,7 +55,7 @@ index f0149bf..b77de55 100644 if (j1 >= -128 && j1 < 128 && k1 >= -128 && k1 < 128 && l1 >= -128 && l1 < 128 && this.v <= 400 && !this.x && this.y == this.tracker.onGround) { if ((!flag || !flag1) && !(this.tracker instanceof EntityArrow)) { if (flag) { -@@ -173,7 +174,24 @@ public class EntityTrackerEntry { +@@ -173,7 +178,26 @@ public class EntityTrackerEntry { } if (object != null) { @@ -59,30 +65,33 @@ index f0149bf..b77de55 100644 + if (object instanceof PacketPlayOutEntityTeleport) { + this.broadcast((Packet) object); + } else { -+ PacketPlayOutEntityTeleport teleportPacket = new PacketPlayOutEntityTeleport(this.tracker.getId(), i, j, k, (byte) l, (byte) i1, this.tracker.onGround); ++ PacketPlayOutEntityTeleport teleportPacket = null; + -+ for (EntityPlayer viewer : (Set) this.trackedPlayers) { -+ if (this.freshViewers.contains(viewer)) { -+ viewer.playerConnection.sendPacket(teleportPacket); ++ for (java.util.Map.Entry viewer : trackedPlayerMap.entrySet()) { ++ if (viewer.getValue()) { ++ viewer.setValue(false); ++ if (teleportPacket == null) { ++ teleportPacket = new PacketPlayOutEntityTeleport(this.tracker.getId(), i, j, k, (byte) l, (byte) i1, this.tracker.onGround); ++ } ++ viewer.getKey().playerConnection.sendPacket(teleportPacket); + } else { -+ viewer.playerConnection.sendPacket((Packet) object); ++ viewer.getKey().playerConnection.sendPacket((Packet) object); + } + } + } -+ -+ this.freshViewers.clear(); + // PaperSpigot end } this.b(); -@@ -324,6 +342,7 @@ public class EntityTrackerEntry { +@@ -324,7 +348,7 @@ public class EntityTrackerEntry { entityplayer.removeQueue.remove(Integer.valueOf(this.tracker.getId())); // CraftBukkit end -+ this.freshViewers.add(entityplayer); // PaperSpigot - this.trackedPlayers.add(entityplayer); +- this.trackedPlayers.add(entityplayer); ++ this.trackedPlayerMap.put(entityplayer, true); // PaperBukkit Packet packet = this.c(); + entityplayer.playerConnection.sendPacket(packet); -- -2.5.2 +2.6.4