mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-20 07:34:48 +01:00
parent
2960bff05e
commit
7b903b41cb
6 changed files with 105 additions and 21 deletions
|
@ -24,6 +24,7 @@ import org.bukkit.block.Biome;
|
||||||
import org.bukkit.block.BlockType;
|
import org.bukkit.block.BlockType;
|
||||||
import org.bukkit.block.banner.PatternType;
|
import org.bukkit.block.banner.PatternType;
|
||||||
import org.bukkit.craftbukkit.attribute.CraftAttribute;
|
import org.bukkit.craftbukkit.attribute.CraftAttribute;
|
||||||
|
import org.bukkit.craftbukkit.block.CraftBiome;
|
||||||
import org.bukkit.craftbukkit.block.CraftBlockType;
|
import org.bukkit.craftbukkit.block.CraftBlockType;
|
||||||
import org.bukkit.craftbukkit.block.banner.CraftPatternType;
|
import org.bukkit.craftbukkit.block.banner.CraftPatternType;
|
||||||
import org.bukkit.craftbukkit.damage.CraftDamageType;
|
import org.bukkit.craftbukkit.damage.CraftDamageType;
|
||||||
|
@ -136,6 +137,9 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
if (bukkitClass == Attribute.class) {
|
if (bukkitClass == Attribute.class) {
|
||||||
return new CraftRegistry<>(Attribute.class, registryHolder.lookupOrThrow(Registries.ATTRIBUTE), CraftAttribute::new, FieldRename.ATTRIBUTE_RENAME);
|
return new CraftRegistry<>(Attribute.class, registryHolder.lookupOrThrow(Registries.ATTRIBUTE), CraftAttribute::new, FieldRename.ATTRIBUTE_RENAME);
|
||||||
}
|
}
|
||||||
|
if (bukkitClass == Biome.class) {
|
||||||
|
return new CraftRegistry<>(Biome.class, registryHolder.lookupOrThrow(Registries.BIOME), CraftBiome::new, FieldRename.BIOME_RENAME);
|
||||||
|
}
|
||||||
if (bukkitClass == Enchantment.class) {
|
if (bukkitClass == Enchantment.class) {
|
||||||
return new CraftRegistry<>(Enchantment.class, registryHolder.lookupOrThrow(Registries.ENCHANTMENT), CraftEnchantment::new, FieldRename.ENCHANTMENT_RENAME);
|
return new CraftRegistry<>(Enchantment.class, registryHolder.lookupOrThrow(Registries.ENCHANTMENT), CraftEnchantment::new, FieldRename.ENCHANTMENT_RENAME);
|
||||||
}
|
}
|
||||||
|
@ -211,10 +215,6 @@ public class CraftRegistry<B extends Keyed, M> implements Registry<B> {
|
||||||
if (bukkit instanceof Registry.SimpleRegistry<?> simple) {
|
if (bukkit instanceof Registry.SimpleRegistry<?> simple) {
|
||||||
Class<?> bClass = simple.getType();
|
Class<?> bClass = simple.getType();
|
||||||
|
|
||||||
if (bClass == Biome.class) {
|
|
||||||
return bukkit.get(FieldRename.BIOME_RENAME.apply(namespacedKey, apiVersion));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bClass == EntityType.class) {
|
if (bClass == EntityType.class) {
|
||||||
return bukkit.get(FieldRename.ENTITY_TYPE_RENAME.apply(namespacedKey, apiVersion));
|
return bukkit.get(FieldRename.ENTITY_TYPE_RENAME.apply(namespacedKey, apiVersion));
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,28 +1,23 @@
|
||||||
package org.bukkit.craftbukkit.block;
|
package org.bukkit.craftbukkit.block;
|
||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
import java.util.Locale;
|
||||||
import net.minecraft.core.Holder;
|
import net.minecraft.core.Holder;
|
||||||
import net.minecraft.core.IRegistry;
|
import net.minecraft.core.IRegistry;
|
||||||
import net.minecraft.core.registries.Registries;
|
import net.minecraft.core.registries.Registries;
|
||||||
import net.minecraft.world.level.biome.BiomeBase;
|
import net.minecraft.world.level.biome.BiomeBase;
|
||||||
|
import org.bukkit.NamespacedKey;
|
||||||
import org.bukkit.Registry;
|
import org.bukkit.Registry;
|
||||||
import org.bukkit.block.Biome;
|
import org.bukkit.block.Biome;
|
||||||
import org.bukkit.craftbukkit.CraftRegistry;
|
import org.bukkit.craftbukkit.CraftRegistry;
|
||||||
import org.bukkit.craftbukkit.util.CraftNamespacedKey;
|
import org.bukkit.craftbukkit.util.Handleable;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public class CraftBiome {
|
public class CraftBiome implements Biome, Handleable<BiomeBase> {
|
||||||
|
|
||||||
|
private static int count = 0;
|
||||||
|
|
||||||
public static Biome minecraftToBukkit(BiomeBase minecraft) {
|
public static Biome minecraftToBukkit(BiomeBase minecraft) {
|
||||||
Preconditions.checkArgument(minecraft != null);
|
return CraftRegistry.minecraftToBukkit(minecraft, Registries.BIOME, Registry.BIOME);
|
||||||
|
|
||||||
IRegistry<BiomeBase> registry = CraftRegistry.getMinecraftRegistry(Registries.BIOME);
|
|
||||||
Biome bukkit = Registry.BIOME.get(CraftNamespacedKey.fromMinecraft(registry.getResourceKey(minecraft).orElseThrow().location()));
|
|
||||||
|
|
||||||
if (bukkit == null) {
|
|
||||||
return Biome.CUSTOM;
|
|
||||||
}
|
|
||||||
|
|
||||||
return bukkit;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Biome minecraftHolderToBukkit(Holder<BiomeBase> minecraft) {
|
public static Biome minecraftHolderToBukkit(Holder<BiomeBase> minecraft) {
|
||||||
|
@ -30,16 +25,15 @@ public class CraftBiome {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static BiomeBase bukkitToMinecraft(Biome bukkit) {
|
public static BiomeBase bukkitToMinecraft(Biome bukkit) {
|
||||||
if (bukkit == null || bukkit == Biome.CUSTOM) {
|
if (bukkit == Biome.CUSTOM) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
return CraftRegistry.getMinecraftRegistry(Registries.BIOME)
|
return CraftRegistry.bukkitToMinecraft(bukkit);
|
||||||
.getOptional(CraftNamespacedKey.toMinecraft(bukkit.getKey())).orElseThrow();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Holder<BiomeBase> bukkitToMinecraftHolder(Biome bukkit) {
|
public static Holder<BiomeBase> bukkitToMinecraftHolder(Biome bukkit) {
|
||||||
if (bukkit == null || bukkit == Biome.CUSTOM) {
|
if (bukkit == Biome.CUSTOM) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,4 +46,75 @@ public class CraftBiome {
|
||||||
throw new IllegalArgumentException("No Reference holder found for " + bukkit
|
throw new IllegalArgumentException("No Reference holder found for " + bukkit
|
||||||
+ ", this can happen if a plugin creates its own biome base with out properly registering it.");
|
+ ", this can happen if a plugin creates its own biome base with out properly registering it.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private final NamespacedKey key;
|
||||||
|
private final BiomeBase biomeBase;
|
||||||
|
private final String name;
|
||||||
|
private final int ordinal;
|
||||||
|
|
||||||
|
public CraftBiome(NamespacedKey key, BiomeBase biomeBase) {
|
||||||
|
this.key = key;
|
||||||
|
this.biomeBase = biomeBase;
|
||||||
|
// For backwards compatibility, minecraft values will stile return the uppercase name without the namespace,
|
||||||
|
// in case plugins use for example the name as key in a config file to receive biome specific values.
|
||||||
|
// Custom biomes will return the key with namespace. For a plugin this should look than like a new biome
|
||||||
|
// (which can always be added in new minecraft versions and the plugin should therefore handle it accordingly).
|
||||||
|
if (NamespacedKey.MINECRAFT.equals(key.getNamespace())) {
|
||||||
|
this.name = key.getKey().toUpperCase(Locale.ROOT);
|
||||||
|
} else {
|
||||||
|
this.name = key.toString();
|
||||||
|
}
|
||||||
|
this.ordinal = count++;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public BiomeBase getHandle() {
|
||||||
|
return biomeBase;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public NamespacedKey getKey() {
|
||||||
|
return key;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int compareTo(@NotNull Biome biome) {
|
||||||
|
return ordinal - biome.ordinal();
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public String name() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int ordinal() {
|
||||||
|
return ordinal;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
// For backwards compatibility
|
||||||
|
return name();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object other) {
|
||||||
|
if (this == other) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(other instanceof CraftBiome otherBiome)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return getKey().equals(otherBiome.getKey());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return getKey().hashCode();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@ import org.bukkit.Fluid;
|
||||||
import org.bukkit.NamespacedKey;
|
import org.bukkit.NamespacedKey;
|
||||||
import org.bukkit.Registry;
|
import org.bukkit.Registry;
|
||||||
import org.bukkit.attribute.Attribute;
|
import org.bukkit.attribute.Attribute;
|
||||||
|
import org.bukkit.block.Biome;
|
||||||
import org.bukkit.block.banner.PatternType;
|
import org.bukkit.block.banner.PatternType;
|
||||||
import org.bukkit.craftbukkit.legacy.FieldRename;
|
import org.bukkit.craftbukkit.legacy.FieldRename;
|
||||||
import org.bukkit.craftbukkit.legacy.reroute.DoNotReroute;
|
import org.bukkit.craftbukkit.legacy.reroute.DoNotReroute;
|
||||||
|
@ -47,6 +48,7 @@ public class EnumEvil {
|
||||||
static {
|
static {
|
||||||
// Add Classes which got changed here
|
// Add Classes which got changed here
|
||||||
REGISTRIES.put(Attribute.class, new LegacyRegistryData(Registry.ATTRIBUTE, Attribute::valueOf));
|
REGISTRIES.put(Attribute.class, new LegacyRegistryData(Registry.ATTRIBUTE, Attribute::valueOf));
|
||||||
|
REGISTRIES.put(Biome.class, new LegacyRegistryData(Registry.BIOME, Biome::valueOf));
|
||||||
REGISTRIES.put(Fluid.class, new LegacyRegistryData(Registry.FLUID, Fluid::valueOf));
|
REGISTRIES.put(Fluid.class, new LegacyRegistryData(Registry.FLUID, Fluid::valueOf));
|
||||||
REGISTRIES.put(Villager.Type.class, new LegacyRegistryData(Registry.VILLAGER_TYPE, Villager.Type::valueOf));
|
REGISTRIES.put(Villager.Type.class, new LegacyRegistryData(Registry.VILLAGER_TYPE, Villager.Type::valueOf));
|
||||||
REGISTRIES.put(Villager.Profession.class, new LegacyRegistryData(Registry.VILLAGER_PROFESSION, Villager.Profession::valueOf));
|
REGISTRIES.put(Villager.Profession.class, new LegacyRegistryData(Registry.VILLAGER_PROFESSION, Villager.Profession::valueOf));
|
||||||
|
|
|
@ -89,6 +89,7 @@ public class Commodore {
|
||||||
"org/bukkit/map/MapCursor$Type", "NOP",
|
"org/bukkit/map/MapCursor$Type", "NOP",
|
||||||
"org/bukkit/block/banner/PatternType", "NOP",
|
"org/bukkit/block/banner/PatternType", "NOP",
|
||||||
"org/bukkit/attribute/Attribute", "NOP",
|
"org/bukkit/attribute/Attribute", "NOP",
|
||||||
|
"org/bukkit/block/Biome", "NOP",
|
||||||
"org/bukkit/Fluid", "NOP"
|
"org/bukkit/Fluid", "NOP"
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -47,10 +47,12 @@ import org.bukkit.UnsafeValues;
|
||||||
import org.bukkit.advancement.Advancement;
|
import org.bukkit.advancement.Advancement;
|
||||||
import org.bukkit.attribute.Attribute;
|
import org.bukkit.attribute.Attribute;
|
||||||
import org.bukkit.attribute.AttributeModifier;
|
import org.bukkit.attribute.AttributeModifier;
|
||||||
|
import org.bukkit.block.Biome;
|
||||||
import org.bukkit.block.data.BlockData;
|
import org.bukkit.block.data.BlockData;
|
||||||
import org.bukkit.craftbukkit.CraftFeatureFlag;
|
import org.bukkit.craftbukkit.CraftFeatureFlag;
|
||||||
import org.bukkit.craftbukkit.CraftRegistry;
|
import org.bukkit.craftbukkit.CraftRegistry;
|
||||||
import org.bukkit.craftbukkit.CraftServer;
|
import org.bukkit.craftbukkit.CraftServer;
|
||||||
|
import org.bukkit.craftbukkit.block.CraftBiome;
|
||||||
import org.bukkit.craftbukkit.block.data.CraftBlockData;
|
import org.bukkit.craftbukkit.block.data.CraftBlockData;
|
||||||
import org.bukkit.craftbukkit.damage.CraftDamageEffect;
|
import org.bukkit.craftbukkit.damage.CraftDamageEffect;
|
||||||
import org.bukkit.craftbukkit.damage.CraftDamageSourceBuilder;
|
import org.bukkit.craftbukkit.damage.CraftDamageSourceBuilder;
|
||||||
|
@ -410,6 +412,16 @@ public final class CraftMagicNumbers implements UnsafeValues {
|
||||||
return CraftRegistry.get(registry, namespacedKey, ApiVersion.CURRENT);
|
return CraftRegistry.get(registry, namespacedKey, ApiVersion.CURRENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Biome customBiome;
|
||||||
|
@Override
|
||||||
|
public Biome getCustomBiome() {
|
||||||
|
if (customBiome == null) {
|
||||||
|
customBiome = new CraftBiome(NamespacedKey.minecraft("custom"), null);
|
||||||
|
}
|
||||||
|
|
||||||
|
return customBiome;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This helper class represents the different NBT Tags.
|
* This helper class represents the different NBT Tags.
|
||||||
* <p>
|
* <p>
|
||||||
|
|
|
@ -14,6 +14,7 @@ import net.minecraft.world.entity.npc.VillagerProfession;
|
||||||
import net.minecraft.world.entity.npc.VillagerType;
|
import net.minecraft.world.entity.npc.VillagerType;
|
||||||
import net.minecraft.world.inventory.Containers;
|
import net.minecraft.world.inventory.Containers;
|
||||||
import net.minecraft.world.item.Instrument;
|
import net.minecraft.world.item.Instrument;
|
||||||
|
import net.minecraft.world.level.biome.BiomeBase;
|
||||||
import net.minecraft.world.level.block.entity.EnumBannerPatternType;
|
import net.minecraft.world.level.block.entity.EnumBannerPatternType;
|
||||||
import net.minecraft.world.level.material.FluidType;
|
import net.minecraft.world.level.material.FluidType;
|
||||||
import net.minecraft.world.level.saveddata.maps.MapDecorationType;
|
import net.minecraft.world.level.saveddata.maps.MapDecorationType;
|
||||||
|
@ -22,6 +23,7 @@ import org.bukkit.GameEvent;
|
||||||
import org.bukkit.JukeboxSong;
|
import org.bukkit.JukeboxSong;
|
||||||
import org.bukkit.MusicInstrument;
|
import org.bukkit.MusicInstrument;
|
||||||
import org.bukkit.attribute.Attribute;
|
import org.bukkit.attribute.Attribute;
|
||||||
|
import org.bukkit.block.Biome;
|
||||||
import org.bukkit.block.BlockType;
|
import org.bukkit.block.BlockType;
|
||||||
import org.bukkit.block.banner.PatternType;
|
import org.bukkit.block.banner.PatternType;
|
||||||
import org.bukkit.craftbukkit.CraftFluid;
|
import org.bukkit.craftbukkit.CraftFluid;
|
||||||
|
@ -29,6 +31,7 @@ import org.bukkit.craftbukkit.CraftGameEvent;
|
||||||
import org.bukkit.craftbukkit.CraftJukeboxSong;
|
import org.bukkit.craftbukkit.CraftJukeboxSong;
|
||||||
import org.bukkit.craftbukkit.CraftMusicInstrument;
|
import org.bukkit.craftbukkit.CraftMusicInstrument;
|
||||||
import org.bukkit.craftbukkit.attribute.CraftAttribute;
|
import org.bukkit.craftbukkit.attribute.CraftAttribute;
|
||||||
|
import org.bukkit.craftbukkit.block.CraftBiome;
|
||||||
import org.bukkit.craftbukkit.block.CraftBlockType;
|
import org.bukkit.craftbukkit.block.CraftBlockType;
|
||||||
import org.bukkit.craftbukkit.block.banner.CraftPatternType;
|
import org.bukkit.craftbukkit.block.banner.CraftPatternType;
|
||||||
import org.bukkit.craftbukkit.damage.CraftDamageType;
|
import org.bukkit.craftbukkit.damage.CraftDamageType;
|
||||||
|
@ -70,6 +73,7 @@ public class RegistriesArgumentProvider implements ArgumentsProvider {
|
||||||
static {
|
static {
|
||||||
// Order: Bukkit class, Minecraft Registry key, CraftBukkit class, Minecraft class
|
// Order: Bukkit class, Minecraft Registry key, CraftBukkit class, Minecraft class
|
||||||
register(Attribute.class, Registries.ATTRIBUTE, CraftAttribute.class, AttributeBase.class);
|
register(Attribute.class, Registries.ATTRIBUTE, CraftAttribute.class, AttributeBase.class);
|
||||||
|
register(Biome.class, Registries.BIOME, CraftBiome.class, BiomeBase.class);
|
||||||
register(Enchantment.class, Registries.ENCHANTMENT, CraftEnchantment.class, net.minecraft.world.item.enchantment.Enchantment.class);
|
register(Enchantment.class, Registries.ENCHANTMENT, CraftEnchantment.class, net.minecraft.world.item.enchantment.Enchantment.class);
|
||||||
register(Fluid.class, Registries.FLUID, CraftFluid.class, FluidType.class);
|
register(Fluid.class, Registries.FLUID, CraftFluid.class, FluidType.class);
|
||||||
register(GameEvent.class, Registries.GAME_EVENT, CraftGameEvent.class, net.minecraft.world.level.gameevent.GameEvent.class);
|
register(GameEvent.class, Registries.GAME_EVENT, CraftGameEvent.class, net.minecraft.world.level.gameevent.GameEvent.class);
|
||||||
|
|
Loading…
Reference in a new issue