mirror of
https://github.com/PaperMC/Paper.git
synced 2025-07-31 12:12:08 -07:00
Fix and add new scoreboard API (#10037)
This commit is contained in:
90
patches/api/Add-more-scoreboard-API.patch
Normal file
90
patches/api/Add-more-scoreboard-API.patch
Normal file
@@ -0,0 +1,90 @@
|
||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
||||
Date: Sat, 16 Dec 2023 14:45:46 -0800
|
||||
Subject: [PATCH] Add more scoreboard API
|
||||
|
||||
|
||||
diff --git a/src/main/java/org/bukkit/scoreboard/Objective.java b/src/main/java/org/bukkit/scoreboard/Objective.java
|
||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||
--- a/src/main/java/org/bukkit/scoreboard/Objective.java
|
||||
+++ b/src/main/java/org/bukkit/scoreboard/Objective.java
|
||||
@@ -0,0 +0,0 @@ public interface Objective {
|
||||
*/
|
||||
@NotNull Score getScoreFor(@NotNull org.bukkit.entity.Entity entity) throws IllegalArgumentException, IllegalStateException;
|
||||
// Paper end - improve scoreboard entries
|
||||
+
|
||||
+ // Paper start - add more score API
|
||||
+ /**
|
||||
+ * Gets if this objective will auto update score
|
||||
+ * displays on changes.
|
||||
+ *
|
||||
+ * @return true if auto updating
|
||||
+ * @throws IllegalStateException if this objective has been unregistered
|
||||
+ */
|
||||
+ boolean willAutoUpdateDisplay();
|
||||
+
|
||||
+ /**
|
||||
+ * Sets if this objective will auto update
|
||||
+ * score displays on changes.
|
||||
+ *
|
||||
+ * @param autoUpdateDisplay true to auto update
|
||||
+ * @throws IllegalStateException if this objective has been unregistered
|
||||
+ */
|
||||
+ void setAutoUpdateDisplay(boolean autoUpdateDisplay);
|
||||
+ // Paper end - add more score API
|
||||
}
|
||||
diff --git a/src/main/java/org/bukkit/scoreboard/Score.java b/src/main/java/org/bukkit/scoreboard/Score.java
|
||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||
--- a/src/main/java/org/bukkit/scoreboard/Score.java
|
||||
+++ b/src/main/java/org/bukkit/scoreboard/Score.java
|
||||
@@ -0,0 +0,0 @@ public interface Score {
|
||||
*/
|
||||
void resetScore() throws IllegalStateException;
|
||||
// Paper end
|
||||
+
|
||||
+ // Paper start - add more score API
|
||||
+ /**
|
||||
+ * Gets if this score is triggerable and cannot
|
||||
+ * be used by the {@code /trigger} command executed
|
||||
+ * by the owner of this score.
|
||||
+ *
|
||||
+ * @return true if triggerable, false if not triggerable, score isn't set, or the objective isn't {@link Criteria#TRIGGER}
|
||||
+ * @throws IllegalStateException if the associated objective has been unregistered
|
||||
+ */
|
||||
+ boolean isTriggerable();
|
||||
+
|
||||
+ /**
|
||||
+ * Sets if this score is triggerable and can
|
||||
+ * be used by the {@code /trigger} command
|
||||
+ * executed by the owner of this score. Can
|
||||
+ * only be set on {@link Criteria#TRIGGER} objectives.
|
||||
+ * <p>
|
||||
+ * If the score doesn't exist (aka {@link #isScoreSet()} returns false),
|
||||
+ * this will create the score with a 0 value.
|
||||
+ *
|
||||
+ * @param triggerable true to enable trigger, false to disable
|
||||
+ * @throws IllegalArgumentException if this objective isn't {@link Criteria#TRIGGER}
|
||||
+ * @throws IllegalStateException if the associated objective has been unregistered
|
||||
+ */
|
||||
+ void setTriggerable(boolean triggerable);
|
||||
+
|
||||
+ /**
|
||||
+ * Get the custom name for this entry.
|
||||
+ *
|
||||
+ * @return the custom name or null if not set (or score isn't set)
|
||||
+ * @throws IllegalStateException if the associated objective has been unregistered
|
||||
+ */
|
||||
+ @Nullable net.kyori.adventure.text.Component customName();
|
||||
+
|
||||
+ /**
|
||||
+ * Sets the custom name for this entry.
|
||||
+ * <p>
|
||||
+ * If the score doesn't exist (aka {@link #isScoreSet()} returns false),
|
||||
+ * this will create the score with a 0 value.
|
||||
+ *
|
||||
+ * @param customName the custom name or null to reset
|
||||
+ * @throws IllegalStateException if the associated objective has been unregistered
|
||||
+ */
|
||||
+ void customName(net.kyori.adventure.text.@Nullable Component customName);
|
||||
+ // Paper end - add more score API
|
||||
}
|
Reference in New Issue
Block a user