From d1e41fdc4772a328f937369bcd1d457f1491d4a5 Mon Sep 17 00:00:00 2001 From: Jake Potrebic Date: Fri, 9 Dec 2022 01:49:15 -0800 Subject: [PATCH] couple more instrument/note fixes --- ...ument-enum.patch => fix-Instruments.patch} | 37 ++++++++- patches/server/fix-Instruments.patch | 76 +++++++++++++++++++ 2 files changed, 112 insertions(+), 1 deletion(-) rename patches/api/{fix-Instrument-enum.patch => fix-Instruments.patch} (57%) create mode 100644 patches/server/fix-Instruments.patch diff --git a/patches/api/fix-Instrument-enum.patch b/patches/api/fix-Instruments.patch similarity index 57% rename from patches/api/fix-Instrument-enum.patch rename to patches/api/fix-Instruments.patch index d4f65ee60f..0d0a11716b 100644 --- a/patches/api/fix-Instrument-enum.patch +++ b/patches/api/fix-Instruments.patch @@ -1,13 +1,33 @@ From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Jake Potrebic Date: Fri, 9 Dec 2022 01:34:03 -0800 -Subject: [PATCH] fix Instrument enum +Subject: [PATCH] fix Instruments +Add missing instrument enums +fix some wrong javadocs diff --git a/src/main/java/org/bukkit/Instrument.java b/src/main/java/org/bukkit/Instrument.java index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 --- a/src/main/java/org/bukkit/Instrument.java +++ b/src/main/java/org/bukkit/Instrument.java +@@ -0,0 +0,0 @@ import org.jetbrains.annotations.Nullable; + public enum Instrument { + + /** +- * Piano is the standard instrument for a note block. ++ * Piano (Harp) is the standard instrument for a note block. + */ + PIANO(0x0), + /** +@@ -0,0 +0,0 @@ public enum Instrument { + */ + 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), @@ -0,0 +0,0 @@ public enum Instrument { /** * Pling is normally played when a note block is on top of a glowstone block. @@ -54,3 +74,18 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 private final byte type; private static final Map BY_DATA = Maps.newHashMap(); +diff --git a/src/main/java/org/bukkit/entity/Player.java b/src/main/java/org/bukkit/entity/Player.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/entity/Player.java ++++ b/src/main/java/org/bukkit/entity/Player.java +@@ -0,0 +0,0 @@ public interface Player extends HumanEntity, Conversable, OfflinePlayer, PluginM + 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 diff --git a/patches/server/fix-Instruments.patch b/patches/server/fix-Instruments.patch new file mode 100644 index 0000000000..14f1c0a3a5 --- /dev/null +++ b/patches/server/fix-Instruments.patch @@ -0,0 +1,76 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Jake Potrebic +Date: Fri, 9 Dec 2022 01:47:23 -0800 +Subject: [PATCH] fix Instruments + +properly handle Player#playNote + +diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java ++++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +@@ -0,0 +0,0 @@ public class CraftPlayer extends CraftHumanEntity implements Player { + public void playNote(Location loc, Instrument instrument, Note note) { + if (this.getHandle().connection == null) return; + +- String instrumentName = null; +- switch (instrument.ordinal()) { +- case 0: +- instrumentName = "harp"; +- break; +- case 1: +- instrumentName = "basedrum"; +- break; +- case 2: +- instrumentName = "snare"; +- break; +- case 3: +- instrumentName = "hat"; +- break; +- case 4: +- instrumentName = "bass"; +- break; +- case 5: +- instrumentName = "flute"; +- break; +- case 6: +- instrumentName = "bell"; +- break; +- case 7: +- instrumentName = "guitar"; +- break; +- case 8: +- instrumentName = "chime"; +- break; +- case 9: +- instrumentName = "xylophone"; +- break; +- case 10: +- instrumentName = "iron_xylophone"; +- break; +- case 11: +- instrumentName = "cow_bell"; +- break; +- case 12: +- instrumentName = "didgeridoo"; +- break; +- case 13: +- instrumentName = "bit"; +- break; +- case 14: +- instrumentName = "banjo"; +- break; +- case 15: +- instrumentName = "pling"; +- break; +- case 16: +- instrumentName = "xylophone"; +- break; +- } ++ net.minecraft.world.level.block.state.properties.NoteBlockInstrument nms = CraftBlockData.toNMS(instrument, net.minecraft.world.level.block.state.properties.NoteBlockInstrument.class); // Paper - really? + float f = (float) Math.pow(2.0D, (note.getId() - 12.0D) / 12.0D); +- this.getHandle().connection.send(new ClientboundSoundPacket(BuiltInRegistries.SOUND_EVENT.wrapAsHolder(CraftSound.getSoundEffect("block.note_block." + instrumentName)), net.minecraft.sounds.SoundSource.RECORDS, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), 3.0f, f, this.getHandle().getRandom().nextLong())); ++ this.getHandle().connection.send(new ClientboundSoundPacket(nms.getSoundEvent(), net.minecraft.sounds.SoundSource.RECORDS, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), 3.0f, f, this.getHandle().getRandom().nextLong())); // Paper + } + + @Override