Paper/Spigot-Server-Patches/0111-Re-track-players-that-dismount-from-other-players.patch

37 Zeilen
1.5 KiB
Diff

From b0a3d2baf0878e99b5852b16ac314019ef009af7 Mon Sep 17 00:00:00 2001
From: Zach Brown <zach.brown@destroystokyo.com>
Date: Sun, 31 Jul 2016 16:33:03 -0500
Subject: [PATCH] Re-track players that dismount from other players
diff --git a/src/main/java/net/minecraft/server/EntityPlayer.java b/src/main/java/net/minecraft/server/EntityPlayer.java
index d4bba876d0..ae1f0d5783 100644
--- a/src/main/java/net/minecraft/server/EntityPlayer.java
+++ b/src/main/java/net/minecraft/server/EntityPlayer.java
@@ -997,6 +997,14 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
if (entity1 != entity && this.playerConnection != null) {
2019-12-12 19:45:00 +01:00
this.playerConnection.a(this.locX(), this.locY(), this.locZ(), this.yaw, this.pitch);
}
+ // Paper start - "Fixes" an issue in which the vehicle player would not be notified that the passenger dismounted
+ if (entity instanceof EntityPlayer) {
2019-05-06 02:57:14 +02:00
+ // TODO verify this solution
+ WorldServer worldServer = (WorldServer) entity.getWorld();
2019-05-06 02:57:14 +02:00
+ worldServer.getChunkProvider().playerChunkMap.removeEntity(this);
+ worldServer.getChunkProvider().playerChunkMap.addEntity(this);
+ }
+ // Paper end
2019-12-12 19:45:00 +01:00
}
@@ -1013,7 +1021,6 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
2019-12-12 19:45:00 +01:00
if (!this.isSpectator()) {
super.b(blockposition);
}
-
}
2019-12-12 19:45:00 +01:00
public void a(double d0, boolean flag) {
--
2.25.1