geforkt von Mirrors/Paper
Ursprung
390618e170
Commit
adb00c117d
@ -2147,56 +2147,73 @@ public final class CraftServer implements Server {
|
|||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public <T extends Keyed> org.bukkit.Tag<T> getTag(String registry, NamespacedKey tag, Class<T> clazz) {
|
public <T extends Keyed> org.bukkit.Tag<T> getTag(String registry, NamespacedKey tag, Class<T> clazz) {
|
||||||
|
Validate.notNull(registry, "registry cannot be null");
|
||||||
|
Validate.notNull(tag, "NamespacedKey cannot be null");
|
||||||
|
Validate.notNull(clazz, "Class cannot be null");
|
||||||
MinecraftKey key = CraftNamespacedKey.toMinecraft(tag);
|
MinecraftKey key = CraftNamespacedKey.toMinecraft(tag);
|
||||||
|
|
||||||
switch (registry) {
|
switch (registry) {
|
||||||
case org.bukkit.Tag.REGISTRY_BLOCKS:
|
case org.bukkit.Tag.REGISTRY_BLOCKS -> {
|
||||||
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Block namespace must have material type");
|
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Block namespace must have material type");
|
||||||
|
TagKey<Block> blockTagKey = TagKey.create(IRegistry.BLOCK_REGISTRY, key);
|
||||||
return (org.bukkit.Tag<T>) new CraftBlockTag(IRegistry.BLOCK, TagKey.create(IRegistry.BLOCK_REGISTRY, key));
|
if (IRegistry.BLOCK.isKnownTagName(blockTagKey)) {
|
||||||
case org.bukkit.Tag.REGISTRY_ITEMS:
|
return (org.bukkit.Tag<T>) new CraftBlockTag(IRegistry.BLOCK, blockTagKey);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case org.bukkit.Tag.REGISTRY_ITEMS -> {
|
||||||
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Item namespace must have material type");
|
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Item namespace must have material type");
|
||||||
|
TagKey<Item> itemTagKey = TagKey.create(IRegistry.ITEM_REGISTRY, key);
|
||||||
return (org.bukkit.Tag<T>) new CraftItemTag(IRegistry.ITEM, TagKey.create(IRegistry.ITEM_REGISTRY, key));
|
if (IRegistry.ITEM.isKnownTagName(itemTagKey)) {
|
||||||
case org.bukkit.Tag.REGISTRY_FLUIDS:
|
return (org.bukkit.Tag<T>) new CraftItemTag(IRegistry.ITEM, itemTagKey);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case org.bukkit.Tag.REGISTRY_FLUIDS -> {
|
||||||
Preconditions.checkArgument(clazz == org.bukkit.Fluid.class, "Fluid namespace must have fluid type");
|
Preconditions.checkArgument(clazz == org.bukkit.Fluid.class, "Fluid namespace must have fluid type");
|
||||||
|
TagKey<FluidType> fluidTagKey = TagKey.create(IRegistry.FLUID_REGISTRY, key);
|
||||||
return (org.bukkit.Tag<T>) new CraftFluidTag(IRegistry.FLUID, TagKey.create(IRegistry.FLUID_REGISTRY, key));
|
if (IRegistry.FLUID.isKnownTagName(fluidTagKey)) {
|
||||||
case org.bukkit.Tag.REGISTRY_ENTITY_TYPES:
|
return (org.bukkit.Tag<T>) new CraftFluidTag(IRegistry.FLUID, fluidTagKey);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
case org.bukkit.Tag.REGISTRY_ENTITY_TYPES -> {
|
||||||
Preconditions.checkArgument(clazz == org.bukkit.entity.EntityType.class, "Entity type namespace must have entity type");
|
Preconditions.checkArgument(clazz == org.bukkit.entity.EntityType.class, "Entity type namespace must have entity type");
|
||||||
|
TagKey<EntityTypes<?>> entityTagKey = TagKey.create(IRegistry.ENTITY_TYPE_REGISTRY, key);
|
||||||
return (org.bukkit.Tag<T>) new CraftEntityTag(IRegistry.ENTITY_TYPE, TagKey.create(IRegistry.ENTITY_TYPE_REGISTRY, key));
|
if (IRegistry.ENTITY_TYPE.isKnownTagName(entityTagKey)) {
|
||||||
default:
|
return (org.bukkit.Tag<T>) new CraftEntityTag(IRegistry.ENTITY_TYPE, entityTagKey);
|
||||||
throw new IllegalArgumentException();
|
}
|
||||||
|
}
|
||||||
|
default -> throw new IllegalArgumentException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public <T extends Keyed> Iterable<org.bukkit.Tag<T>> getTags(String registry, Class<T> clazz) {
|
public <T extends Keyed> Iterable<org.bukkit.Tag<T>> getTags(String registry, Class<T> clazz) {
|
||||||
|
Validate.notNull(registry, "registry cannot be null");
|
||||||
|
Validate.notNull(clazz, "Class cannot be null");
|
||||||
switch (registry) {
|
switch (registry) {
|
||||||
case org.bukkit.Tag.REGISTRY_BLOCKS:
|
case org.bukkit.Tag.REGISTRY_BLOCKS -> {
|
||||||
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Block namespace must have material type");
|
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Block namespace must have material type");
|
||||||
|
|
||||||
IRegistry<Block> blockTags = IRegistry.BLOCK;
|
IRegistry<Block> blockTags = IRegistry.BLOCK;
|
||||||
return blockTags.getTags().map(pair -> (org.bukkit.Tag<T>) new CraftBlockTag(blockTags, pair.getFirst())).collect(ImmutableList.toImmutableList());
|
return blockTags.getTags().map(pair -> (org.bukkit.Tag<T>) new CraftBlockTag(blockTags, pair.getFirst())).collect(ImmutableList.toImmutableList());
|
||||||
case org.bukkit.Tag.REGISTRY_ITEMS:
|
}
|
||||||
|
case org.bukkit.Tag.REGISTRY_ITEMS -> {
|
||||||
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Item namespace must have material type");
|
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Item namespace must have material type");
|
||||||
|
|
||||||
IRegistry<Item> itemTags = IRegistry.ITEM;
|
IRegistry<Item> itemTags = IRegistry.ITEM;
|
||||||
return itemTags.getTags().map(pair -> (org.bukkit.Tag<T>) new CraftItemTag(itemTags, pair.getFirst())).collect(ImmutableList.toImmutableList());
|
return itemTags.getTags().map(pair -> (org.bukkit.Tag<T>) new CraftItemTag(itemTags, pair.getFirst())).collect(ImmutableList.toImmutableList());
|
||||||
case org.bukkit.Tag.REGISTRY_FLUIDS:
|
}
|
||||||
|
case org.bukkit.Tag.REGISTRY_FLUIDS -> {
|
||||||
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Fluid namespace must have fluid type");
|
Preconditions.checkArgument(clazz == org.bukkit.Material.class, "Fluid namespace must have fluid type");
|
||||||
|
|
||||||
IRegistry<FluidType> fluidTags = IRegistry.FLUID;
|
IRegistry<FluidType> fluidTags = IRegistry.FLUID;
|
||||||
return fluidTags.getTags().map(pair -> (org.bukkit.Tag<T>) new CraftFluidTag(fluidTags, pair.getFirst())).collect(ImmutableList.toImmutableList());
|
return fluidTags.getTags().map(pair -> (org.bukkit.Tag<T>) new CraftFluidTag(fluidTags, pair.getFirst())).collect(ImmutableList.toImmutableList());
|
||||||
case org.bukkit.Tag.REGISTRY_ENTITY_TYPES:
|
}
|
||||||
|
case org.bukkit.Tag.REGISTRY_ENTITY_TYPES -> {
|
||||||
Preconditions.checkArgument(clazz == org.bukkit.entity.EntityType.class, "Entity type namespace must have entity type");
|
Preconditions.checkArgument(clazz == org.bukkit.entity.EntityType.class, "Entity type namespace must have entity type");
|
||||||
|
|
||||||
IRegistry<EntityTypes<?>> entityTags = IRegistry.ENTITY_TYPE;
|
IRegistry<EntityTypes<?>> entityTags = IRegistry.ENTITY_TYPE;
|
||||||
return entityTags.getTags().map(pair -> (org.bukkit.Tag<T>) new CraftEntityTag(entityTags, pair.getFirst())).collect(ImmutableList.toImmutableList());
|
return entityTags.getTags().map(pair -> (org.bukkit.Tag<T>) new CraftEntityTag(entityTags, pair.getFirst())).collect(ImmutableList.toImmutableList());
|
||||||
default:
|
}
|
||||||
throw new IllegalArgumentException();
|
default -> throw new IllegalArgumentException();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,6 +29,6 @@ public class CraftBlockTag extends CraftTag<Block, Material> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<Material> getValues() {
|
public Set<Material> getValues() {
|
||||||
return Collections.unmodifiableSet(getHandle().stream().map((block) -> CraftMagicNumbers.getMaterial(block.value())).collect(Collectors.toSet()));
|
return getHandle().stream().map((block) -> CraftMagicNumbers.getMaterial(block.value())).collect(Collectors.toUnmodifiableSet());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package org.bukkit.craftbukkit.tag;
|
package org.bukkit.craftbukkit.tag;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
import java.util.Objects;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
import net.minecraft.core.IRegistry;
|
import net.minecraft.core.IRegistry;
|
||||||
@ -24,6 +25,6 @@ public class CraftEntityTag extends CraftTag<EntityTypes<?>, EntityType> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<EntityType> getValues() {
|
public Set<EntityType> getValues() {
|
||||||
return Collections.unmodifiableSet(getHandle().stream().map((nms) -> Registry.ENTITY_TYPE.get(CraftNamespacedKey.fromMinecraft(EntityTypes.getKey(nms.value())))).collect(Collectors.toSet()));
|
return getHandle().stream().map((nms) -> Registry.ENTITY_TYPE.get(CraftNamespacedKey.fromMinecraft(EntityTypes.getKey(nms.value())))).filter(Objects::nonNull).collect(Collectors.toUnmodifiableSet());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,6 @@ public class CraftFluidTag extends CraftTag<FluidType, Fluid> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<Fluid> getValues() {
|
public Set<Fluid> getValues() {
|
||||||
return Collections.unmodifiableSet(getHandle().stream().map((fluid) -> CraftMagicNumbers.getFluid(fluid.value())).collect(Collectors.toSet()));
|
return getHandle().stream().map((fluid) -> CraftMagicNumbers.getFluid(fluid.value())).collect(Collectors.toUnmodifiableSet());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,6 @@ public class CraftItemTag extends CraftTag<Item, Material> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Set<Material> getValues() {
|
public Set<Material> getValues() {
|
||||||
return Collections.unmodifiableSet(getHandle().stream().map((item) -> CraftMagicNumbers.getMaterial(item.value())).collect(Collectors.toSet()));
|
return getHandle().stream().map((item) -> CraftMagicNumbers.getMaterial(item.value())).collect(Collectors.toUnmodifiableSet());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -18,13 +18,10 @@ public abstract class CraftTag<N, B extends Keyed> implements Tag<B> {
|
|||||||
public CraftTag(IRegistry<N> registry, TagKey<N> tag) {
|
public CraftTag(IRegistry<N> registry, TagKey<N> tag) {
|
||||||
this.registry = registry;
|
this.registry = registry;
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
|
this.handle = registry.getTag(this.tag).orElseThrow();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected HolderSet.Named<N> getHandle() {
|
protected HolderSet.Named<N> getHandle() {
|
||||||
if (handle == null) {
|
|
||||||
handle = registry.getTag(tag).get();
|
|
||||||
}
|
|
||||||
|
|
||||||
return handle;
|
return handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren