Expose more data for MusicInstrument (#12415)

This commit is contained in:
Pedro
2025-05-24 17:16:54 -04:00
committed by GitHub
parent 84ee4249c9
commit b9d6ba243c
3 changed files with 72 additions and 23 deletions

View File

@@ -5,10 +5,12 @@ import io.papermc.paper.registry.RegistryAccess;
import io.papermc.paper.registry.RegistryKey; import io.papermc.paper.registry.RegistryKey;
import java.util.Collection; import java.util.Collection;
import java.util.Collections; import java.util.Collections;
import org.jetbrains.annotations.NotNull; import net.kyori.adventure.text.Component;
import org.jetbrains.annotations.Nullable; import org.jspecify.annotations.NullMarked;
import org.jspecify.annotations.Nullable;
public abstract class MusicInstrument implements Keyed, net.kyori.adventure.translation.Translatable { // Paper - translation keys @NullMarked
public abstract class MusicInstrument implements Keyed, net.kyori.adventure.translation.Translatable {
// Start generate - MusicInstrument // Start generate - MusicInstrument
// @GeneratedFrom 1.21.5 // @GeneratedFrom 1.21.5
@@ -38,7 +40,7 @@ public abstract class MusicInstrument implements Keyed, net.kyori.adventure.tran
*/ */
@Nullable @Nullable
@Deprecated(since = "1.20.1") @Deprecated(since = "1.20.1")
public static MusicInstrument getByKey(@NotNull NamespacedKey namespacedKey) { public static MusicInstrument getByKey(final NamespacedKey namespacedKey) {
return Registry.INSTRUMENT.get(namespacedKey); return Registry.INSTRUMENT.get(namespacedKey);
} }
@@ -48,25 +50,50 @@ public abstract class MusicInstrument implements Keyed, net.kyori.adventure.tran
* @return the memoryKeys * @return the memoryKeys
* @deprecated use {@link Registry#iterator()}. * @deprecated use {@link Registry#iterator()}.
*/ */
@NotNull
@Deprecated(since = "1.20.1") @Deprecated(since = "1.20.1")
public static Collection<MusicInstrument> values() { public static Collection<MusicInstrument> values() {
return Collections.unmodifiableCollection(Lists.newArrayList(Registry.INSTRUMENT)); return Collections.unmodifiableCollection(Lists.newArrayList(Registry.INSTRUMENT));
} }
@NotNull private static MusicInstrument getInstrument(final String key) {
private static MusicInstrument getInstrument(@NotNull String key) {
return RegistryAccess.registryAccess().getRegistry(RegistryKey.INSTRUMENT).getOrThrow(NamespacedKey.minecraft(key)); return RegistryAccess.registryAccess().getRegistry(RegistryKey.INSTRUMENT).getOrThrow(NamespacedKey.minecraft(key));
} }
// Paper start - deprecate getKey /**
* Gets the use duration of this music instrument.
*
* @return the duration expressed in seconds.
*/
public abstract float getDuration();
/**
* Gets the range of the sound.
*
* @return the range of the sound.
*/
public abstract float getRange();
/**
* Provides the description of this instrument as displayed to the client.
*
* @return the description component.
*/
public abstract Component description();
/**
* Gets the sound for this instrument.
*
* @return the sound
*/
public abstract Sound getSound();
/** /**
* @deprecated use {@link Registry#getKey(Keyed)}, {@link io.papermc.paper.registry.RegistryAccess#getRegistry(io.papermc.paper.registry.RegistryKey)}, * @deprecated use {@link Registry#getKey(Keyed)}, {@link io.papermc.paper.registry.RegistryAccess#getRegistry(io.papermc.paper.registry.RegistryKey)},
* and {@link io.papermc.paper.registry.RegistryKey#INSTRUMENT}. MusicInstruments can exist without a key. * and {@link io.papermc.paper.registry.RegistryKey#INSTRUMENT}. MusicInstruments can exist without a key.
*/ */
@Deprecated(forRemoval = true, since = "1.20.5") @Deprecated(forRemoval = true, since = "1.20.5")
@Override @Override
public abstract @NotNull NamespacedKey getKey(); public abstract NamespacedKey getKey();
/** /**
* @deprecated use {@link Registry#getKey(Keyed)}, {@link io.papermc.paper.registry.RegistryAccess#getRegistry(io.papermc.paper.registry.RegistryKey)}, * @deprecated use {@link Registry#getKey(Keyed)}, {@link io.papermc.paper.registry.RegistryAccess#getRegistry(io.papermc.paper.registry.RegistryKey)},
@@ -78,15 +105,11 @@ public abstract class MusicInstrument implements Keyed, net.kyori.adventure.tran
return Keyed.super.key(); return Keyed.super.key();
} }
// Paper end - deprecate getKey
// Paper start - mark translation key as deprecated
/** /**
* @deprecated this method assumes that the instrument description * @deprecated this method assumes that the instrument description
* always be a translatable component which is not guaranteed. * always be a translatable component which is not guaranteed.
*/ */
@Override @Override
@Deprecated(forRemoval = true) @Deprecated(forRemoval = true)
public abstract @NotNull String translationKey(); public abstract String translationKey();
// Paper end - mark translation key as deprecated
} }

View File

@@ -1,14 +1,16 @@
package org.bukkit.craftbukkit; package org.bukkit.craftbukkit;
import com.google.common.base.Preconditions; import com.google.common.base.Preconditions;
import io.papermc.paper.adventure.PaperAdventure;
import io.papermc.paper.registry.RegistryKey; import io.papermc.paper.registry.RegistryKey;
import io.papermc.paper.util.Holderable; import io.papermc.paper.util.Holderable;
import net.kyori.adventure.text.Component;
import net.minecraft.core.Holder; import net.minecraft.core.Holder;
import net.minecraft.core.registries.Registries; import net.minecraft.core.registries.Registries;
import net.minecraft.world.item.Instrument; import net.minecraft.world.item.Instrument;
import org.bukkit.MusicInstrument; import org.bukkit.MusicInstrument;
import org.bukkit.NamespacedKey; import org.bukkit.NamespacedKey;
import org.bukkit.Registry; import org.bukkit.Sound;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
public class CraftMusicInstrument extends MusicInstrument implements io.papermc.paper.util.Holderable<Instrument> { public class CraftMusicInstrument extends MusicInstrument implements io.papermc.paper.util.Holderable<Instrument> {
@@ -26,19 +28,19 @@ public class CraftMusicInstrument extends MusicInstrument implements io.papermc.
} }
public static Holder<Instrument> bukkitToMinecraftHolder(MusicInstrument bukkit) { public static Holder<Instrument> bukkitToMinecraftHolder(MusicInstrument bukkit) {
return CraftRegistry.bukkitToMinecraftHolder(bukkit, Registries.INSTRUMENT); // Paper - switch to Holder return CraftRegistry.bukkitToMinecraftHolder(bukkit, Registries.INSTRUMENT);
} }
public static Object bukkitToString(MusicInstrument bukkit) { // Paper - switch to Holder public static Object bukkitToString(MusicInstrument bukkit) {
Preconditions.checkArgument(bukkit != null); Preconditions.checkArgument(bukkit != null);
return ((CraftMusicInstrument) bukkit).toBukkitSerializationObject(Instrument.DIRECT_CODEC); // Paper - switch to Holder return ((CraftMusicInstrument) bukkit).toBukkitSerializationObject(Instrument.DIRECT_CODEC);
} }
public static MusicInstrument stringToBukkit(Object string) { // Paper - switch to Holder public static MusicInstrument stringToBukkit(Object string) {
Preconditions.checkArgument(string != null); Preconditions.checkArgument(string != null);
return io.papermc.paper.util.Holderable.fromBukkitSerializationObject(string, Instrument.CODEC, RegistryKey.INSTRUMENT); // Paper - switch to Holder return io.papermc.paper.util.Holderable.fromBukkitSerializationObject(string, Instrument.CODEC, RegistryKey.INSTRUMENT);
} }
@Override @Override
@@ -63,8 +65,28 @@ public class CraftMusicInstrument extends MusicInstrument implements io.papermc.
} }
@Override @Override
public Holder<Instrument> getHolder() { // Paper - switch to Holder public Holder<Instrument> getHolder() {
return this.holder; // Paper - switch to Holder return this.holder;
}
@Override
public float getDuration() {
return this.getHandle().useDuration();
}
@Override
public float getRange() {
return this.getHandle().range();
}
@Override
public Component description() {
return PaperAdventure.asAdventure(this.getHandle().description());
}
@Override
public Sound getSound() {
return CraftSound.minecraftHolderToBukkit(this.getHandle().soundEvent());
} }
@NotNull @NotNull
@@ -76,7 +98,7 @@ public class CraftMusicInstrument extends MusicInstrument implements io.papermc.
@Override @Override
public @NotNull String translationKey() { public @NotNull String translationKey() {
if (!(this.getHandle().description().getContents() instanceof final net.minecraft.network.chat.contents.TranslatableContents translatableContents)) { if (!(this.getHandle().description().getContents() instanceof final net.minecraft.network.chat.contents.TranslatableContents translatableContents)) {
throw new UnsupportedOperationException("Description isn't translatable!"); // Paper throw new UnsupportedOperationException("Description isn't translatable!");
} }
return translatableContents.getKey(); return translatableContents.getKey();
} }

View File

@@ -14,6 +14,10 @@ public class CraftSound extends OldEnumHolderable<Sound, SoundEvent> implements
return CraftRegistry.minecraftToBukkit(minecraft, Registries.SOUND_EVENT); return CraftRegistry.minecraftToBukkit(minecraft, Registries.SOUND_EVENT);
} }
public static Sound minecraftHolderToBukkit(Holder<SoundEvent> minecraft) {
return CraftRegistry.minecraftHolderToBukkit(minecraft, Registries.SOUND_EVENT);
}
public static SoundEvent bukkitToMinecraft(Sound bukkit) { public static SoundEvent bukkitToMinecraft(Sound bukkit) {
return CraftRegistry.bukkitToMinecraft(bukkit); return CraftRegistry.bukkitToMinecraft(bukkit);
} }