aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0888-Fix-team-sidebar-objectives-not-being-cleared.patch
diff options
context:
space:
mode:
authorLulu13022002 <[email protected]>2024-09-21 21:19:02 +0200
committerGitHub <[email protected]>2024-09-21 21:19:02 +0200
commit1ed64f82704c299d0f7ae9af710579be995af8de (patch)
tree8de9a329fed8373ae5eccc59a9ee9558a53ee3fd /patches/server/0888-Fix-team-sidebar-objectives-not-being-cleared.patch
parent593faf4fc3ad433ef523672b6553124dd99f8ca3 (diff)
downloadPaper-1ed64f82704c299d0f7ae9af710579be995af8de.tar.gz
Paper-1ed64f82704c299d0f7ae9af710579be995af8de.zip
Update launchProjectile API (#11300)
Diffstat (limited to 'patches/server/0888-Fix-team-sidebar-objectives-not-being-cleared.patch')
-rw-r--r--patches/server/0888-Fix-team-sidebar-objectives-not-being-cleared.patch25
1 files changed, 25 insertions, 0 deletions
diff --git a/patches/server/0888-Fix-team-sidebar-objectives-not-being-cleared.patch b/patches/server/0888-Fix-team-sidebar-objectives-not-being-cleared.patch
new file mode 100644
index 0000000000..88a39d0b20
--- /dev/null
+++ b/patches/server/0888-Fix-team-sidebar-objectives-not-being-cleared.patch
@@ -0,0 +1,25 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Jake Potrebic <[email protected]>
+Date: Sat, 23 Sep 2023 22:31:54 -0700
+Subject: [PATCH] Fix team sidebar objectives not being cleared
+
+Objectives displayed in team sidebars were not cleared when switching
+scoreboards. If a player's scoreboard has a displayed objective for the
+'gold' sidebar, and their scoreboard was switched to one where they
+still had a 'gold' team, it would still be displayed
+
+diff --git a/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftScoreboardManager.java b/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftScoreboardManager.java
+index cad42a0f3c016bf65181e50d139ae4e2fb9158a5..b3e1adeb932da9b3bed16acd94e2f16da48a7c72 100644
+--- a/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftScoreboardManager.java
++++ b/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftScoreboardManager.java
+@@ -87,8 +87,8 @@ public final class CraftScoreboardManager implements ScoreboardManager {
+
+ // Old objective tracking
+ HashSet<Objective> removed = new HashSet<>();
+- for (int i = 0; i < 3; ++i) {
+- Objective scoreboardobjective = oldboard.getDisplayObjective(net.minecraft.world.scores.DisplaySlot.BY_ID.apply(i));
++ for (net.minecraft.world.scores.DisplaySlot slot : net.minecraft.world.scores.DisplaySlot.values()) { // Paper - clear all display slots
++ Objective scoreboardobjective = oldboard.getDisplayObjective(slot); // Paper - clear all display slots
+ if (scoreboardobjective != null && !removed.contains(scoreboardobjective)) {
+ entityplayer.connection.send(new ClientboundSetObjectivePacket(scoreboardobjective, 1));
+ removed.add(scoreboardobjective);