From 82d6028aa7e39cc73c0deabe0c58d22627b6dc51 Mon Sep 17 00:00:00 2001 From: Aikar Date: Wed, 17 Oct 2018 19:30:57 -0400 Subject: [PATCH] MC-50319: Check other worlds for shooter of projectiles Say a player shoots an arrow through a nether portal, the game would lose the shooter for determining things such as Player Kills, because the entity is in another world. If the projectile fails to find the shooter in the current world, check other worlds. --- ...ther-worlds-for-shooter-of-projectil.patch | 40 +++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 Spigot-Server-Patches/MC-50319-Check-other-worlds-for-shooter-of-projectil.patch diff --git a/Spigot-Server-Patches/MC-50319-Check-other-worlds-for-shooter-of-projectil.patch b/Spigot-Server-Patches/MC-50319-Check-other-worlds-for-shooter-of-projectil.patch new file mode 100644 index 000000000..efd7a52e3 --- /dev/null +++ b/Spigot-Server-Patches/MC-50319-Check-other-worlds-for-shooter-of-projectil.patch @@ -0,0 +1,40 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Aikar +Date: Wed, 17 Oct 2018 19:17:27 -0400 +Subject: [PATCH] MC-50319: Check other worlds for shooter of projectiles + +Say a player shoots an arrow through a nether portal, the game +would lose the shooter for determining things such as Player Kills, +because the entity is in another world. + +If the projectile fails to find the shooter in the current world, check +other worlds. + +diff --git a/src/main/java/net/minecraft/server/EntityProjectile.java b/src/main/java/net/minecraft/server/EntityProjectile.java +index dd8af4be80..b4a5bc600f 100644 +--- a/src/main/java/net/minecraft/server/EntityProjectile.java ++++ b/src/main/java/net/minecraft/server/EntityProjectile.java +@@ -0,0 +0,0 @@ public abstract class EntityProjectile extends Entity implements IProjectile { + public EntityLiving getShooter() { + if (this.shooter == null && this.shooterId != null && this.world instanceof WorldServer) { + Entity entity = ((WorldServer) this.world).getEntity(this.shooterId); ++ // Paper start - MC-50319 - shooter might be in another world (arrows through portals) ++ if (entity == null) { ++ for (WorldServer world : world.getMinecraftServer().getWorlds()) { ++ entity = world.getEntity(this.shooterId); ++ if (entity != null) { ++ break; ++ } ++ } ++ } ++ // Paper end + + if (entity instanceof EntityLiving) { + this.shooter = (EntityLiving) entity; + } else { +- this.shooterId = null; ++ //this.shooterId = null; // Paper - don't unset shooterId + } + } + +-- \ No newline at end of file