aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0822-Improve-scoreboard-entries.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0822-Improve-scoreboard-entries.patch')
-rw-r--r--patches/server/0822-Improve-scoreboard-entries.patch84
1 files changed, 84 insertions, 0 deletions
diff --git a/patches/server/0822-Improve-scoreboard-entries.patch b/patches/server/0822-Improve-scoreboard-entries.patch
new file mode 100644
index 0000000000..ee3bcefafe
--- /dev/null
+++ b/patches/server/0822-Improve-scoreboard-entries.patch
@@ -0,0 +1,84 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Jake Potrebic <[email protected]>
+Date: Thu, 4 Nov 2021 12:31:24 -0700
+Subject: [PATCH] Improve scoreboard entries
+
+
+diff --git a/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftObjective.java b/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftObjective.java
+index 6752cd9b3bc246fc2a7764df0d2b40d3e638fa62..c5cf800ab8cbb5ebcf1b06ad591f08be75859b8c 100644
+--- a/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftObjective.java
++++ b/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftObjective.java
+@@ -138,6 +138,14 @@ final class CraftObjective extends CraftScoreboardComponent implements Objective
+ return new CraftScore(this, entry);
+ }
+
++ // Paper start
++ @Override
++ public Score getScoreFor(org.bukkit.entity.Entity entity) throws IllegalArgumentException, IllegalStateException {
++ Validate.notNull(entity, "Entity cannot be null");
++ return getScore(((org.bukkit.craftbukkit.entity.CraftEntity) entity).getHandle().getScoreboardName());
++ }
++ // Paper end
++
+ @Override
+ public void unregister() throws IllegalStateException {
+ CraftScoreboard scoreboard = this.checkState();
+diff --git a/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftScoreboard.java b/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftScoreboard.java
+index 944080939ceaf2db8bcd7d3c01f4b97440e35cc1..0102c475b6e49777c1e24c32e5eff2992e51c89f 100644
+--- a/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftScoreboard.java
++++ b/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftScoreboard.java
+@@ -234,4 +234,23 @@ public final class CraftScoreboard implements org.bukkit.scoreboard.Scoreboard {
+ public Scoreboard getHandle() {
+ return this.board;
+ }
++ // Paper start
++ @Override
++ public ImmutableSet<Score> getScoresFor(org.bukkit.entity.Entity entity) throws IllegalArgumentException {
++ Validate.notNull(entity, "Entity cannot be null");
++ return this.getScores(((org.bukkit.craftbukkit.entity.CraftEntity) entity).getHandle().getScoreboardName());
++ }
++
++ @Override
++ public void resetScoresFor(org.bukkit.entity.Entity entity) throws IllegalArgumentException {
++ Validate.notNull(entity, "Entity cannot be null");
++ this.resetScores(((org.bukkit.craftbukkit.entity.CraftEntity) entity).getHandle().getScoreboardName());
++ }
++
++ @Override
++ public Team getEntityTeam(org.bukkit.entity.Entity entity) throws IllegalArgumentException {
++ Validate.notNull(entity, "Entity cannot be null");
++ return this.getEntryTeam(((org.bukkit.craftbukkit.entity.CraftEntity) entity).getHandle().getScoreboardName());
++ }
++ // Paper end
+ }
+diff --git a/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftTeam.java b/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftTeam.java
+index 2b87a652798cb632fe76bf20e9e7f8cb8bfb3b7b..47f2e8824fff51f4271e7aa61e233d57e3ca2942 100644
+--- a/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftTeam.java
++++ b/src/main/java/org/bukkit/craftbukkit/scoreboard/CraftTeam.java
+@@ -302,6 +302,26 @@ final class CraftTeam extends CraftScoreboardComponent implements Team {
+ }
+ }
+
++ // Paper start
++ @Override
++ public void addEntity(org.bukkit.entity.Entity entity) throws IllegalStateException, IllegalArgumentException {
++ Validate.notNull(entity, "Entity cannot be null");
++ this.addEntry(((org.bukkit.craftbukkit.entity.CraftEntity) entity).getHandle().getScoreboardName());
++ }
++
++ @Override
++ public boolean removeEntity(org.bukkit.entity.Entity entity) throws IllegalStateException, IllegalArgumentException {
++ Validate.notNull(entity, "Entity cannot be null");
++ return this.removeEntry(((org.bukkit.craftbukkit.entity.CraftEntity) entity).getHandle().getScoreboardName());
++ }
++
++ @Override
++ public boolean hasEntity(org.bukkit.entity.Entity entity) throws IllegalStateException, IllegalArgumentException {
++ Validate.notNull(entity, "Entity cannot be null");
++ return this.hasEntry(((org.bukkit.craftbukkit.entity.CraftEntity) entity).getHandle().getScoreboardName());
++ }
++ // Paper end
++
+ public static Visibility bukkitToNotch(NameTagVisibility visibility) {
+ switch (visibility) {
+ case ALWAYS: