From 6c0f3574b1964d5ad016cad43f3b16e022a62109 Mon Sep 17 00:00:00 2001 From: CraftBukkit/Spigot Date: Wed, 7 Mar 2018 21:43:33 +1100 Subject: [PATCH] SPIGOT-3845: Fix spawnRadius on respawn Thanks senmori for the investigation in PR #431 By: md_5 --- paper-server/nms-patches/EntityPlayer.patch | 130 ++++++++++++-------- paper-server/nms-patches/PlayerList.patch | 2 +- 2 files changed, 82 insertions(+), 50 deletions(-) diff --git a/paper-server/nms-patches/EntityPlayer.patch b/paper-server/nms-patches/EntityPlayer.patch index 4081768d63..364fe7e447 100644 --- a/paper-server/nms-patches/EntityPlayer.patch +++ b/paper-server/nms-patches/EntityPlayer.patch @@ -29,7 +29,7 @@ public PlayerConnection playerConnection; public final MinecraftServer server; public final PlayerInteractManager playerInteractManager; -@@ -50,6 +67,19 @@ +@@ -50,10 +67,45 @@ public int ping; public boolean viewingCredits; @@ -49,19 +49,53 @@ public EntityPlayer(MinecraftServer minecraftserver, WorldServer worldserver, GameProfile gameprofile, PlayerInteractManager playerinteractmanager) { super(worldserver, gameprofile); playerinteractmanager.player = this; -@@ -81,6 +111,11 @@ - this.setPosition(this.locX, this.locY + 1.0D, this.locZ); - } - + this.playerInteractManager = playerinteractmanager; ++ // CraftBukkit start ++ BlockPosition blockposition = getSpawnPoint(minecraftserver, worldserver); ++ ++ this.server = minecraftserver; ++ this.bZ = minecraftserver.getPlayerList().getStatisticManager(this); ++ this.bY = minecraftserver.getPlayerList().h(this); ++ this.P = 1.0F; ++ this.setPositionRotation(blockposition, 0.0F, 0.0F); ++ // CraftBukkit end ++ ++ while (!worldserver.getCubes(this, this.getBoundingBox()).isEmpty() && this.locY < 255.0D) { ++ this.setPosition(this.locX, this.locY + 1.0D, this.locZ); ++ } ++ + // CraftBukkit start + this.displayName = this.getName(); + this.canPickUpLoot = true; + this.maxHealthCache = this.getMaxHealth(); + // CraftBukkit end ++ } ++ ++ public final BlockPosition getSpawnPoint(MinecraftServer minecraftserver, WorldServer worldserver) { + BlockPosition blockposition = worldserver.getSpawn(); + + if (worldserver.worldProvider.m() && worldserver.getWorldData().getGameType() != EnumGamemode.ADVENTURE) { +@@ -71,17 +123,9 @@ + blockposition = worldserver.q(blockposition.a(this.random.nextInt(i * 2 + 1) - i, 0, this.random.nextInt(i * 2 + 1) - i)); + } + +- this.server = minecraftserver; +- this.bZ = minecraftserver.getPlayerList().getStatisticManager(this); +- this.bY = minecraftserver.getPlayerList().h(this); +- this.P = 1.0F; +- this.setPositionRotation(blockposition, 0.0F, 0.0F); +- +- while (!worldserver.getCubes(this, this.getBoundingBox()).isEmpty() && this.locY < 255.0D) { +- this.setPosition(this.locX, this.locY + 1.0D, this.locZ); +- } +- ++ return blockposition; } ++ // CraftBukkit end public void a(NBTTagCompound nbttagcompound) { -@@ -103,6 +138,7 @@ + super.a(nbttagcompound); +@@ -103,6 +147,7 @@ if (nbttagcompound.hasKeyOfType("recipeBook", 10)) { this.cr.a(nbttagcompound.getCompound("recipeBook")); } @@ -69,13 +103,13 @@ } -@@ -149,8 +185,34 @@ +@@ -149,7 +194,33 @@ } nbttagcompound.set("recipeBook", this.cr.c()); + this.getBukkitEntity().setExtraData(nbttagcompound); // CraftBukkit - } - ++ } ++ + // CraftBukkit start - World fallback code, either respawn location or global spawn + public void spawnIn(World world) { + super.spawnIn(world); @@ -98,13 +132,12 @@ + } + this.dimension = ((WorldServer) this.world).dimension; + this.playerInteractManager.a((WorldServer) world); -+ } + } + // CraftBukkit end -+ + public void levelDown(int i) { super.levelDown(i); - this.lastSentExp = -1; -@@ -184,6 +246,11 @@ +@@ -184,6 +255,11 @@ } public void B_() { @@ -116,7 +149,7 @@ this.playerInteractManager.a(); --this.invulnerableTicks; if (this.noDamageTicks > 0) { -@@ -249,7 +316,7 @@ +@@ -249,7 +325,7 @@ } if (this.getHealth() != this.lastHealthSent || this.ch != this.foodData.getFoodLevel() || this.foodData.getSaturationLevel() == 0.0F != this.ci) { @@ -125,7 +158,7 @@ this.lastHealthSent = this.getHealth(); this.ch = this.foodData.getFoodLevel(); this.ci = this.foodData.getSaturationLevel() == 0.0F; -@@ -270,6 +337,12 @@ +@@ -270,6 +346,12 @@ this.a(IScoreboardCriteria.i, MathHelper.f((float) this.cc)); } @@ -138,7 +171,7 @@ if (this.getArmorStrength() != this.cd) { this.cd = this.getArmorStrength(); this.a(IScoreboardCriteria.j, MathHelper.f((float) this.cd)); -@@ -294,6 +367,16 @@ +@@ -294,6 +376,16 @@ CriterionTriggers.o.a(this); } @@ -155,7 +188,7 @@ } catch (Throwable throwable) { CrashReport crashreport = CrashReport.a(throwable, "Ticking player"); CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Player being ticked"); -@@ -304,12 +387,11 @@ +@@ -304,12 +396,11 @@ } private void a(IScoreboardCriteria iscoreboardcriteria, int i) { @@ -170,7 +203,7 @@ scoreboardscore.setScore(i); } -@@ -320,32 +402,62 @@ +@@ -320,32 +411,62 @@ boolean flag = this.world.getGameRules().getBoolean("showDeathMessages"); this.playerConnection.sendPacket(new PacketPlayOutCombatEvent(this.getCombatTracker(), PacketPlayOutCombatEvent.EnumCombatEventType.ENTITY_DIED, flag)); @@ -192,15 +225,15 @@ + } + + IChatBaseComponent chatmessage = this.getCombatTracker().getDeathMessage(); ++ ++ String deathmessage = chatmessage.toPlainText(); ++ org.bukkit.event.entity.PlayerDeathEvent event = CraftEventFactory.callPlayerDeathEvent(this, loot, deathmessage, keepInventory); - if (scoreboardteambase != null && scoreboardteambase.getDeathMessageVisibility() != ScoreboardTeamBase.EnumNameTagVisibility.ALWAYS) { - if (scoreboardteambase.getDeathMessageVisibility() == ScoreboardTeamBase.EnumNameTagVisibility.HIDE_FOR_OTHER_TEAMS) { - this.server.getPlayerList().a((EntityHuman) this, this.getCombatTracker().getDeathMessage()); - } else if (scoreboardteambase.getDeathMessageVisibility() == ScoreboardTeamBase.EnumNameTagVisibility.HIDE_FOR_OWN_TEAM) { - this.server.getPlayerList().b((EntityHuman) this, this.getCombatTracker().getDeathMessage()); -+ String deathmessage = chatmessage.toPlainText(); -+ org.bukkit.event.entity.PlayerDeathEvent event = CraftEventFactory.callPlayerDeathEvent(this, loot, deathmessage, keepInventory); -+ + String deathMessage = event.getDeathMessage(); + + if (deathMessage != null && deathMessage.length() > 0 && flag) { // TODO: allow plugins to override? @@ -247,7 +280,7 @@ scoreboardscore.incrementScore(); } -@@ -373,29 +485,36 @@ +@@ -373,29 +494,36 @@ if (entity != this) { super.a(entity, i, damagesource); this.addScore(i); @@ -290,7 +323,7 @@ String s = entity instanceof EntityHuman ? entity.getName() : entity.bn(); ScoreboardTeam scoreboardteam = this.getScoreboard().getPlayerTeam(this.getName()); -@@ -420,7 +539,10 @@ +@@ -420,7 +548,10 @@ int j = scoreboardteam1.getColor().b(); if (j >= 0 && j < IScoreboardCriteria.m.length) { @@ -302,7 +335,7 @@ } } -@@ -462,12 +584,14 @@ +@@ -462,12 +593,14 @@ } private boolean canPvP() { @@ -319,7 +352,7 @@ if (this.dimension == 0 && i == -1) { this.cv = new Vec3D(this.locX, this.locY, this.locZ); } else if (this.dimension != -1 && i != 0) { -@@ -475,6 +599,7 @@ +@@ -475,6 +608,7 @@ } if (this.dimension == 1 && i == 1) { @@ -327,7 +360,7 @@ this.world.kill(this); if (!this.viewingCredits) { this.viewingCredits = true; -@@ -488,7 +613,10 @@ +@@ -488,7 +622,10 @@ i = 1; } @@ -339,7 +372,7 @@ this.playerConnection.sendPacket(new PacketPlayOutWorldEvent(1032, BlockPosition.ZERO, 0, false)); this.lastSentExp = -1; this.lastHealthSent = -1.0F; -@@ -534,6 +662,7 @@ +@@ -534,6 +671,7 @@ } public void a(boolean flag, boolean flag1, boolean flag2) { @@ -347,7 +380,7 @@ if (this.isSleeping()) { this.x().getTracker().sendPacketToEntity(this, new PacketPlayOutAnimation(this, 2)); } -@@ -612,23 +741,55 @@ +@@ -612,23 +750,55 @@ this.playerConnection.sendPacket(new PacketPlayOutOpenSignEditor(tileentitysign.getPosition())); } @@ -406,7 +439,7 @@ if (iinventory instanceof ILootable && ((ILootable) iinventory).b() != null && this.isSpectator()) { this.a((new ChatMessage("container.spectatorCantOpen", new Object[0])).setChatModifier((new ChatModifier()).setColor(EnumChatFormat.RED)), true); } else { -@@ -642,18 +803,21 @@ +@@ -642,18 +812,21 @@ if (itileinventory.isLocked() && !this.a(itileinventory.getLock()) && !this.isSpectator()) { this.playerConnection.sendPacket(new PacketPlayOutChat(new ChatMessage("container.isLocked", new Object[] { iinventory.getScoreboardDisplayName()}), ChatMessageType.GAME_INFO)); this.playerConnection.sendPacket(new PacketPlayOutNamedSoundEffect(SoundEffects.ab, SoundCategory.BLOCKS, this.locX, this.locY, this.locZ, 1.0F, 1.0F)); @@ -430,7 +463,7 @@ this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); -@@ -661,8 +825,14 @@ +@@ -661,8 +834,14 @@ } public void openTrade(IMerchant imerchant) { @@ -446,7 +479,7 @@ this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); InventoryMerchant inventorymerchant = ((ContainerMerchant) this.activeContainer).e(); -@@ -682,13 +852,20 @@ +@@ -682,13 +861,20 @@ } public void openHorseInventory(EntityHorseAbstract entityhorseabstract, IInventory iinventory) { @@ -468,7 +501,7 @@ this.activeContainer.windowId = this.containerCounter; this.activeContainer.addSlotListener(this); } -@@ -729,6 +906,11 @@ +@@ -729,6 +915,11 @@ public void a(Container container, NonNullList nonnulllist) { this.playerConnection.sendPacket(new PacketPlayOutWindowItems(container.windowId, nonnulllist)); this.playerConnection.sendPacket(new PacketPlayOutSetSlot(-1, -1, this.inventory.getCarried())); @@ -480,7 +513,7 @@ } public void setContainerData(Container container, int i, int j) { -@@ -743,6 +925,7 @@ +@@ -743,6 +934,7 @@ } public void closeInventory() { @@ -488,7 +521,7 @@ this.playerConnection.sendPacket(new PacketPlayOutCloseWindow(this.activeContainer.windowId)); this.r(); } -@@ -814,10 +997,16 @@ +@@ -814,10 +1006,16 @@ for (int j = 0; j < i; ++j) { MinecraftKey minecraftkey = aminecraftkey1[j]; @@ -506,25 +539,24 @@ } public void b(List list) { -@@ -839,8 +1028,17 @@ +@@ -839,7 +1037,16 @@ public void triggerHealthUpdate() { this.lastHealthSent = -1.0E8F; + this.lastSentExp = -1; // CraftBukkit - Added to reset - } - ++ } ++ + // CraftBukkit start - Support multi-line messages + public void sendMessage(IChatBaseComponent[] ichatbasecomponent) { + for (IChatBaseComponent component : ichatbasecomponent) { + this.sendMessage(component); + } -+ } + } + // CraftBukkit end -+ + public void a(IChatBaseComponent ichatbasecomponent, boolean flag) { this.playerConnection.sendPacket(new PacketPlayOutChat(ichatbasecomponent, flag ? ChatMessageType.GAME_INFO : ChatMessageType.CHAT)); - } -@@ -879,7 +1077,7 @@ +@@ -879,7 +1086,7 @@ this.lastSentExp = -1; this.lastHealthSent = -1.0F; this.ch = -1; @@ -533,7 +565,7 @@ this.removeQueue.addAll(entityplayer.removeQueue); this.cq = entityplayer.cq; this.cv = entityplayer.cv; -@@ -938,6 +1136,18 @@ +@@ -938,6 +1145,18 @@ } public void a(EnumGamemode enumgamemode) { @@ -552,7 +584,7 @@ this.playerInteractManager.setGameMode(enumgamemode); this.playerConnection.sendPacket(new PacketPlayOutGameStateChange(3, (float) enumgamemode.getId())); if (enumgamemode == EnumGamemode.SPECTATOR) { -@@ -964,6 +1174,7 @@ +@@ -964,6 +1183,7 @@ } public boolean a(int i, String s) { @@ -560,7 +592,7 @@ if ("seed".equals(s) && !this.server.aa()) { return true; } else if (!"tell".equals(s) && !"help".equals(s) && !"me".equals(s) && !"trigger".equals(s)) { -@@ -977,6 +1188,15 @@ +@@ -977,6 +1197,15 @@ } else { return true; } @@ -576,7 +608,7 @@ } public String A() { -@@ -988,6 +1208,16 @@ +@@ -988,6 +1217,16 @@ } public void a(PacketPlayInSettings packetplayinsettings) { @@ -593,7 +625,7 @@ this.locale = packetplayinsettings.a(); this.cl = packetplayinsettings.c(); this.cm = packetplayinsettings.d(); -@@ -1053,7 +1283,7 @@ +@@ -1053,7 +1292,7 @@ this.co = (Entity) (entity == null ? this : entity); if (entity1 != this.co) { this.playerConnection.sendPacket(new PacketPlayOutCamera(this.co)); @@ -602,7 +634,7 @@ } } -@@ -1080,7 +1310,7 @@ +@@ -1080,7 +1319,7 @@ @Nullable public IChatBaseComponent getPlayerListName() { @@ -611,7 +643,7 @@ } public void a(EnumHand enumhand) { -@@ -1097,12 +1327,17 @@ +@@ -1097,12 +1336,17 @@ } public void N() { @@ -629,7 +661,7 @@ } public AdvancementDataPlayer getAdvancementData() { -@@ -1113,4 +1348,144 @@ +@@ -1113,4 +1357,144 @@ public Vec3D Q() { return this.cv; } diff --git a/paper-server/nms-patches/PlayerList.patch b/paper-server/nms-patches/PlayerList.patch index 0a9fd678fd..c61f54fd05 100644 --- a/paper-server/nms-patches/PlayerList.patch +++ b/paper-server/nms-patches/PlayerList.patch @@ -484,7 +484,7 @@ + + if (location == null) { + cworld = (CraftWorld) this.server.server.getWorlds().get(0); -+ blockposition = cworld.getHandle().getSpawn(); ++ blockposition = entityplayer1.getSpawnPoint(this.server, cworld.getHandle()); + location = new Location(cworld, (double) ((float) blockposition.getX() + 0.5F), (double) ((float) blockposition.getY() + 0.1F), (double) ((float) blockposition.getZ() + 0.5F)); } +