2022-12-09 09:34:39 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
|
|
|
Date: Fri, 9 Dec 2022 01:34:03 -0800
|
2022-12-09 09:49:15 +00:00
|
|
|
Subject: [PATCH] fix Instruments
|
2022-12-09 09:34:39 +00:00
|
|
|
|
2022-12-09 09:49:15 +00:00
|
|
|
Add missing instrument enums
|
|
|
|
fix some wrong javadocs
|
2022-12-09 09:34:39 +00:00
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/Instrument.java b/src/main/java/org/bukkit/Instrument.java
|
2023-04-09 00:00:50 +00:00
|
|
|
index 8f70d86a1d39351424335842c38625d42cfbdfb8..271fb4d41909654b87519edba1c1d4f418cdd3a5 100644
|
2022-12-09 09:34:39 +00:00
|
|
|
--- a/src/main/java/org/bukkit/Instrument.java
|
|
|
|
+++ b/src/main/java/org/bukkit/Instrument.java
|
2023-04-09 00:00:50 +00:00
|
|
|
@@ -8,7 +8,7 @@ import org.jetbrains.annotations.Nullable;
|
2022-12-09 09:49:15 +00:00
|
|
|
public enum Instrument {
|
|
|
|
|
|
|
|
/**
|
|
|
|
- * Piano is the standard instrument for a note block.
|
|
|
|
+ * Piano (Harp) is the standard instrument for a note block.
|
|
|
|
*/
|
|
|
|
PIANO(0x0),
|
|
|
|
/**
|
2023-04-09 00:00:50 +00:00
|
|
|
@@ -22,7 +22,7 @@ public enum Instrument {
|
2022-12-09 09:49:15 +00:00
|
|
|
*/
|
|
|
|
SNARE_DRUM(0x2),
|
|
|
|
/**
|
|
|
|
- * Sticks are normally played when a note block is on top of a glass
|
|
|
|
+ * Sticks (Hat) are normally played when a note block is on top of a glass
|
|
|
|
* block.
|
|
|
|
*/
|
|
|
|
STICKS(0x3),
|
2023-04-09 00:00:50 +00:00
|
|
|
@@ -81,50 +81,48 @@ public enum Instrument {
|
2022-12-09 09:34:39 +00:00
|
|
|
*/
|
2023-04-09 00:00:50 +00:00
|
|
|
@MinecraftExperimental
|
|
|
|
@ApiStatus.Experimental
|
2022-12-26 17:53:35 +00:00
|
|
|
- ZOMBIE,
|
|
|
|
+ ZOMBIE(0x10), // Paper
|
|
|
|
/**
|
|
|
|
* Skeleton is normally played when a Skeleton Head is on top of the note block.
|
|
|
|
*/
|
2023-04-09 00:00:50 +00:00
|
|
|
@MinecraftExperimental
|
|
|
|
@ApiStatus.Experimental
|
2022-12-26 17:53:35 +00:00
|
|
|
- SKELETON,
|
|
|
|
+ SKELETON(0x11), // Paper
|
|
|
|
/**
|
|
|
|
* Creeper is normally played when a Creeper Head is on top of the note block.
|
|
|
|
*/
|
2023-04-09 00:00:50 +00:00
|
|
|
@MinecraftExperimental
|
|
|
|
@ApiStatus.Experimental
|
2022-12-26 17:53:35 +00:00
|
|
|
- CREEPER,
|
|
|
|
+ CREEPER(0x12), // Paper
|
|
|
|
/**
|
|
|
|
* Dragon is normally played when a Dragon Head is on top of the note block.
|
|
|
|
*/
|
2023-04-09 00:00:50 +00:00
|
|
|
@MinecraftExperimental
|
|
|
|
@ApiStatus.Experimental
|
2022-12-26 17:53:35 +00:00
|
|
|
- DRAGON,
|
|
|
|
+ DRAGON(0x13), // Paper
|
|
|
|
/**
|
|
|
|
* Wither Skeleton is normally played when a Wither Skeleton Head is on top of the note block.
|
|
|
|
*/
|
2023-04-09 00:00:50 +00:00
|
|
|
@MinecraftExperimental
|
|
|
|
@ApiStatus.Experimental
|
2022-12-26 17:53:35 +00:00
|
|
|
- WITHER_SKELETON,
|
|
|
|
+ WITHER_SKELETON(0x14), // Paper
|
|
|
|
/**
|
|
|
|
* Piglin is normally played when a Piglin Head is on top of the note block.
|
|
|
|
*/
|
2023-04-09 00:00:50 +00:00
|
|
|
@MinecraftExperimental
|
|
|
|
@ApiStatus.Experimental
|
2022-12-26 17:53:35 +00:00
|
|
|
- PIGLIN,
|
|
|
|
+ PIGLIN(0x15), // Paper
|
|
|
|
/**
|
|
|
|
* Custom Sound is normally played when a Player Head with the required data is on top of the note block.
|
|
|
|
*/
|
2023-04-09 00:00:50 +00:00
|
|
|
@MinecraftExperimental
|
|
|
|
@ApiStatus.Experimental
|
2022-12-26 17:53:35 +00:00
|
|
|
- CUSTOM_HEAD;
|
|
|
|
+ CUSTOM_HEAD(0x16); // Paper
|
2022-12-09 09:34:39 +00:00
|
|
|
|
|
|
|
private final byte type;
|
|
|
|
private static final Map<Byte, Instrument> BY_DATA = Maps.newHashMap();
|
2022-12-26 17:53:35 +00:00
|
|
|
|
|
|
|
- private Instrument() {
|
|
|
|
- this(-1);
|
|
|
|
- }
|
|
|
|
+ // Paper - remove ctor (the server still uses the byte magic value)
|
|
|
|
|
|
|
|
private Instrument(final int type) {
|
|
|
|
this.type = (byte) type;
|
2023-04-09 00:00:50 +00:00
|
|
|
@@ -132,9 +130,8 @@ public enum Instrument {
|
2022-12-26 17:53:35 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return The type ID of this instrument.
|
|
|
|
- * @deprecated Magic value
|
|
|
|
*/
|
|
|
|
- @Deprecated
|
|
|
|
+ @org.jetbrains.annotations.ApiStatus.Internal // Paper
|
|
|
|
public byte getType() {
|
|
|
|
return this.type;
|
|
|
|
}
|
2023-04-09 00:00:50 +00:00
|
|
|
@@ -144,9 +141,8 @@ public enum Instrument {
|
2022-12-26 17:53:35 +00:00
|
|
|
*
|
|
|
|
* @param type The type ID
|
|
|
|
* @return The instrument
|
|
|
|
- * @deprecated Magic value
|
|
|
|
*/
|
|
|
|
- @Deprecated
|
|
|
|
+ @org.jetbrains.annotations.ApiStatus.Internal // Paper
|
|
|
|
@Nullable
|
|
|
|
public static Instrument getByType(final byte type) {
|
|
|
|
return BY_DATA.get(type);
|
2022-12-09 09:49:15 +00:00
|
|
|
diff --git a/src/main/java/org/bukkit/entity/Player.java b/src/main/java/org/bukkit/entity/Player.java
|
2023-05-31 23:36:57 +00:00
|
|
|
index bdb63e445c1bc2e08bfa840d61cdeb2d8576bde7..fabe9a415c88d3669c7b09e4d7c2453c0f2edeff 100644
|
2022-12-09 09:49:15 +00:00
|
|
|
--- a/src/main/java/org/bukkit/entity/Player.java
|
|
|
|
+++ b/src/main/java/org/bukkit/entity/Player.java
|
2023-05-31 23:36:57 +00:00
|
|
|
@@ -393,9 +393,7 @@ public interface Player extends HumanEntity, Conversable, OfflinePlayer, PluginM
|
2022-12-09 09:49:15 +00:00
|
|
|
public void playNote(@NotNull Location loc, byte instrument, byte note);
|
|
|
|
|
|
|
|
/**
|
|
|
|
- * Play a note for a player at a location. This requires a note block
|
|
|
|
- * at the particular location (as far as the client is concerned). This
|
|
|
|
- * will not work without a note block. This will not work with cake.
|
|
|
|
+ * Play a note for a player at a location.
|
|
|
|
*
|
|
|
|
* @param loc The location of a note block
|
|
|
|
* @param instrument The instrument
|
2022-12-26 17:53:35 +00:00
|
|
|
diff --git a/src/test/java/org/bukkit/InstrumentTest.java b/src/test/java/org/bukkit/InstrumentTest.java
|
|
|
|
index 14ad060eba6b78c6b7c7deeecc455ea385b92f36..e3d718d75474c5b31c95bd64cb58247ab72364e4 100644
|
|
|
|
--- a/src/test/java/org/bukkit/InstrumentTest.java
|
|
|
|
+++ b/src/test/java/org/bukkit/InstrumentTest.java
|
|
|
|
@@ -8,9 +8,7 @@ public class InstrumentTest {
|
|
|
|
@Test
|
|
|
|
public void getByType() {
|
|
|
|
for (Instrument instrument : Instrument.values()) {
|
|
|
|
- if (instrument.getType() < 0) {
|
|
|
|
- continue;
|
|
|
|
- }
|
|
|
|
+ // Paper - byte magic values are still used
|
|
|
|
|
|
|
|
assertThat(Instrument.getByType(instrument.getType()), is(instrument));
|
|
|
|
}
|