mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 06:30:46 +01:00
Switch Impl types to Holderable (#11662)
* Switch Impl types to Holderable * Fix compile issues * more improvements * compile fixes * remove unneeded unwrapAndConvertHolder call --------- Co-authored-by: Bjarne Koll <git@lynxplay.dev>
This commit is contained in:
parent
e7ac163b76
commit
a53051b155
10 changed files with 917 additions and 288 deletions
|
@ -45,14 +45,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import org.jetbrains.annotations.Contract;
|
+import org.jetbrains.annotations.Contract;
|
||||||
+import org.jetbrains.annotations.Range;
|
+import org.jetbrains.annotations.Range;
|
||||||
+import org.jetbrains.annotations.Unmodifiable;
|
+import org.jetbrains.annotations.Unmodifiable;
|
||||||
+import org.jspecify.annotations.NullMarked;
|
|
||||||
+import org.jspecify.annotations.Nullable;
|
+import org.jspecify.annotations.Nullable;
|
||||||
+
|
+
|
||||||
+/**
|
+/**
|
||||||
+ * A data-centric version-specific registry entry for the {@link Enchantment} type.
|
+ * A data-centric version-specific registry entry for the {@link Enchantment} type.
|
||||||
+ */
|
+ */
|
||||||
+@ApiStatus.Experimental
|
+@ApiStatus.Experimental
|
||||||
+@NullMarked
|
|
||||||
+@ApiStatus.NonExtendable
|
+@ApiStatus.NonExtendable
|
||||||
+public interface EnchantmentRegistryEntry {
|
+public interface EnchantmentRegistryEntry {
|
||||||
+
|
+
|
||||||
|
@ -372,13 +370,11 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import org.jetbrains.annotations.ApiStatus;
|
+import org.jetbrains.annotations.ApiStatus;
|
||||||
+import org.jetbrains.annotations.Contract;
|
+import org.jetbrains.annotations.Contract;
|
||||||
+import org.jetbrains.annotations.Range;
|
+import org.jetbrains.annotations.Range;
|
||||||
+import org.jspecify.annotations.NullMarked;
|
|
||||||
+
|
+
|
||||||
+/**
|
+/**
|
||||||
+ * A data-centric version-specific registry entry for the {@link GameEvent} type.
|
+ * A data-centric version-specific registry entry for the {@link GameEvent} type.
|
||||||
+ */
|
+ */
|
||||||
+@ApiStatus.Experimental
|
+@ApiStatus.Experimental
|
||||||
+@NullMarked
|
|
||||||
+@ApiStatus.NonExtendable
|
+@ApiStatus.NonExtendable
|
||||||
+public interface GameEventRegistryEntry {
|
+public interface GameEventRegistryEntry {
|
||||||
+
|
+
|
||||||
|
@ -423,21 +419,18 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+package io.papermc.paper.registry.data;
|
+package io.papermc.paper.registry.data;
|
||||||
+
|
+
|
||||||
+import io.papermc.paper.registry.RegistryBuilder;
|
+import io.papermc.paper.registry.RegistryBuilder;
|
||||||
+import java.util.Optional;
|
|
||||||
+import net.kyori.adventure.key.Key;
|
+import net.kyori.adventure.key.Key;
|
||||||
+import net.kyori.adventure.text.Component;
|
+import net.kyori.adventure.text.Component;
|
||||||
+import org.bukkit.Art;
|
+import org.bukkit.Art;
|
||||||
+import org.jetbrains.annotations.ApiStatus;
|
+import org.jetbrains.annotations.ApiStatus;
|
||||||
+import org.jetbrains.annotations.Contract;
|
+import org.jetbrains.annotations.Contract;
|
||||||
+import org.jetbrains.annotations.Range;
|
+import org.jetbrains.annotations.Range;
|
||||||
+import org.jspecify.annotations.NullMarked;
|
|
||||||
+import org.jspecify.annotations.Nullable;
|
+import org.jspecify.annotations.Nullable;
|
||||||
+
|
+
|
||||||
+/**
|
+/**
|
||||||
+ * A data-centric version-specific registry entry for the {@link Art} type.
|
+ * A data-centric version-specific registry entry for the {@link Art} type.
|
||||||
+ */
|
+ */
|
||||||
+@ApiStatus.Experimental
|
+@ApiStatus.Experimental
|
||||||
+@NullMarked
|
|
||||||
+@ApiStatus.NonExtendable
|
+@ApiStatus.NonExtendable
|
||||||
+public interface PaintingVariantRegistryEntry {
|
+public interface PaintingVariantRegistryEntry {
|
||||||
+
|
+
|
||||||
|
@ -565,7 +558,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ * Registry entries are not expected to be used during plugin runtime interactions with the API but are mostly
|
+ * Registry entries are not expected to be used during plugin runtime interactions with the API but are mostly
|
||||||
+ * exposed during registry creation/modification.
|
+ * exposed during registry creation/modification.
|
||||||
+ */
|
+ */
|
||||||
|
+@NullMarked
|
||||||
+package io.papermc.paper.registry.data;
|
+package io.papermc.paper.registry.data;
|
||||||
|
+
|
||||||
|
+import org.jspecify.annotations.NullMarked;
|
||||||
diff --git a/src/main/java/io/papermc/paper/registry/event/RegistryEvents.java b/src/main/java/io/papermc/paper/registry/event/RegistryEvents.java
|
diff --git a/src/main/java/io/papermc/paper/registry/event/RegistryEvents.java b/src/main/java/io/papermc/paper/registry/event/RegistryEvents.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/io/papermc/paper/registry/event/RegistryEvents.java
|
--- a/src/main/java/io/papermc/paper/registry/event/RegistryEvents.java
|
||||||
|
|
|
@ -223,6 +223,25 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void collectClasses(@NotNull File from, @NotNull Map<String, ClassNode> to) throws IOException {
|
private static void collectClasses(@NotNull File from, @NotNull Map<String, ClassNode> to) throws IOException {
|
||||||
|
if (from.isDirectory()) {
|
||||||
|
+ // Paper start - skip packages with @NullMarked
|
||||||
|
+ final File packageInfo = new File(from, "package-info.class");
|
||||||
|
+ if (packageInfo.exists()) {
|
||||||
|
+ try (final FileInputStream in = new FileInputStream(packageInfo)) {
|
||||||
|
+ final ClassReader cr = new ClassReader(in);
|
||||||
|
+
|
||||||
|
+ final ClassNode node = new ClassNode();
|
||||||
|
+ cr.accept(node, ClassReader.SKIP_CODE | ClassReader.SKIP_DEBUG | ClassReader.SKIP_FRAMES);
|
||||||
|
+
|
||||||
|
+ if (isClassNullMarked0(node)) {
|
||||||
|
+ return; // skip packages with @NullMarked
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ // Paper end - skip packages with @NullMarked
|
||||||
|
final File[] files = from.listFiles();
|
||||||
|
assert files != null;
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class AnnotationTest {
|
@@ -0,0 +0,0 @@ public class AnnotationTest {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -83,8 +83,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import org.bukkit.potion.PotionEffectType;
|
+import org.bukkit.potion.PotionEffectType;
|
||||||
+import org.jspecify.annotations.Nullable;
|
+import org.jspecify.annotations.Nullable;
|
||||||
+
|
+
|
||||||
+import static io.papermc.paper.registry.entry.RegistryEntry.apiOnly;
|
+import static io.papermc.paper.registry.entry.RegistryEntryBuilder.start;
|
||||||
+import static io.papermc.paper.registry.entry.RegistryEntry.entry;
|
|
||||||
+
|
+
|
||||||
+public final class PaperRegistries {
|
+public final class PaperRegistries {
|
||||||
+
|
+
|
||||||
|
@ -94,39 +93,39 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ static {
|
+ static {
|
||||||
+ REGISTRY_ENTRIES = List.of(
|
+ REGISTRY_ENTRIES = List.of(
|
||||||
+ // built-ins
|
+ // built-ins
|
||||||
+ entry(Registries.GAME_EVENT, RegistryKey.GAME_EVENT, GameEvent.class, CraftGameEvent::new),
|
+ start(Registries.GAME_EVENT, RegistryKey.GAME_EVENT).craft(GameEvent.class, CraftGameEvent::new).build(),
|
||||||
+ entry(Registries.STRUCTURE_TYPE, RegistryKey.STRUCTURE_TYPE, StructureType.class, CraftStructureType::new),
|
+ start(Registries.STRUCTURE_TYPE, RegistryKey.STRUCTURE_TYPE).craft(StructureType.class, CraftStructureType::new).build(),
|
||||||
+ entry(Registries.MOB_EFFECT, RegistryKey.MOB_EFFECT, PotionEffectType.class, CraftPotionEffectType::new),
|
+ start(Registries.MOB_EFFECT, RegistryKey.MOB_EFFECT).craft(PotionEffectType.class, CraftPotionEffectType::new).build(),
|
||||||
+ entry(Registries.BLOCK, RegistryKey.BLOCK, BlockType.class, CraftBlockType::new),
|
+ start(Registries.BLOCK, RegistryKey.BLOCK).craft(BlockType.class, CraftBlockType::new).build(),
|
||||||
+ entry(Registries.ITEM, RegistryKey.ITEM, ItemType.class, CraftItemType::new),
|
+ start(Registries.ITEM, RegistryKey.ITEM).craft(ItemType.class, CraftItemType::new).build(),
|
||||||
+ entry(Registries.CAT_VARIANT, RegistryKey.CAT_VARIANT, Cat.Type.class, CraftCat.CraftType::new),
|
+ start(Registries.CAT_VARIANT, RegistryKey.CAT_VARIANT).craft(Cat.Type.class, CraftCat.CraftType::new).build(),
|
||||||
+ entry(Registries.FROG_VARIANT, RegistryKey.FROG_VARIANT, Frog.Variant.class, CraftFrog.CraftVariant::new),
|
+ start(Registries.FROG_VARIANT, RegistryKey.FROG_VARIANT).craft(Frog.Variant.class, CraftFrog.CraftVariant::new).build(),
|
||||||
+ entry(Registries.VILLAGER_PROFESSION, RegistryKey.VILLAGER_PROFESSION, Villager.Profession.class, CraftVillager.CraftProfession::new),
|
+ start(Registries.VILLAGER_PROFESSION, RegistryKey.VILLAGER_PROFESSION).craft(Villager.Profession.class, CraftVillager.CraftProfession::new).build(),
|
||||||
+ entry(Registries.VILLAGER_TYPE, RegistryKey.VILLAGER_TYPE, Villager.Type.class, CraftVillager.CraftType::new),
|
+ start(Registries.VILLAGER_TYPE, RegistryKey.VILLAGER_TYPE).craft(Villager.Type.class, CraftVillager.CraftType::new).build(),
|
||||||
+ entry(Registries.MAP_DECORATION_TYPE, RegistryKey.MAP_DECORATION_TYPE, MapCursor.Type.class, CraftMapCursor.CraftType::new),
|
+ start(Registries.MAP_DECORATION_TYPE, RegistryKey.MAP_DECORATION_TYPE).craft(MapCursor.Type.class, CraftMapCursor.CraftType::new).build(),
|
||||||
+ entry(Registries.MENU, RegistryKey.MENU, MenuType.class, CraftMenuType::new),
|
+ start(Registries.MENU, RegistryKey.MENU).craft(MenuType.class, CraftMenuType::new).build(),
|
||||||
+ entry(Registries.ATTRIBUTE, RegistryKey.ATTRIBUTE, Attribute.class, CraftAttribute::new),
|
+ start(Registries.ATTRIBUTE, RegistryKey.ATTRIBUTE).craft(Attribute.class, CraftAttribute::new).build(),
|
||||||
+ entry(Registries.FLUID, RegistryKey.FLUID, Fluid.class, CraftFluid::new),
|
+ start(Registries.FLUID, RegistryKey.FLUID).craft(Fluid.class, CraftFluid::new).build(),
|
||||||
+ entry(Registries.SOUND_EVENT, RegistryKey.SOUND_EVENT, Sound.class, CraftSound::new),
|
+ start(Registries.SOUND_EVENT, RegistryKey.SOUND_EVENT).craft(Sound.class, CraftSound::new).build(),
|
||||||
+
|
+
|
||||||
+ // data-drivens
|
+ // data-drivens
|
||||||
+ entry(Registries.BIOME, RegistryKey.BIOME, Biome.class, CraftBiome::new).delayed(),
|
+ start(Registries.BIOME, RegistryKey.BIOME).craft(Biome.class, CraftBiome::new).build().delayed(),
|
||||||
+ entry(Registries.STRUCTURE, RegistryKey.STRUCTURE, Structure.class, CraftStructure::new).delayed(),
|
+ start(Registries.STRUCTURE, RegistryKey.STRUCTURE).craft(Structure.class, CraftStructure::new).build().delayed(),
|
||||||
+ entry(Registries.TRIM_MATERIAL, RegistryKey.TRIM_MATERIAL, TrimMaterial.class, CraftTrimMaterial::new).delayed(),
|
+ start(Registries.TRIM_MATERIAL, RegistryKey.TRIM_MATERIAL).craft(TrimMaterial.class, CraftTrimMaterial::new).build().delayed(),
|
||||||
+ entry(Registries.TRIM_PATTERN, RegistryKey.TRIM_PATTERN, TrimPattern.class, CraftTrimPattern::new).delayed(),
|
+ start(Registries.TRIM_PATTERN, RegistryKey.TRIM_PATTERN).craft(TrimPattern.class, CraftTrimPattern::new).build().delayed(),
|
||||||
+ entry(Registries.DAMAGE_TYPE, RegistryKey.DAMAGE_TYPE, DamageType.class, CraftDamageType::new).delayed(),
|
+ start(Registries.DAMAGE_TYPE, RegistryKey.DAMAGE_TYPE).craft(DamageType.class, CraftDamageType::new).build().delayed(),
|
||||||
+ entry(Registries.WOLF_VARIANT, RegistryKey.WOLF_VARIANT, Wolf.Variant.class, CraftWolf.CraftVariant::new).delayed(),
|
+ start(Registries.WOLF_VARIANT, RegistryKey.WOLF_VARIANT).craft(Wolf.Variant.class, CraftWolf.CraftVariant::new).build().delayed(),
|
||||||
+ entry(Registries.ENCHANTMENT, RegistryKey.ENCHANTMENT, Enchantment.class, CraftEnchantment::new).withSerializationUpdater(FieldRename.ENCHANTMENT_RENAME).delayed(),
|
+ start(Registries.ENCHANTMENT, RegistryKey.ENCHANTMENT).craft(Enchantment.class, CraftEnchantment::new).build().withSerializationUpdater(FieldRename.ENCHANTMENT_RENAME).delayed(),
|
||||||
+ entry(Registries.JUKEBOX_SONG, RegistryKey.JUKEBOX_SONG, JukeboxSong.class, CraftJukeboxSong::new).delayed(),
|
+ start(Registries.JUKEBOX_SONG, RegistryKey.JUKEBOX_SONG).craft(JukeboxSong.class, CraftJukeboxSong::new).build().delayed(),
|
||||||
+ entry(Registries.BANNER_PATTERN, RegistryKey.BANNER_PATTERN, PatternType.class, CraftPatternType::new).delayed(),
|
+ start(Registries.BANNER_PATTERN, RegistryKey.BANNER_PATTERN).craft(PatternType.class, CraftPatternType::new).build().delayed(),
|
||||||
+ entry(Registries.PAINTING_VARIANT, RegistryKey.PAINTING_VARIANT, Art.class, CraftArt::new).delayed(),
|
+ start(Registries.PAINTING_VARIANT, RegistryKey.PAINTING_VARIANT).craft(Art.class, CraftArt::new).build().delayed(),
|
||||||
+ entry(Registries.INSTRUMENT, RegistryKey.INSTRUMENT, MusicInstrument.class, CraftMusicInstrument::new).delayed(),
|
+ start(Registries.INSTRUMENT, RegistryKey.INSTRUMENT).craft(MusicInstrument.class, CraftMusicInstrument::new).build().delayed(),
|
||||||
+
|
+
|
||||||
+ // api-only
|
+ // api-only
|
||||||
+ apiOnly(Registries.ENTITY_TYPE, RegistryKey.ENTITY_TYPE, PaperSimpleRegistry::entityType),
|
+ start(Registries.ENTITY_TYPE, RegistryKey.ENTITY_TYPE).apiOnly(PaperSimpleRegistry::entityType),
|
||||||
+ apiOnly(Registries.PARTICLE_TYPE, RegistryKey.PARTICLE_TYPE, PaperSimpleRegistry::particleType),
|
+ start(Registries.PARTICLE_TYPE, RegistryKey.PARTICLE_TYPE).apiOnly(PaperSimpleRegistry::particleType),
|
||||||
+ apiOnly(Registries.POTION, RegistryKey.POTION, PaperSimpleRegistry::potion),
|
+ start(Registries.POTION, RegistryKey.POTION).apiOnly(PaperSimpleRegistry::potion),
|
||||||
+ apiOnly(Registries.MEMORY_MODULE_TYPE, RegistryKey.MEMORY_MODULE_TYPE, () -> (org.bukkit.Registry<MemoryKey<?>>) (org.bukkit.Registry) org.bukkit.Registry.MEMORY_MODULE_TYPE)
|
+ start(Registries.MEMORY_MODULE_TYPE, RegistryKey.MEMORY_MODULE_TYPE).apiOnly(() -> (org.bukkit.Registry<MemoryKey<?>>) (org.bukkit.Registry) org.bukkit.Registry.MEMORY_MODULE_TYPE)
|
||||||
+ );
|
+ );
|
||||||
+ final Map<RegistryKey<?>, RegistryEntry<?, ?>> byRegistryKey = new IdentityHashMap<>(REGISTRY_ENTRIES.size());
|
+ final Map<RegistryKey<?>, RegistryEntry<?, ?>> byRegistryKey = new IdentityHashMap<>(REGISTRY_ENTRIES.size());
|
||||||
+ final Map<ResourceKey<?>, RegistryEntry<?, ?>> byResourceKey = new IdentityHashMap<>(REGISTRY_ENTRIES.size());
|
+ final Map<ResourceKey<?>, RegistryEntry<?, ?>> byResourceKey = new IdentityHashMap<>(REGISTRY_ENTRIES.size());
|
||||||
|
@ -467,9 +466,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+package io.papermc.paper.registry.entry;
|
+package io.papermc.paper.registry.entry;
|
||||||
+
|
+
|
||||||
+import com.google.common.base.Preconditions;
|
+import com.google.common.base.Preconditions;
|
||||||
|
+import com.mojang.datafixers.util.Either;
|
||||||
+import io.papermc.paper.registry.RegistryHolder;
|
+import io.papermc.paper.registry.RegistryHolder;
|
||||||
+import io.papermc.paper.registry.RegistryKey;
|
+import io.papermc.paper.registry.RegistryKey;
|
||||||
+import java.util.function.BiFunction;
|
+import java.util.function.BiFunction;
|
||||||
|
+import java.util.function.Function;
|
||||||
|
+import net.minecraft.core.Holder;
|
||||||
+import net.minecraft.core.Registry;
|
+import net.minecraft.core.Registry;
|
||||||
+import net.minecraft.resources.ResourceKey;
|
+import net.minecraft.resources.ResourceKey;
|
||||||
+import org.bukkit.Keyed;
|
+import org.bukkit.Keyed;
|
||||||
|
@ -482,14 +484,14 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ private static final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> EMPTY = (namespacedKey, apiVersion) -> namespacedKey;
|
+ private static final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> EMPTY = (namespacedKey, apiVersion) -> namespacedKey;
|
||||||
+
|
+
|
||||||
+ protected final Class<?> classToPreload;
|
+ protected final Class<?> classToPreload;
|
||||||
+ protected final BiFunction<NamespacedKey, M, B> minecraftToBukkit;
|
+ protected final RegistryTypeMapper<M, B> minecraftToBukkit;
|
||||||
+ protected BiFunction<NamespacedKey, ApiVersion, NamespacedKey> updater = EMPTY;
|
+ protected BiFunction<NamespacedKey, ApiVersion, NamespacedKey> updater = EMPTY;
|
||||||
+
|
+
|
||||||
+ protected CraftRegistryEntry(
|
+ protected CraftRegistryEntry(
|
||||||
+ final ResourceKey<? extends Registry<M>> mcKey,
|
+ final ResourceKey<? extends Registry<M>> mcKey,
|
||||||
+ final RegistryKey<B> apiKey,
|
+ final RegistryKey<B> apiKey,
|
||||||
+ final Class<?> classToPreload,
|
+ final Class<?> classToPreload,
|
||||||
+ final BiFunction<NamespacedKey, M, B> minecraftToBukkit
|
+ final RegistryTypeMapper<M, B> minecraftToBukkit
|
||||||
+ ) {
|
+ ) {
|
||||||
+ super(mcKey, apiKey);
|
+ super(mcKey, apiKey);
|
||||||
+ Preconditions.checkArgument(!classToPreload.getPackageName().startsWith("net.minecraft"), classToPreload + " should not be in the net.minecraft package as the class-to-preload");
|
+ Preconditions.checkArgument(!classToPreload.getPackageName().startsWith("net.minecraft"), classToPreload + " should not be in the net.minecraft package as the class-to-preload");
|
||||||
|
@ -524,9 +526,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import io.papermc.paper.registry.RegistryKey;
|
+import io.papermc.paper.registry.RegistryKey;
|
||||||
+import io.papermc.paper.registry.legacy.DelayedRegistryEntry;
|
+import io.papermc.paper.registry.legacy.DelayedRegistryEntry;
|
||||||
+import java.util.function.BiFunction;
|
+import java.util.function.BiFunction;
|
||||||
+import java.util.function.Supplier;
|
|
||||||
+import net.minecraft.core.Registry;
|
+import net.minecraft.core.Registry;
|
||||||
+import net.minecraft.resources.ResourceKey;
|
|
||||||
+import org.bukkit.Keyed;
|
+import org.bukkit.Keyed;
|
||||||
+import org.bukkit.NamespacedKey;
|
+import org.bukkit.NamespacedKey;
|
||||||
+import org.bukkit.craftbukkit.util.ApiVersion;
|
+import org.bukkit.craftbukkit.util.ApiVersion;
|
||||||
|
@ -548,22 +548,74 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ default RegistryEntry<M, B> delayed() {
|
+ default RegistryEntry<M, B> delayed() {
|
||||||
+ return new DelayedRegistryEntry<>(this);
|
+ return new DelayedRegistryEntry<>(this);
|
||||||
+ }
|
+ }
|
||||||
|
+}
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/registry/entry/RegistryEntryBuilder.java b/src/main/java/io/papermc/paper/registry/entry/RegistryEntryBuilder.java
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/src/main/java/io/papermc/paper/registry/entry/RegistryEntryBuilder.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
+package io.papermc.paper.registry.entry;
|
||||||
+
|
+
|
||||||
+ static <M, B extends Keyed> RegistryEntry<M, B> entry(
|
+import com.mojang.datafixers.util.Either;
|
||||||
|
+import io.papermc.paper.registry.RegistryKey;
|
||||||
|
+import java.util.function.BiFunction;
|
||||||
|
+import java.util.function.Function;
|
||||||
|
+import java.util.function.Supplier;
|
||||||
|
+import net.minecraft.core.Holder;
|
||||||
|
+import net.minecraft.core.Registry;
|
||||||
|
+import net.minecraft.resources.ResourceKey;
|
||||||
|
+import org.bukkit.Keyed;
|
||||||
|
+import org.bukkit.NamespacedKey;
|
||||||
|
+
|
||||||
|
+public class RegistryEntryBuilder<M, A extends Keyed> { // TODO remove Keyed
|
||||||
|
+
|
||||||
|
+ public static <M, A extends Keyed> RegistryEntryBuilder<M, A> start( // TODO remove Keyed
|
||||||
+ final ResourceKey<? extends Registry<M>> mcKey,
|
+ final ResourceKey<? extends Registry<M>> mcKey,
|
||||||
+ final RegistryKey<B> apiKey,
|
+ final RegistryKey<A> apiKey
|
||||||
+ final Class<?> classToPreload,
|
|
||||||
+ final BiFunction<NamespacedKey, M, B> minecraftToBukkit
|
|
||||||
+ ) {
|
+ ) {
|
||||||
+ return new CraftRegistryEntry<>(mcKey, apiKey, classToPreload, minecraftToBukkit);
|
+ return new RegistryEntryBuilder<>(mcKey, apiKey);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ static <M, B extends Keyed> RegistryEntry<M, B> apiOnly(
|
+ protected final ResourceKey<? extends Registry<M>> mcKey;
|
||||||
|
+ protected final RegistryKey<A> apiKey;
|
||||||
|
+
|
||||||
|
+ private RegistryEntryBuilder(final ResourceKey<? extends Registry<M>> mcKey, RegistryKey<A> apiKey) {
|
||||||
|
+ this.mcKey = mcKey;
|
||||||
|
+ this.apiKey = apiKey;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public RegistryEntry<M, A> apiOnly(final Supplier<org.bukkit.Registry<A>> apiRegistrySupplier) {
|
||||||
|
+ return new ApiRegistryEntry<>(this.mcKey, this.apiKey, apiRegistrySupplier);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public CraftStage<M, A> craft(final Class<?> classToPreload, final BiFunction<? super NamespacedKey, M, ? extends A> minecraftToBukkit) {
|
||||||
|
+ return new CraftStage<>(this.mcKey, this.apiKey, classToPreload, new RegistryTypeMapper<>(minecraftToBukkit));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public CraftStage<M, A> craft(final Class<?> classToPreload, final Function<Holder<M>, ? extends A> minecraftToBukkit) {
|
||||||
|
+ return new CraftStage<>(this.mcKey, this.apiKey, classToPreload, new RegistryTypeMapper<>(minecraftToBukkit));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public static final class CraftStage<M, A extends Keyed> extends RegistryEntryBuilder<M, A> { // TODO remove Keyed
|
||||||
|
+
|
||||||
|
+ private final Class<?> classToPreload;
|
||||||
|
+ private final RegistryTypeMapper<M, A> minecraftToBukkit;
|
||||||
|
+
|
||||||
|
+ private CraftStage(
|
||||||
+ final ResourceKey<? extends Registry<M>> mcKey,
|
+ final ResourceKey<? extends Registry<M>> mcKey,
|
||||||
+ final RegistryKey<B> apiKey,
|
+ final RegistryKey<A> apiKey,
|
||||||
+ final Supplier<org.bukkit.Registry<B>> apiRegistrySupplier
|
+ final Class<?> classToPreload,
|
||||||
|
+ final RegistryTypeMapper<M, A> minecraftToBukkit
|
||||||
+ ) {
|
+ ) {
|
||||||
+ return new ApiRegistryEntry<>(mcKey, apiKey, apiRegistrySupplier);
|
+ super(mcKey, apiKey);
|
||||||
|
+ this.classToPreload = classToPreload;
|
||||||
|
+ this.minecraftToBukkit = minecraftToBukkit;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public RegistryEntry<M, A> build() {
|
||||||
|
+ return new CraftRegistryEntry<>(this.mcKey, this.apiKey, this.classToPreload, this.minecraftToBukkit);
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+}
|
+}
|
||||||
diff --git a/src/main/java/io/papermc/paper/registry/entry/RegistryEntryInfo.java b/src/main/java/io/papermc/paper/registry/entry/RegistryEntryInfo.java
|
diff --git a/src/main/java/io/papermc/paper/registry/entry/RegistryEntryInfo.java b/src/main/java/io/papermc/paper/registry/entry/RegistryEntryInfo.java
|
||||||
|
@ -584,6 +636,49 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
+ RegistryKey<B> apiKey();
|
+ RegistryKey<B> apiKey();
|
||||||
+}
|
+}
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/registry/entry/RegistryTypeMapper.java b/src/main/java/io/papermc/paper/registry/entry/RegistryTypeMapper.java
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/src/main/java/io/papermc/paper/registry/entry/RegistryTypeMapper.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
+package io.papermc.paper.registry.entry;
|
||||||
|
+
|
||||||
|
+import com.google.common.base.Preconditions;
|
||||||
|
+import com.mojang.datafixers.util.Either;
|
||||||
|
+import java.util.function.BiFunction;
|
||||||
|
+import java.util.function.Function;
|
||||||
|
+import net.minecraft.core.Holder;
|
||||||
|
+import org.bukkit.NamespacedKey;
|
||||||
|
+
|
||||||
|
+public final class RegistryTypeMapper<M, A> {
|
||||||
|
+
|
||||||
|
+ final Either<BiFunction<? super NamespacedKey, M, ? extends A>, Function<Holder<M>, ? extends A>> minecraftToBukkit;
|
||||||
|
+
|
||||||
|
+ public RegistryTypeMapper(final BiFunction<? super NamespacedKey, M, ? extends A> byValueCreator) {
|
||||||
|
+ this.minecraftToBukkit = Either.left(byValueCreator);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public RegistryTypeMapper(final Function<Holder<M>, ? extends A> byHolderCreator) {
|
||||||
|
+ this.minecraftToBukkit = Either.right(byHolderCreator);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public A createBukkit(final NamespacedKey key, final Holder<M> minecraft) {
|
||||||
|
+ return this.minecraftToBukkit.map(
|
||||||
|
+ minecraftToBukkit -> minecraftToBukkit.apply(key, minecraft.value()),
|
||||||
|
+ minecraftToBukkit -> minecraftToBukkit.apply(minecraft)
|
||||||
|
+ );
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public boolean supportsDirectHolders() {
|
||||||
|
+ return this.minecraftToBukkit.right().isPresent();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public A convertDirectHolder(final Holder<M> directHolder) {
|
||||||
|
+ Preconditions.checkArgument(this.supportsDirectHolders() && directHolder.kind() == Holder.Kind.DIRECT);
|
||||||
|
+ return this.minecraftToBukkit.right().orElseThrow().apply(directHolder);
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
diff --git a/src/main/java/io/papermc/paper/registry/entry/package-info.java b/src/main/java/io/papermc/paper/registry/entry/package-info.java
|
diff --git a/src/main/java/io/papermc/paper/registry/entry/package-info.java b/src/main/java/io/papermc/paper/registry/entry/package-info.java
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
|
@ -748,6 +843,26 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+package io.papermc.paper.registry;
|
+package io.papermc.paper.registry;
|
||||||
+
|
+
|
||||||
+import org.jspecify.annotations.NullMarked;
|
+import org.jspecify.annotations.NullMarked;
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/util/Holderable.java b/src/main/java/io/papermc/paper/util/Holderable.java
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/src/main/java/io/papermc/paper/util/Holderable.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
+package io.papermc.paper.util;
|
||||||
|
+
|
||||||
|
+import net.minecraft.core.Holder;
|
||||||
|
+import org.bukkit.craftbukkit.util.Handleable;
|
||||||
|
+
|
||||||
|
+public interface Holderable<M> extends Handleable<M> {
|
||||||
|
+
|
||||||
|
+ Holder<M> getHolder();
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ default M getHandle() {
|
||||||
|
+ return this.getHolder().value();
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
diff --git a/src/main/java/net/minecraft/core/registries/BuiltInRegistries.java b/src/main/java/net/minecraft/core/registries/BuiltInRegistries.java
|
diff --git a/src/main/java/net/minecraft/core/registries/BuiltInRegistries.java b/src/main/java/net/minecraft/core/registries/BuiltInRegistries.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/core/registries/BuiltInRegistries.java
|
--- a/src/main/java/net/minecraft/core/registries/BuiltInRegistries.java
|
||||||
|
@ -784,10 +899,83 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
Map<ResourceLocation, T> map = new HashMap<>();
|
Map<ResourceLocation, T> map = new HashMap<>();
|
||||||
SimpleJsonResourceReloadListener.scanDirectory(resourceManager, type.registryKey(), ops, type.codec(), map);
|
SimpleJsonResourceReloadListener.scanDirectory(resourceManager, type.registryKey(), ops, type.codec(), map);
|
||||||
map.forEach((id, value) -> writableRegistry.register(ResourceKey.create(type.registryKey(), id), (T)value, DEFAULT_REGISTRATION_INFO));
|
map.forEach((id, value) -> writableRegistry.register(ResourceKey.create(type.registryKey(), id), (T)value, DEFAULT_REGISTRATION_INFO));
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftParticle.java b/src/main/java/org/bukkit/craftbukkit/CraftParticle.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftParticle.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftParticle.java
|
||||||
|
@@ -0,0 +0,0 @@ public abstract class CraftParticle<D> implements Keyed {
|
||||||
|
}
|
||||||
|
|
||||||
|
public CraftParticleRegistry(net.minecraft.core.Registry<net.minecraft.core.particles.ParticleType<?>> minecraftRegistry) {
|
||||||
|
- super(CraftParticle.class, minecraftRegistry, null, FieldRename.PARTICLE_TYPE_RENAME);
|
||||||
|
+ super(CraftParticle.class, minecraftRegistry, CraftParticleRegistry::createBukkit, FieldRename.PARTICLE_TYPE_RENAME); // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
- @Override
|
||||||
|
- public CraftParticle<?> createBukkit(NamespacedKey namespacedKey, net.minecraft.core.particles.ParticleType<?> particle) {
|
||||||
|
+ public static CraftParticle<?> createBukkit(NamespacedKey namespacedKey, net.minecraft.core.particles.ParticleType<?> particle) { // Paper - idk why this is a separate implementation, just wrap the function
|
||||||
|
if (particle == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java b/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java b/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
|
Preconditions.checkArgument(minecraft != null);
|
||||||
|
|
||||||
|
net.minecraft.core.Registry<M> registry = CraftRegistry.getMinecraftRegistry(registryKey);
|
||||||
|
- B bukkit = bukkitRegistry.get(CraftNamespacedKey.fromMinecraft(registry.getResourceKey(minecraft)
|
||||||
|
- .orElseThrow(() -> new IllegalStateException(String.format("Cannot convert '%s' to bukkit representation, since it is not registered.", minecraft))).location()));
|
||||||
|
+ // Paper start - support direct Holders
|
||||||
|
+ final java.util.Optional<ResourceKey<M>> resourceKey = registry.getResourceKey(minecraft);
|
||||||
|
+ if (resourceKey.isEmpty() && bukkitRegistry instanceof final CraftRegistry<?, ?> craftRegistry && craftRegistry.supportsDirectHolders()) {
|
||||||
|
+ return ((CraftRegistry<B, M>) registry).convertDirectHolder(Holder.direct(minecraft));
|
||||||
|
+ } else if (resourceKey.isEmpty()) {
|
||||||
|
+ throw new IllegalStateException(String.format("Cannot convert '%s' to bukkit representation, since it is not registered.", minecraft));
|
||||||
|
+ }
|
||||||
|
+ final B bukkit = bukkitRegistry.get(CraftNamespacedKey.fromMinecraft(resourceKey.get().location()));
|
||||||
|
+ // Paper end - support direct Holders
|
||||||
|
+
|
||||||
|
+ Preconditions.checkArgument(bukkit != null);
|
||||||
|
+
|
||||||
|
+ return bukkit;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
+ // Paper start - support direct Holders
|
||||||
|
+ public static <B extends Keyed, M> B minecraftHolderToBukkit(final Holder<M> minecraft, final Registry<B> bukkitRegistry) {
|
||||||
|
+ Preconditions.checkArgument(minecraft != null);
|
||||||
|
+
|
||||||
|
+ final B bukkit = switch (minecraft) {
|
||||||
|
+ case final Holder.Direct<M> direct -> {
|
||||||
|
+ if (!(bukkitRegistry instanceof final CraftRegistry<?, ?> craftRegistry) || !craftRegistry.supportsDirectHolders()) {
|
||||||
|
+ throw new IllegalArgumentException("Cannot convert direct holder to bukkit representation");
|
||||||
|
+ }
|
||||||
|
+ yield ((CraftRegistry<B, M>) bukkitRegistry).convertDirectHolder(direct);
|
||||||
|
+ }
|
||||||
|
+ case final Holder.Reference<M> reference -> bukkitRegistry.get(io.papermc.paper.util.MCUtil.fromResourceKey(reference.key()));
|
||||||
|
+ default -> throw new IllegalArgumentException("Unknown holder: " + minecraft);
|
||||||
|
+ };
|
||||||
|
Preconditions.checkArgument(bukkit != null);
|
||||||
|
|
||||||
|
return bukkit;
|
||||||
|
}
|
||||||
|
+ // Paper end - support direct Holders
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Usage note: Only use this method to delegate the conversion methods from the individual Craft classes to here.
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
|
|
||||||
|
public static <B extends Keyed, M> Holder<M> bukkitToMinecraftHolder(B bukkit, ResourceKey<net.minecraft.core.Registry<M>> registryKey) {
|
||||||
|
Preconditions.checkArgument(bukkit != null);
|
||||||
|
+ // Paper start - support direct Holder
|
||||||
|
+ if (bukkit instanceof io.papermc.paper.util.Holderable<?>) {
|
||||||
|
+ return ((io.papermc.paper.util.Holderable<M>) bukkit).getHolder();
|
||||||
|
+ }
|
||||||
|
+ // Paper end - support direct Holder
|
||||||
|
|
||||||
|
net.minecraft.core.Registry<M> registry = CraftRegistry.getMinecraftRegistry(registryKey);
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
+ ", this can happen if a plugin creates its own registry entry with out properly registering it.");
|
+ ", this can happen if a plugin creates its own registry entry with out properly registering it.");
|
||||||
}
|
}
|
||||||
|
@ -896,13 +1084,19 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ private final Class<?> bukkitClass; // Paper - relax preload class
|
+ private final Class<?> bukkitClass; // Paper - relax preload class
|
||||||
private final Map<NamespacedKey, B> cache = new HashMap<>();
|
private final Map<NamespacedKey, B> cache = new HashMap<>();
|
||||||
private final net.minecraft.core.Registry<M> minecraftRegistry;
|
private final net.minecraft.core.Registry<M> minecraftRegistry;
|
||||||
private final BiFunction<NamespacedKey, M, B> minecraftToBukkit;
|
- private final BiFunction<NamespacedKey, M, B> minecraftToBukkit;
|
||||||
- private final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> updater;
|
- private final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> updater;
|
||||||
|
+ private final io.papermc.paper.registry.entry.RegistryTypeMapper<M, B> minecraftToBukkit; // Paper - switch to Holder
|
||||||
+ private final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater; // Paper - rename to make it *clear* what it is *only* for
|
+ private final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater; // Paper - rename to make it *clear* what it is *only* for
|
||||||
private boolean init;
|
private boolean init;
|
||||||
|
|
||||||
- public CraftRegistry(Class<? super B> bukkitClass, net.minecraft.core.Registry<M> minecraftRegistry, BiFunction<NamespacedKey, M, B> minecraftToBukkit, BiFunction<NamespacedKey, ApiVersion, NamespacedKey> updater) {
|
- public CraftRegistry(Class<? super B> bukkitClass, net.minecraft.core.Registry<M> minecraftRegistry, BiFunction<NamespacedKey, M, B> minecraftToBukkit, BiFunction<NamespacedKey, ApiVersion, NamespacedKey> updater) {
|
||||||
+ public CraftRegistry(Class<?> bukkitClass, net.minecraft.core.Registry<M> minecraftRegistry, BiFunction<NamespacedKey, M, B> minecraftToBukkit, BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater) { // Paper - relax preload class
|
+ public CraftRegistry(Class<?> bukkitClass, net.minecraft.core.Registry<M> minecraftRegistry, BiFunction<? super NamespacedKey, M, B> minecraftToBukkit, BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater) { // Paper - relax preload class
|
||||||
|
+ // Paper start - switch to Holder
|
||||||
|
+ this(bukkitClass, minecraftRegistry, new io.papermc.paper.registry.entry.RegistryTypeMapper<>(minecraftToBukkit), serializationUpdater);
|
||||||
|
+ }
|
||||||
|
+ public CraftRegistry(Class<?> bukkitClass, net.minecraft.core.Registry<M> minecraftRegistry, io.papermc.paper.registry.entry.RegistryTypeMapper<M, B> minecraftToBukkit, BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater) { // Paper - relax preload class
|
||||||
|
+ // Paper end - support Holders
|
||||||
this.bukkitClass = bukkitClass;
|
this.bukkitClass = bukkitClass;
|
||||||
this.minecraftRegistry = minecraftRegistry;
|
this.minecraftRegistry = minecraftRegistry;
|
||||||
this.minecraftToBukkit = minecraftToBukkit;
|
this.minecraftToBukkit = minecraftToBukkit;
|
||||||
|
@ -917,6 +1111,39 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public B get(NamespacedKey namespacedKey) {
|
public B get(NamespacedKey namespacedKey) {
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
|
return this.get(namespacedKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
- B bukkit = this.createBukkit(namespacedKey, this.minecraftRegistry.getOptional(CraftNamespacedKey.toMinecraft(namespacedKey)).orElse(null));
|
||||||
|
+ B bukkit = this.createBukkit(namespacedKey, this.minecraftRegistry.get(CraftNamespacedKey.toMinecraft(namespacedKey)).orElse(null)); // Paper - switch to Holder
|
||||||
|
if (bukkit == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
|
return this.stream().iterator();
|
||||||
|
}
|
||||||
|
|
||||||
|
- public B createBukkit(NamespacedKey namespacedKey, M minecraft) {
|
||||||
|
+ public B createBukkit(NamespacedKey namespacedKey, Holder<M> minecraft) { // Paper - switch to Holder
|
||||||
|
if (minecraft == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
- return this.minecraftToBukkit.apply(namespacedKey, minecraft);
|
||||||
|
+ return this.minecraftToBukkit.createBukkit(namespacedKey, minecraft); // Paper - switch to Holder
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ // Paper start - support Direct Holders
|
||||||
|
+ public boolean supportsDirectHolders() {
|
||||||
|
+ return this.minecraftToBukkit.supportsDirectHolders();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public B convertDirectHolder(Holder<M> holder) {
|
||||||
|
+ return this.minecraftToBukkit.convertDirectHolder(holder);
|
||||||
|
}
|
||||||
|
+ // Paper end - support Direct Holders
|
||||||
|
}
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
||||||
|
|
|
@ -22,22 +22,22 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
static {
|
static {
|
||||||
REGISTRY_ENTRIES = List.of(
|
REGISTRY_ENTRIES = List.of(
|
||||||
// built-ins
|
// built-ins
|
||||||
- entry(Registries.GAME_EVENT, RegistryKey.GAME_EVENT, GameEvent.class, CraftGameEvent::new),
|
- start(Registries.GAME_EVENT, RegistryKey.GAME_EVENT).craft(GameEvent.class, CraftGameEvent::new).build(),
|
||||||
+ writable(Registries.GAME_EVENT, RegistryKey.GAME_EVENT, GameEvent.class, CraftGameEvent::new, PaperGameEventRegistryEntry.PaperBuilder::new),
|
+ start(Registries.GAME_EVENT, RegistryKey.GAME_EVENT).craft(GameEvent.class, CraftGameEvent::new).writable(PaperGameEventRegistryEntry.PaperBuilder::new),
|
||||||
entry(Registries.STRUCTURE_TYPE, RegistryKey.STRUCTURE_TYPE, StructureType.class, CraftStructureType::new),
|
start(Registries.STRUCTURE_TYPE, RegistryKey.STRUCTURE_TYPE).craft(StructureType.class, CraftStructureType::new).build(),
|
||||||
entry(Registries.MOB_EFFECT, RegistryKey.MOB_EFFECT, PotionEffectType.class, CraftPotionEffectType::new),
|
start(Registries.MOB_EFFECT, RegistryKey.MOB_EFFECT).craft(PotionEffectType.class, CraftPotionEffectType::new).build(),
|
||||||
entry(Registries.BLOCK, RegistryKey.BLOCK, BlockType.class, CraftBlockType::new),
|
start(Registries.BLOCK, RegistryKey.BLOCK).craft(BlockType.class, CraftBlockType::new).build(),
|
||||||
@@ -0,0 +0,0 @@ public final class PaperRegistries {
|
@@ -0,0 +0,0 @@ public final class PaperRegistries {
|
||||||
entry(Registries.TRIM_PATTERN, RegistryKey.TRIM_PATTERN, TrimPattern.class, CraftTrimPattern::new).delayed(),
|
start(Registries.TRIM_PATTERN, RegistryKey.TRIM_PATTERN).craft(TrimPattern.class, CraftTrimPattern::new).build().delayed(),
|
||||||
entry(Registries.DAMAGE_TYPE, RegistryKey.DAMAGE_TYPE, DamageType.class, CraftDamageType::new).delayed(),
|
start(Registries.DAMAGE_TYPE, RegistryKey.DAMAGE_TYPE).craft(DamageType.class, CraftDamageType::new).build().delayed(),
|
||||||
entry(Registries.WOLF_VARIANT, RegistryKey.WOLF_VARIANT, Wolf.Variant.class, CraftWolf.CraftVariant::new).delayed(),
|
start(Registries.WOLF_VARIANT, RegistryKey.WOLF_VARIANT).craft(Wolf.Variant.class, CraftWolf.CraftVariant::new).build().delayed(),
|
||||||
- entry(Registries.ENCHANTMENT, RegistryKey.ENCHANTMENT, Enchantment.class, CraftEnchantment::new).withSerializationUpdater(FieldRename.ENCHANTMENT_RENAME).delayed(),
|
- start(Registries.ENCHANTMENT, RegistryKey.ENCHANTMENT).craft(Enchantment.class, CraftEnchantment::new).build().withSerializationUpdater(FieldRename.ENCHANTMENT_RENAME).delayed(),
|
||||||
+ writable(Registries.ENCHANTMENT, RegistryKey.ENCHANTMENT, Enchantment.class, CraftEnchantment::new, PaperEnchantmentRegistryEntry.PaperBuilder::new).withSerializationUpdater(FieldRename.ENCHANTMENT_RENAME).delayed(),
|
+ start(Registries.ENCHANTMENT, RegistryKey.ENCHANTMENT).craft(Enchantment.class, CraftEnchantment::new).writable(PaperEnchantmentRegistryEntry.PaperBuilder::new).withSerializationUpdater(FieldRename.ENCHANTMENT_RENAME).delayed(),
|
||||||
entry(Registries.JUKEBOX_SONG, RegistryKey.JUKEBOX_SONG, JukeboxSong.class, CraftJukeboxSong::new).delayed(),
|
start(Registries.JUKEBOX_SONG, RegistryKey.JUKEBOX_SONG).craft(JukeboxSong.class, CraftJukeboxSong::new).build().delayed(),
|
||||||
entry(Registries.BANNER_PATTERN, RegistryKey.BANNER_PATTERN, PatternType.class, CraftPatternType::new).delayed(),
|
start(Registries.BANNER_PATTERN, RegistryKey.BANNER_PATTERN).craft(PatternType.class, CraftPatternType::new).build().delayed(),
|
||||||
- entry(Registries.PAINTING_VARIANT, RegistryKey.PAINTING_VARIANT, Art.class, CraftArt::new).delayed(),
|
- start(Registries.PAINTING_VARIANT, RegistryKey.PAINTING_VARIANT).craft(Art.class, CraftArt::new).build().delayed(),
|
||||||
+ writable(Registries.PAINTING_VARIANT, RegistryKey.PAINTING_VARIANT, Art.class, CraftArt::new, PaperPaintingVariantRegistryEntry.PaperBuilder::new).delayed(),
|
+ start(Registries.PAINTING_VARIANT, RegistryKey.PAINTING_VARIANT).craft(Art.class, CraftArt::new).writable(PaperPaintingVariantRegistryEntry.PaperBuilder::new).delayed(),
|
||||||
entry(Registries.INSTRUMENT, RegistryKey.INSTRUMENT, MusicInstrument.class, CraftMusicInstrument::new).delayed(),
|
start(Registries.INSTRUMENT, RegistryKey.INSTRUMENT).craft(MusicInstrument.class, CraftMusicInstrument::new).build().delayed(),
|
||||||
|
|
||||||
// api-only
|
// api-only
|
||||||
diff --git a/src/main/java/io/papermc/paper/registry/data/PaperEnchantmentRegistryEntry.java b/src/main/java/io/papermc/paper/registry/data/PaperEnchantmentRegistryEntry.java
|
diff --git a/src/main/java/io/papermc/paper/registry/data/PaperEnchantmentRegistryEntry.java b/src/main/java/io/papermc/paper/registry/data/PaperEnchantmentRegistryEntry.java
|
||||||
|
@ -103,7 +103,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
+ public PaperEnchantmentRegistryEntry(
|
+ public PaperEnchantmentRegistryEntry(
|
||||||
+ final Conversions conversions,
|
+ final Conversions conversions,
|
||||||
+ final TypedKey<org.bukkit.enchantments.Enchantment> ignoredKey,
|
|
||||||
+ final @Nullable Enchantment internal
|
+ final @Nullable Enchantment internal
|
||||||
+ ) {
|
+ ) {
|
||||||
+ this.conversions = conversions;
|
+ this.conversions = conversions;
|
||||||
|
@ -188,8 +187,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ public static final class PaperBuilder extends PaperEnchantmentRegistryEntry implements EnchantmentRegistryEntry.Builder,
|
+ public static final class PaperBuilder extends PaperEnchantmentRegistryEntry implements EnchantmentRegistryEntry.Builder,
|
||||||
+ PaperRegistryBuilder<Enchantment, org.bukkit.enchantments.Enchantment> {
|
+ PaperRegistryBuilder<Enchantment, org.bukkit.enchantments.Enchantment> {
|
||||||
+
|
+
|
||||||
+ public PaperBuilder(final Conversions conversions, final TypedKey<org.bukkit.enchantments.Enchantment> key, final @Nullable Enchantment internal) {
|
+ public PaperBuilder(final Conversions conversions, final @Nullable Enchantment internal) {
|
||||||
+ super(conversions, key, internal);
|
+ super(conversions, internal);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
|
@ -300,7 +299,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
+ public PaperGameEventRegistryEntry(
|
+ public PaperGameEventRegistryEntry(
|
||||||
+ final Conversions ignoredConversions,
|
+ final Conversions ignoredConversions,
|
||||||
+ final io.papermc.paper.registry.TypedKey<org.bukkit.GameEvent> ignoredKey,
|
|
||||||
+ final @Nullable GameEvent internal
|
+ final @Nullable GameEvent internal
|
||||||
+ ) {
|
+ ) {
|
||||||
+ if (internal == null) return;
|
+ if (internal == null) return;
|
||||||
|
@ -318,10 +316,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
+ public PaperBuilder(
|
+ public PaperBuilder(
|
||||||
+ final Conversions conversions,
|
+ final Conversions conversions,
|
||||||
+ final io.papermc.paper.registry.TypedKey<org.bukkit.GameEvent> key,
|
|
||||||
+ final @Nullable GameEvent internal
|
+ final @Nullable GameEvent internal
|
||||||
+ ) {
|
+ ) {
|
||||||
+ super(conversions, key, internal);
|
+ super(conversions, internal);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
|
@ -346,7 +343,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
+import io.papermc.paper.adventure.PaperAdventure;
|
+import io.papermc.paper.adventure.PaperAdventure;
|
||||||
+import io.papermc.paper.registry.PaperRegistryBuilder;
|
+import io.papermc.paper.registry.PaperRegistryBuilder;
|
||||||
+import io.papermc.paper.registry.TypedKey;
|
|
||||||
+import io.papermc.paper.registry.data.util.Conversions;
|
+import io.papermc.paper.registry.data.util.Conversions;
|
||||||
+import java.util.Optional;
|
+import java.util.Optional;
|
||||||
+import java.util.OptionalInt;
|
+import java.util.OptionalInt;
|
||||||
|
@ -356,14 +352,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import net.minecraft.world.entity.decoration.PaintingVariant;
|
+import net.minecraft.world.entity.decoration.PaintingVariant;
|
||||||
+import org.bukkit.Art;
|
+import org.bukkit.Art;
|
||||||
+import org.jetbrains.annotations.Range;
|
+import org.jetbrains.annotations.Range;
|
||||||
+import org.jspecify.annotations.NullMarked;
|
|
||||||
+import org.jspecify.annotations.Nullable;
|
+import org.jspecify.annotations.Nullable;
|
||||||
+
|
+
|
||||||
+import static io.papermc.paper.registry.data.util.Checks.asArgument;
|
+import static io.papermc.paper.registry.data.util.Checks.asArgument;
|
||||||
+import static io.papermc.paper.registry.data.util.Checks.asArgumentRange;
|
+import static io.papermc.paper.registry.data.util.Checks.asArgumentRange;
|
||||||
+import static io.papermc.paper.registry.data.util.Checks.asConfigured;
|
+import static io.papermc.paper.registry.data.util.Checks.asConfigured;
|
||||||
+
|
+
|
||||||
+@NullMarked
|
|
||||||
+public class PaperPaintingVariantRegistryEntry implements PaintingVariantRegistryEntry {
|
+public class PaperPaintingVariantRegistryEntry implements PaintingVariantRegistryEntry {
|
||||||
+
|
+
|
||||||
+ protected OptionalInt width = OptionalInt.empty();
|
+ protected OptionalInt width = OptionalInt.empty();
|
||||||
|
@ -376,7 +370,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
+ public PaperPaintingVariantRegistryEntry(
|
+ public PaperPaintingVariantRegistryEntry(
|
||||||
+ final Conversions conversions,
|
+ final Conversions conversions,
|
||||||
+ final TypedKey<Art> ignoredKey,
|
|
||||||
+ final @Nullable PaintingVariant internal
|
+ final @Nullable PaintingVariant internal
|
||||||
+ ) {
|
+ ) {
|
||||||
+ this.conversions = conversions;
|
+ this.conversions = conversions;
|
||||||
|
@ -416,8 +409,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
+ public static final class PaperBuilder extends PaperPaintingVariantRegistryEntry implements PaintingVariantRegistryEntry.Builder, PaperRegistryBuilder<PaintingVariant, Art> {
|
+ public static final class PaperBuilder extends PaperPaintingVariantRegistryEntry implements PaintingVariantRegistryEntry.Builder, PaperRegistryBuilder<PaintingVariant, Art> {
|
||||||
+
|
+
|
||||||
+ public PaperBuilder(final Conversions conversions, final TypedKey<Art> key, final @Nullable PaintingVariant internal) {
|
+ public PaperBuilder(final Conversions conversions, final @Nullable PaintingVariant internal) {
|
||||||
+ super(conversions, key, internal);
|
+ super(conversions, internal);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
|
|
|
@ -3704,19 +3704,19 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import io.papermc.paper.adventure.PaperAdventure;
|
import io.papermc.paper.adventure.PaperAdventure;
|
||||||
+import io.papermc.paper.datacomponent.DataComponentType;
|
+import io.papermc.paper.datacomponent.DataComponentTypes;
|
||||||
+import io.papermc.paper.datacomponent.PaperDataComponentType;
|
+import io.papermc.paper.datacomponent.PaperDataComponentType;
|
||||||
import io.papermc.paper.registry.data.PaperEnchantmentRegistryEntry;
|
import io.papermc.paper.registry.data.PaperEnchantmentRegistryEntry;
|
||||||
import io.papermc.paper.registry.data.PaperGameEventRegistryEntry;
|
import io.papermc.paper.registry.data.PaperGameEventRegistryEntry;
|
||||||
import io.papermc.paper.registry.data.PaperPaintingVariantRegistryEntry;
|
import io.papermc.paper.registry.data.PaperPaintingVariantRegistryEntry;
|
||||||
@@ -0,0 +0,0 @@ public final class PaperRegistries {
|
@@ -0,0 +0,0 @@ public final class PaperRegistries {
|
||||||
entry(Registries.ATTRIBUTE, RegistryKey.ATTRIBUTE, Attribute.class, CraftAttribute::new),
|
start(Registries.ATTRIBUTE, RegistryKey.ATTRIBUTE).craft(Attribute.class, CraftAttribute::new).build(),
|
||||||
entry(Registries.FLUID, RegistryKey.FLUID, Fluid.class, CraftFluid::new),
|
start(Registries.FLUID, RegistryKey.FLUID).craft(Fluid.class, CraftFluid::new).build(),
|
||||||
entry(Registries.SOUND_EVENT, RegistryKey.SOUND_EVENT, Sound.class, CraftSound::new),
|
start(Registries.SOUND_EVENT, RegistryKey.SOUND_EVENT).craft(Sound.class, CraftSound::new).build(),
|
||||||
+ entry(Registries.DATA_COMPONENT_TYPE, RegistryKey.DATA_COMPONENT_TYPE, DataComponentType.class, PaperDataComponentType::of),
|
+ start(Registries.DATA_COMPONENT_TYPE, RegistryKey.DATA_COMPONENT_TYPE).craft(DataComponentTypes.class, PaperDataComponentType::of).build(),
|
||||||
|
|
||||||
// data-drivens
|
// data-drivens
|
||||||
entry(Registries.BIOME, RegistryKey.BIOME, Biome.class, CraftBiome::new).delayed(),
|
start(Registries.BIOME, RegistryKey.BIOME).craft(Biome.class, CraftBiome::new).build().delayed(),
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
||||||
|
|
|
@ -31,6 +31,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public static <T extends org.bukkit.Keyed, M> java.util.Optional<T> unwrapAndConvertHolder(final Registry<T> registry, final Holder<M> value) {
|
+ public static <T extends org.bukkit.Keyed, M> java.util.Optional<T> unwrapAndConvertHolder(final Registry<T> registry, final Holder<M> value) {
|
||||||
|
+ if (registry instanceof CraftRegistry<?,?> craftRegistry && craftRegistry.supportsDirectHolders() && value.kind() == Holder.Kind.DIRECT) {
|
||||||
|
+ return java.util.Optional.of(((CraftRegistry<T, M>) registry).convertDirectHolder(value));
|
||||||
|
+ }
|
||||||
+ return value.unwrapKey().map(key -> registry.get(CraftNamespacedKey.fromMinecraft(key.location())));
|
+ return value.unwrapKey().map(key -> registry.get(CraftNamespacedKey.fromMinecraft(key.location())));
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end - fixup upstream being dum
|
+ // Paper end - fixup upstream being dum
|
||||||
|
@ -80,22 +83,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
|
||||||
@@ -0,0 +0,0 @@ public class CraftMetaArmor extends CraftMetaItem implements ArmorMeta {
|
|
||||||
super(tag);
|
|
||||||
|
|
||||||
getOrEmpty(tag, CraftMetaArmor.TRIM).ifPresent((trimCompound) -> {
|
|
||||||
- TrimMaterial trimMaterial = CraftTrimMaterial.minecraftHolderToBukkit(trimCompound.material());
|
|
||||||
- TrimPattern trimPattern = CraftTrimPattern.minecraftHolderToBukkit(trimCompound.pattern());
|
|
||||||
+ TrimMaterial trimMaterial = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(io.papermc.paper.registry.RegistryKey.TRIM_MATERIAL, trimCompound.material()).orElse(null); // Paper - fix upstream not being correct
|
|
||||||
+ TrimPattern trimPattern = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(io.papermc.paper.registry.RegistryKey.TRIM_PATTERN, trimCompound.pattern()).orElse(null); // Paper - fix upstream not being correct
|
|
||||||
+ if (trimMaterial == null || trimPattern == null) return; // Paper - just delete the trim because upstream is not doing this right
|
|
||||||
|
|
||||||
this.trim = new ArmorTrim(trimMaterial, trimPattern);
|
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBanner.java
|
||||||
|
@ -109,19 +96,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
if (color != null && pattern != null) {
|
if (color != null && pattern != null) {
|
||||||
this.patterns.add(new Pattern(color, pattern));
|
this.patterns.add(new Pattern(color, pattern));
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
|
||||||
@@ -0,0 +0,0 @@ public class CraftMetaMusicInstrument extends CraftMetaItem implements MusicInst
|
|
||||||
super(tag);
|
|
||||||
|
|
||||||
getOrEmpty(tag, CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT).ifPresent((instrument) -> {
|
|
||||||
- this.instrument = CraftMusicInstrument.minecraftHolderToBukkit(instrument);
|
|
||||||
+ this.instrument = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(org.bukkit.Registry.INSTRUMENT, instrument).orElse(null); // Paper - fix upstream not handling inlined instrument
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaShield.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaShield.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaShield.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaShield.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaShield.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaShield.java
|
||||||
|
|
|
@ -38,7 +38,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
private final Map<NamespacedKey, B> cache = new HashMap<>();
|
private final Map<NamespacedKey, B> cache = new HashMap<>();
|
||||||
+ private final Map<B, NamespacedKey> byValue = new java.util.IdentityHashMap<>(); // Paper - improve Registry
|
+ private final Map<B, NamespacedKey> byValue = new java.util.IdentityHashMap<>(); // Paper - improve Registry
|
||||||
private final net.minecraft.core.Registry<M> minecraftRegistry;
|
private final net.minecraft.core.Registry<M> minecraftRegistry;
|
||||||
private final BiFunction<NamespacedKey, M, B> minecraftToBukkit;
|
private final io.papermc.paper.registry.entry.RegistryTypeMapper<M, B> minecraftToBukkit; // Paper - switch to Holder
|
||||||
private final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater; // Paper - rename to make it *clear* what it is *only* for
|
private final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater; // Paper - rename to make it *clear* what it is *only* for
|
||||||
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
}
|
}
|
||||||
|
@ -49,9 +49,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
return bukkit;
|
return bukkit;
|
||||||
}
|
}
|
||||||
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
|
return this.minecraftToBukkit.convertDirectHolder(holder);
|
||||||
return this.minecraftToBukkit.apply(namespacedKey, minecraft);
|
|
||||||
}
|
}
|
||||||
|
// Paper end - support Direct Holders
|
||||||
+
|
+
|
||||||
+ // Paper start - improve Registry
|
+ // Paper start - improve Registry
|
||||||
+ @Override
|
+ @Override
|
||||||
|
|
|
@ -20,14 +20,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.IdentityHashMap;
|
import java.util.IdentityHashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -0,0 +0,0 @@ import org.jspecify.annotations.Nullable;
|
|
||||||
|
|
||||||
import static io.papermc.paper.registry.entry.RegistryEntry.apiOnly;
|
|
||||||
import static io.papermc.paper.registry.entry.RegistryEntry.entry;
|
|
||||||
+import static io.papermc.paper.registry.entry.RegistryEntry.writable;
|
|
||||||
|
|
||||||
public final class PaperRegistries {
|
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public final class PaperRegistries {
|
@@ -0,0 +0,0 @@ public final class PaperRegistries {
|
||||||
return ResourceKey.create((ResourceKey<? extends Registry<M>>) PaperRegistries.registryToNms(typedKey.registryKey()), PaperAdventure.asVanilla(typedKey.key()));
|
return ResourceKey.create((ResourceKey<? extends Registry<M>>) PaperRegistries.registryToNms(typedKey.registryKey()), PaperAdventure.asVanilla(typedKey.key()));
|
||||||
}
|
}
|
||||||
|
@ -81,17 +73,17 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ @FunctionalInterface
|
+ @FunctionalInterface
|
||||||
+ interface Filler<M, T, B extends PaperRegistryBuilder<M, T>> {
|
+ interface Filler<M, T, B extends PaperRegistryBuilder<M, T>> {
|
||||||
+
|
+
|
||||||
+ B fill(Conversions conversions, TypedKey<T> key, @Nullable M nms);
|
+ B fill(Conversions conversions, @Nullable M nms);
|
||||||
+
|
+
|
||||||
+ default Factory<M, T, B> asFactory() {
|
+ default Factory<M, T, B> asFactory() {
|
||||||
+ return (lookup, key) -> this.fill(lookup, key, null);
|
+ return (lookup) -> this.fill(lookup, null);
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @FunctionalInterface
|
+ @FunctionalInterface
|
||||||
+ interface Factory<M, T, B extends PaperRegistryBuilder<M, T>> {
|
+ interface Factory<M, T, B extends PaperRegistryBuilder<M, T>> {
|
||||||
+
|
+
|
||||||
+ B create(Conversions conversions, TypedKey<T> key);
|
+ B create(Conversions conversions);
|
||||||
+ }
|
+ }
|
||||||
+}
|
+}
|
||||||
diff --git a/src/main/java/io/papermc/paper/registry/PaperRegistryListenerManager.java b/src/main/java/io/papermc/paper/registry/PaperRegistryListenerManager.java
|
diff --git a/src/main/java/io/papermc/paper/registry/PaperRegistryListenerManager.java b/src/main/java/io/papermc/paper/registry/PaperRegistryListenerManager.java
|
||||||
|
@ -204,7 +196,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ }
|
+ }
|
||||||
+ final RegistryEntry.Modifiable<M, T, B> modifiableEntry = RegistryEntry.Modifiable.asModifiable(entry);
|
+ final RegistryEntry.Modifiable<M, T, B> modifiableEntry = RegistryEntry.Modifiable.asModifiable(entry);
|
||||||
+ @SuppressWarnings("PatternValidation") final TypedKey<T> typedKey = TypedKey.create(entry.apiKey(), Key.key(key.location().getNamespace(), key.location().getPath()));
|
+ @SuppressWarnings("PatternValidation") final TypedKey<T> typedKey = TypedKey.create(entry.apiKey(), Key.key(key.location().getNamespace(), key.location().getPath()));
|
||||||
+ final B builder = modifiableEntry.fillBuilder(conversions, typedKey, nms);
|
+ final B builder = modifiableEntry.fillBuilder(conversions, nms);
|
||||||
+ return this.registerWithListeners(registry, modifiableEntry, key, nms, builder, registrationInfo, registerMethod, conversions);
|
+ return this.registerWithListeners(registry, modifiableEntry, key, nms, builder, registrationInfo, registerMethod, conversions);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
@ -324,9 +316,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+package io.papermc.paper.registry;
|
+package io.papermc.paper.registry;
|
||||||
+
|
+
|
||||||
+import com.mojang.serialization.Lifecycle;
|
+import com.mojang.serialization.Lifecycle;
|
||||||
+import io.papermc.paper.adventure.PaperAdventure;
|
|
||||||
+import io.papermc.paper.registry.data.util.Conversions;
|
+import io.papermc.paper.registry.data.util.Conversions;
|
||||||
+import io.papermc.paper.registry.entry.RegistryEntry;
|
+import io.papermc.paper.registry.entry.RegistryEntry;
|
||||||
|
+import io.papermc.paper.registry.entry.RegistryTypeMapper;
|
||||||
+import io.papermc.paper.registry.event.WritableRegistry;
|
+import io.papermc.paper.registry.event.WritableRegistry;
|
||||||
+import java.util.Optional;
|
+import java.util.Optional;
|
||||||
+import java.util.function.BiFunction;
|
+import java.util.function.BiFunction;
|
||||||
|
@ -338,7 +330,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import org.bukkit.NamespacedKey;
|
+import org.bukkit.NamespacedKey;
|
||||||
+import org.bukkit.craftbukkit.CraftRegistry;
|
+import org.bukkit.craftbukkit.CraftRegistry;
|
||||||
+import org.bukkit.craftbukkit.util.ApiVersion;
|
+import org.bukkit.craftbukkit.util.ApiVersion;
|
||||||
+import org.jspecify.annotations.Nullable;
|
|
||||||
+
|
+
|
||||||
+public class WritableCraftRegistry<M, T extends Keyed, B extends PaperRegistryBuilder<M, T>> extends CraftRegistry<T, M> {
|
+public class WritableCraftRegistry<M, T extends Keyed, B extends PaperRegistryBuilder<M, T>> extends CraftRegistry<T, M> {
|
||||||
+
|
+
|
||||||
|
@ -347,7 +338,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ private final RegistryEntry.BuilderHolder<M, T, B> entry;
|
+ private final RegistryEntry.BuilderHolder<M, T, B> entry;
|
||||||
+ private final MappedRegistry<M> registry;
|
+ private final MappedRegistry<M> registry;
|
||||||
+ private final PaperRegistryBuilder.Factory<M, T, ? extends B> builderFactory;
|
+ private final PaperRegistryBuilder.Factory<M, T, ? extends B> builderFactory;
|
||||||
+ private final BiFunction<? super NamespacedKey, M, T> minecraftToBukkit;
|
|
||||||
+
|
+
|
||||||
+ public WritableCraftRegistry(
|
+ public WritableCraftRegistry(
|
||||||
+ final RegistryEntry.BuilderHolder<M, T, B> entry,
|
+ final RegistryEntry.BuilderHolder<M, T, B> entry,
|
||||||
|
@ -355,19 +345,18 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ final MappedRegistry<M> registry,
|
+ final MappedRegistry<M> registry,
|
||||||
+ final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater,
|
+ final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater,
|
||||||
+ final PaperRegistryBuilder.Factory<M, T, ? extends B> builderFactory,
|
+ final PaperRegistryBuilder.Factory<M, T, ? extends B> builderFactory,
|
||||||
+ final BiFunction<? super NamespacedKey, M, T> minecraftToBukkit
|
+ final RegistryTypeMapper<M, T> minecraftToBukkit
|
||||||
+ ) {
|
+ ) {
|
||||||
+ super(classToPreload, registry, null, serializationUpdater);
|
+ super(classToPreload, registry, minecraftToBukkit, serializationUpdater);
|
||||||
+ this.entry = entry;
|
+ this.entry = entry;
|
||||||
+ this.registry = registry;
|
+ this.registry = registry;
|
||||||
+ this.builderFactory = builderFactory;
|
+ this.builderFactory = builderFactory;
|
||||||
+ this.minecraftToBukkit = minecraftToBukkit;
|
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public void register(final TypedKey<T> key, final Consumer<? super B> value, final Conversions conversions) {
|
+ public void register(final TypedKey<T> key, final Consumer<? super B> value, final Conversions conversions) {
|
||||||
+ final ResourceKey<M> resourceKey = ResourceKey.create(this.registry.key(), PaperAdventure.asVanilla(key.key()));
|
+ final ResourceKey<M> resourceKey = PaperRegistries.toNms(key);
|
||||||
+ this.registry.validateWrite(resourceKey);
|
+ this.registry.validateWrite(resourceKey);
|
||||||
+ final B builder = this.newBuilder(conversions, key);
|
+ final B builder = this.newBuilder(conversions);
|
||||||
+ value.accept(builder);
|
+ value.accept(builder);
|
||||||
+ PaperRegistryListenerManager.INSTANCE.registerWithListeners(
|
+ PaperRegistryListenerManager.INSTANCE.registerWithListeners(
|
||||||
+ this.registry,
|
+ this.registry,
|
||||||
|
@ -379,24 +368,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ );
|
+ );
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
|
||||||
+ public final @Nullable T createBukkit(final NamespacedKey namespacedKey, final @Nullable M minecraft) {
|
|
||||||
+ if (minecraft == null) {
|
|
||||||
+ return null;
|
|
||||||
+ }
|
|
||||||
+ return this.minecraftToBukkit(namespacedKey, minecraft);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ public WritableRegistry<T, B> createApiWritableRegistry(final Conversions conversions) {
|
+ public WritableRegistry<T, B> createApiWritableRegistry(final Conversions conversions) {
|
||||||
+ return new ApiWritableRegistry(conversions);
|
+ return new ApiWritableRegistry(conversions);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public T minecraftToBukkit(final NamespacedKey namespacedKey, final M minecraft) {
|
+ protected B newBuilder(final Conversions conversions) {
|
||||||
+ return this.minecraftToBukkit.apply(namespacedKey, minecraft);
|
+ return this.builderFactory.create(conversions);
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ protected B newBuilder(final Conversions conversions, final TypedKey<T> key) {
|
|
||||||
+ return this.builderFactory.create(conversions, key);
|
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public class ApiWritableRegistry implements WritableRegistry<T, B> {
|
+ public class ApiWritableRegistry implements WritableRegistry<T, B> {
|
||||||
|
@ -421,15 +398,40 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@
|
@@ -0,0 +0,0 @@
|
||||||
+package io.papermc.paper.registry.data.util;
|
+package io.papermc.paper.registry.data.util;
|
||||||
+
|
+
|
||||||
|
+import com.google.common.base.Preconditions;
|
||||||
+import com.mojang.serialization.JavaOps;
|
+import com.mojang.serialization.JavaOps;
|
||||||
+import io.papermc.paper.adventure.WrapperAwareSerializer;
|
+import io.papermc.paper.adventure.WrapperAwareSerializer;
|
||||||
|
+import java.util.Optional;
|
||||||
+import net.kyori.adventure.text.Component;
|
+import net.kyori.adventure.text.Component;
|
||||||
|
+import net.minecraft.core.Registry;
|
||||||
|
+import net.minecraft.core.RegistryAccess;
|
||||||
+import net.minecraft.resources.RegistryOps;
|
+import net.minecraft.resources.RegistryOps;
|
||||||
|
+import net.minecraft.resources.ResourceKey;
|
||||||
|
+import org.bukkit.craftbukkit.CraftRegistry;
|
||||||
+import org.jetbrains.annotations.Contract;
|
+import org.jetbrains.annotations.Contract;
|
||||||
+import org.jspecify.annotations.Nullable;
|
+import org.jspecify.annotations.Nullable;
|
||||||
+
|
+
|
||||||
+public class Conversions {
|
+public class Conversions {
|
||||||
+
|
+
|
||||||
|
+ private static @Nullable Conversions globalInstance;
|
||||||
|
+ public static Conversions global() {
|
||||||
|
+ if (globalInstance == null) {
|
||||||
|
+ final RegistryAccess globalAccess = CraftRegistry.getMinecraftRegistry();
|
||||||
|
+ Preconditions.checkState(globalAccess != null, "Global registry access is not available");
|
||||||
|
+ globalInstance = new Conversions(new RegistryOps.RegistryInfoLookup() {
|
||||||
|
+ @Override
|
||||||
|
+ public <T> Optional<RegistryOps.RegistryInfo<T>> lookup(final ResourceKey<? extends Registry<? extends T>> registryRef) {
|
||||||
|
+ final Registry<T> registry = globalAccess.lookupOrThrow(registryRef);
|
||||||
|
+ return Optional.of(
|
||||||
|
+ new RegistryOps.RegistryInfo<>(registry, registry, registry.registryLifecycle())
|
||||||
|
+ );
|
||||||
|
+ }
|
||||||
|
+ });
|
||||||
|
+ }
|
||||||
|
+ return globalInstance;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+
|
||||||
+ private final RegistryOps.RegistryInfoLookup lookup;
|
+ private final RegistryOps.RegistryInfoLookup lookup;
|
||||||
+ private final WrapperAwareSerializer serializer;
|
+ private final WrapperAwareSerializer serializer;
|
||||||
+
|
+
|
||||||
|
@ -473,15 +475,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import io.papermc.paper.registry.PaperRegistryBuilder;
|
+import io.papermc.paper.registry.PaperRegistryBuilder;
|
||||||
+import io.papermc.paper.registry.RegistryHolder;
|
+import io.papermc.paper.registry.RegistryHolder;
|
||||||
+import io.papermc.paper.registry.RegistryKey;
|
+import io.papermc.paper.registry.RegistryKey;
|
||||||
+import io.papermc.paper.registry.TypedKey;
|
|
||||||
+import io.papermc.paper.registry.WritableCraftRegistry;
|
+import io.papermc.paper.registry.WritableCraftRegistry;
|
||||||
+import io.papermc.paper.registry.data.util.Conversions;
|
+import io.papermc.paper.registry.data.util.Conversions;
|
||||||
+import java.util.function.BiFunction;
|
|
||||||
+import net.minecraft.core.MappedRegistry;
|
+import net.minecraft.core.MappedRegistry;
|
||||||
+import net.minecraft.core.Registry;
|
+import net.minecraft.core.Registry;
|
||||||
+import net.minecraft.resources.ResourceKey;
|
+import net.minecraft.resources.ResourceKey;
|
||||||
+import org.bukkit.Keyed;
|
+import org.bukkit.Keyed;
|
||||||
+import org.bukkit.NamespacedKey;
|
|
||||||
+
|
+
|
||||||
+public class AddableRegistryEntry<M, T extends Keyed, B extends PaperRegistryBuilder<M, T>> extends CraftRegistryEntry<M, T> implements RegistryEntry.Addable<M, T, B> {
|
+public class AddableRegistryEntry<M, T extends Keyed, B extends PaperRegistryBuilder<M, T>> extends CraftRegistryEntry<M, T> implements RegistryEntry.Addable<M, T, B> {
|
||||||
+
|
+
|
||||||
|
@ -491,7 +490,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ final ResourceKey<? extends Registry<M>> mcKey,
|
+ final ResourceKey<? extends Registry<M>> mcKey,
|
||||||
+ final RegistryKey<T> apiKey,
|
+ final RegistryKey<T> apiKey,
|
||||||
+ final Class<?> classToPreload,
|
+ final Class<?> classToPreload,
|
||||||
+ final BiFunction<NamespacedKey, M, T> minecraftToBukkit,
|
+ final RegistryTypeMapper<M, T> minecraftToBukkit,
|
||||||
+ final PaperRegistryBuilder.Filler<M, T, B> builderFiller
|
+ final PaperRegistryBuilder.Filler<M, T, B> builderFiller
|
||||||
+ ) {
|
+ ) {
|
||||||
+ super(mcKey, apiKey, classToPreload, minecraftToBukkit);
|
+ super(mcKey, apiKey, classToPreload, minecraftToBukkit);
|
||||||
|
@ -508,8 +507,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public B fillBuilder(final Conversions conversions, final TypedKey<T> key, final M nms) {
|
+ public B fillBuilder(final Conversions conversions, final M nms) {
|
||||||
+ return this.builderFiller.fill(conversions, key, nms);
|
+ return this.builderFiller.fill(conversions, nms);
|
||||||
+ }
|
+ }
|
||||||
+}
|
+}
|
||||||
diff --git a/src/main/java/io/papermc/paper/registry/entry/ModifiableRegistryEntry.java b/src/main/java/io/papermc/paper/registry/entry/ModifiableRegistryEntry.java
|
diff --git a/src/main/java/io/papermc/paper/registry/entry/ModifiableRegistryEntry.java b/src/main/java/io/papermc/paper/registry/entry/ModifiableRegistryEntry.java
|
||||||
|
@ -522,13 +521,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+
|
+
|
||||||
+import io.papermc.paper.registry.PaperRegistryBuilder;
|
+import io.papermc.paper.registry.PaperRegistryBuilder;
|
||||||
+import io.papermc.paper.registry.RegistryKey;
|
+import io.papermc.paper.registry.RegistryKey;
|
||||||
+import io.papermc.paper.registry.TypedKey;
|
|
||||||
+import io.papermc.paper.registry.data.util.Conversions;
|
+import io.papermc.paper.registry.data.util.Conversions;
|
||||||
+import java.util.function.BiFunction;
|
|
||||||
+import net.minecraft.core.Registry;
|
+import net.minecraft.core.Registry;
|
||||||
+import net.minecraft.resources.ResourceKey;
|
+import net.minecraft.resources.ResourceKey;
|
||||||
+import org.bukkit.Keyed;
|
+import org.bukkit.Keyed;
|
||||||
+import org.bukkit.NamespacedKey;
|
|
||||||
+
|
+
|
||||||
+public class ModifiableRegistryEntry<M, T extends Keyed, B extends PaperRegistryBuilder<M, T>> extends CraftRegistryEntry<M, T> implements RegistryEntry.Modifiable<M, T, B> {
|
+public class ModifiableRegistryEntry<M, T extends Keyed, B extends PaperRegistryBuilder<M, T>> extends CraftRegistryEntry<M, T> implements RegistryEntry.Modifiable<M, T, B> {
|
||||||
+
|
+
|
||||||
|
@ -538,7 +534,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ final ResourceKey<? extends Registry<M>> mcKey,
|
+ final ResourceKey<? extends Registry<M>> mcKey,
|
||||||
+ final RegistryKey<T> apiKey,
|
+ final RegistryKey<T> apiKey,
|
||||||
+ final Class<?> toPreload,
|
+ final Class<?> toPreload,
|
||||||
+ final BiFunction<NamespacedKey, M, T> minecraftToBukkit,
|
+ final RegistryTypeMapper<M, T> minecraftToBukkit,
|
||||||
+ final PaperRegistryBuilder.Filler<M, T, B> builderFiller
|
+ final PaperRegistryBuilder.Filler<M, T, B> builderFiller
|
||||||
+ ) {
|
+ ) {
|
||||||
+ super(mcKey, apiKey, toPreload, minecraftToBukkit);
|
+ super(mcKey, apiKey, toPreload, minecraftToBukkit);
|
||||||
|
@ -546,8 +542,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public B fillBuilder(final Conversions conversions, final TypedKey<T> key, final M nms) {
|
+ public B fillBuilder(final Conversions conversions, final M nms) {
|
||||||
+ return this.builderFiller.fill(conversions, key, nms);
|
+ return this.builderFiller.fill(conversions, nms);
|
||||||
+ }
|
+ }
|
||||||
+}
|
+}
|
||||||
diff --git a/src/main/java/io/papermc/paper/registry/entry/RegistryEntry.java b/src/main/java/io/papermc/paper/registry/entry/RegistryEntry.java
|
diff --git a/src/main/java/io/papermc/paper/registry/entry/RegistryEntry.java b/src/main/java/io/papermc/paper/registry/entry/RegistryEntry.java
|
||||||
|
@ -567,8 +563,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import io.papermc.paper.registry.event.RegistryFreezeEventImpl;
|
+import io.papermc.paper.registry.event.RegistryFreezeEventImpl;
|
||||||
import io.papermc.paper.registry.legacy.DelayedRegistryEntry;
|
import io.papermc.paper.registry.legacy.DelayedRegistryEntry;
|
||||||
import java.util.function.BiFunction;
|
import java.util.function.BiFunction;
|
||||||
import java.util.function.Supplier;
|
import net.minecraft.core.Registry;
|
||||||
@@ -0,0 +0,0 @@ import net.minecraft.resources.ResourceKey;
|
|
||||||
import org.bukkit.Keyed;
|
import org.bukkit.Keyed;
|
||||||
import org.bukkit.NamespacedKey;
|
import org.bukkit.NamespacedKey;
|
||||||
import org.bukkit.craftbukkit.util.ApiVersion;
|
import org.bukkit.craftbukkit.util.ApiVersion;
|
||||||
|
@ -577,12 +572,13 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
public interface RegistryEntry<M, B extends Keyed> extends RegistryEntryInfo<M, B> { // TODO remove Keyed
|
public interface RegistryEntry<M, B extends Keyed> extends RegistryEntryInfo<M, B> { // TODO remove Keyed
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public interface RegistryEntry<M, B extends Keyed> extends RegistryEntryInfo<M,
|
@@ -0,0 +0,0 @@ public interface RegistryEntry<M, B extends Keyed> extends RegistryEntryInfo<M,
|
||||||
|
default RegistryEntry<M, B> delayed() {
|
||||||
return new DelayedRegistryEntry<>(this);
|
return new DelayedRegistryEntry<>(this);
|
||||||
}
|
}
|
||||||
|
+
|
||||||
+ interface BuilderHolder<M, T, B extends PaperRegistryBuilder<M, T>> extends RegistryEntryInfo<M, T> {
|
+ interface BuilderHolder<M, T, B extends PaperRegistryBuilder<M, T>> extends RegistryEntryInfo<M, T> {
|
||||||
+
|
+
|
||||||
+ B fillBuilder(Conversions conversions, TypedKey<T> key, M nms);
|
+ B fillBuilder(Conversions conversions, M nms);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ /**
|
+ /**
|
||||||
|
@ -638,34 +634,36 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ private static <M, B extends Keyed> RegistryEntryInfo<M, B> possiblyUnwrap(final RegistryEntryInfo<M, B> entry) {
|
+ private static <M, B extends Keyed> RegistryEntryInfo<M, B> possiblyUnwrap(final RegistryEntryInfo<M, B> entry) {
|
||||||
+ return entry instanceof final DelayedRegistryEntry<M, B> delayed ? delayed.delegate() : entry;
|
+ return entry instanceof final DelayedRegistryEntry<M, B> delayed ? delayed.delegate() : entry;
|
||||||
+ }
|
+ }
|
||||||
+
|
}
|
||||||
static <M, B extends Keyed> RegistryEntry<M, B> entry(
|
diff --git a/src/main/java/io/papermc/paper/registry/entry/RegistryEntryBuilder.java b/src/main/java/io/papermc/paper/registry/entry/RegistryEntryBuilder.java
|
||||||
final ResourceKey<? extends Registry<M>> mcKey,
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
final RegistryKey<B> apiKey,
|
--- a/src/main/java/io/papermc/paper/registry/entry/RegistryEntryBuilder.java
|
||||||
@@ -0,0 +0,0 @@ public interface RegistryEntry<M, B extends Keyed> extends RegistryEntryInfo<M,
|
+++ b/src/main/java/io/papermc/paper/registry/entry/RegistryEntryBuilder.java
|
||||||
) {
|
@@ -0,0 +0,0 @@
|
||||||
return new ApiRegistryEntry<>(mcKey, apiKey, apiRegistrySupplier);
|
package io.papermc.paper.registry.entry;
|
||||||
|
|
||||||
|
import com.mojang.datafixers.util.Either;
|
||||||
|
+import io.papermc.paper.registry.PaperRegistryBuilder;
|
||||||
|
import io.papermc.paper.registry.RegistryKey;
|
||||||
|
import java.util.function.BiFunction;
|
||||||
|
import java.util.function.Function;
|
||||||
|
@@ -0,0 +0,0 @@ public class RegistryEntryBuilder<M, A extends Keyed> { // TODO remove Keyed
|
||||||
|
public RegistryEntry<M, A> build() {
|
||||||
|
return new CraftRegistryEntry<>(this.mcKey, this.apiKey, this.classToPreload, this.minecraftToBukkit);
|
||||||
}
|
}
|
||||||
+
|
+
|
||||||
+ static <M, T extends Keyed, B extends PaperRegistryBuilder<M, T>> RegistryEntry<M, T> modifiable(
|
+ public <B extends PaperRegistryBuilder<M, A>> RegistryEntry<M, A> modifiable(final PaperRegistryBuilder.Filler<M, A, B> filler) {
|
||||||
+ final ResourceKey<? extends Registry<M>> mcKey,
|
+ return new ModifiableRegistryEntry<>(this.mcKey, this.apiKey, this.classToPreload, this.minecraftToBukkit, filler);
|
||||||
+ final RegistryKey<T> apiKey,
|
|
||||||
+ final Class<?> toPreload,
|
|
||||||
+ final BiFunction<NamespacedKey, M, T> minecraftToBukkit,
|
|
||||||
+ final PaperRegistryBuilder.Filler<M, T, B> filler
|
|
||||||
+ ) {
|
|
||||||
+ return new ModifiableRegistryEntry<>(mcKey, apiKey, toPreload, minecraftToBukkit, filler);
|
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ static <M, T extends Keyed, B extends PaperRegistryBuilder<M, T>> RegistryEntry<M, T> writable(
|
+ public <B extends PaperRegistryBuilder<M, A>> RegistryEntry<M, A> addable(final PaperRegistryBuilder.Filler<M, A, B> filler) {
|
||||||
+ final ResourceKey<? extends Registry<M>> mcKey,
|
+ return new AddableRegistryEntry<>(this.mcKey, this.apiKey, this.classToPreload, this.minecraftToBukkit, filler);
|
||||||
+ final RegistryKey<T> apiKey,
|
|
||||||
+ final Class<?> toPreload,
|
|
||||||
+ final BiFunction<NamespacedKey, M, T> minecraftToBukkit,
|
|
||||||
+ final PaperRegistryBuilder.Filler<M, T, B> filler
|
|
||||||
+ ) {
|
|
||||||
+ return new WritableRegistryEntry<>(mcKey, apiKey, toPreload, minecraftToBukkit, filler);
|
|
||||||
+ }
|
+ }
|
||||||
|
+
|
||||||
|
+ public <B extends PaperRegistryBuilder<M, A>> RegistryEntry<M, A> writable(final PaperRegistryBuilder.Filler<M, A, B> filler) {
|
||||||
|
+ return new WritableRegistryEntry<>(this.mcKey, this.apiKey, this.classToPreload, this.minecraftToBukkit, filler);
|
||||||
|
+ }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
diff --git a/src/main/java/io/papermc/paper/registry/entry/WritableRegistryEntry.java b/src/main/java/io/papermc/paper/registry/entry/WritableRegistryEntry.java
|
diff --git a/src/main/java/io/papermc/paper/registry/entry/WritableRegistryEntry.java b/src/main/java/io/papermc/paper/registry/entry/WritableRegistryEntry.java
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
|
@ -675,9 +673,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
@@ -0,0 +0,0 @@
|
@@ -0,0 +0,0 @@
|
||||||
+package io.papermc.paper.registry.entry;
|
+package io.papermc.paper.registry.entry;
|
||||||
+
|
+
|
||||||
|
+import com.mojang.datafixers.util.Either;
|
||||||
+import io.papermc.paper.registry.PaperRegistryBuilder;
|
+import io.papermc.paper.registry.PaperRegistryBuilder;
|
||||||
+import io.papermc.paper.registry.RegistryKey;
|
+import io.papermc.paper.registry.RegistryKey;
|
||||||
+import java.util.function.BiFunction;
|
+import java.util.function.BiFunction;
|
||||||
|
+import java.util.function.Function;
|
||||||
|
+import net.minecraft.core.Holder;
|
||||||
+import net.minecraft.core.Registry;
|
+import net.minecraft.core.Registry;
|
||||||
+import net.minecraft.resources.ResourceKey;
|
+import net.minecraft.resources.ResourceKey;
|
||||||
+import org.bukkit.Keyed;
|
+import org.bukkit.Keyed;
|
||||||
|
@ -689,7 +690,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ final ResourceKey<? extends Registry<M>> mcKey,
|
+ final ResourceKey<? extends Registry<M>> mcKey,
|
||||||
+ final RegistryKey<T> apiKey,
|
+ final RegistryKey<T> apiKey,
|
||||||
+ final Class<?> classToPreload,
|
+ final Class<?> classToPreload,
|
||||||
+ final BiFunction<NamespacedKey, M, T> minecraftToBukkit,
|
+ final RegistryTypeMapper<M, T> minecraftToBukkit,
|
||||||
+ final PaperRegistryBuilder.Filler<M, T, B> builderFiller
|
+ final PaperRegistryBuilder.Filler<M, T, B> builderFiller
|
||||||
+ ) {
|
+ ) {
|
||||||
+ super(mcKey, apiKey, classToPreload, minecraftToBukkit, builderFiller);
|
+ super(mcKey, apiKey, classToPreload, minecraftToBukkit, builderFiller);
|
||||||
|
@ -1213,40 +1214,12 @@ diff --git a/src/main/java/net/minecraft/resources/RegistryDataLoader.java b/src
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/resources/RegistryDataLoader.java
|
--- a/src/main/java/net/minecraft/resources/RegistryDataLoader.java
|
||||||
+++ b/src/main/java/net/minecraft/resources/RegistryDataLoader.java
|
+++ b/src/main/java/net/minecraft/resources/RegistryDataLoader.java
|
||||||
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
|
||||||
public static RegistryAccess.Frozen load(
|
|
||||||
ResourceManager resourceManager, List<HolderLookup.RegistryLookup<?>> registries, List<RegistryDataLoader.RegistryData<?>> entries
|
|
||||||
) {
|
|
||||||
- return load((loader, infoGetter) -> loader.loadFromResources(resourceManager, infoGetter), registries, entries);
|
|
||||||
+ return load((loader, infoGetter, conversions) -> loader.loadFromResources(resourceManager, infoGetter, conversions), registries, entries); // Paper - pass conversions
|
|
||||||
}
|
|
||||||
|
|
||||||
public static RegistryAccess.Frozen load(
|
|
||||||
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
|
||||||
List<HolderLookup.RegistryLookup<?>> registries,
|
|
||||||
List<RegistryDataLoader.RegistryData<?>> entries
|
|
||||||
) {
|
|
||||||
- return load((loader, infoGetter) -> loader.loadFromNetwork(data, factory, infoGetter), registries, entries);
|
|
||||||
+ return load((loader, infoGetter, conversions) -> loader.loadFromNetwork(data, factory, infoGetter, conversions), registries, entries); // Paper - pass conversions
|
|
||||||
}
|
|
||||||
|
|
||||||
private static RegistryAccess.Frozen load(
|
|
||||||
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
|
||||||
Map<ResourceKey<?>, Exception> map = new HashMap<>();
|
|
||||||
List<RegistryDataLoader.Loader<?>> list = entries.stream().map(entry -> entry.create(Lifecycle.stable(), map)).collect(Collectors.toUnmodifiableList());
|
|
||||||
RegistryOps.RegistryInfoLookup registryInfoLookup = createContext(registries, list);
|
|
||||||
- list.forEach(loader -> loadable.apply((RegistryDataLoader.Loader<?>)loader, registryInfoLookup));
|
|
||||||
+ final io.papermc.paper.registry.data.util.Conversions conversions = new io.papermc.paper.registry.data.util.Conversions(registryInfoLookup); // Paper - create conversions
|
|
||||||
+ list.forEach(loader -> loadable.apply((RegistryDataLoader.Loader<?>)loader, registryInfoLookup, conversions));
|
|
||||||
list.forEach(loader -> {
|
|
||||||
Registry<?> registry = loader.registry();
|
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static <E> void loadElementFromResource(
|
private static <E> void loadElementFromResource(
|
||||||
- WritableRegistry<E> registry, Decoder<E> decoder, RegistryOps<JsonElement> ops, ResourceKey<E> key, Resource resource, RegistrationInfo entryInfo
|
- WritableRegistry<E> registry, Decoder<E> decoder, RegistryOps<JsonElement> ops, ResourceKey<E> key, Resource resource, RegistrationInfo entryInfo
|
||||||
+ WritableRegistry<E> registry, Decoder<E> decoder, RegistryOps<JsonElement> ops, ResourceKey<E> key, Resource resource, RegistrationInfo entryInfo, io.papermc.paper.registry.data.util.Conversions conversions
|
+ WritableRegistry<E> registry, Decoder<E> decoder, RegistryOps<JsonElement> ops, ResourceKey<E> key, Resource resource, RegistrationInfo entryInfo, io.papermc.paper.registry.data.util.Conversions conversions // Paper - pass conversions
|
||||||
) throws IOException {
|
) throws IOException {
|
||||||
try (Reader reader = resource.openAsReader()) {
|
try (Reader reader = resource.openAsReader()) {
|
||||||
JsonElement jsonElement = JsonParser.parseReader(reader);
|
JsonElement jsonElement = JsonParser.parseReader(reader);
|
||||||
|
@ -1258,15 +1231,13 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
||||||
RegistryOps.RegistryInfoLookup infoGetter,
|
|
||||||
WritableRegistry<E> registry,
|
|
||||||
Decoder<E> elementDecoder,
|
|
||||||
- Map<ResourceKey<?>, Exception> errors
|
|
||||||
+ Map<ResourceKey<?>, Exception> errors,
|
|
||||||
+ io.papermc.paper.registry.data.util.Conversions conversions // Paper - pass conversions
|
|
||||||
) {
|
|
||||||
FileToIdConverter fileToIdConverter = FileToIdConverter.registry(registry.key());
|
FileToIdConverter fileToIdConverter = FileToIdConverter.registry(registry.key());
|
||||||
RegistryOps<JsonElement> registryOps = RegistryOps.create(JsonOps.INSTANCE, infoGetter);
|
RegistryOps<JsonElement> registryOps = RegistryOps.create(JsonOps.INSTANCE, infoGetter);
|
||||||
|
|
||||||
|
+ final io.papermc.paper.registry.data.util.Conversions conversions = new io.papermc.paper.registry.data.util.Conversions(infoGetter); // Paper - create conversions
|
||||||
|
for (Entry<ResourceLocation, Resource> entry : fileToIdConverter.listMatchingResources(resourceManager).entrySet()) {
|
||||||
|
ResourceLocation resourceLocation = entry.getKey();
|
||||||
|
ResourceKey<E> resourceKey = ResourceKey.create(registry.key(), fileToIdConverter.fileToId(resourceLocation));
|
||||||
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
||||||
RegistrationInfo registrationInfo = REGISTRATION_INFO_CACHE.apply(resource.knownPackInfo());
|
RegistrationInfo registrationInfo = REGISTRATION_INFO_CACHE.apply(resource.knownPackInfo());
|
||||||
|
|
||||||
|
@ -1285,15 +1256,13 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
||||||
RegistryOps.RegistryInfoLookup infoGetter,
|
RegistryOps<JsonElement> registryOps2 = RegistryOps.create(JsonOps.INSTANCE, infoGetter);
|
||||||
WritableRegistry<E> registry,
|
FileToIdConverter fileToIdConverter = FileToIdConverter.registry(registry.key());
|
||||||
Decoder<E> decoder,
|
|
||||||
- Map<ResourceKey<?>, Exception> loadingErrors
|
+ final io.papermc.paper.registry.data.util.Conversions conversions = new io.papermc.paper.registry.data.util.Conversions(infoGetter); // Paper - create conversions
|
||||||
+ Map<ResourceKey<?>, Exception> loadingErrors,
|
for (RegistrySynchronization.PackedRegistryEntry packedRegistryEntry : networkedRegistryData.elements) {
|
||||||
+ io.papermc.paper.registry.data.util.Conversions conversions // Paper - pass conversions
|
ResourceKey<E> resourceKey = ResourceKey.create(registry.key(), packedRegistryEntry.id());
|
||||||
) {
|
Optional<Tag> optional = packedRegistryEntry.data();
|
||||||
RegistryDataLoader.NetworkedRegistryData networkedRegistryData = data.get(registry.key());
|
|
||||||
if (networkedRegistryData != null) {
|
|
||||||
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
@ -1303,35 +1272,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
} catch (Exception var17) {
|
} catch (Exception var17) {
|
||||||
loadingErrors.put(resourceKey, new IllegalStateException("Failed to parse local data", var17));
|
loadingErrors.put(resourceKey, new IllegalStateException("Failed to parse local data", var17));
|
||||||
}
|
}
|
||||||
@@ -0,0 +0,0 @@ public class RegistryDataLoader {
|
|
||||||
}
|
|
||||||
|
|
||||||
static record Loader<T>(RegistryDataLoader.RegistryData<T> data, WritableRegistry<T> registry, Map<ResourceKey<?>, Exception> loadingErrors) {
|
|
||||||
- public void loadFromResources(ResourceManager resourceManager, RegistryOps.RegistryInfoLookup infoGetter) {
|
|
||||||
- RegistryDataLoader.loadContentsFromManager(resourceManager, infoGetter, this.registry, this.data.elementCodec, this.loadingErrors);
|
|
||||||
+ public void loadFromResources(ResourceManager resourceManager, RegistryOps.RegistryInfoLookup infoGetter, io.papermc.paper.registry.data.util.Conversions conversions) { // Paper - pass conversions
|
|
||||||
+ RegistryDataLoader.loadContentsFromManager(resourceManager, infoGetter, this.registry, this.data.elementCodec, this.loadingErrors, conversions); // Paper - pass conversions
|
|
||||||
}
|
|
||||||
|
|
||||||
public void loadFromNetwork(
|
|
||||||
Map<ResourceKey<? extends Registry<?>>, RegistryDataLoader.NetworkedRegistryData> data,
|
|
||||||
ResourceProvider factory,
|
|
||||||
- RegistryOps.RegistryInfoLookup infoGetter
|
|
||||||
+ RegistryOps.RegistryInfoLookup infoGetter,
|
|
||||||
+ io.papermc.paper.registry.data.util.Conversions conversions // Paper
|
|
||||||
) {
|
|
||||||
- RegistryDataLoader.loadContentsFromNetwork(data, factory, infoGetter, this.registry, this.data.elementCodec, this.loadingErrors);
|
|
||||||
+ RegistryDataLoader.loadContentsFromNetwork(data, factory, infoGetter, this.registry, this.data.elementCodec, this.loadingErrors, conversions); // Paper - pass conversions
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@FunctionalInterface
|
|
||||||
interface LoadingFunction {
|
|
||||||
- void apply(RegistryDataLoader.Loader<?> loader, RegistryOps.RegistryInfoLookup infoGetter);
|
|
||||||
+ void apply(RegistryDataLoader.Loader<?> loader, RegistryOps.RegistryInfoLookup infoGetter, io.papermc.paper.registry.data.util.Conversions conversions); // Paper - pass conversions
|
|
||||||
}
|
|
||||||
|
|
||||||
public static record NetworkedRegistryData(List<RegistrySynchronization.PackedRegistryEntry> elements, TagNetworkSerialization.NetworkPayload tags) {
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/ReloadableServerRegistries.java b/src/main/java/net/minecraft/server/ReloadableServerRegistries.java
|
diff --git a/src/main/java/net/minecraft/server/ReloadableServerRegistries.java b/src/main/java/net/minecraft/server/ReloadableServerRegistries.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/server/ReloadableServerRegistries.java
|
--- a/src/main/java/net/minecraft/server/ReloadableServerRegistries.java
|
||||||
|
@ -1368,20 +1308,6 @@ diff --git a/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java b/src/main/
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftRegistry.java
|
||||||
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
|
||||||
private final Map<NamespacedKey, B> cache = new HashMap<>();
|
|
||||||
private final Map<B, NamespacedKey> byValue = new java.util.IdentityHashMap<>(); // Paper - improve Registry
|
|
||||||
private final net.minecraft.core.Registry<M> minecraftRegistry;
|
|
||||||
- private final BiFunction<NamespacedKey, M, B> minecraftToBukkit;
|
|
||||||
+ private final BiFunction<? super NamespacedKey, M, B> minecraftToBukkit; // Paper
|
|
||||||
private final BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater; // Paper - rename to make it *clear* what it is *only* for
|
|
||||||
private boolean init;
|
|
||||||
|
|
||||||
- public CraftRegistry(Class<?> bukkitClass, net.minecraft.core.Registry<M> minecraftRegistry, BiFunction<NamespacedKey, M, B> minecraftToBukkit, BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater) { // Paper - relax preload class
|
|
||||||
+ public CraftRegistry(Class<?> bukkitClass, net.minecraft.core.Registry<M> minecraftRegistry, BiFunction<? super NamespacedKey, M, B> minecraftToBukkit, BiFunction<NamespacedKey, ApiVersion, NamespacedKey> serializationUpdater) { // Paper - relax preload class
|
|
||||||
this.bukkitClass = bukkitClass;
|
|
||||||
this.minecraftRegistry = minecraftRegistry;
|
|
||||||
this.minecraftToBukkit = minecraftToBukkit;
|
|
||||||
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
@@ -0,0 +0,0 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
return this.byValue.get(value);
|
return this.byValue.get(value);
|
||||||
}
|
}
|
||||||
|
@ -1452,7 +1378,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ <M, T> void testEquality(final RegistryEntry.BuilderHolder<M, T, ?> registryEntry) {
|
+ <M, T> void testEquality(final RegistryEntry.BuilderHolder<M, T, ?> registryEntry) {
|
||||||
+ final Registry<M> registry = RegistryHelper.getRegistry().lookupOrThrow(registryEntry.mcKey());
|
+ final Registry<M> registry = RegistryHelper.getRegistry().lookupOrThrow(registryEntry.mcKey());
|
||||||
+ for (final Map.Entry<ResourceKey<M>, M> entry : registry.entrySet()) {
|
+ for (final Map.Entry<ResourceKey<M>, M> entry : registry.entrySet()) {
|
||||||
+ final M built = registryEntry.fillBuilder(new Conversions(new RegistryOps.HolderLookupAdapter(RegistryHelper.getRegistry())), PaperRegistries.fromNms(entry.getKey()), entry.getValue()).build();
|
+ final M built = registryEntry.fillBuilder(new Conversions(new RegistryOps.HolderLookupAdapter(RegistryHelper.getRegistry())), entry.getValue()).build();
|
||||||
+ assertEquals(entry.getValue(), built);
|
+ assertEquals(entry.getValue(), built);
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
|
|
494
patches/server/Switch-Impl-types-to-Holderable.patch
Normal file
494
patches/server/Switch-Impl-types-to-Holderable.patch
Normal file
|
@ -0,0 +1,494 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
||||||
|
Date: Sun, 24 Nov 2024 15:08:19 -0800
|
||||||
|
Subject: [PATCH] Switch Impl types to Holderable
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/util/Holderable.java b/src/main/java/io/papermc/paper/util/Holderable.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/io/papermc/paper/util/Holderable.java
|
||||||
|
+++ b/src/main/java/io/papermc/paper/util/Holderable.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
package io.papermc.paper.util;
|
||||||
|
|
||||||
|
+import com.google.gson.JsonElement;
|
||||||
|
+import com.google.gson.JsonObject;
|
||||||
|
+import com.mojang.serialization.Codec;
|
||||||
|
+import com.mojang.serialization.JsonOps;
|
||||||
|
+import net.kyori.adventure.key.Key;
|
||||||
|
import net.minecraft.core.Holder;
|
||||||
|
+import net.minecraft.resources.RegistryOps;
|
||||||
|
+import org.bukkit.Keyed;
|
||||||
|
+import org.bukkit.Registry;
|
||||||
|
+import org.bukkit.craftbukkit.CraftRegistry;
|
||||||
|
import org.bukkit.craftbukkit.util.Handleable;
|
||||||
|
+import org.intellij.lang.annotations.Subst;
|
||||||
|
+import org.jspecify.annotations.NullMarked;
|
||||||
|
+import org.jspecify.annotations.Nullable;
|
||||||
|
|
||||||
|
+@NullMarked
|
||||||
|
public interface Holderable<M> extends Handleable<M> {
|
||||||
|
|
||||||
|
Holder<M> getHolder();
|
||||||
|
@@ -0,0 +0,0 @@ public interface Holderable<M> extends Handleable<M> {
|
||||||
|
default M getHandle() {
|
||||||
|
return this.getHolder().value();
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ static <T extends Keyed, M> @Nullable T fromBukkitSerializationObject(final Object deserialized, final Codec<? extends Holder<M>> codec, final Registry<T> registry) { // TODO remove Keyed
|
||||||
|
+ return switch (deserialized) {
|
||||||
|
+ case @Subst("key:value") final String string -> {
|
||||||
|
+ if (!(Key.parseable(string))) {
|
||||||
|
+ yield null;
|
||||||
|
+ }
|
||||||
|
+ yield registry.get(Key.key(string));
|
||||||
|
+ }
|
||||||
|
+ case JsonObjectWrapper(final JsonObject element) -> {
|
||||||
|
+ if (!(registry instanceof final CraftRegistry<?, ?> craftRegistry) || !craftRegistry.supportsDirectHolders()) {
|
||||||
|
+ throw new IllegalArgumentException("Cannot deserialize direct holders for " + registry);
|
||||||
|
+ }
|
||||||
|
+ final RegistryOps<JsonElement> ops = CraftRegistry.getMinecraftRegistry().createSerializationContext(JsonOps.INSTANCE);
|
||||||
|
+ final Holder<M> holder = codec.decode(ops, element).getOrThrow().getFirst();
|
||||||
|
+ yield ((CraftRegistry<T, M>) registry).convertDirectHolder(holder);
|
||||||
|
+ }
|
||||||
|
+ default -> throw new IllegalArgumentException("Cannot deserialize " + deserialized);
|
||||||
|
+ };
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ default Object toBukkitSerializationObject(final Codec<? super Holder<M>> codec) {
|
||||||
|
+ return switch (this.getHolder()) {
|
||||||
|
+ case final Holder.Direct<M> direct -> {
|
||||||
|
+ final RegistryOps<JsonElement> ops = CraftRegistry.getMinecraftRegistry().createSerializationContext(JsonOps.INSTANCE);
|
||||||
|
+ yield new JsonObjectWrapper(codec.encodeStart(ops, direct).getOrThrow().getAsJsonObject());
|
||||||
|
+ }
|
||||||
|
+ case final Holder.Reference<M> reference -> reference.key().location().toString();
|
||||||
|
+ default -> throw new IllegalArgumentException("Cannot serialize " + this.getHolder());
|
||||||
|
+ };
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * All implementations should use this as their hashCode implementation
|
||||||
|
+ */
|
||||||
|
+ default int implHashCode() {
|
||||||
|
+ return this.getHolder().hashCode();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * All implementations should use this as their equals implementation
|
||||||
|
+ */
|
||||||
|
+ default boolean implEquals(final @Nullable Object o) {
|
||||||
|
+ if (o == null || this.getClass() != o.getClass()) return false;
|
||||||
|
+ final Holderable<?> that = (Holderable<?>) o;
|
||||||
|
+ return this.getHolder().equals(that.getHolder());
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ default String implToString() {
|
||||||
|
+ return "%s{holder=%s}".formatted(this.getClass().getSimpleName(), this.getHolder().toString());
|
||||||
|
+ }
|
||||||
|
}
|
||||||
|
diff --git a/src/main/java/io/papermc/paper/util/JsonObjectWrapper.java b/src/main/java/io/papermc/paper/util/JsonObjectWrapper.java
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/src/main/java/io/papermc/paper/util/JsonObjectWrapper.java
|
||||||
|
@@ -0,0 +0,0 @@
|
||||||
|
+package io.papermc.paper.util;
|
||||||
|
+
|
||||||
|
+import com.google.gson.Gson;
|
||||||
|
+import com.google.gson.JsonElement;
|
||||||
|
+import com.google.gson.JsonObject;
|
||||||
|
+import com.google.gson.JsonParser;
|
||||||
|
+import java.util.Map;
|
||||||
|
+import org.bukkit.configuration.serialization.ConfigurationSerializable;
|
||||||
|
+import org.bukkit.configuration.serialization.ConfigurationSerialization;
|
||||||
|
+import org.jspecify.annotations.NullMarked;
|
||||||
|
+
|
||||||
|
+@NullMarked
|
||||||
|
+public record JsonObjectWrapper(JsonObject element) implements ConfigurationSerializable {
|
||||||
|
+
|
||||||
|
+ private static final String KEY = "value";
|
||||||
|
+ private static final Gson GSON = new Gson();
|
||||||
|
+
|
||||||
|
+ static {
|
||||||
|
+ ConfigurationSerialization.registerClass(JsonObjectWrapper.class);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public JsonObjectWrapper(final JsonElement element) {
|
||||||
|
+ this(element.getAsJsonObject());
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public JsonObjectWrapper(final Map<String, Object> input) {
|
||||||
|
+ this(JsonParser.parseString((String) input.get(KEY)).getAsJsonObject());
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public Map<String, Object> serialize() {
|
||||||
|
+ return Map.of(KEY, GSON.toJson(this.element));
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftMusicInstrument.java b/src/main/java/org/bukkit/craftbukkit/CraftMusicInstrument.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftMusicInstrument.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftMusicInstrument.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.bukkit.Registry;
|
||||||
|
import org.bukkit.craftbukkit.util.Handleable;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
-public class CraftMusicInstrument extends MusicInstrument implements Handleable<Instrument> {
|
||||||
|
+public class CraftMusicInstrument extends MusicInstrument implements io.papermc.paper.util.Holderable<Instrument> {
|
||||||
|
|
||||||
|
public static MusicInstrument minecraftToBukkit(Instrument minecraft) {
|
||||||
|
return CraftRegistry.minecraftToBukkit(minecraft, Registries.INSTRUMENT, Registry.INSTRUMENT);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static MusicInstrument minecraftHolderToBukkit(Holder<Instrument> minecraft) {
|
||||||
|
- return CraftMusicInstrument.minecraftToBukkit(minecraft.value());
|
||||||
|
+ return CraftRegistry.minecraftHolderToBukkit(minecraft, Registry.INSTRUMENT); // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Instrument bukkitToMinecraft(MusicInstrument bukkit) {
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMusicInstrument extends MusicInstrument implements Handleable<
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Holder<Instrument> bukkitToMinecraftHolder(MusicInstrument bukkit) {
|
||||||
|
- Preconditions.checkArgument(bukkit != null);
|
||||||
|
-
|
||||||
|
- net.minecraft.core.Registry<Instrument> registry = CraftRegistry.getMinecraftRegistry(Registries.INSTRUMENT);
|
||||||
|
-
|
||||||
|
- if (registry.wrapAsHolder(CraftMusicInstrument.bukkitToMinecraft(bukkit)) instanceof Holder.Reference<Instrument> holder) {
|
||||||
|
- return holder;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- throw new IllegalArgumentException("No Reference holder found for " + bukkit
|
||||||
|
- + ", this can happen if a plugin creates its own instrument without properly registering it.");
|
||||||
|
+ return CraftRegistry.bukkitToMinecraftHolder(bukkit, Registries.INSTRUMENT); // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
- public static String bukkitToString(MusicInstrument bukkit) {
|
||||||
|
+ public static Object bukkitToString(MusicInstrument bukkit) { // Paper - switch to Holder
|
||||||
|
Preconditions.checkArgument(bukkit != null);
|
||||||
|
|
||||||
|
- return bukkit.getKey().toString();
|
||||||
|
+ return ((CraftMusicInstrument) bukkit).toBukkitSerializationObject(Instrument.CODEC); // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
- public static MusicInstrument stringToBukkit(String string) {
|
||||||
|
+ public static MusicInstrument stringToBukkit(Object string) { // Paper - switch to Holder
|
||||||
|
Preconditions.checkArgument(string != null);
|
||||||
|
|
||||||
|
- return Registry.INSTRUMENT.get(NamespacedKey.fromString(string));
|
||||||
|
+ return io.papermc.paper.util.Holderable.fromBukkitSerializationObject(string, Instrument.CODEC, Registry.INSTRUMENT); // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
private final NamespacedKey key;
|
||||||
|
private final Instrument handle;
|
||||||
|
|
||||||
|
- public CraftMusicInstrument(NamespacedKey key, Instrument handle) {
|
||||||
|
- this.key = key;
|
||||||
|
- this.handle = handle;
|
||||||
|
+ // Paper start - switch to Holder
|
||||||
|
+ @Override
|
||||||
|
+ public boolean equals(final Object o) {
|
||||||
|
+ return this.implEquals(o);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public int hashCode() {
|
||||||
|
+ return this.implHashCode();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public String toString() {
|
||||||
|
+ return this.implToString();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ private final Holder<Instrument> holder;
|
||||||
|
+ public CraftMusicInstrument(Holder<Instrument> holder) {
|
||||||
|
+ this.holder = holder;
|
||||||
|
+ this.key = holder.unwrapKey().map(io.papermc.paper.util.MCUtil::fromResourceKey).orElse(null);
|
||||||
|
+ this.handle = holder.value();
|
||||||
|
+ // Paper end - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
- public Instrument getHandle() {
|
||||||
|
- return this.handle;
|
||||||
|
+ public Holder<Instrument> getHolder() { // Paper - switch to Holder
|
||||||
|
+ return this.holder; // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMusicInstrument extends MusicInstrument implements Handleable<
|
||||||
|
}
|
||||||
|
// Paper end - add translationKey methods
|
||||||
|
|
||||||
|
- @Override
|
||||||
|
- public boolean equals(Object other) {
|
||||||
|
- if (this == other) {
|
||||||
|
- return true;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- if (!(other instanceof CraftMusicInstrument)) {
|
||||||
|
- return false;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- return this.getKey().equals(((MusicInstrument) other).getKey());
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- @Override
|
||||||
|
- public int hashCode() {
|
||||||
|
- return this.getKey().hashCode();
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- @Override
|
||||||
|
- public String toString() {
|
||||||
|
- return "CraftMusicInstrument{key=" + this.key + "}";
|
||||||
|
- }
|
||||||
|
+ // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmor.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaArmor extends CraftMetaItem implements ArmorMeta {
|
||||||
|
|
||||||
|
Map<?, ?> trimData = SerializableMeta.getObject(Map.class, map, CraftMetaArmor.TRIM.BUKKIT, true);
|
||||||
|
if (trimData != null) {
|
||||||
|
- String materialKeyString = SerializableMeta.getString(trimData, CraftMetaArmor.TRIM_MATERIAL.BUKKIT, true);
|
||||||
|
- String patternKeyString = SerializableMeta.getString(trimData, CraftMetaArmor.TRIM_PATTERN.BUKKIT, true);
|
||||||
|
+ Object materialKeyString = SerializableMeta.getObject(Object.class, trimData, CraftMetaArmor.TRIM_MATERIAL.BUKKIT, true); // Paper - switch to Holder
|
||||||
|
+ Object patternKeyString = SerializableMeta.getObject(Object.class, trimData, CraftMetaArmor.TRIM_PATTERN.BUKKIT, true); // Paper - switch to Holder
|
||||||
|
|
||||||
|
if (materialKeyString != null && patternKeyString != null) {
|
||||||
|
- NamespacedKey materialKey = NamespacedKey.fromString(materialKeyString);
|
||||||
|
- NamespacedKey patternKey = NamespacedKey.fromString(patternKeyString);
|
||||||
|
-
|
||||||
|
- if (materialKey != null && patternKey != null) {
|
||||||
|
- TrimMaterial trimMaterial = Registry.TRIM_MATERIAL.get(materialKey);
|
||||||
|
- TrimPattern trimPattern = Registry.TRIM_PATTERN.get(patternKey);
|
||||||
|
-
|
||||||
|
- if (trimMaterial != null && trimPattern != null) {
|
||||||
|
- this.trim = new ArmorTrim(trimMaterial, trimPattern);
|
||||||
|
- }
|
||||||
|
+ // Paper start - switch to Holder
|
||||||
|
+ TrimMaterial trimMaterial = CraftTrimMaterial.objectToBukkit(materialKeyString);
|
||||||
|
+ TrimPattern trimPattern = CraftTrimPattern.objectToBukkit(patternKeyString);
|
||||||
|
+ if (trimMaterial != null && trimPattern != null) {
|
||||||
|
+ this.trim = new ArmorTrim(trimMaterial, trimPattern);
|
||||||
|
}
|
||||||
|
+ // Paper end - switch to Holder
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaArmor extends CraftMetaItem implements ArmorMeta {
|
||||||
|
super.serialize(builder);
|
||||||
|
|
||||||
|
if (this.hasTrim()) {
|
||||||
|
- Map<String, String> trimData = new HashMap<>();
|
||||||
|
- trimData.put(CraftMetaArmor.TRIM_MATERIAL.BUKKIT, this.trim.getMaterial().getKey().toString());
|
||||||
|
- trimData.put(CraftMetaArmor.TRIM_PATTERN.BUKKIT, this.trim.getPattern().getKey().toString());
|
||||||
|
+ Map<String, Object> trimData = new HashMap<>(); // Paper - switch to Holder
|
||||||
|
+ trimData.put(CraftMetaArmor.TRIM_MATERIAL.BUKKIT, CraftTrimMaterial.bukkitToObject(this.trim.getMaterial())); // Paper - switch to Holder
|
||||||
|
+ trimData.put(CraftMetaArmor.TRIM_PATTERN.BUKKIT, CraftTrimPattern.bukkitToObject(this.trim.getPattern())); // Paper - switch to Holder
|
||||||
|
builder.put(CraftMetaArmor.TRIM.BUKKIT, trimData);
|
||||||
|
}
|
||||||
|
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaMusicInstrument.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftMetaMusicInstrument extends CraftMetaItem implements MusicInst
|
||||||
|
CraftMetaMusicInstrument(Map<String, Object> map) {
|
||||||
|
super(map);
|
||||||
|
|
||||||
|
- String instrumentString = SerializableMeta.getString(map, CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT.BUKKIT, true);
|
||||||
|
+ Object instrumentString = SerializableMeta.getObject(Object.class, map, CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT.BUKKIT, true); // Paper - switch to Holder
|
||||||
|
if (instrumentString != null) {
|
||||||
|
this.instrument = CraftMusicInstrument.stringToBukkit(instrumentString);
|
||||||
|
}
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/trim/CraftTrimMaterial.java b/src/main/java/org/bukkit/craftbukkit/inventory/trim/CraftTrimMaterial.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/trim/CraftTrimMaterial.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/trim/CraftTrimMaterial.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.bukkit.craftbukkit.util.Handleable;
|
||||||
|
import org.bukkit.inventory.meta.trim.TrimMaterial;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
-public class CraftTrimMaterial implements TrimMaterial, Handleable<net.minecraft.world.item.equipment.trim.TrimMaterial> {
|
||||||
|
+public class CraftTrimMaterial implements TrimMaterial, io.papermc.paper.util.Holderable<net.minecraft.world.item.equipment.trim.TrimMaterial> { // Paper - switch to Holder
|
||||||
|
|
||||||
|
public static TrimMaterial minecraftToBukkit(net.minecraft.world.item.equipment.trim.TrimMaterial minecraft) {
|
||||||
|
return CraftRegistry.minecraftToBukkit(minecraft, Registries.TRIM_MATERIAL, Registry.TRIM_MATERIAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static TrimMaterial minecraftHolderToBukkit(Holder<net.minecraft.world.item.equipment.trim.TrimMaterial> minecraft) {
|
||||||
|
- return CraftTrimMaterial.minecraftToBukkit(minecraft.value());
|
||||||
|
+ return CraftRegistry.minecraftHolderToBukkit(minecraft, Registry.TRIM_MATERIAL); // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
public static net.minecraft.world.item.equipment.trim.TrimMaterial bukkitToMinecraft(TrimMaterial bukkit) {
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftTrimMaterial implements TrimMaterial, Handleable<net.minecraft
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Holder<net.minecraft.world.item.equipment.trim.TrimMaterial> bukkitToMinecraftHolder(TrimMaterial bukkit) {
|
||||||
|
+ return CraftRegistry.bukkitToMinecraftHolder(bukkit, Registries.TRIM_MATERIAL); // Paper - switch to Holder
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ private final NamespacedKey key;
|
||||||
|
+ private final net.minecraft.world.item.equipment.trim.TrimMaterial handle;
|
||||||
|
+
|
||||||
|
+ // Paper start - switch to Holder
|
||||||
|
+ private final Holder<net.minecraft.world.item.equipment.trim.TrimMaterial> holder;
|
||||||
|
+
|
||||||
|
+ public static Object bukkitToObject(TrimMaterial bukkit) {
|
||||||
|
Preconditions.checkArgument(bukkit != null);
|
||||||
|
|
||||||
|
- net.minecraft.core.Registry<net.minecraft.world.item.equipment.trim.TrimMaterial> registry = CraftRegistry.getMinecraftRegistry(Registries.TRIM_MATERIAL);
|
||||||
|
+ return ((CraftTrimMaterial) bukkit).toBukkitSerializationObject(net.minecraft.world.item.equipment.trim.TrimMaterial.CODEC); // Paper - switch to Holder
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- if (registry.wrapAsHolder(CraftTrimMaterial.bukkitToMinecraft(bukkit)) instanceof Holder.Reference<net.minecraft.world.item.equipment.trim.TrimMaterial> holder) {
|
||||||
|
- return holder;
|
||||||
|
- }
|
||||||
|
+ public static TrimMaterial objectToBukkit(Object object) {
|
||||||
|
+ Preconditions.checkArgument(object != null);
|
||||||
|
|
||||||
|
- throw new IllegalArgumentException("No Reference holder found for " + bukkit
|
||||||
|
- + ", this can happen if a plugin creates its own trim material without properly registering it.");
|
||||||
|
+ return io.papermc.paper.util.Holderable.fromBukkitSerializationObject(object, net.minecraft.world.item.equipment.trim.TrimMaterial.CODEC, Registry.TRIM_MATERIAL); // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
- private final NamespacedKey key;
|
||||||
|
- private final net.minecraft.world.item.equipment.trim.TrimMaterial handle;
|
||||||
|
+ @Override
|
||||||
|
+ public boolean equals(final Object o) {
|
||||||
|
+ return this.implEquals(o);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public int hashCode() {
|
||||||
|
+ return this.implHashCode();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public String toString() {
|
||||||
|
+ return this.implToString();
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- public CraftTrimMaterial(NamespacedKey key, net.minecraft.world.item.equipment.trim.TrimMaterial handle) {
|
||||||
|
- this.key = key;
|
||||||
|
- this.handle = handle;
|
||||||
|
+ public CraftTrimMaterial(final Holder<net.minecraft.world.item.equipment.trim.TrimMaterial> holder) {
|
||||||
|
+ this.key = holder.unwrapKey().map(io.papermc.paper.util.MCUtil::fromResourceKey).orElse(null);
|
||||||
|
+ this.handle = holder.value();
|
||||||
|
+ this.holder = holder;
|
||||||
|
+ // Paper end - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
- public net.minecraft.world.item.equipment.trim.TrimMaterial getHandle() {
|
||||||
|
- return this.handle;
|
||||||
|
+ public Holder<net.minecraft.world.item.equipment.trim.TrimMaterial> getHolder() { // Paper - switch to Holder
|
||||||
|
+ return this.holder; // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/trim/CraftTrimPattern.java b/src/main/java/org/bukkit/craftbukkit/inventory/trim/CraftTrimPattern.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/trim/CraftTrimPattern.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/trim/CraftTrimPattern.java
|
||||||
|
@@ -0,0 +0,0 @@ import org.bukkit.craftbukkit.util.Handleable;
|
||||||
|
import org.bukkit.inventory.meta.trim.TrimPattern;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
-public class CraftTrimPattern implements TrimPattern, Handleable<net.minecraft.world.item.equipment.trim.TrimPattern> {
|
||||||
|
+public class CraftTrimPattern implements TrimPattern, io.papermc.paper.util.Holderable<net.minecraft.world.item.equipment.trim.TrimPattern> { // Paper - switch to Holder
|
||||||
|
|
||||||
|
public static TrimPattern minecraftToBukkit(net.minecraft.world.item.equipment.trim.TrimPattern minecraft) {
|
||||||
|
return CraftRegistry.minecraftToBukkit(minecraft, Registries.TRIM_PATTERN, Registry.TRIM_PATTERN);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static TrimPattern minecraftHolderToBukkit(Holder<net.minecraft.world.item.equipment.trim.TrimPattern> minecraft) {
|
||||||
|
- return CraftTrimPattern.minecraftToBukkit(minecraft.value());
|
||||||
|
+ return CraftRegistry.minecraftHolderToBukkit(minecraft, Registry.TRIM_PATTERN); // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
public static net.minecraft.world.item.equipment.trim.TrimPattern bukkitToMinecraft(TrimPattern bukkit) {
|
||||||
|
@@ -0,0 +0,0 @@ public class CraftTrimPattern implements TrimPattern, Handleable<net.minecraft.w
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Holder<net.minecraft.world.item.equipment.trim.TrimPattern> bukkitToMinecraftHolder(TrimPattern bukkit) {
|
||||||
|
+ return CraftRegistry.bukkitToMinecraftHolder(bukkit, Registries.TRIM_PATTERN); // Paper - switch to Holder
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ private final NamespacedKey key;
|
||||||
|
+ private final net.minecraft.world.item.equipment.trim.TrimPattern handle;
|
||||||
|
+
|
||||||
|
+ // Paper start - switch to Holder
|
||||||
|
+ private final Holder<net.minecraft.world.item.equipment.trim.TrimPattern> holder; // Paper - switch to Holder
|
||||||
|
+
|
||||||
|
+ public static Object bukkitToObject(TrimPattern bukkit) {
|
||||||
|
Preconditions.checkArgument(bukkit != null);
|
||||||
|
|
||||||
|
- net.minecraft.core.Registry<net.minecraft.world.item.equipment.trim.TrimPattern> registry = CraftRegistry.getMinecraftRegistry(Registries.TRIM_PATTERN);
|
||||||
|
+ return ((CraftTrimPattern) bukkit).toBukkitSerializationObject(net.minecraft.world.item.equipment.trim.TrimPattern.CODEC); // Paper - switch to Holder
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- if (registry.wrapAsHolder(CraftTrimPattern.bukkitToMinecraft(bukkit)) instanceof Holder.Reference<net.minecraft.world.item.equipment.trim.TrimPattern> holder) {
|
||||||
|
- return holder;
|
||||||
|
- }
|
||||||
|
+ public static TrimPattern objectToBukkit(Object object) {
|
||||||
|
+ Preconditions.checkArgument(object != null);
|
||||||
|
|
||||||
|
- throw new IllegalArgumentException("No Reference holder found for " + bukkit
|
||||||
|
- + ", this can happen if a plugin creates its own trim pattern without properly registering it.");
|
||||||
|
+ return io.papermc.paper.util.Holderable.fromBukkitSerializationObject(object, net.minecraft.world.item.equipment.trim.TrimPattern.CODEC, Registry.TRIM_PATTERN); // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
- private final NamespacedKey key;
|
||||||
|
- private final net.minecraft.world.item.equipment.trim.TrimPattern handle;
|
||||||
|
+ @Override
|
||||||
|
+ public boolean equals(final Object o) {
|
||||||
|
+ return this.implEquals(o);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public int hashCode() {
|
||||||
|
+ return this.implHashCode();
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public String toString() {
|
||||||
|
+ return this.implToString();
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- public CraftTrimPattern(NamespacedKey key, net.minecraft.world.item.equipment.trim.TrimPattern handle) {
|
||||||
|
- this.key = key;
|
||||||
|
- this.handle = handle;
|
||||||
|
+ public CraftTrimPattern(Holder<net.minecraft.world.item.equipment.trim.TrimPattern> handle) {
|
||||||
|
+ this.key = handle.unwrapKey().map(io.papermc.paper.util.MCUtil::fromResourceKey).orElse(null);
|
||||||
|
+ this.handle = handle.value();
|
||||||
|
+ this.holder = handle;
|
||||||
|
+ // Paper end - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
- public net.minecraft.world.item.equipment.trim.TrimPattern getHandle() {
|
||||||
|
- return this.handle;
|
||||||
|
+ public Holder<net.minecraft.world.item.equipment.trim.TrimPattern> getHolder() { // Paper - switch to Holder
|
||||||
|
+ return this.holder; // Paper - switch to Holder
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
diff --git a/src/test/java/org/bukkit/registry/RegistryConversionTest.java b/src/test/java/org/bukkit/registry/RegistryConversionTest.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/test/java/org/bukkit/registry/RegistryConversionTest.java
|
||||||
|
+++ b/src/test/java/org/bukkit/registry/RegistryConversionTest.java
|
||||||
|
@@ -0,0 +0,0 @@ public class RegistryConversionTest {
|
||||||
|
Class<? extends Keyed> craftClazz, Class<?> minecraftClazz) throws IllegalAccessException {
|
||||||
|
this.checkValidMinecraftToBukkit(clazz);
|
||||||
|
|
||||||
|
+ if (type == io.papermc.paper.registry.RegistryKey.TRIM_MATERIAL || type == io.papermc.paper.registry.RegistryKey.TRIM_PATTERN || type == io.papermc.paper.registry.RegistryKey.INSTRUMENT) return; // Paper - manually skip for now
|
||||||
|
try {
|
||||||
|
|
||||||
|
Object minecraft = mock(minecraftClazz);
|
|
@ -244,7 +244,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ super(tag, extraHandledDcts); // Paper
|
+ super(tag, extraHandledDcts); // Paper
|
||||||
|
|
||||||
getOrEmpty(tag, CraftMetaArmor.TRIM).ifPresent((trimCompound) -> {
|
getOrEmpty(tag, CraftMetaArmor.TRIM).ifPresent((trimCompound) -> {
|
||||||
TrimMaterial trimMaterial = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(io.papermc.paper.registry.RegistryKey.TRIM_MATERIAL, trimCompound.material()).orElse(null); // Paper - fix upstream not being correct
|
TrimMaterial trimMaterial = CraftTrimMaterial.minecraftHolderToBukkit(trimCompound.material());
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaArmorStand.java
|
||||||
|
@ -696,7 +696,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ super(tag, extraHandledDcts); // Paper
|
+ super(tag, extraHandledDcts); // Paper
|
||||||
|
|
||||||
getOrEmpty(tag, CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT).ifPresent((instrument) -> {
|
getOrEmpty(tag, CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT).ifPresent((instrument) -> {
|
||||||
this.instrument = org.bukkit.craftbukkit.CraftRegistry.unwrapAndConvertHolder(org.bukkit.Registry.INSTRUMENT, instrument).orElse(null); // Paper - fix upstream not handling inlined instrument
|
this.instrument = CraftMusicInstrument.minecraftHolderToBukkit(instrument);
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaOminousBottle.java
|
||||||
|
|
Loading…
Reference in a new issue