geforkt von Mirrors/Paper
125 Zeilen
8.2 KiB
Diff
125 Zeilen
8.2 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Nassim Jahnke <nassim@njahnke.dev>
|
||
|
Date: Sat, 6 Jan 2024 14:31:00 +0100
|
||
|
Subject: [PATCH] Fixup ResourceLocation handling
|
||
|
|
||
|
|
||
|
diff --git a/src/main/java/com/destroystokyo/paper/loottable/PaperContainerEntityLootableInventory.java b/src/main/java/com/destroystokyo/paper/loottable/PaperContainerEntityLootableInventory.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/com/destroystokyo/paper/loottable/PaperContainerEntityLootableInventory.java
|
||
|
+++ b/src/main/java/com/destroystokyo/paper/loottable/PaperContainerEntityLootableInventory.java
|
||
|
@@ -0,0 +0,0 @@ public class PaperContainerEntityLootableInventory implements PaperLootableEntit
|
||
|
|
||
|
@Override
|
||
|
public org.bukkit.loot.LootTable getLootTable() {
|
||
|
- return entity.getLootTable() != null ? Bukkit.getLootTable(CraftNamespacedKey.fromMinecraft(entity.getLootTable())) : null;
|
||
|
+ return entity.getLootTable() != null && !entity.getLootTable().getPath().isEmpty() ? Bukkit.getLootTable(CraftNamespacedKey.fromMinecraft(entity.getLootTable())) : null;
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
diff --git a/src/main/java/com/destroystokyo/paper/loottable/PaperTileEntityLootableInventory.java b/src/main/java/com/destroystokyo/paper/loottable/PaperTileEntityLootableInventory.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/com/destroystokyo/paper/loottable/PaperTileEntityLootableInventory.java
|
||
|
+++ b/src/main/java/com/destroystokyo/paper/loottable/PaperTileEntityLootableInventory.java
|
||
|
@@ -0,0 +0,0 @@ public class PaperTileEntityLootableInventory implements PaperLootableBlockInven
|
||
|
|
||
|
@Override
|
||
|
public org.bukkit.loot.LootTable getLootTable() {
|
||
|
- return tileEntityLootable.lootTable != null ? Bukkit.getLootTable(CraftNamespacedKey.fromMinecraft(tileEntityLootable.lootTable)) : null;
|
||
|
+ return tileEntityLootable.lootTable != null && !tileEntityLootable.lootTable.getPath().isEmpty() ? Bukkit.getLootTable(CraftNamespacedKey.fromMinecraft(tileEntityLootable.lootTable)) : null;
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java b/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java
|
||
|
+++ b/src/main/java/org/bukkit/craftbukkit/attribute/CraftAttribute.java
|
||
|
@@ -0,0 +0,0 @@ public class CraftAttribute {
|
||
|
public static Attribute stringToBukkit(String bukkit) {
|
||
|
Preconditions.checkArgument(bukkit != null);
|
||
|
|
||
|
- return Registry.ATTRIBUTE.get(NamespacedKey.fromString(bukkit));
|
||
|
+ // Paper start - Fixup NamespacedKey handling
|
||
|
+ final NamespacedKey key = NamespacedKey.fromString(bukkit);
|
||
|
+ return key != null ? Registry.ATTRIBUTE.get(key) : null;
|
||
|
+ // Paper end - Fixup NamespacedKey handling
|
||
|
}
|
||
|
|
||
|
public static net.minecraft.world.entity.ai.attributes.Attribute bukkitToMinecraft(Attribute bukkit) {
|
||
|
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 {
|
||
|
if (tag.contains(CraftMetaArmor.TRIM.NBT)) {
|
||
|
CompoundTag trimCompound = tag.getCompound(CraftMetaArmor.TRIM.NBT);
|
||
|
|
||
|
- if (trimCompound.contains(CraftMetaArmor.TRIM_MATERIAL.NBT) && trimCompound.contains(CraftMetaArmor.TRIM_PATTERN.NBT)) {
|
||
|
- TrimMaterial trimMaterial = Registry.TRIM_MATERIAL.get(NamespacedKey.fromString(trimCompound.getString(CraftMetaArmor.TRIM_MATERIAL.NBT)));
|
||
|
- TrimPattern trimPattern = Registry.TRIM_PATTERN.get(NamespacedKey.fromString(trimCompound.getString(CraftMetaArmor.TRIM_PATTERN.NBT)));
|
||
|
+ // Paper start - Fixup NamedspacedKey handling
|
||
|
+ if (trimCompound.contains(CraftMetaArmor.TRIM_MATERIAL.NBT, net.minecraft.nbt.Tag.TAG_STRING) && trimCompound.contains(CraftMetaArmor.TRIM_PATTERN.NBT, net.minecraft.nbt.Tag.TAG_STRING)) { // TODO Can also be inlined in a compound tag
|
||
|
+ TrimMaterial trimMaterial = registryEntry(Registry.TRIM_MATERIAL, trimCompound.getString(TRIM_MATERIAL.NBT));
|
||
|
+ TrimPattern trimPattern = registryEntry(Registry.TRIM_PATTERN, trimCompound.getString(TRIM_PATTERN.NBT));
|
||
|
|
||
|
- this.trim = new ArmorTrim(trimMaterial, trimPattern);
|
||
|
+ this.trim = trimMaterial != null && trimPattern != null ? new ArmorTrim(trimMaterial, trimPattern) : null;
|
||
|
+ // Paper end - Fixup NamedspacedKey handling
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
+ // Paper start - Fixup NamedspacedKey handling
|
||
|
+ private <T extends org.bukkit.Keyed> T registryEntry(final Registry<T> registry, final String value) {
|
||
|
+ final NamespacedKey key = NamespacedKey.fromString(value);
|
||
|
+ return key != null ? registry.get(key) : null;
|
||
|
+ }
|
||
|
+ // Paper end - Fixup NamedspacedKey handling
|
||
|
|
||
|
CraftMetaArmor(Map<String, Object> map) {
|
||
|
super(map);
|
||
|
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
|
||
|
|
||
|
if (tag.contains(CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT.NBT)) {
|
||
|
String string = tag.getString(CraftMetaMusicInstrument.GOAT_HORN_INSTRUMENT.NBT);
|
||
|
- this.instrument = Registry.INSTRUMENT.get(NamespacedKey.fromString(string));
|
||
|
+ // Paper start - Fixup NamespacedKey handling
|
||
|
+ final NamespacedKey key = NamespacedKey.fromString(string);
|
||
|
+ this.instrument = key != null ? Registry.INSTRUMENT.get(key) : null;
|
||
|
+ // Paper end - Fixup NamespacedKey handling
|
||
|
}
|
||
|
}
|
||
|
|
||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java b/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java
|
||
|
+++ b/src/main/java/org/bukkit/craftbukkit/potion/CraftPotionType.java
|
||
|
@@ -0,0 +0,0 @@ public class CraftPotionType implements PotionType.InternalPotionData {
|
||
|
public static PotionType stringToBukkit(String string) {
|
||
|
Preconditions.checkArgument(string != null);
|
||
|
|
||
|
- return Registry.POTION.get(NamespacedKey.fromString(string));
|
||
|
+ // Paper start - Fixup NamespacedKey handling
|
||
|
+ final NamespacedKey key = NamespacedKey.fromString(string);
|
||
|
+ return key != null ? Registry.POTION.get(key) : null;
|
||
|
+ // Paper end - Fixup NamespacedKey handling
|
||
|
}
|
||
|
|
||
|
private final NamespacedKey key;
|
||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/util/CraftNamespacedKey.java b/src/main/java/org/bukkit/craftbukkit/util/CraftNamespacedKey.java
|
||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||
|
--- a/src/main/java/org/bukkit/craftbukkit/util/CraftNamespacedKey.java
|
||
|
+++ b/src/main/java/org/bukkit/craftbukkit/util/CraftNamespacedKey.java
|
||
|
@@ -0,0 +0,0 @@ public final class CraftNamespacedKey {
|
||
|
return null;
|
||
|
}
|
||
|
ResourceLocation minecraft = ResourceLocation.tryParse(string);
|
||
|
- return (minecraft == null) ? null : CraftNamespacedKey.fromMinecraft(minecraft);
|
||
|
+ return (minecraft == null || minecraft.getPath().isEmpty()) ? null : CraftNamespacedKey.fromMinecraft(minecraft); // Paper - Bukkit's parser does not match Vanilla for empty paths
|
||
|
}
|
||
|
|
||
|
public static NamespacedKey fromString(String string) {
|