mirror of
https://github.com/PaperMC/Paper.git
synced 2025-08-05 14:42:22 -07:00
Expose more data for MusicInstrument (#12415)
This commit is contained in:
@@ -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
|
|
||||||
}
|
}
|
||||||
|
@@ -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();
|
||||||
}
|
}
|
||||||
|
@@ -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);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user